K-近邻算法((k-Nearest Neighbor,KNN)概述

概述

           本文讲述K-NN算法的概念、工作原理以及例子。


一、概念

           k-近邻算法,采用测量不同特征值之间的距离方法进行分类。

           优点:精度高,对异常值不敏感,元数据输入假定。

           缺点:计算发杂度高,空间复杂度高。


二、工作原理

            存在一个样本数据集合,也称作训练样本集。并且样本集中每一数据都存在标签,即我们知道样本集中每一数据与所属分类的对应关系。输入没有标签的新数据后,将新数据的每个特征与样本集中数据对应特征进行比较,然后提取样本集中特征最相似的数据(最近邻)的分类标签。一般我们只选择样本集中最相近的前K个数据。最后,选择k个最相似的数据中出现按次数最多的分类,作为新数据的分类。


三、例子

             电影分类


使用打斗和接吻镜头分类电影


电影分类表


已知电影与未知电影的距离

       假定k=3,则按照k-NN算法,判定电影是爱情片。


四、代码实现

  1.创建kNN.py文件

from numpy import *

import operator

defclassify0(inX, dataSet, labels, k):

    dataSetSize = dataSet.shape[0]

    diffMat = tile(inX, (dataSetSize,1)) - dataSet

    sqDiffMat = diffMat**2

    sqDistances = sqDiffMat.sum(axis=1)

    distances = sqDistances**0.5

    sortedDistIndicies = distances.argsort()

    classCount={}

    for i in range(k):

        voteIlabel = labels[sortedDistIndicies[i]]

        classCount[voteIlabel] = classCount.get(voteIlabel,0) +1

sortedClassCount = sorted(classCount.items(), key=operator.itemgetter(1), reverse=True)

return sortedClassCount[0][0]

def createDataSet():

    group = array([[1.0,1.1],[1.0,1.0],[0,0],[0,0.1]])

    labels = ['A','A','B','B']

    return group, labels

  2.代码注释

      1.numpy

      NumPy系统是Python的一种开源的数值计算扩展。这种工具可用来存储和处理大型矩阵,比Python自身的嵌套列表(nested list structure)结构要高效的多(该结构也可以用来表示矩阵(matrix))。据说NumPy将Python相当于变成一种免费的更强大的MatLab系统。

       2.operator库

       本模块主要包括一些Python内部操作符对应的函数。比如operator.add(x,y)对应表达式:x+y。在这些函数里,一般是带前缀和后缀的下划线,在这里不带这些下划线的函数,也是合法的。这些函数主要分为几类:对象比较、逻辑比较、算术运算和序列操作。

       3.numpy函数:shape用法

        shape函数是numpy.core.fromnumeric中的函数,它的功能是读取矩阵的长度

        它可以作为单独的函数来使用,此时它的输入参数可以使一个整数表示维度,也可以是一个矩阵。

        也可以作为矩阵的属性来使用,如arrayName.shape[0]表示矩阵的第一维长度(行数),arrayName.shaoe[1]表示矩阵的第二维长度(列数)。

        3.numpy函数:tile()

        格式:tile(A,reps)

        * A: 输入的array

        * reps: A沿各个维度重复的次数

          举例:A=[1,2]

           1. tile(A,2)

           结果:[1,2,1,2]

           2. tile(A,(2,3))

           结果:[[1,2,1,2,1,2], [1,2,1,2,1,2]]

           3. tile(A,(2,2,3))

           结果:[[[1,2,1,2,1,2], [1,2,1,2,1,2]],

           [[1,2,1,2,1,2], [1,2,1,2,1,2]]]

          4.diffMat**2

            矩阵中所有元素平方

          5.numpy函数:sum()

            两种用法,分别是作为单独的函数和作为矩阵的方法。

            作为方法时:arrayName.sum(axis=0)或arrayName.sum(axis=1)

             axis=0表示将矩阵的列元素全部相加,组成新的矩阵;axis=1表示将矩阵的行元素全部相加,组成新的矩阵

            例如:>>>group = array([[1,2,3],[1,2,3]])

                       >>> group.sum(axis=0)

                       array([2, 4, 6])

                        >>> group.sum(axis=1)

                       array([6, 6])

          6.numpy函数:argsort()

            argsort函数返回的是数组值从小到大的索引值

             Examples

              >>> import numpy

              --------

             One dimensional array:一维数组

              >>> x = np.array([3, 1, 2])

              >>> np.argsort(x)

              array([1, 2, 0])

              Two-dimensional array:二维数组

               >>> x = np.array([[0, 3], [2, 2]])

               >>> x

               array([[0, 3],

               [2, 2]])

               >>> np.argsort(x, axis=0) #按列排序

              array([[0, 1],

               [1, 0]])

               >>> np.argsort(x, axis=1) #按行排序

               array([[0, 1],

               [0, 1]])

             7.classCount.get(voteIlabel,0)

              不存在相对应key值的value则返回0

             8.python函数:sorted()

              我们需要对List进行排序,Python提供了两个方法:对给定的List L进行排序,方法1.用List的成员函数sort进行排序,方法2.用built-in函数sorted进行排序

               >>> help(sorted)

               Help on built-in function sorted in module __builtin__:

               sorted(...)

               sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list


               iterable:是可迭代类型;

               cmp:用于比较的函数,比较什么由key决定,有默认值,迭代集合中的一项;

                key:用列表元素的某个属性和函数进行作为关键字,有默认值,迭代集合中的一项;

                reverse:排序规则. reverse = True 或者 reverse = False,有默认值。

                返回值:是一个经过排序的可迭代类型,与iterable一样。

    3.运行结果

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容