一、 K邻近算法思想:存在一个样本数据集合,称为训练样本集,并且每个数据都存在标签,即我们知道样本集中每一数据(这里的数据是一组数据,可以是n维向量)与所属分类的对应关系。输入没有标签的新数据后,将新数据的每个特征(向量的每个元素)与样本集中数据对应的特征进行比较,然后算法提取样本集中特征最相似的的分类标签。由于样本集可以很大,我们选取前k个最相似数据,然后统计k个数据中出现频率最高的标签为新数据的标签。

  K邻近算法的一般流程:

  (1)收集数据:可以是本地数据,也可以从网页抓取。

  (2)准备数据:将数据结构化,方便操作。

  (3)分析数据:可以使用任何方法。

  (4)训练算法:此步骤不适用于k邻近算法。

  (5)测试算法:计算错误率;计算公式:错误率=测试出错次数/总测试次数

  (6)使用算法:输入样本数据,输出结构化的结果,判断新数据属于哪个分类。

  二、使用K近邻算法的一个例子

  我使用的是spyder的开发环境,python的版本是3.5,spyder自带了numpy函数库。新建一个KNN.py文件,在本文件中完成本章实验。

  在KNN中写一个数据生成函数:

  1.  
  1. from numpy import *
  2. import operator
  3.  
  4. def createDataset():
  5. group = array([[1.0,1.1],[1.0,1.0],[0.0,0.0],[0.0,0.1]])
  6. labels = ['A','A','B','B']
  7. return group,labels
  1.  

  在spyder中输入 :

  >>> import KNN

  >>>group,labels = KNN.createDataSet()

  >>>group

  array([[ 1. , 1.1],
     [ 1. , 1. ],
     [ 0. , 0. ],
     [ 0. , 0.1]])

  >>>labels

  ['A', 'A', 'B', 'B']

  出现以上提示则说明函数正确。

  三、K近邻算法函数

  

  1. def classify(inX,dataset,labels,k):
  2. dataSetSize = dataset.shape[0]
  3. diffMat = tile(inX,(dataSetSize,1))-dataset
  4. sqDiffMat = diffMat**2
  5. sqDistances = sqDiffMat.sum(axis=1)
  6. distances = sqDistances**0.5
  7. sortedDistIndicies = distances.argsort()
  8. classCount ={}
  9. for i in range(k):
  10. voteIlabel = labels[sortedDistIndicies[i]]
  11. classCount[voteIlabel] = classCount.get(voteIlabel,0)+1
  12. sortedClassCount = sorted(classCount.items(),
  13. key=operator.itemgetter(1),reverse=True)
  14. return sortedClassCount[0][0]

  验证:在spyder中输入

  >>> KNN.classify([0,0],group,labels,3)

  输出结果应该为'B'。

  四、例子:约会网站匹配改进

  海伦收集约会数据已经有一段时间,她把这些数据放在文本文件datingdata.txt中,每个样本数据占据一行,共有1000行(她可能约会过1000个人,太可怕了^_^),每个样本主要包括以下3中特征:

  1、每年获得的飞行常客里程数

  2、玩视频游戏所耗的时间百分数

  3、每周消费的冰激凌公升数

  上述数据保存在文本文件中,数据之间以空格间隔,在数据输入分类器之前,必须将待处理数据改变为分类器可以处理的数据,在KNN中创建名为file2matrix的函数,进行数据处理。

  1. def file2matrix(filename):
  2. fr = open(filename,'r')
  3. arrayOLines = fr.readlines()
  4. numberOfLines = len(arrayOLines)
  5. returnMat = zeros((numberOfLines,3))
  6. classLabelVector = []
  7. index = 0
  8. for line in arrayOLines:
  9. line = line.strip()
  10. listFromLine = line.split('\t')
  11. returnMat[index,:] = listFromLine[0:3]
  12. classLabelVector.append(int(listFromLine[-1]))
  13. index += 1
  14. return returnMat,classLabelVector
  15. retarnmat,classlabelvector = file2matrix('datingdata.txt')

  在我运行这段程序,总是出现错误提示:could not convert string to float: '12 34 56',对于这个问题,我的改法是将文本中数据间的空格改为','并将

  1. listFromLine = line.split('\t')改为
  1. listFromLine = line.split(',')
    这样就可以解决问题,但是不是最好的方法,还需要改进。

《机器学习实战》学习笔记一K邻近算法的更多相关文章

  1. 机器学习实战 - 读书笔记(12) - 使用FP-growth算法来高效发现频繁项集

    前言 最近在看Peter Harrington写的"机器学习实战",这是我的学习心得,这次是第12章 - 使用FP-growth算法来高效发现频繁项集. 基本概念 FP-growt ...

  2. 机器学习实战 - 读书笔记(11) - 使用Apriori算法进行关联分析

    前言 最近在看Peter Harrington写的"机器学习实战",这是我的学习心得,这次是第11章 - 使用Apriori算法进行关联分析. 基本概念 关联分析(associat ...

  3. 【机器学习实战学习笔记(1-1)】k-近邻算法原理及python实现

    笔者本人是个初入机器学习的小白,主要是想把学习过程中的大概知识和自己的一些经验写下来跟大家分享,也可以加强自己的记忆,有不足的地方还望小伙伴们批评指正,点赞评论走起来~ 文章目录 1.k-近邻算法概述 ...

  4. 机器学习实战读书笔记(二)k-近邻算法

    knn算法: 1.优点:精度高.对异常值不敏感.无数据输入假定 2.缺点:计算复杂度高.空间复杂度高. 3.适用数据范围:数值型和标称型. 一般流程: 1.收集数据 2.准备数据 3.分析数据 4.训 ...

  5. 【机器学习实战学习笔记(2-2)】决策树python3.6实现及简单应用

    文章目录 1.ID3及C4.5算法基础 1.1 计算香农熵 1.2 按照给定特征划分数据集 1.3 选择最优特征 1.4 多数表决实现 2.基于ID3.C4.5生成算法创建决策树 3.使用决策树进行分 ...

  6. 【机器学习实战学习笔记(1-2)】k-近邻算法应用实例python代码

    文章目录 1.改进约会网站匹配效果 1.1 准备数据:从文本文件中解析数据 1.2 分析数据:使用Matplotlib创建散点图 1.3 准备数据:归一化特征 1.4 测试算法:作为完整程序验证分类器 ...

  7. 《机器学习实战》---第二章 k近邻算法 kNN

    下面的代码是在python3中运行, # -*- coding: utf-8 -*- """ Created on Tue Jul 3 17:29:27 2018 @au ...

  8. <机器学习实战>读书笔记--k邻近算法KNN

    k邻近算法的伪代码: 对未知类别属性的数据集中的每个点一次执行以下操作: (1)计算已知类别数据集中的点与当前点之间的距离: (2)按照距离递增次序排列 (3)选取与当前点距离最小的k个点 (4)确定 ...

  9. 机器学习实战(Machine Learning in Action)学习笔记————02.k-邻近算法(KNN)

    机器学习实战(Machine Learning in Action)学习笔记————02.k-邻近算法(KNN) 关键字:邻近算法(kNN: k Nearest Neighbors).python.源 ...

随机推荐

  1. PostgreSQL全文检索zhparser使用

    本文引用自: http://blog.chinaunix.net/uid-20726500-id-4820580.html 防止文章丢失才进行复制 PostgreSQL支持全文检索,其内置的缺省的分词 ...

  2. java基础总结——开篇

    工作三年多了,一直没时间静下心来好好总结,2016年马上就要过去了.也算是给自己在新一年的一个任务吧!总结java基础,然后再总结javaweb.纯属个人学习总结,总结过程中如有模糊的地方,望各位看官 ...

  3. 索引中include的魅力(具有包含性列的索引) (转)

    开文之前首先要讲讲几个概念 [覆盖查询] 当索引包含查询引用的所有列时,它通常称为“覆盖查询”. [索引覆盖] 如果返回的数据列就包含于索引的键值中,或者包含于索引的键值+聚集索引的键值中,那么就不会 ...

  4. 【Android测试】UI自动化代码优化之路(临时发布, 随时删除)

    ◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:http://www.cnblogs.com/by-dream/p/5993622.html 关于UI自动化的抱怨 听过不少人这样 ...

  5. Magento table rates表运费设置

    在magento中集成了Table rate表运费,这种运输方式.表运费就是我们自己写个运费表,根据距离和商品重量设置运费,制做成一张csv格式的表,导入到magento中,来实现运费的控制. 在我的 ...

  6. 第三篇:白话tornado源码之请求来了

    上一篇<白话tornado源码之待请求阶段>中介绍了tornado框架在客户端请求之前所做的准备(下图1.2部分),本质上就是创建了一个socket服务端,并进行了IP和端口的绑定,但是未 ...

  7. Python模拟实现Linux系统unix2dos功能

    目标 1.Linux系统与windows系统文件系统换行符问题 2.实现unix文件转换成dos文件格式 1.Linux系统与windows系统文件系统换行符 •关于回车|换行的来历 在计算机还没有出 ...

  8. kdiff3的主窗口说明 Base Local Remote 分别代表什么分支

  9. C# 实现函数回调

    public class Lib { public delegate void UserFunctionCB(); private static UserFunctionCB m_userFnCB; ...

  10. c++防止客户端多开巧妙代码

    在读OBS源码时看到一个比较有意思的关于防止用户多开程序的写法,简单有效,记录下 //make sure only one instance of the application can be ope ...