IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 实验5 SVM -> 正文阅读

[人工智能]实验5 SVM

对于二分类问题,我们通过观察二维的二分类问题容易想到存在一条直线能将其最优分类,观察三维的,我们也能想到存在一个平面。由此我们想到,对于n维数据集,存在一个超平面,能将其二分类。这就是SVM的背景,那怎样求这个超平面哪?

?

代码如下:对此仍然有疑惑,比如若P矩阵不增加一个单位矩阵,其不正定,无法调用标准库。

LBP处理数据:

import numpy as np

from matplotlib import colors, pyplot as plt

from numpy.core.fromnumeric import transpose

import random

from cvxopt import solvers

from numpy.lib.function_base import append

import qpsolvers

# image=np.zeros((28,28),dtype=int)

inilabel=[]

inidata=[]

File=open('C:/Users/18110/Desktop/ML/lab5/data5/test-01-images.svm')

for i in range(0,2115):

? ? image=np.zeros((28,28),dtype=int)

? ? nowline=File.readline()

? ? # nowline=nowline.split("\n")[0]

? ? nowline=nowline.split(" ")

? ? inilabel.append(int(nowline[0]))

? ? for element in nowline:

? ? ? ? if(element==nowline[0] or element==nowline[len(nowline)-1]):continue

? ? ? ? nowelement=element.split(":")

? ? ? ? row=int(int(nowelement[0])/28)

? ? ? ? col=int(int(nowelement[0])%28)

? ? ? ?

? ? ? ? image[row][col]=int(nowelement[1])

? ? inidata.append(image)

prodata=np.zeros((2115,256),dtype=int)

for index in range(0,2115):

? ? for row in range(1,27):

? ? ? ? for col in range(1,27):

? ? ? ? ? ? nownum=0

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row-1][col-1]):nownum+=1

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row-1][col]):nownum+=2

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row-1][col+1]):nownum+=4

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row][col-1]):nownum+=8

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row][col+1]):nownum+=16

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row+1][col-1]):nownum+=32

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row+1][col]):nownum+=64

? ? ? ? ? ? if(inidata[index][row][col]>inidata[index][row+1][col+1]):nownum+=128

? ? ? ? ? ? prodata[index][nownum]+=1

inilabel=np.array(inilabel,dtype=int)

prodata=np.array(prodata,dtype=int)

l=np.c_[inilabel,prodata]

np.savetxt("C:/Users/18110/Desktop/ML/lab5/data5/lab5-2testdata.txt",l)

5-1:

import numpy as np

from matplotlib import colors, pyplot as plt

from numpy.core.fromnumeric import transpose

import random

from cvxopt import solvers

import qpsolvers

x=np.loadtxt('C:/Users/18110/Desktop/ML/lab5/data5/training_2.txt')

test=np.loadtxt('C:/Users/18110/Desktop/ML/lab5/data5/test_2.txt')

m=len(x)

u=test[:,0]

v=test[:,1]

y=x[:,2]

y=y.reshape(1500,)

x=x[:,0:2]

plt.scatter(u,v,s=4,c=test[:,2])

P=np.zeros((m,m))

for i in range(0,m):

? ? for j in ?range(0,m):

? ? ? ? P[i][j]=y[i]*y[j]*np.dot(x[i],x[j])

? ? ? ? if(i==j):

? ? ? ? ? ? P[i][j]+=10

G=np.r_[np.identity(m),-np.identity(m)]

h=np.r_[np.ones((m,)),np.zeros((m,))]

# h=np.r_[np.zeros((m,)),np.ones((m,))]

q=-np.ones((m,))

b=np.zeros((1,))

alfa=qpsolvers.solve_qp(P=P,q=q,G=G,h=h,A=y,b=b).reshape(1500,1)

w=np.zeros(2)# w=alfa[0]*y[0]*x[0]

num1=0

finalb=0

for i in range(0,m):

? ? w+=alfa[i]*y[i]*x[i]

for i in range(0,m):

? ? ?if(alfa[i]>=0):

? ? ? ? finalb+=y[i]-np.dot(x[i],w)

? ? ? ? num1+=1

finalb/=num1


?

tx=[]

ty1=[]

ty2=[]

ty3=[]

for a ?in range(50,160,10):

? ? tx.append(a)

? ? ty1.append(-a*w[0]/w[1]-(finalb-1)/w[1])

? ? ty2.append(-a*w[0]/w[1]-(finalb+1)/w[1])

? ? ty3.append(-a*w[0]/w[1]-(finalb)/w[1])

plt.plot(tx,ty1)

plt.plot(tx,ty2)

plt.plot(tx,ty3)

test=np.loadtxt('C:/Users/18110/Desktop/ML/lab5/data5/test_2.txt')

num=0

sum=len(test)

for i in test:

? ? now=i[0:2]

? ? if((np.dot(w,now)>0 and i[2]==1 )or(np.dot(w,now)<0 and i[2]==-1) ):

? ? ? ? num+=1

print(sum,num)

print(num/sum)

plt.show()



lab5 -2

import numpy as np

from matplotlib import colors, pyplot as plt

from numpy.core.fromnumeric import transpose

import random

from cvxopt import solvers

from numpy.core.numeric import tensordot

from numpy.lib.function_base import append

import qpsolvers


?

f=np.loadtxt("C:/Users/18110/Desktop/ML/lab5/data5/lab5-2traindata.txt")

y=f[0:1000,0]

x=f[0:1000,1:257]

m=len(y)

P=np.zeros((m,m))

for i in range(0,m):

? ? for j in ?range(0,m):

? ? ? ? P[i][j]=y[i]*y[j]*np.dot(x[i],x[j])

? ? ? ? # print(P[i][j])

? ? ? ? # print(np.dot(x[i],x[j]))

? ? ? ? if(i==j):

? ? ? ? ? ? P[i][j]+=1

G=np.r_[np.identity(m),-np.identity(m)]

h=np.r_[0.05*np.ones((m,)),np.zeros((m,))]

q=-np.ones((m,))

b=np.zeros((1,))

alfa=qpsolvers.solve_qp(P=P,q=q,G=G,h=h,A=y,b=b).reshape((1000,1))

w=np.zeros(256)

num1=0

finalb=0

for i in range(0,m):

? ? w+=alfa[i]*y[i]*x[i]

for i in range(0,m):

? ? if(alfa[i]>=0):

? ? ? ? finalb+=y[i]-np.dot(x[i],w)

? ? ? ? num1+=1

finalb/=num1


?

#print(w,finalb)

test=np.loadtxt("C:/Users/18110/Desktop/ML/lab5/data5/lab5-2testdata.txt")

num1=0

num2=0

for i in test:

? ? ? ? now=i[1:257]

? ? ? ? if((np.dot(w,now)+finalb>0 and i[0]==1 )or(np.dot(w,now)+finalb<0 and i[0]==-1) ):

? ? ? ? ? ? num1+=1

? ? ? ? else: print(num1)

for i in f:

? ? ? ? now=i[1:257]

? ? ? ? if((np.dot(w,now)+finalb> 0 and i[0]==1 )or(np.dot(w,now)+finalb<0 and i[0]==-1) ):

? ? ? ? ? ? num2+=1

? ?

print("测试数据的准确率为",num1/len(test))

print("训练数据的准确率为",num2/12665)

? ?lab5-3

import numpy as np

from matplotlib import colors, pyplot as plt

from numpy.core.fromnumeric import transpose

import random

from cvxopt import solvers

from numpy.core.numeric import tensordot

from numpy.lib.function_base import append

import qpsolvers

def knerl(a,b):

? ? return np.exp(-100*np.linalg.norm(a-b)**2)

def cal(alfa,b,y,x,nowx,nowy):

? ? result=0

? ? for i in range (0,211):

? ? ? ? if(alfa[i]>0):

? ? ? ? ? ? result+=alfa[i]*y[i]*knerl(x[i],[nowx,nowy])

? ? return abs(result+b)


?

def svm(train,C=1,a=1):

? ? y=train[:,2]

? ? x=train[:,0:2]

? ? m=len(train)

? ? P=np.zeros((m,m))

? ? for i in range(0,m):

? ? ? ? for j in ?range(0,m):

? ? ? ? ? ? P[i][j]=y[i]*y[j]*knerl(x[i],x[j])

? ? ? ? ? ? if(i==j):

? ? ? ? ? ? ? ? P[i][j]+=a

? ? G=np.r_[np.identity(m),-np.identity(m)]

? ? h=np.r_[C*np.ones((m,)),np.zeros((m,))]

? ? q=-np.ones((m,))

? ? b=np.zeros((1,))

? ? alfa=qpsolvers.solve_qp(P=P,q=q,G=G,h=h,A=y,b=b).reshape((211,1))

? ? w=np.zeros(2)

? ? num1=0

? ?

? ? finalb=0

? ? for i in range(0,m):

? ? ? ? finalb+=y[i]

? ? ? ? for j in range(0,m): ? ?

? ? ? ? ? ? if(alfa[j]>=0):

? ? ? ? ? ? ? ? finalb-=y[j]*alfa[j]*knerl(x[i],x[j])

? ? finalb/=m

? ? print(finalb)

? ? tx=[]

? ? ty=[]

? ? for a in np.arange(-0.6,0.4,0.01):

? ? ? ? print(a)

? ? ? ? for j in np.arange(-0.6,0.6,0.01):

? ? ? ? ?calnum=cal(alfa,finalb,y,x,a,j)

? ? ? ? ?if(calnum<0.1 and calnum!=0):

? ? ? ? ? ? ?tx.append(a)

? ? ? ? ? ? ?ty.append(j)

? ? plt.scatter(tx,ty)

? ? plt.show()


?

? ? num2=0

? ? for i in train:

? ? ? ? now=i[0:2]

? ? ? ? if((np.dot(w,now)>0 and i[2]==1 )or(np.dot(w,now)<0 and i[2]==-1) ):

? ? ? ? ? ? num2+=1

? ? ? ?

x=np.loadtxt('C:/Users/18110/Desktop/ML/lab5/data5/training_3.text')

u=x[:,0]

v=x[:,1]

co=x[:,2]

plt.scatter(u,v,c=co)

a=svm(x,1,0.01)


?

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-11-24 07:56:48  更:2021-11-24 07:58:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 4:23:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码