欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python可視化實(shí)現(xiàn)KNN算法

 更新時(shí)間:2019年10月16日 10:45:08   作者:Kalankalan  
這篇文章主要為大家詳細(xì)介紹了python可視化實(shí)現(xiàn)KNN算法,通過(guò)繪圖工具M(jìn)atplotlib包可視化實(shí)現(xiàn)機(jī)器學(xué)習(xí)中的KNN算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

簡(jiǎn)介

這里通過(guò)python的繪圖工具M(jìn)atplotlib包可視化實(shí)現(xiàn)機(jī)器學(xué)習(xí)中的KNN算法。

需要提前安裝python的Numpy和Matplotlib包。

KNN–最近鄰分類算法,算法邏輯比較簡(jiǎn)單,思路如下:

1.設(shè)一待分類數(shù)據(jù)iData,先計(jì)算其到已標(biāo)記數(shù)據(jù)集中每個(gè)數(shù)據(jù)的距離,例如歐拉距離sqrt((x1-x2)^2+(y1-y2)^2);

2.然后根據(jù)離iData最近的k個(gè)數(shù)據(jù)的分類,出現(xiàn)次數(shù)最多的類別定為iData的分類。

KNN——最近鄰算法python代碼

代碼實(shí)現(xiàn):

import numpy as np
import matplotlib as mpl
import matplotlib.pyplot as plt

def KNNClassify(labelData,predData,k): #數(shù)據(jù)集包含分類屬性
#labelData 是已經(jīng)標(biāo)記分類的數(shù)據(jù)集
#predData 未分類的待預(yù)測(cè)數(shù)據(jù)集
 labShape = labelData.shape
 for i in range(predData.shape[0]): #以predData的每行數(shù)據(jù)進(jìn)行遍歷
 iData = predData[i]
 iDset = np.tile(iData,(labShape[0],1)) #將iData重復(fù),擴(kuò)展成與labelData同形的矩陣
 #這里用歐拉距離sqrt((x1-x2)^2+(y1-y2)^2)
 diff = iDset[...,:-1] - labelData[...,:-1]
 diff = diff**2
 distance = np.sum(diff,axis=1)
 distance = distance ** 0.5 #開(kāi)根號(hào)
 sortedIND = np.argsort(distance) #排序,以序號(hào)返回。
 classCount = { }
 for j in range(k): #計(jì)算距離最近的前k個(gè)標(biāo)記數(shù)據(jù)的類別
 voteLabel = labelData[sortedIND[j],-1]
 classCount[voteLabel] = classCount.get(voteLabel,0)+1

 maxcls = max(classCount,key=classCount.get) #類別最多的,返回鍵名(類別名)
 predData[i][...,-1] = maxcls

 return predData

為了測(cè)試這個(gè)算法,需要現(xiàn)成的已分類數(shù)據(jù)集,由于手動(dòng)輸入很有限,數(shù)據(jù)量少,耗時(shí)。作為學(xué)習(xí)我們這里用代碼模擬生成數(shù)據(jù)來(lái)進(jìn)行測(cè)試。下面是生成已分類數(shù)據(jù)集的代碼:

生成模擬數(shù)據(jù)的函數(shù)

import numpy as np
import matplotlib as mpl
import matplotlib.pyplot as plt

#模擬生成分類數(shù)據(jù)
#目標(biāo)是產(chǎn)生二維坐標(biāo)中的幾堆數(shù)據(jù)集,每堆為一個(gè)類
#函數(shù)邏輯:
#將x軸分段,每個(gè)段設(shè)一個(gè)中心的,所有的中心點(diǎn)用cores存儲(chǔ)。
#設(shè)置每個(gè)數(shù)據(jù)中心點(diǎn)core的類別,由中心點(diǎn)在一定范圍內(nèi)隨機(jī)產(chǎn)生數(shù)據(jù),并將這些數(shù)據(jù)設(shè)為和core一樣的類別
#所以每類的數(shù)據(jù)會(huì)簡(jiǎn)單的被X軸的每段大致分開(kāi)

def makeKNNData(colnum,clsnum,nums,cores = []):
#colnum單個(gè)數(shù)據(jù)擁有特征數(shù)量(包括數(shù)據(jù)的分類);
# clsnum表示共有多少種分類;
# nums是一個(gè)元組,表示每個(gè)類別希望產(chǎn)生多少數(shù)據(jù)樣本,如colnum為5,nums為[56, 69, 60, 92, 95];
#cores非必要參數(shù),手動(dòng)給出只是用于測(cè)試,cores提供每類的中心點(diǎn),以中心點(diǎn)為依據(jù)產(chǎn)生該類數(shù)據(jù)。

 dataSet = np.zeros((sum(nums),colnum)) #初始化數(shù)據(jù)集,用于存放隨后生成的所有數(shù)據(jù)
 n=0 #記錄生成數(shù)據(jù)的下標(biāo)
 step = 20/clsnum #假定X坐標(biāo)軸只顯示0~20的范圍,step為X軸分段后的段長(zhǎng)
 for j in range(clsnum): #循環(huán)生成各個(gè)類數(shù)據(jù)
 try:
 core = cores[j] #如果cores沒(méi)有給出則,則出錯(cuò),跳至except執(zhí)行
 except IndexError :
 core = np.random.rand(1,3) #中心點(diǎn)為array([[x1,x2,c]]),c用于表示類別,這里產(chǎn)生的是1*3的二維數(shù)組
 core[0][0] =j*step + core[0][0]*step #將x1限制在各段中
 core[0][1] *=15 #將x2即y軸限制在0~15范圍內(nèi)
 core[0][2] = j #設(shè)置類別
 cores.append(core)
 for i in range(nums[j]): #按nums中指定了每類數(shù)據(jù)的數(shù)量,用循環(huán)生成。
 point= core[0][:2] + np.random.rand(1,2)*step -step/2 #產(chǎn)生點(diǎn)point(x,y),x以中心點(diǎn)在(core_x - step/2, core_x + step/2)范圍隨機(jī)波動(dòng),y同理。
 row = np.column_stack((point,core[0][2])) #加上類別成為一個(gè)數(shù)據(jù)
 dataSet[n] = row
 n +=1
 i +=1

 j +=1

 #print("print cores:",cores)
 return dataSet

有了數(shù)據(jù)集之后,我們可以用Matplotlib將數(shù)據(jù)可視化,以直觀顯示出來(lái)

數(shù)據(jù)可視化函數(shù)

import numpy as np
import matplotlib as mpl
import matplotlib.pyplot as plt

#繪圖展示數(shù)據(jù),每類數(shù)據(jù)點(diǎn)以不同的顏色顯示
def showFigure(dataSet,clsnum):
 fig = plt.figure()
 ax = fig.add_subplot(1,1,1) #界面只需顯示一個(gè)視圖
 ax.set_title('KNN separable data set') #視圖名稱,這里簡(jiǎn)單統(tǒng)一定這個(gè)名稱吧
 plt.xlabel('X') #坐標(biāo)軸名稱
 plt.ylabel('Y')

 colors = ['r','g','b','y','k'] #定義顯示的顏色b為blue,k為black
 for i in range(clsnum):
 idx = np.where(dataSet[:,2] == i) #查詢每類的索引號(hào)
 ax.scatter(dataSet[idx,0], dataSet[idx,1], marker='o', color=colors[i%5], label=1, s=10) #在視圖中的顯示方式

 plt.legend(loc = 'upper right') #圖例顯示位置
 plt.show()


#測(cè)試一下
#需要結(jié)合模擬生成數(shù)據(jù)的函數(shù)
classnum = 5
nums = np.random.randint(50,100,classnum) #示例 array([56, 69, 60, 92, 95]),每個(gè)數(shù)字在50~100范圍內(nèi)
dataSet = makeKNNData(3,classnum,nums)
showFigure(dataSet,classnum)

生成的模擬數(shù)據(jù)展示結(jié)果如下:

完整代碼

import numpy as np
import matplotlib as mpl
import matplotlib.pyplot as plt

#模擬生成分類數(shù)據(jù)
#目標(biāo)是產(chǎn)生二維坐標(biāo)中的幾堆數(shù)據(jù)集,每堆為一個(gè)類
#函數(shù)邏輯:
#將x軸分段,每個(gè)段設(shè)一個(gè)中心的,所有的中心點(diǎn)用cores存儲(chǔ)。
#設(shè)置每個(gè)數(shù)據(jù)中心點(diǎn)core的類別,由中心點(diǎn)在一定范圍內(nèi)隨機(jī)產(chǎn)生數(shù)據(jù),并將這些數(shù)據(jù)設(shè)為和core一樣的類別
#所以每類的數(shù)據(jù)會(huì)簡(jiǎn)單的被X軸的每段大致分開(kāi)

def makeKNNData(colnum,clsnum,nums,cores = []):
#colnum單個(gè)數(shù)據(jù)擁有特征數(shù)量(包括數(shù)據(jù)的分類);
# clsnum表示共有多少種分類;
# nums是一個(gè)元組,表示每個(gè)類別希望產(chǎn)生多少數(shù)據(jù)樣本;
#cores非必要參數(shù),手動(dòng)給出只是用于測(cè)試,cores提供每類的中心點(diǎn),以中心點(diǎn)為依據(jù)產(chǎn)生該類數(shù)據(jù)。

 dataSet = np.zeros((sum(nums),colnum)) #初始化數(shù)據(jù)集,用于存放隨后生成的所有數(shù)據(jù)
 n=0 #記錄生成數(shù)據(jù)的下標(biāo)
 step = 20/clsnum #假定X坐標(biāo)軸只顯示0~20的范圍,step為X軸分段后的段長(zhǎng)
 for j in range(clsnum): #循環(huán)生成各個(gè)類數(shù)據(jù)
 try:
 core = cores[j] #如果cores沒(méi)有給出則,則出錯(cuò),跳至except執(zhí)行
 except IndexError :
 core = np.random.rand(1,3) #中心點(diǎn)為array([[x1,x2,c]]),c用于表示類別,這里產(chǎn)生的是1*3的二維數(shù)組
 core[0][0] =j*step + core[0][0]*step #將x1限制在各段中
 core[0][1] *=15 #將x2即y軸限制在0~15范圍內(nèi)
 core[0][2] = j #設(shè)置類別
 cores.append(core)
 for i in range(nums[j]): #按nums中指定了每類數(shù)據(jù)的數(shù)量,用循環(huán)生成。
 point= core[0][:2] + np.random.rand(1,2)*step -step/2 #產(chǎn)生點(diǎn)point(x,y),x以中心點(diǎn)在(core_x - step/2, core_x + step/2)范圍隨機(jī)波動(dòng),y同理。
 row = np.column_stack((point,core[0][2])) #加上類別成為一個(gè)數(shù)據(jù)
 dataSet[n] = row
 n +=1
 i +=1

 j +=1

 #print("print cores:",cores)
 return dataSet

#繪圖展示數(shù)據(jù),每類數(shù)據(jù)點(diǎn)以不同的顏色顯示
def showFigure(dataSet,clsnum):
 fig = plt.figure()
 ax = fig.add_subplot(1,1,1) #界面只需顯示一個(gè)視圖
 ax.set_title('KNN separable data set') #視圖名稱,這里簡(jiǎn)單統(tǒng)一定這個(gè)名稱吧
 plt.xlabel('X') #坐標(biāo)軸名稱
 plt.ylabel('Y')

 colors = ['r','g','b','y','k'] #定義顯示的顏色b為blue,k為black
 for i in range(clsnum):
 idx = np.where(dataSet[:,2] == i) #查詢每類的索引號(hào)
 ax.scatter(dataSet[idx,0], dataSet[idx,1], marker='o', color=colors[i%5], label=1, s=10) #在視圖中的顯示方式

 plt.legend(loc = 'upper right') #圖例顯示位置
 plt.show()


#分類算法:
#待分類數(shù)據(jù)iData,先計(jì)算其到已標(biāo)記數(shù)據(jù)集中每個(gè)數(shù)據(jù)的距離
#然后根據(jù)離iData最近的k個(gè)數(shù)據(jù)的分類,出現(xiàn)次數(shù)最多的類別定為iData的分類。

def KNNClassify(labelData,predData,k): #數(shù)據(jù)集包含分類屬性
#labelData 是已經(jīng)標(biāo)記分類的數(shù)據(jù)集
#predData 待預(yù)測(cè)數(shù)據(jù)集
 labShape = labelData.shape
 for i in range(predData.shape[0]): #以predData的每行數(shù)據(jù)進(jìn)行遍歷
 iData = predData[i]
 iDset = np.tile(iData,(labShape[0],1)) #將iData重復(fù),擴(kuò)展成與labelData同形的矩陣
 #這里用歐拉距離sqrt((x1-x2)^2+(y1-y2)^2)
 diff = iDset[...,:-1] - labelData[...,:-1]
 diff = diff**2
 distance = np.sum(diff,axis=1)
 distance = distance ** 0.5 #開(kāi)根號(hào)
 sortedIND = np.argsort(distance) #排序,以序號(hào)返回。
 classCount = { }
 for j in range(k): #計(jì)算距離最近的前k個(gè)標(biāo)記數(shù)據(jù)的類別
 voteLabel = labelData[sortedIND[j],-1]
 classCount[voteLabel] = classCount.get(voteLabel,0)+1

 maxcls = max(classCount,key=classCount.get) #類別最多的,返回鍵名(類別名)
 predData[i][...,-1] = maxcls

 return predData

#測(cè)試
labNums = np.random.randint(50,200,classnum)
predNums = np.random.randint(10,80,classnum)
#cores = [np.array([[ 0.08321641, 12.22596938, 0. ]]), np.array([[9.99891798, 4.24009775, 1. ]]), np.array([[14.98097374, 9.80120399, 2. ]])]

labelData = makeKNNData(3,classnum,labNums)
showFigure(labelData,classnum)
predData = makeKNNData(3,classnum,predNums) #這里為了方便,不在寫(xiě)產(chǎn)生待分類數(shù)據(jù)的代碼,只需用之前的函數(shù)并忽略其類別就好。
predData[...,-1]=0
showFigure(predData,classnum)

k = 10
KNNData = KNNClassify(labelData,predData,k)
showFigure(KNNData,classnum)

運(yùn)行程序,結(jié)果如下:

1.labelData的數(shù)據(jù)(已知分類的數(shù)據(jù)) 

 

2.predData的數(shù)據(jù)(未標(biāo)記的數(shù)據(jù)) 

 

3KNNData的數(shù)據(jù)(用KNN算法進(jìn)行分類后的數(shù)據(jù))

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python實(shí)現(xiàn)的生成word文檔功能示例

    python實(shí)現(xiàn)的生成word文檔功能示例

    這篇文章主要介紹了python實(shí)現(xiàn)的生成word文檔功能,涉及Python數(shù)據(jù)查詢、遍歷及word文檔生成相關(guān)操作技巧,需要的朋友可以參考下
    2019-08-08
  • BP神經(jīng)網(wǎng)絡(luò)原理及Python實(shí)現(xiàn)代碼

    BP神經(jīng)網(wǎng)絡(luò)原理及Python實(shí)現(xiàn)代碼

    這篇文章主要為大家詳細(xì)介紹了BP神經(jīng)網(wǎng)絡(luò)原理,以及Python實(shí)現(xiàn)BP神經(jīng)網(wǎng)絡(luò),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • PyTorch搭建CNN實(shí)現(xiàn)風(fēng)速預(yù)測(cè)

    PyTorch搭建CNN實(shí)現(xiàn)風(fēng)速預(yù)測(cè)

    PyTorch是一個(gè)開(kāi)源的Python機(jī)器學(xué)習(xí)庫(kù),基于Torch,用于自然語(yǔ)言處理等應(yīng)用程序。它不僅能夠?qū)崿F(xiàn)強(qiáng)大的GPU加速,同時(shí)還支持動(dòng)態(tài)神經(jīng)網(wǎng)絡(luò)。本文將介紹PyTorch搭建CNN如何實(shí)現(xiàn)風(fēng)速預(yù)測(cè),感興趣的可以學(xué)習(xí)一下
    2021-12-12
  • Python提取PDF發(fā)票信息保存Excel文件并制作EXE程序的全過(guò)程

    Python提取PDF發(fā)票信息保存Excel文件并制作EXE程序的全過(guò)程

    之前零散的用過(guò)一點(diǎn)python做數(shù)據(jù)處理,這次又遇到一個(gè)數(shù)據(jù)處理的小功能,下面這篇文章主要給大家介紹了關(guān)于Python提取PDF發(fā)票信息保存Excel文件并制作EXE程序的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • pycharm終端解釋器與Python解釋器配置

    pycharm終端解釋器與Python解釋器配置

    這篇文章主要介紹了pycharm終端解釋器與Python解釋器配置,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-06-06
  • Python?分支結(jié)構(gòu)詳解

    Python?分支結(jié)構(gòu)詳解

    這篇文章主要介紹了Python?分支結(jié)構(gòu),分支結(jié)構(gòu)包括單分支結(jié)構(gòu)、雙分支結(jié)構(gòu)、多分支結(jié)構(gòu)等內(nèi)容,下文ui分支結(jié)構(gòu)進(jìn)行詳細(xì)分析,需要的小伙伴可以參考一下
    2022-02-02
  • 最新評(píng)論