日韩性视频-久久久蜜桃-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算法的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 无码国产伦一区二区三区视频 | 国产精品成人无码免费 | 黄色片在哪里看 | 亚洲 欧美 日韩 综合 | wwwav视频 | 日本aa大片 | 欧美激情免费在线观看 | 极品美女扒开粉嫩小泬 | 韩国一区二区三区视频 | 男生操女生逼逼 | 国产精品无码免费播放 | 国产高潮视频 | 久久久久久亚洲中文字幕无码 | 在线无码va中文字幕无码 | 亚洲色图久久 | 免费成人高清视频 | 日本免费福利视频 | 久草最新网址 | 欧美日韩综合一区二区 | 久久久噜噜噜久久中文字幕色伊伊 | 日韩在线视频观看免费 | 欧美成人国产精品一区二区 | 国产乡下妇女做爰毛片 | 成人高清免费 | a毛片网站 | 不卡一区在线 | 亚洲av无码不卡一区二区三区 | 午夜黄网| 日本簧片在线观看 | 国产后入清纯学生妹 | 亚洲天堂男人 | 91精品视频免费观看 | 男人的天堂色偷偷 | jizz成熟丰满日本少妇 | 在线天堂1 | 卡通动漫精品一区二区三区 | 视频在线91 | 日本成人免费在线视频 | 久操视频在线观看 | av亚州| 国产女女 | 国产精品露脸视频 | 欧美成人性生活片 | 亚洲精品乱码久久久久99 | 日韩在线视频观看免费 | 在线美女av | 国产做受高潮漫动 | 亚洲码欧美码一区二区三区 | 久久麻豆av | 四虎av影院 | 国产精品伦一区二区三区 | 欧美xx视频 | 久久av高潮av无码av喷吹 | 欧美性受xxx | 高清18麻豆| 91视频直接看 | 国产精品国产三级国产普通话蜜臀 | 一本色道综合久久欧美日韩精品 | 色婷五月 | 自拍偷拍视频在线观看 | 欧美高清视频 | 欧美1314 | 欧美日韩国产免费一区二区三区 | 日韩性猛交ⅹxxx乱大交 | 亚洲欧洲中文 | 欧洲人妻丰满av无码久久不卡 | 国产偷亚洲偷欧美偷精品 | 欧美一区二区三区四 | 处女朱莉 | 三级黄色视屏 | 久久这里有精品 | 成人av毛片| 久久久久国产精品夜夜夜夜夜 | 加勒比hezyo黑人专区 | 毛片123 | 亚洲人在线观看视频 | 韩国一区二区三区四区 | 久久久久久久久91 | 一级在线观看 | 综合久久影院 | 国产视色 | 日韩在线不卡视频 | 88国产精品 | 日本午夜电影网站 | 91精品国产一区二区三竹菊影视 | 99久久精品免费看国产四区 | 少妇高潮久久久久久潘金莲 | 国产精品中文久久久久久 | 夜夜操导航 | 在线观看不卡av | 色漫在线观看 | 女十八毛片 | 亚洲另类春色 | 亚洲三级小视频 | 男人天堂免费视频 | 国产又粗又长又黄的视频 | 亚洲精品鲁一鲁一区二区三区 | 国产三级做爰高清在线 | 成年人拍拍视频 |