博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
机器学习笔记(4)---K-近邻算法(2)---使用sklearn中的KNN算法
阅读量:4011 次
发布时间:2019-05-24

本文共 1177 字,大约阅读时间需要 3 分钟。

前言

上一篇文章中进行距离计算时使用的函数是由自己实现的classify0()完成,本篇文章改用sklearn库的KNN相关的接口实现。其实只要学会了上一节中的K-近邻算法,在其基础上只要做如下修改即可。最主要的修改就是调用分类函数的地方改成调用sklearn的库,然后在预测时注意下其返回的结果是个ndarray,取值方式稍有不同,其它都一样的。

转载请注明出处:

Scikit learn 简介

也简称 sklearn, 是机器学习领域当中最知名的 python 模块之一。Sklearn 包含了很多种机器学习的方式:

  • Classification 分类
  • Regression 回归
  • Clustering 非监督分类
  • Dimensionality reduction 数据降维
  • Preprocessing 数据预处理

源码实现

from sklearn.neighbors import KNeighborsClassifierdef sklearn_classifyPerson():    resultList = ['没有魅力', '魅力一般', '极具魅力']    ffMiles = float(input("每年飞行公里数?"))    percentTats=float(input("打游戏耗费时间的百分比?"))    iceCream = float(input("每周消费的冰激凌?"))    datingDataMat, datingLabels = file2matrix('datingTestSet2.txt')    normMat, ranges, minVals = autoNorm(datingDataMat)    inArr = np.array([ffMiles,percentTats,iceCream])    # classifierResult = classify0((inArr-minVals)/ranges, normMat, datingLabels, 3)    neigh = KNeighborsClassifier(n_neighbors=3)    neigh.fit(normMat, datingLabels)    classifierResult = neigh.predict([(inArr-minVals)/ranges])[0]#其返回的是ndarray,后面加[0]表示取里面的值。    print("这个人:", resultList[classifierResult-1])

直接在Python的main函数中调用sklearn_classifyPerson函数即可。

运行结果如下:
使用sklearn KNN算法运行结果

如有疑问之处欢迎加我微信交流,共同进步!请备注“CSDN博客”

这里写图片描述

你可能感兴趣的文章
C++中使用Mongo执行count和distinct运算
查看>>
一些socket的编程经验
查看>>
socket编程中select的使用
查看>>
C++获取文件大小常用技巧分享
查看>>
未来5年大机遇:做贩卖多巴胺的超级玩家
查看>>
关于AIS编码解码的两个小问题
查看>>
GitHub 万星推荐:黑客成长技术清单
查看>>
可以在线C++编译的工具站点
查看>>
关于无人驾驶的过去、现在以及未来,看这篇文章就够了!
查看>>
所谓的进步和提升,就是完成认知升级
查看>>
昨夜今晨最大八卦终于坐实——人类首次直接探测到了引力波
查看>>
如何优雅、机智地和新公司谈薪水?
查看>>
为什么读了很多书,却学不到什么东西?
查看>>
长文干货:如何轻松应对工作中最棘手的13种场景?
查看>>
如何确保自己的Mac数据安全呢?这里有四个“小秘诀”
查看>>
如何用好碎片化时间,让思维更有效率?
查看>>
第一性原理:戳中问题本质的人是怎么思考的?
查看>>
No.147 - LeetCode1108
查看>>
No.148 - LeetCode771
查看>>
No.174 - LeetCode1305 - 合并两个搜索树
查看>>