麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Python > 正文

kNN算法python實(shí)現(xiàn)和簡單數(shù)字識(shí)別的方法

2020-02-23 06:10:46
字體:
供稿:網(wǎng)友

本文實(shí)例講述了kNN算法python實(shí)現(xiàn)和簡單數(shù)字識(shí)別的方法。分享給大家供大家參考。具體如下:

kNN算法算法優(yōu)缺點(diǎn):

優(yōu)點(diǎn):精度高、對(duì)異常值不敏感、無輸入數(shù)據(jù)假定
缺點(diǎn):時(shí)間復(fù)雜度和空間復(fù)雜度都很高
適用數(shù)據(jù)范圍:數(shù)值型和標(biāo)稱型

算法的思路:

KNN算法(全稱K最近鄰算法),算法的思想很簡單,簡單的說就是物以類聚,也就是說我們從一堆已知的訓(xùn)練集中找出k個(gè)與目標(biāo)最靠近的,然后看他們中最多的分類是哪個(gè),就以這個(gè)為依據(jù)分類。

函數(shù)解析:

庫函數(shù):

tile()
如tile(A,n)就是將A重復(fù)n次
代碼如下:a = np.array([0, 1, 2])
np.tile(a, 2)
array([0, 1, 2, 0, 1, 2])
np.tile(a, (2, 2))
array([[0, 1, 2, 0, 1, 2],[0, 1, 2, 0, 1, 2]])
np.tile(a, (2, 1, 2))
array([[[0, 1, 2, 0, 1, 2]],[[0, 1, 2, 0, 1, 2]]])
b = np.array([[1, 2], [3, 4]])
np.tile(b, 2)
array([[1, 2, 1, 2],[3, 4, 3, 4]])
np.tile(b, (2, 1))
array([[1, 2],[3, 4],[1, 2],[3, 4]])`
自己實(shí)現(xiàn)的函數(shù)

createDataSet()生成測試數(shù)組
kNNclassify(inputX, dataSet, labels, k)分類函數(shù)

inputX 輸入的參數(shù)
dataSet 訓(xùn)練集
labels 訓(xùn)練集的標(biāo)號(hào)
k 最近鄰的數(shù)目

代碼如下:
#coding=utf-8
from numpy import *
import operator

def createDataSet():
    group = array([[1.0, 0.9], [1.0, 1.0], [0.1, 0.2], [0.0, 0.1]])
    labels = ['A','A','B','B']
    return group,labels
#inputX表示輸入向量(也就是我們要判斷它屬于哪一類的)
#dataSet表示訓(xùn)練樣本
#label表示訓(xùn)練樣本的標(biāo)簽
#k是最近鄰的參數(shù),選最近k個(gè)
def kNNclassify(inputX, dataSet, labels, k):
    dataSetSize = dataSet.shape[0]#計(jì)算有幾個(gè)訓(xùn)練數(shù)據(jù)
    #開始計(jì)算歐幾里得距離
    diffMat = tile(inputX, (dataSetSize,1)) - dataSet
   
    sqDiffMat = diffMat ** 2
    sqDistances = sqDiffMat.sum(axis=1)#矩陣每一行向量相加
    distances = sqDistances ** 0.5
    #歐幾里得距離計(jì)算完畢
    sortedDistance = distances.argsort()
    classCount = {}
    for i in xrange(k):
        voteLabel = labels[sortedDistance[i]]
        classCount[voteLabel] = classCount.get(voteLabel,0) + 1
    res = max(classCount)
    return res

def main():
    group,labels = createDataSet()
    t = kNNclassify([0,0],group,labels,3)
    print t
   
if __name__=='__main__':

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 免费国产在线视频 | 国产一有一级毛片视频 | 日日草夜夜操 | 成人三级视频网站 | 亚洲午夜不卡 | 成人男男视频拍拍拍在线观看 | 在线a亚洲视频播放在线观看 | 把娇妻调教成暴露狂 | 日韩中字幕| 国产做爰| 欧美精品免费一区二区三区 | 日本人乱人乱亲乱色视频观看 | 国产成人精品一区二区视频免费 | 日韩在线激情 | 亚洲无av | 久久久久久久久久网站 | 亚洲黑人在线观看 | h视频免费观看 | 黄色7777 | av电影在线网站 | 国产亚洲精久久久久久蜜臀 | 欧美另类在线视频 | 精品久久久一二三区播放播放播放视频 | 99精品视频久久精品视频 | 伊人在线视频 | 99精品视频在线 | 久色免费 | 久久久久久久国产视频 | 亚洲精久久 | 1314成人网 | 操操电影| 一级尻逼视频 | 成人免费观看在线视频 | 免费午夜网站 | 特级黄色一级毛片 | 午夜国产在线 | 黄视频网址 | 精品亚洲午夜久久久久91 | 成人免费在线观看视频 | 超碰一区| 欧美日韩色 |