本节练习是为了应用SVM进行非线性拟合,使用Gaussian Kernel
首先load数据集并plot
#----------------------------part4---------------------------#
#读取数据1,并将数据整理成可识别的格式
path = 'C:\\Users\Huanuo\PycharmProjects\ml\ex6_svm\ex6\ex6data2.mat'
m = loadmat(path)
df1 = pd.DataFrame(m['X'])
df2 = pd.DataFrame(m['y'])
df3 = pd.concat([df1,df2],axis=1)
df3.columns = [1,2,3]
#将数据可视化
n = 1024
X1 = df3.loc[df3[3]==1,1]
Y1 = df3.loc[df3[3]==1,2]
scatter(X1,Y1,marker = '*',color = 'r')
X2 = df3.loc[df3[3]==0,1]
Y2 = df3.loc[df3[3]==0,2]
scatter(X2,Y2,marker = '+',color = 'y')
show()
然后应用SVM进行建模,这中间踩了很多坑,大坑,首先贴一下成功的代码:
import numpy as np
from sklearn.svm import SVC
fro