




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
KNNKNNKNNKNNKNNKNN分類算法PythonKNNKNNKNNKNNk1、理解KNN算法的思2KNNkNN本質(zhì)上,KNN3k找鄰居:圈定距離最近的k做分類:根據(jù)這k新樣本時(shí),該樣本的K個(gè)鄰居中大容量類的樣本占多數(shù)。KKNNPythonkNNAABB??Python首先,我們新建一個(gè)kNN.py文件,文件里面包含兩個(gè)函數(shù),一個(gè)用來生成小數(shù)據(jù)集,kNN分類算法。代碼如下:#kNN:kNearest#輸入 向#輸出fromnumpyimportimport#24def#group=array([[1.0,0.9],[1.0,1.0],[0.1,0.2],[0.0,4labels=['A','A','B',returngroup,KNNdefkNNClassify(newInput,dataSet,labels,numSamples #step1:tile(Areps):Areps#thefollowingcopynumSamplesrowsfordifftile(newInputnumSamples,1) #squaredDiffdiff** squaredDistsum(squaredDiffaxis #distancesquaredDist** step2:argsort()sortedDistIndices=classCount={}#defineadictionary(canbeappendelement)foriinxrange(k):step3:k abel=step4:k#whenthekeyvo abelisnotindictionaryclassCount,get()#willreturn0 abel]= abel,0)+##step5:返回出現(xiàn)次數(shù)最多的類 maxCount=forkey,valueinclassCount.items():ifvalue>maxCount:maxCount=valuemaxIndex=keyreturn 試importimportfromnumpyimport*dataSetlabelskNN.createDataSet()testX=array([1.2,1.0])k=3outputLabel=kNN.kNNClassify(testX,dataSet,labels,print"Yourinputis:",testX,"andclassifiedtoclass:",testX=array([0.1,outputLabel=kNN.kNNClassify(testX,dataSet,labels,print"Yourinputis:",testX,"andclassifiedtoclass:",YourYourinputis:[ 1.0]andclassifiedto Yourinputis:[ 0.3]andclassifiedto kNNknn算法來實(shí)現(xiàn)對手寫數(shù)字的自動(dòng)識別;0-9200每個(gè)樣本保持在一個(gè)txt32x32txt個(gè)數(shù)字,01 testDigits900KNN算法來實(shí)現(xiàn)。沒錯(cuò),pythonkNN##kNN:kNearest#參數(shù)inX:vectortocomparetoexistingdatasetdataSet:sizemdatasetofknownvectors(NxM)labels:datasetlabels(1xMvector)k:numberofneighborstousefor#輸出fromnumpyimportimportos#KNN分 方defkNNClassify(newInput,dataSet,labels,numSamples #step1:tile(Areps):Areps#thefollowingcopynumSamplesrowsfordiff=tile(newInput,(numSamples,1))-dataSet #Subtractelement-wisesquaredDiff=diff**2#squaredforthesubtractsquaredDist=sum(squaredDiff,axis=1) #sumisperformedbyrowdistance=squaredDist**0.5step2:#sortedDistIndices=classCount #foriinstep3:k abel=step4:#whenthekeyvo abelisnotindictionaryclassCount,get()#willreturn0 abel]= abel,0)+step5:返回出現(xiàn)次數(shù)最多的類別作為分類結(jié)果maxCount=0forkey,valueinclassCount.items():ifvalue>maxCount:maxCount=valuemaxIndex=keyreturn# 轉(zhuǎn)換為向 rows=32cols=imgVector=zeros((1,rows*cols))fileIn=open(filename)forrowinlineStr=fileIn.readline()forcolinxrange(cols):imgVector[0,row*32+col]=int(lineStr[col])returnimgVector#def##step1: printGettingtrainingset..."dataSetDir==+' #numSamples=train_x=zeros((numSamples,1024))train_y=[]foriinfilename=#gettrain_x[i,:]=img2vector(dataSetDir+'trainingDigits/%s'%#getlabelfromfilenamesuchas"1_18.txt"label=int(filename.split('_')[0])#return1##step2: printGettingtestingset..."testingFileList=os.listdir(dataSetDir+'testDigits')#loadthetestingsetnumSamples=len(testingFileList)test_x=zeros((numSamples,1024))test_y=[]foriinfilename=#gettest_x[i,:]=img2vector(dataSetDir+'testDigits/%s'%#getlabelfromfilenamesuchas"1_18.txt"label=int(filename.split('_')[0])#return1###step1:加載數(shù)據(jù)print"step1:loadtrain_x,train_y,test_x,test_y=##step2:模型訓(xùn)練.printstep2training..."step3:print"step3:numTestSamples=test_x.shape[0]matchCount=0foriinpredict=kNNClassify(test_x[i],train_x,train_y,3)ifpredict==test_y[i]:matchCountmatchCount+=accuracy=float(matchCount)/step4:print"step4:showtheprint'Theclassifyaccuracyis:%.2f%%'%(accuracy*importimportstepstep1:loa
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五商鋪物業(yè)委托管理合同(含社區(qū)健康管理與醫(yī)療支持)
- 二零二五年校園環(huán)境衛(wèi)生管理與綠化合同
- 二零二五年度農(nóng)村土地承包經(jīng)營權(quán)與農(nóng)村社會保障合作合同
- 二零二五年度夜店酒吧員工安全協(xié)議與安全教育培訓(xùn)費(fèi)用合同
- 2025年度電動(dòng)車買賣協(xié)議模版
- 二零二五年度知識產(chǎn)權(quán)法律風(fēng)險(xiǎn)管理顧問合同
- 二零二五年度武漢房屋租賃合同物業(yè)管理約定
- 二零二五年度摩托車第三者責(zé)任保險(xiǎn)合同
- 《物流系統(tǒng)分析》課件 項(xiàng)目九-任務(wù)三 (一)車輛路徑優(yōu)化模型1
- 2025年包頭a2貨運(yùn)資格證模擬考試
- 液壓支架與泵站(第二版)課件匯總?cè)珪娮咏贪竿暾嬲n件最全幻燈片(最新)
- DB61∕T 1186-2018 花椒主要病蟲害防治技術(shù)規(guī)范
- DB32T 4013-2021 第三方社會穩(wěn)定風(fēng)險(xiǎn)評估技術(shù)規(guī)范
- QC成果提高大跨度多節(jié)點(diǎn)曲面鋼桁架一次安裝合格率
- 國家電網(wǎng)有限公司十八項(xiàng)電網(wǎng)重大反事故措施(修訂版)
- 環(huán)氧乙烷固定床反應(yīng)器課程設(shè)計(jì)
- 班、團(tuán)、隊(duì)一體化建設(shè)實(shí)施方案
- 如何建構(gòu)結(jié)構(gòu)性思維 課后測試
- 施工方案(行車拆除)
- 開網(wǎng)店全部流程PPT課件
- 《春》帶拼音
評論
0/150
提交評論