基于python实现KNN分类算法


Posted in Python onApril 23, 2020

kNN算法的核心思想是如果一个样本在特征空间中的k个最相邻的样本中的大多数属于某一个类别,则该样本也属于这个类别,并具有这个类别上样本的特性。该方法在确定分类决策上只依据最邻近的一个或者几个样本的类别来决定待分样本所属的类别。 kNN方法在类别决策时,只与极少量的相邻样本有关。由于kNN方法主要靠周围有限的邻近的样本,而不是靠判别类域的方法来确定所属类别的,因此对于类域的交叉或重叠较多的待分样本集来说,kNN方法较其他方法更为适合。

通俗简单的说,就是将这个样本进行分类,怎么分类,就是用该样本的特征与空间中其他样本做计算距离,当出现大多数距离偏向于某个样本类时,我们认为该样本属于这个类别。

举例说明:淘宝商品是按类进行售卖的,对于零食类商品a,b,c,价格与销量分别对应(19,1000),(89,500),(9.9,3000)对与电器类商品d,e,f,价格与销量分别为(1000,10),(499,30),(999,100),对于一个未知的产品(300,80),我们使用kNN算法进行求解,我们假设k=3(k的值要时情况而定,没有确定的),分别求出未知产品到这六个点的欧式距离,即:sqrt((x1-y1)**2+(x2-y2)**2)计算出结果进行倒序排序,我们得出前三的点分别为:e,b,f。所以我们认为未知产品是电器类产品,当然实际生活中不能仅仅有价格,销量这两个二维数据,可能是n维数据,欧式距离的公式也是一样的,现实中也不仅仅有这两个分类,kNN提供了一种简单的解决思路。其中a,b,c,d,e,f称为训练数据,未知数据称为测试数据。

还有在进行计算时有时需要格式化一下数据,例如对于c产品与未知产品,明显计算销量所产生的数据要远大于价格,为了减小这个带来的误差,可以使用以下:

def normData(dataSet):
 maxVals = dataSet.max(axis=0)#按列获取最大值,并返回数组
 minVals = dataSet.min(axis=0)
 ranges = maxVals - minVals
 retData = (dataSet - minVals) / ranges
 return retData, ranges, minVals

代码

#!/user/bin/env python
#-*- coding:utf-8 -*-
import numpy as np
import operator as opt

def normData(dataSet):#标准化训练集数据
 maxVals = dataSet.max(axis=0)
 minVals = dataSet.min(axis=0)
 ranges = maxVals - minVals
 retData = (dataSet - minVals) / ranges
 return retData, ranges, minVals

def kNN(dataSet, labels, testData, k):
 distSquareMat = (dataSet - testData) ** 2 # 计算差值的平方
 distSquareSums = distSquareMat.sum(axis=1) # 求每一行的差值平方和,axis=0则按列计算
 distances = distSquareSums ** 0.5 # 开根号,得出每个样本到测试点的距离
 sortedIndices = distances.argsort() # 排序,得到排序后的下标
 indices = sortedIndices[:k] # 取最小的k个
 labelCount = {} # 存储每个label的出现次数,出现次数最多的就是我们要选择的类别
 for i in indices:
 label = labels[i]
 labelCount[label] = labelCount.get(label, 0) + 1 # 次数加一,使用字典的get方法,第一次出现时默认值是0
 sortedCount = sorted(labelCount.items(), key=opt.itemgetter(1), reverse=True) # 对label出现的次数从大到小进行排序
 return sortedCount[0][0] # 返回出现次数最大的label

if __name__ == "__main__":#测试程序
 dataSet = np.array([[2, 3], [6, 8]])#训练集
 normDataSet, ranges, minVals = normData(dataSet)
 labels = ['a', 'b']#训练集分别为a和b类
 testData = np.array([3.9, 5.5])#测试数据
 normTestData = (testData - minVals) / ranges#同样需要将测试数据标准化
 result = kNN(normDataSet, labels, normTestData, 1)#k=1
 print(result)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python登录并获取CSDN博客所有文章列表代码实例
Dec 28 Python
Python将多个excel文件合并为一个文件
Jan 03 Python
python opencv实现图像边缘检测
Apr 29 Python
python使用MQTT给硬件传输图片的实现方法
May 05 Python
实例详解Python装饰器与闭包
Jul 29 Python
python+django+rest框架配置创建方法
Aug 31 Python
基于h5py的使用及数据封装代码
Dec 26 Python
python解释器pycharm安装及环境变量配置教程图文详解
Feb 26 Python
在Python中使用K-Means聚类和PCA主成分分析进行图像压缩
Apr 10 Python
PyInstaller将Python文件打包为exe后如何反编译(破解源码)以及防止反编译
Apr 15 Python
python 基于selectors库实现文件上传与下载
Dec 31 Python
只需要这一行代码就能让python计算速度提高十倍
May 24 Python
python实现定时发送qq消息
Jan 18 #Python
如何在Django中设置定时任务的方法示例
Jan 18 #Python
Python设计模式之工厂方法模式实例详解
Jan 18 #Python
Python设计模式之原型模式实例详解
Jan 18 #Python
基于Python实现迪杰斯特拉和弗洛伊德算法
May 27 #Python
Python中logging实例讲解
Jan 17 #Python
python矩阵/字典实现最短路径算法
Jan 17 #Python
You might like
解决ajax+php中文乱码的方法详解
2013/06/09 PHP
ThinkPHP验证码使用简明教程
2014/03/05 PHP
用javascript实现的激活输入框后隐藏初始内容
2007/06/29 Javascript
checkbox 复选框不能为空
2009/07/11 Javascript
Javascript操作cookie的函数代码
2012/10/03 Javascript
jquery实现个人中心导航菜单效果和美观都非常不错
2014/09/02 Javascript
如何编写高质量JS代码
2014/12/28 Javascript
JS获取时间的方法
2015/01/21 Javascript
XML文件转化成NSData对象的方法
2015/08/12 Javascript
javascript实现起伏的水波背景效果
2016/05/16 Javascript
AngularJS中的指令全面解析(必看)
2016/05/20 Javascript
JavaScript作用域示例详解
2016/07/07 Javascript
利用js查找数组中指定元素并返回该元素的所有索引示例
2017/03/29 Javascript
使用JS编写的随机抽取号码的小程序
2017/08/11 Javascript
python爬取安居客二手房网站数据(实例讲解)
2017/10/19 Javascript
使用Vue自定义数字键盘组件(体验度极好)
2017/12/19 Javascript
每周一练 之 数据结构与算法(Stack)
2019/04/16 Javascript
20个必会的JavaScript面试题(小结)
2019/07/02 Javascript
js判断密码强度的方法
2020/03/18 Javascript
python itchat实现微信自动回复的示例代码
2017/08/14 Python
Python最火、R极具潜力 2017机器学习调查报告
2017/12/11 Python
python+pygame简单画板实现代码实例
2017/12/13 Python
关于python多重赋值的小问题
2019/04/17 Python
python误差棒图errorbar()函数实例解析
2020/02/11 Python
Python3开发实例之非关系型图数据库Neo4j安装方法及Python3连接操作Neo4j方法实例
2020/03/18 Python
css3 条纹化和透明化表格Firefox下测试成功
2014/04/15 HTML / CSS
在canvas上实现元素图片镜像翻转动画效果的方法
2018/03/20 HTML / CSS
美国男装连锁零售商:Men’s Wearhouse
2016/10/14 全球购物
光声世纪笔试题目
2012/08/25 面试题
个人评价范文分享
2014/01/11 职场文书
2014三八妇女节活动总结
2014/03/01 职场文书
3.12植树节活动总结2014
2014/03/13 职场文书
中国梦演讲稿开场白
2014/08/28 职场文书
第二批党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
独生子女证明范本
2015/06/19 职场文书
2015年挂职锻炼个人总结
2015/10/22 职场文书