ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

ML之SVM:随机产生100个点,建立SVM模型,找出超平面方程

2021-06-15 20:58:57  阅读:261  来源: 互联网

标签:SVM 个点 clf vectors yy xx 超平面 100 pl


ML之SVM:随机产生100个点,建立SVM模型,找出超平面方程

 

 

目录

实现结果

代码实例

 


 

 

 

实现结果

 

 

代码实例

import numpy as np
import pylab as pl 
from sklearn import svm

X = np.r_[np.random.randn(100, 2) - [2, 2], np.random.randn(100, 2) + [2, 2]]  

Y = [0]*100 +[1]*100  

clf = svm.SVC(kernel='linear')
clf.fit(X, Y)

w = clf.coef_[0]  
a = -w[0]/w[1]          
xx = np.linspace(-5, 5)  
yy = a*xx - (clf.intercept_[0])/w[1]   


b = clf.support_vectors_[0]
yy_down = a*xx + (b[1] - a*b[0])
b = clf.support_vectors_[-1]
yy_up = a*xx + (b[1] - a*b[0])

print ("w: ", w)
print ("a: ", a)

# print "xx: ", xx
# print "yy: ", yy
print ("support_vectors_: ", clf.support_vectors_)
print ("clf.coef_: ", clf.coef_)


# plot the line, the points, and the nearest vectors to the plane
pl.plot(xx, yy, 'k-')  
pl.plot(xx, yy_down, 'k--')  
pl.plot(xx, yy_up, 'k--')

pl.scatter(clf.support_vectors_[:, 0], clf.support_vectors_[:, 1], 
          s=80, facecolors='none')
pl.scatter(X[:, 0], X[:, 1], c=Y, cmap=pl.cm.Paired)

pl.axis('tight')
pl.show()  

 

 

 

相关文章
ML之SVM:随机产生100个点,建立SVM模型,找出超平面方程

 

标签:SVM,个点,clf,vectors,yy,xx,超平面,100,pl
来源: https://blog.51cto.com/u_14217737/2906451

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有