青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 51, 文章 - 1, 評論 - 41, 引用 - 0
數(shù)據(jù)加載中……

K近鄰算法

概述

k近鄰(k nearest neighbor)算法是一種監(jiān)督算法,用于分類。它基本思想是計(jì)算新實(shí)例和訓(xùn)練集元素的**距離**,找出k個(gè)最接近的實(shí)例(neighbor),統(tǒng)計(jì)它們所屬分類,次數(shù)最多的類別作為新實(shí)例的類別。

原理與步驟

監(jiān)督算法可大致分成兩個(gè)步驟:訓(xùn)練(train)和分類(classify)。從實(shí)現(xiàn)考慮還需要算法初始化過程。

本節(jié)的代碼為python風(fēng)格的示意代碼,不能直接運(yùn)行,可運(yùn)行代碼參考zxml。

示意代碼

?

class KNearestNeighbor:

    def __init__(...):  pass

    def train(...):     pass

    def classify(...):  pass

訓(xùn)練(train)

理論上k近鄰算法不需要訓(xùn)練,可直接使用原始數(shù)據(jù)進(jìn)行分類。

歸一化

數(shù)據(jù)的分類的量綱差別較大時(shí),小量綱分類在計(jì)算的權(quán)重將被削弱。使用歸一化消除這種影響。方法如下:

x??=?(x???xmin)/(xmax???xmin)

預(yù)處理

將數(shù)據(jù)進(jìn)行某種形式的處理可加快尋找k近鄰的速度,常用的處理方式有KD-Tree和Ball-Tree,前者對低維歐氏距離有效,后者對所有距離有效。

示意代碼

?

def train(self, X, C):

    '''X,C分別代表實(shí)例和類別'''

?

    # 實(shí)例數(shù)據(jù)歸一化,并保留數(shù)據(jù)備份

    (self.X, self.C) = (normalize(X), C.copy())

?

    # 可選,如果需要,則構(gòu)建KD-Tree()

    self.tree = KDTree()

    self.tree.create(self.X)

分類(classify)

分類的大致步驟:找出k個(gè)近鄰 和*統(tǒng)計(jì)類別的次數(shù)* 。 分類的部分處理與訓(xùn)練的處理向?qū)?yīng),如:

  • 訓(xùn)練對數(shù)據(jù)進(jìn)行歸一化,則分類是也需要?dú)w一化。
  • 訓(xùn)練使用如KD-Tree等方式進(jìn)行處理,則分類使用對應(yīng)的方法尋找k個(gè)近鄰。

示意代碼

?

def classify(self, x):

?

    _x = normalize(x)                   # 將x歸一化

    nearest = self.find_neighbors(_x)   # 找出k個(gè)近鄰

    freq = frequency(nearests)          # 統(tǒng)計(jì)每個(gè)類型的次數(shù)

    return freq.sorted()[-1]            # 排序后,返回次數(shù)最多的類別

?

def find_neighbors(self, x):

    '''尋找與x最接近的k個(gè)點(diǎn)'''

?

    if self.tree == None:               # 判斷是否使用了kd-tree

        ds = self.distance(x, self.X)   # 計(jì)算所有點(diǎn)的距離

        indices = ds.argsort()[0:k]     # 排序后,取前面k個(gè)

?

    else:

        indices = self.tree.find_neighbors(x, self.k)

?

    # indices是k個(gè)近鄰的索引位置

    return self.C[indices]

初始化(init)

初始化需要設(shè)置算法參數(shù),如k的值,距離公式。

距離

實(shí)例之間的距離一般采用歐氏距離,但不排除使用其它的距離計(jì)算方法。歐氏距離:

d?=?x???y?=?((xi???yi)2)?≥?xi???yi

?

def __init__(self, k, distance=euclidean ):

    (self.k, self.distance) = (k, distance)

scikit-learn

下面使用scikit-learn中的k近鄰算法分類的例子。

?

import numpy as np

from sklearn import neighbors

?

# 準(zhǔn)備數(shù)據(jù),分成A B兩類。A類在[0,0]附近,B類在[1,1]附近。

X = np.array([[0, 0.1],   [-0.1, 0],

              [0.1, 0.1], [0, 0],

              [1, 1],     [1.1, 1],

              [1, 1.1],   [1.1, 1.1]])

?

C = ['A','A','A','A','B','B','B','B']

?

# 初始化

clf = neighbors.KNeighborsClassifier(n_neighbors=3, weights="uniform")

?

# 訓(xùn)練

clf.fit(X, C)

?

# 分類

c = clf.predict(np.array([[0.9,0.8]]))

print(c)

上面的例子可以將k近鄰算法分成三步,初始化、訓(xùn)練和分類。初始化可設(shè)置參數(shù),本文涉及到的參數(shù)有:

  • n_neighbors: 指參數(shù)k
  • weights: 指定數(shù)據(jù)分類的權(quán)重,歸一化 是其中的一個(gè)方式。
  • algorithm: 該參數(shù)可設(shè)定使用kd-tree等方法。
  • metric: 距離計(jì)算公式

參考資料

posted on 2016-10-28 16:18 lemene 閱讀(462) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区二区三区免费视频| 蜜臀久久99精品久久久画质超高清 | 女人天堂亚洲aⅴ在线观看| 亚洲免费电影在线| 久久视频国产精品免费视频在线| 国产精品伦一区| 亚洲视频在线免费观看| 亚洲电影中文字幕| 夜夜嗨av一区二区三区中文字幕| 欧美 日韩 国产在线| 一区二区三区在线免费播放| 久久精品成人欧美大片古装| 亚洲砖区区免费| 国产精品视频观看| 欧美一级精品大片| 性伦欧美刺激片在线观看| 国产精品一二三| 国产人妖伪娘一区91| 香蕉久久夜色| 亚洲欧美激情视频| 国产偷国产偷精品高清尤物| 久久精品123| 久久久精品一区| 狠狠色狠色综合曰曰| 欧美大片专区| 欧美高清视频一二三区| 中文精品99久久国产香蕉| 亚洲精品国产精品乱码不99按摩 | 国产精品久久久久久av福利软件| 亚洲精品在线观看视频| 亚洲精品日韩在线| 国产精品久久久久久久久久久久久久| 亚洲制服av| 欧美一区二区黄| 在线观看成人小视频| 亚洲国产黄色片| 欧美日韩一区二区三区在线 | 欧美一区免费视频| 亚洲高清在线播放| 亚洲精品在线免费| 国产日韩欧美在线播放| 欧美大片网址| 国产精品盗摄久久久| 久久九九热免费视频| 免费成人美女女| 亚洲影视在线播放| 久久久www成人免费无遮挡大片 | 亚洲黄色毛片| 国产精品日韩专区| 欧美搞黄网站| 国产精品区二区三区日本| 久热精品在线| 国产精品v欧美精品v日本精品动漫 | 一区二区三区高清在线| 国产欧美一区二区精品忘忧草 | 久久综合九色综合网站| 一区二区三区欧美| 久久av一区| 一区二区三区日韩在线观看| 午夜欧美理论片| 日韩视频中文字幕| 久久国产乱子精品免费女 | 亚洲欧美日韩中文播放| 久久资源在线| 欧美在线免费一级片| 欧美日韩国产区| 猛男gaygay欧美视频| 国产精品入口福利| 日韩视频三区| 亚洲日本理论电影| 久久大逼视频| 欧美在线一二三| 欧美色网一区二区| 亚洲激情视频| ●精品国产综合乱码久久久久| 亚洲免费在线精品一区| 夜夜爽av福利精品导航| 麻豆国产va免费精品高清在线| 欧美在线一级va免费观看| 欧美日韩少妇| 在线成人h网| 久久精品视频播放| 国产精品不卡在线| 亚洲激情啪啪| 亚洲人成毛片在线播放女女| 欧美在线视频网站| 欧美中文在线字幕| 国产伦精品一区二区三区| 艳妇臀荡乳欲伦亚洲一区| 亚洲人成在线影院| 免费看亚洲片| 欧美国内亚洲| 亚洲激情在线播放| 夜夜嗨av色一区二区不卡| 一本大道av伊人久久综合| 欧美freesex交免费视频| 美日韩免费视频| 亚洲国产成人高清精品| 久久夜色精品国产欧美乱极品| 久久一区视频| 亚洲第一在线综合网站| 久色成人在线| 亚洲欧洲精品一区二区三区波多野1战4| 在线国产欧美| 欧美激情一级片一区二区| 亚洲另类在线一区| 亚洲影音一区| 国产一区av在线| 久久激情综合| 欧美激情在线| 中文一区字幕| 国产区二精品视| 久久久另类综合| 欧美激情一区二区三区高清视频 | 一区二区三区波多野结衣在线观看| 嫩草成人www欧美| 亚洲三级色网| 性欧美在线看片a免费观看| 国产午夜精品一区理论片飘花 | 欧美在线在线| 欧美大胆成人| 亚洲欧美成aⅴ人在线观看| 国产热re99久久6国产精品| 久色婷婷小香蕉久久| 在线综合+亚洲+欧美中文字幕| 欧美专区中文字幕| 亚洲电影免费观看高清完整版在线| 欧美fxxxxxx另类| 亚洲午夜免费福利视频| 久久综合九色九九| 制服丝袜亚洲播放| 国产一区欧美| 欧美日本在线| 久久精品99国产精品| 亚洲三级性片| 久久免费少妇高潮久久精品99| 亚洲美女视频网| 亚洲国产精品成人精品| 久久综合久色欧美综合狠狠| 日韩亚洲欧美成人| 久久久亚洲影院你懂的| 一区二区三区欧美在线| 狠狠色丁香久久婷婷综合丁香| 欧美日韩二区三区| 欧美一区二区三区的| 麻豆国产精品777777在线| 亚洲精品一区二区在线观看| 久久免费视频一区| 亚洲午夜精品国产| 91久久精品视频| 国产欧美一区二区三区久久人妖| 欧美成人免费全部观看天天性色| 亚洲欧美中文在线视频| 亚洲精品一区二区三区蜜桃久| 久久视频一区二区| 午夜精品偷拍| 在线视频日本亚洲性| 亚洲二区三区四区| 国产亚洲精品bt天堂精选| 国产精品成人一区二区网站软件| 免费日韩一区二区| 久久精品综合网| 亚洲男人第一av网站| 日韩视频一区二区三区在线播放免费观看 | 亚洲欧美激情诱惑| 亚洲免费电影在线| 91久久久久久久久| 另类综合日韩欧美亚洲| 久久精品人人做人人综合| 午夜亚洲影视| 午夜精品久久久久久久男人的天堂 | 国产精品成人观看视频国产奇米| 欧美国产成人精品| 老司机午夜精品视频在线观看| 久久精品91久久久久久再现| 欧美一区二区| 欧美在线视频网站| 久久福利资源站| 亚洲午夜电影网| 一区二区三区精品视频| 国产精品自拍视频| 欧美国产视频日韩| 亚洲电影在线| 91久久中文| 一个色综合av| 亚洲欧美激情精品一区二区| 亚洲一区二区免费看| 亚洲一区三区在线观看| 亚洲一区二区在线免费观看| 亚洲欧美另类国产| 久久精品国产亚洲一区二区| 久久久久免费| 欧美精品一区三区在线观看| 欧美精品乱人伦久久久久久| 欧美日韩一区二区三区在线 | 亚洲黄色大片| 一区二区三区蜜桃网| 亚洲欧美春色| 久久久最新网址| 欧美精品在线免费播放|