婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python機器學(xué)習(xí)之AdaBoost算法

Python機器學(xué)習(xí)之AdaBoost算法

熱門標(biāo)簽:沈陽防封電銷卡品牌 沈陽外呼系統(tǒng)呼叫系統(tǒng) 外呼系統(tǒng)哪些好辦 池州外呼調(diào)研線路 江西省地圖標(biāo)注 沈陽人工外呼系統(tǒng)價格 武漢外呼系統(tǒng)平臺 如何申請400電話費用 富錦商家地圖標(biāo)注

一、算法概述

  • AdaBoost 是英文 Adaptive Boosting(自適應(yīng)增強)的縮寫,由 Yoav Freund 和Robert Schapire 在1995年提出。
  • AdaBoost 的自適應(yīng)在于前一個基本分類器分類錯誤的樣本的權(quán)重會得到加強,加強后的全體樣本再次被用來訓(xùn)練下一個基本分類器。同時,在每一輪訓(xùn)練中加入一個新的弱分類器,直到達到某個預(yù)定的足夠小的錯誤率或達到預(yù)先指定的最大迭代次數(shù)時停止訓(xùn)練。
  • AdaBoost 算法是一種集成學(xué)習(xí)的算法,其核心思想就是對多個機器學(xué)習(xí)模型進行組合形成一個精度更高的模型,參與組合的模型稱為弱學(xué)習(xí)器。

二、算法原理

  • AdaBoost 的核心思想是針對同一訓(xùn)練集訓(xùn)練不同的分類器(弱分類器),然后把這些弱分類器集合起來,構(gòu)成一個更強大的最終分類器(強分類器)。也 就是通過一些手段獲得多個弱分類器,將它們集成起來構(gòu)成強分類器,綜合所有分類器的預(yù)測得出最終的結(jié)果。
  • AdaBoost 算法本身是通過改變數(shù)據(jù)分布來實現(xiàn)的,它根據(jù)每次訓(xùn)練集中每個樣本的分類是否正確,以及上次的總體分類的準(zhǔn)確率,來確定每個樣本的權(quán)值。將修改過權(quán)值的新數(shù)據(jù)集送給下層分類器進行訓(xùn)練,最后將每次訓(xùn)練得到的分類器最后融合起來,作為最后的決策分類器。

三、算法步驟

1.初始化訓(xùn)練數(shù)據(jù)的權(quán)值分布,每一個訓(xùn)練樣本最開始時都被賦予相同的權(quán)值 1/n

2.進行多輪迭代,用 m = 1,2,…,k 表示迭代到第幾輪

3.使用具有權(quán)值分布 Gm 的訓(xùn)練數(shù)據(jù)集學(xué)習(xí),得到基本分類器

4.計算 Gm(x) 在訓(xùn)練數(shù)據(jù)集上的分類誤差率

5.計算 Gm(x) 的系數(shù),am表示 Gm(x) 在最終分類器中的重要程度

6.更新訓(xùn)練數(shù)據(jù)集的權(quán)值分布,得到樣本的新的權(quán)值分布,用于下一輪迭代

7.組合各個弱分類器

四、算法實現(xiàn)

from numpy import *
import matplotlib.pyplot as plt


# 加載數(shù)據(jù)集
def loadDataSet(fileName):
    numFeat = len(open(fileName).readline().split('\t'))
    dataMat = []
    labelMat = []
    fr = open(fileName)
    for line in fr.readlines():
        lineArr = []
        curLine = line.strip().split('\t')
        for i in range(numFeat - 1):
            lineArr.append(float(curLine[i]))
        dataMat.append(lineArr)
        labelMat.append(float(curLine[-1]))
    return dataMat, labelMat


# 返回分類預(yù)測結(jié)果  根據(jù)閾值所以有兩種返回情況
def stumpClassify(dataMatrix, dimen, threshVal, threshIneq):
    retArray = ones((shape(dataMatrix)[0], 1))
    if threshIneq == 'lt':
        retArray[dataMatrix[:, dimen] = threshVal] = -1.0
    else:
        retArray[dataMatrix[:, dimen] > threshVal] = -1.0
    return retArray


# 返回 該弱分類器單層決策樹的信息  更新D向量的錯誤率 更新D向量的預(yù)測目標(biāo)
def buildStump(dataArr, classLabels, D):
    dataMatrix = mat(dataArr)
    labelMat = mat(classLabels).T
    m, n = shape(dataMatrix)
    numSteps = 10.0
    bestStump = {}  # 字典用于保存每個分類器信息
    bestClasEst = mat(zeros((m, 1)))
    minError = inf  # 初始化最小誤差最大
    for i in range(n):  # 特征循環(huán)  (三層循環(huán),遍歷所有的可能性)
        rangeMin = dataMatrix[:, i].min()
        rangeMax = dataMatrix[:, i].max()
        stepSize = (rangeMax - rangeMin) / numSteps  # (大-小)/分割數(shù)  得到最小值到最大值需要的每一段距離
        for j in range(-1, int(numSteps) + 1):  # 遍歷步長 最小值到最大值的需要次數(shù)
            for inequal in ['lt', 'gt']:  # 在大于和小于之間切換
                threshVal = (rangeMin + float(j) * stepSize)  # 最小值+次數(shù)*步長  每一次從最小值走的長度
                predictedVals = stumpClassify(dataMatrix, i, threshVal,
                                              inequal)  # 最優(yōu)預(yù)測目標(biāo)值  用于與目標(biāo)值比較得到誤差
                errArr = mat(ones((m, 1)))
                errArr[predictedVals == labelMat] = 0
                weightedError = D.T * errArr
                if weightedError  minError:  # 選出最小錯誤的那個特征
                    minError = weightedError  # 最小誤差 后面用來更新D權(quán)值的
                    bestClasEst = predictedVals.copy()  # 最優(yōu)預(yù)測值

                    bestStump['dim'] = i  # 特征
                    bestStump['thresh'] = threshVal  # 到最小值的距離 (得到最優(yōu)預(yù)測值的那個距離)
                    bestStump['ineq'] = inequal  # 大于還是小于 最優(yōu)距離為-1
    return bestStump, minError, bestClasEst


# 循環(huán)構(gòu)建numIt個弱分類器
def adaBoostTrainDS(dataArr, classLabels, numIt=40):
    weakClassArr = []  # 保存弱分類器數(shù)組
    m = shape(dataArr)[0]
    D = mat(ones((m, 1)) / m)  # D向量 每條樣本所對應(yīng)的一個權(quán)重
    aggClassEst = mat(zeros((m, 1)))  # 統(tǒng)計類別估計累積值
    for i in range(numIt):
        bestStump, error, classEst = buildStump(dataArr, classLabels, D)
        alpha = float(0.5 * log((1.0 - error) / max(error, 1e-16)))
        bestStump['alpha'] = alpha
        weakClassArr.append(bestStump)  # 加入單層決策樹

        # 得到運算公式中的向量+/-α,預(yù)測正確為-α,錯誤則+α。每條樣本一個α
        # multiply對應(yīng)位置相乘  這里很聰明,用-1*真實目標(biāo)值*預(yù)測值,實現(xiàn)了錯誤分類則-,正確則+
        expon = multiply(-1 * alpha * mat(classLabels).T, classEst)
        D = multiply(D, exp(expon))  # 這三步為更新概率分布D向量 拆分開來了,每一步與公式相同
        D = D / D.sum()

        # 計算停止條件錯誤率=0 以及計算每次的aggClassEst類別估計累計值
        aggClassEst += alpha * classEst
        # 很聰明的計算方法 計算得到錯誤的個數(shù),向量中為1則錯誤值
        aggErrors = multiply(sign(aggClassEst) != mat(classLabels).T, ones((m, 1)))  # sign返回數(shù)值的正負符號,以1、-1表示
        errorRate = aggErrors.sum() / m  # 錯誤個數(shù)/總個數(shù)
        # print("錯誤率:", errorRate)
        if errorRate == 0.0:
            break
    return weakClassArr, aggClassEst


# 預(yù)測 累加 多個弱分類器獲得預(yù)測值*該alpha 得到結(jié)果
def adaClassify(datToClass, classifierArr):  # classifierArr是元組,所以在取值時需要注意
    dataMatrix = mat(datToClass)
    m = shape(dataMatrix)[0]
    aggClassEst = mat(zeros((m, 1)))
    # 循環(huán)所有弱分類器
    for i in range(len(classifierArr[0])):
        # 獲得預(yù)測結(jié)果
        classEst = stumpClassify(dataMatrix, classifierArr[0][i]['dim'], classifierArr[0][i]['thresh'],
                                 classifierArr[0][i]['ineq'])
        # 該分類器α*預(yù)測結(jié)果 用于累加得到最終的正負判斷條件
        aggClassEst += classifierArr[0][i]['alpha'] * classEst  # 這里就是集合所有弱分類器的意見,得到最終的意見
    return sign(aggClassEst)  # 提取數(shù)據(jù)符號

# ROC曲線,類別累計值、目標(biāo)標(biāo)簽
def plotROC(predStrengths, classLabels):
    cur = (1.0, 1.0)  # 每次畫線的起點游標(biāo)點
    ySum = 0.0  # 用于計算AUC的值 矩形面積的高度累計值
    numPosClas = sum(array(classLabels) == 1.0)  # 所有真實正例    確定了在y坐標(biāo)軸上的步進數(shù)目
    yStep = 1 / float(numPosClas)  # 1/所有真實正例 y軸上的步長
    xStep = 1 / float(len(classLabels) - numPosClas)  # 1/所有真實反例 x軸上的步長
    sortedIndicies = predStrengths.argsort()  # 獲得累計值向量從小到大排序的下表index [50,88,2,71...]
    fig = plt.figure()
    fig.clf()
    ax = plt.subplot(111)
    # 循環(huán)所有的累計值 從小到大
    for index in sortedIndicies.tolist()[0]:
        if classLabels[index] == 1.0:
            delX = 0  # 若為一個真正例,則沿y降一個步長,即不斷降低真陽率;
            delY = yStep  # 若為一個非真正例,則沿x退一個步長,尖笑陽率
        else:
            delX = xStep
            delY = 0
            ySum += cur[1]  # 向下移動一次,則累計一個高度。寬度不變,我們只計算高度
        ax.plot([cur[0], cur[0] - delX], [cur[1], cur[1] - delY], c='b')  # 始終會有一個點是沒有改變的
        cur = (cur[0] - delX, cur[1] - delY)
    ax.plot([0, 1], [0, 1], 'b--')
    plt.xlabel('False positive rate')
    plt.ylabel('True positive rate')
    plt.title('ROC curve for AdaBoost horse colic detection system')
    ax.axis([0, 1, 0, 1])
    plt.show()
    print("the Area Under the Curve is: ", ySum * xStep)  # AUC面積我們以 高*低 的矩形來計算


# 測試正確率
datArr, labelArr = loadDataSet('horseColicTraining2.txt')
classifierArr = adaBoostTrainDS(datArr, labelArr, 15)

testArr, testLabelArr = loadDataSet('horseColicTest2.txt')
prediction10 = adaClassify(testArr, classifierArr)

errArr = mat(ones((67, 1)))  # 一共有67個樣本
cnt = errArr[prediction10 != mat(testLabelArr).T].sum()
print(cnt / 67)

# 畫出ROC曲線
datArr, labelArr = loadDataSet('horseColicTraining2.txt')
classifierArray, aggClassEst = adaBoostTrainDS(datArr, labelArr, 10)
plotROC(aggClassEst.T, labelArr)

五、算法優(yōu)化

  • 權(quán)值更新方法的改進

在實際訓(xùn)練過程中可能存在正負樣本失衡的問題,分類器會過于關(guān)注大容量樣本,導(dǎo)致分類器不能較好地完成區(qū)分小樣本的目的。此時可以適度增大小樣本的權(quán)重使重心達到平衡。在實際訓(xùn)練中還會出現(xiàn)困難樣本權(quán)重過高而發(fā)生過擬合的問題,因此有必要設(shè)置困難樣本分類的權(quán)值上限。

  • 訓(xùn)練方法的改進

AdaBoost算法由于其多次迭代訓(xùn)練分類器的原因,訓(xùn)練時間一般會比別的分類器長。對此一般可以采用實現(xiàn)AdaBoost的并行計算或者訓(xùn)練過程中動態(tài)剔除掉權(quán)重偏小的樣本以加速訓(xùn)練過程。

  • 多算法結(jié)合的改進

除了以上算法外,AdaBoost還可以考慮與其它算法結(jié)合產(chǎn)生新的算法,如在訓(xùn)練過程中使用SVM算法加速挑選簡單分類器來替代原始AdaBoost中的窮舉法挑選簡單的分類器。

到此這篇關(guān)于Python機器學(xué)習(xí)之AdaBoost算法的文章就介紹到這了,更多相關(guān)Python AdaBoost算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python實現(xiàn)AdaBoost算法的示例
  • 使用python-cv2實現(xiàn)Harr+Adaboost人臉識別的示例
  • Python基于OpenCV庫Adaboost實現(xiàn)人臉識別功能詳解
  • Python 機器學(xué)習(xí)工具包SKlearn的安裝與使用
  • Python機器學(xué)習(xí)之邏輯回歸
  • python機器學(xué)習(xí)之線性回歸詳解
  • python機器學(xué)習(xí)包mlxtend的安裝和配置詳解
  • Python機器學(xué)習(xí)算法庫scikit-learn學(xué)習(xí)之決策樹實現(xiàn)方法詳解
  • python 機器學(xué)習(xí)之支持向量機非線性回歸SVR模型

標(biāo)簽:潛江 株洲 呂梁 常德 通遼 黑龍江 銅川 阿里

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python機器學(xué)習(xí)之AdaBoost算法》,本文關(guān)鍵詞  Python,機器,學(xué),習(xí)之,AdaBoost,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python機器學(xué)習(xí)之AdaBoost算法》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python機器學(xué)習(xí)之AdaBoost算法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    666欧美在线视频| 国产精品视频在线看| 久久久99精品免费观看| 日本亚洲免费观看| 日韩欧美国产一区二区在线播放| 免费观看久久久4p| 欧美一卡二卡三卡| 精品一区二区三区免费| 久久夜色精品一区| 不卡电影一区二区三区| 亚洲乱码精品一二三四区日韩在线| av男人天堂一区| 亚洲成人免费影院| 91精品国产乱| 成人av在线播放网站| 亚洲国产日韩在线一区模特| 欧美一区二区三区在线| 国产成人综合自拍| 亚洲一区二区成人在线观看| 日韩欧美123| gogogo免费视频观看亚洲一| 婷婷中文字幕一区三区| 国产亚洲精品7777| 欧美欧美欧美欧美首页| 国产成人av一区二区| 亚洲a一区二区| 国产精品久久久久久亚洲伦 | 亚洲黄色小说网站| 欧美精品在线观看一区二区| 国产精品一区免费在线观看| 亚洲一区中文日韩| 国产精品女同一区二区三区| 欧美一区二区网站| av中文字幕在线不卡| 精品在线一区二区| 亚洲成av人影院| 亚洲视频在线一区二区| 精品欧美乱码久久久久久1区2区| 色综合久久综合中文综合网| 成人一区二区三区视频在线观看| 日韩国产在线一| 亚洲一区在线观看网站| 国产精品国产馆在线真实露脸| 欧美一区二区三区四区五区| 色综合中文综合网| 亚洲国产日韩综合久久精品| 国产欧美综合在线观看第十页| 91精品国产高清一区二区三区蜜臀| 99re视频这里只有精品| 国产麻豆一精品一av一免费 | 一卡二卡欧美日韩| 国产精品少妇自拍| 国产欧美一区二区三区沐欲| 日韩精品专区在线影院重磅| 91精品国产欧美一区二区成人| 欧美丝袜第三区| 欧美在线影院一区二区| 91麻豆自制传媒国产之光| 国产91精品一区二区麻豆亚洲| 久久狠狠亚洲综合| 精品一区中文字幕| 另类欧美日韩国产在线| 免费看精品久久片| 美日韩一区二区| 裸体健美xxxx欧美裸体表演| 免费欧美日韩国产三级电影| 麻豆国产欧美日韩综合精品二区| 日韩影院精彩在线| 捆绑紧缚一区二区三区视频 | 成人黄色小视频| 国产激情一区二区三区四区| 国产精品一区二区无线| 国产69精品久久久久毛片| 国产精华液一区二区三区| 成人蜜臀av电影| 一本久道中文字幕精品亚洲嫩| 91丝袜美腿高跟国产极品老师 | 久久精品人人爽人人爽| 国产欧美一二三区| 国产精品国产三级国产aⅴ无密码| 国产欧美一区二区精品仙草咪| 国产欧美一区二区在线观看| 亚洲人成在线播放网站岛国| 亚洲自拍另类综合| 蜜乳av一区二区三区| 波多野结衣中文字幕一区二区三区 | 成人午夜视频在线| 91视频com| 色94色欧美sute亚洲13| 色噜噜夜夜夜综合网| 欧美日韩激情一区二区三区| 日韩精品一区二区三区在线播放| 欧美日韩国产影片| 精品久久久久久久人人人人传媒 | 91蜜桃在线免费视频| 色欧美日韩亚洲| 日韩欧美一区二区久久婷婷| 国产精品久久久久久久久搜平片| 亚洲va国产天堂va久久en| 人人狠狠综合久久亚洲| 成人国产精品免费观看视频| 欧美午夜一区二区三区| 久久影院视频免费| 一区二区三区在线高清| 亚洲第一主播视频| 精品一区二区久久| 色噜噜狠狠色综合中国| 精品国产成人在线影院| 久久精品欧美一区二区三区麻豆| 亚洲福利一二三区| 国产成人综合自拍| 91精品国产色综合久久久蜜香臀| 国产日韩欧美制服另类| 亚洲欧美日韩久久| 国产凹凸在线观看一区二区| 欧美一区二区视频观看视频| 亚洲免费色视频| 国产成人亚洲综合色影视| 在线不卡免费欧美| 亚洲综合男人的天堂| 91偷拍与自偷拍精品| 中文字幕在线一区免费| 国产成人免费视频精品含羞草妖精| 91精品在线麻豆| 日本免费在线视频不卡一不卡二 | 欧美成va人片在线观看| 亚洲小说欧美激情另类| 99久久久久免费精品国产| 久久精品一区二区三区四区| 蜜桃视频一区二区三区 | 精品视频在线免费看| 亚洲天天做日日做天天谢日日欢 | 亚洲精品免费一二三区| 国产黄色91视频| 国产亚洲精品7777| 成人亚洲一区二区一| 国产精品青草综合久久久久99| 国产成人精品影视| 欧美国产1区2区| 成人av动漫在线| 亚洲精品伦理在线| 91国产精品成人| 亚洲成人久久影院| 欧美一级片在线看| 久久99国产精品尤物| 久久九九99视频| 色哟哟欧美精品| 亚洲成a天堂v人片| 欧美日韩一级视频| 国产在线国偷精品免费看| 国产精品天美传媒| 色婷婷av一区二区三区大白胸 | 视频一区视频二区中文| 欧美一区二区播放| 国内外成人在线| 国产精品欧美精品| 91久久精品网| 视频一区二区不卡| 国产亚洲女人久久久久毛片| 91欧美一区二区| 视频一区二区三区中文字幕| 欧美videossexotv100| 高清av一区二区| 亚洲亚洲人成综合网络| www国产成人| 91一区一区三区| 麻豆精品视频在线观看| 亚洲人成网站影音先锋播放| 在线电影院国产精品| 国产成人综合亚洲网站| 亚洲国产视频一区二区| 精品国产凹凸成av人导航| 色哟哟在线观看一区二区三区| 麻豆精品国产传媒mv男同| 最新日韩在线视频| 欧美成人一区二区三区在线观看| 国产一二三精品| 亚洲一区在线视频观看| 久久精品视频免费| 在线播放中文一区| 不卡电影一区二区三区| 精品一区二区三区影院在线午夜 | 日韩毛片精品高清免费| 日韩欧美在线影院| 91看片淫黄大片一级在线观看| 免费观看在线色综合| 亚洲人成伊人成综合网小说| 久久综合九色综合欧美98 | 性做久久久久久久久| 国产精品麻豆99久久久久久| 日韩欧美一区中文| 日本精品免费观看高清观看| 国产成人在线视频免费播放| 欧美aaaaaa午夜精品| 亚洲午夜电影网| 亚洲观看高清完整版在线观看| 中文字幕一区二区三| 中文一区二区在线观看| 国产亚洲短视频| 国产日韩av一区|