日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

【机器学习算法-python实现】svm支持向量机(2)—简化版SMO算法

發布時間:2025/4/5 python 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【机器学习算法-python实现】svm支持向量机(2)—简化版SMO算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

(轉載請注明出處:http://blog.csdn.net/buptgshengod)

1.背景知識

? ? ?通過上一節我們通過引入拉格朗日乗子得到支持向量機變形公式。詳細變法可以參考這位大神的博客——地址? 參照拉格朗日公式F(x1,x2,...λ)=f(x1,x2,...)-λg(x1,x2...)。我們把上面的式子變型為:
?約束條件就變成了:下面就根據最小優化算法SMO(Sequential Minimal Optimization)。找出距離分隔面最近的點,也就是支持向量集。如下圖的藍色點所示。




2.代碼

import matplotlib.pyplot as plt from numpy import * from time import sleepdef loadDataSet(fileName):dataMat = []; labelMat = []fr = open(fileName)for line in fr.readlines():lineArr = line.strip().split('\t')dataMat.append([float(lineArr[0]), float(lineArr[1])])labelMat.append(float(lineArr[2]))return dataMat,labelMatdef selectJrand(i,m):j=i #we want to select any J not equal to iwhile (j==i):j = int(random.uniform(0,m))return jdef clipAlpha(aj,H,L):if aj > H: aj = Hif L > aj:aj = Lreturn ajdef smoSimple(dataMatIn, classLabels, C, toler, maxIter):dataMatrix = mat(dataMatIn); labelMat = mat(classLabels).transpose()b = 0; m,n = shape(dataMatrix)alphas = mat(zeros((m,1)))iter = 0while (iter < maxIter):alphaPairsChanged = 0for i in range(m):fXi = float(multiply(alphas,labelMat).T*(dataMatrix*dataMatrix[i,:].T)) + bEi = fXi - float(labelMat[i])#if checks if an example violates KKT conditionsif ((labelMat[i]*Ei < -toler) and (alphas[i] < C)) or ((labelMat[i]*Ei > toler) and (alphas[i] > 0)):j = selectJrand(i,m)fXj = float(multiply(alphas,labelMat).T*(dataMatrix*dataMatrix[j,:].T)) + bEj = fXj - float(labelMat[j])alphaIold = alphas[i].copy(); alphaJold = alphas[j].copy();if (labelMat[i] != labelMat[j]):L = max(0, alphas[j] - alphas[i])H = min(C, C + alphas[j] - alphas[i])else:L = max(0, alphas[j] + alphas[i] - C)H = min(C, alphas[j] + alphas[i]) # if L==H: print "L==H"; continueeta = 2.0 * dataMatrix[i,:]*dataMatrix[j,:].T - dataMatrix[i,:]*dataMatrix[i,:].T - dataMatrix[j,:]*dataMatrix[j,:].Tif eta >= 0: print "eta>=0"; continuealphas[j] -= labelMat[j]*(Ei - Ej)/etaalphas[j] = clipAlpha(alphas[j],H,L) # if (abs(alphas[j] - alphaJold) < 0.00001): print "j not moving enough"; continuealphas[i] += labelMat[j]*labelMat[i]*(alphaJold - alphas[j])#update i by the same amount as j#the update is in the oppostie directionb1 = b - Ei- labelMat[i]*(alphas[i]-alphaIold)*dataMatrix[i,:]*dataMatrix[i,:].T - labelMat[j]*(alphas[j]-alphaJold)*dataMatrix[i,:]*dataMatrix[j,:].Tb2 = b - Ej- labelMat[i]*(alphas[i]-alphaIold)*dataMatrix[i,:]*dataMatrix[j,:].T - labelMat[j]*(alphas[j]-alphaJold)*dataMatrix[j,:]*dataMatrix[j,:].Tif (0 < alphas[i]) and (C > alphas[i]): b = b1elif (0 < alphas[j]) and (C > alphas[j]): b = b2else: b = (b1 + b2)/2.0alphaPairsChanged += 1 # print "iter: %d i:%d, pairs changed %d" % (iter,i,alphaPairsChanged)if (alphaPairsChanged == 0): iter += 1else: iter = 0 # print "iteration number: %d" % iterreturn b,alphasdef matplot(dataMat,lableMat):xcord1 = []; ycord1 = []xcord2 = []; ycord2 = []xcord3 = []; ycord3 = []for i in range(100):if lableMat[i]==1:xcord1.append(dataMat[i][0])ycord1.append(dataMat[i][1])else:xcord2.append(dataMat[i][0])ycord2.append(dataMat[i][1]) b,alphas=smoSimple(dataMat,labelMat,0.6,0.001,40)for j in range(100):if alphas[j]>0:xcord3.append(dataMat[j][0])ycord3.append(dataMat[j][1]) fig = plt.figure()ax = fig.add_subplot(111)ax.scatter(xcord1, ycord1, s=30, c='red', marker='s')ax.scatter(xcord2, ycord2, s=30, c='green')ax.scatter(xcord3, ycord3, s=80, c='blue')ax.plot()plt.xlabel('X1'); plt.ylabel('X2');plt.show() if __name__=='__main__':dataMat,labelMat=loadDataSet('/Users/hakuri/Desktop/testSet.txt') # b,alphas=smoSimple(dataMat,labelMat,0.6,0.001,40) # print b,alphas[alphas>0]matplot(dataMat,labelMat)


代碼下載

總結

以上是生活随笔為你收集整理的【机器学习算法-python实现】svm支持向量机(2)—简化版SMO算法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产免费色视频 | 日本激情影院 | 日本 奴役 捆绑 受虐狂xxxx | 午夜黄色网 | 国产又粗又黄又猛 | av解说在线观看 | 日韩无 | 国产福利三区 | 999久久久免费精品国产 | 亚洲日本欧美在线 | 精品成人无码久久久久久 | 超碰p| 91香蕉国产在线观看软件 | 午夜欧美视频 | 第一色综合 | brazzers欧美大波霸 | 国产小视频在线免费观看 | 久久久久国产精品一区二区 | 国产精品久久久久久影视 | 亚洲高清视频一区二区 | 精品无码一区二区三区免费 | 国产黑丝在线观看 | 亚洲视频综合 | 国产成人在线视频播放 | 妺妺窝人体色www在线小说 | 国产午夜电影 | 国产精品分类 | 国产成人8x视频一区二区 | 风流僵尸艳片a级 | 思思99re| 精品在线视频一区二区三区 | 鸭子av | 黑人导航 | 在线观看黄色大片 | 成年人在线播放 | 午夜两性| 国产精品一卡二卡在线观看 | 成人黄色短视频在线观看 | 中文字幕av一区二区三区人妻少妇 | 秋霞在线视频 | 少女视频的播放方法 | 美女福利一区 | 成人福利社 | 免费观看成人 | 成人中文字幕在线观看 | 欧美一级片一区 | 夜夜欢视频 | 亚洲精品国产成人av在线 | 你懂的在线网站 | 一卡二卡三卡在线视频 | 一区二区三区免费 | 日本一区二区成人 | 国产精品va无码一区二区三区 | 男人的天堂免费视频 | 亚洲AV无码乱码国产精品色欲 | 十八禁视频网站在线观看 | 中文字幕在线资源 | 激情午夜影院 | 狠狠爱夜夜操 | 午夜日韩电影 | 国产三级精品三级在线 | 爆操巨乳美女 | 国产黑丝在线观看 | 亚洲综合在线观看视频 | gai免费观看网站外网 | 51久久 | 中文字幕日韩欧美一区二区 | 久成人| 91免费看国产 | 精品色综合 | bt天堂新版中文在线地址 | 岛国av大片| 你懂的在线播放 | 含羞草一区二区三区 | 五月婷婷深深爱 | 日韩欧美一二三四区 | 人妻熟女aⅴ一区二区三区汇编 | 国产对白刺激视频 | 91在线播放国产 | 性生交大片免费看l | 三级全黄做爰在线观看 | 好爽又高潮了毛片 | 性生活一区 | av综合在线观看 | 91亚洲精品久久久久久久久久久久 | 老牛影视av老牛影视av | 中文字幕乱码一区 | 女性私密整形视频 | 外国黄色网址 | 欧美一级爆毛片 | 岛国精品资源网站 | 中文字幕日韩欧美一区二区 | 欧美黄色一级大片 | 国产情侣久久久久aⅴ免费 caoporn成人 | 极品少妇一区二区三区 | 精品黑人一区二区三区国语馆 | av片毛片| 99香蕉视频| 国产精品毛片一区二区 |