算法笔记(5)-K最近邻算法及python代码实现

2023-10-27

K最近邻算法既可以用于分类又可以用于回归。

K最近邻(k-Nearest Neighbor,KNN)算法分类的基本原理:如果一个样本在特征空间中的k个最相似(即特征空间中最邻近)的样本中的大多数属于某一个类别,则该样本也属于这个类别。
K最近邻(k-Nearest Neighbor,KNN)算法回归的基本原理:当我们使用K最近邻回归计算某个数据点的预测值时,模型会选择离数据点最近的若干个训练数据集中的点,并且将他们的y值取平均值,并把该平均值作为新数据点的预测值。

一、K最近邻算法在分类任务中的应用

下面实现一个数据点在训练好的模型下分类,可视化效果图如下

#%%

import numpy as np
clf = KNeighborsClassifier()
clf.fit(X,y)

#下面的代码用于画图
x_min, x_max = X[:, 0].min() - 1, X[:, 0].max() + 1
y_min, y_max = X[:, 1].min() - 1, X[:, 1].max() + 1
xx, yy = np.meshgrid(np.arange(x_min, x_max, .02),
                     np.arange(y_min, y_max, .02))
Z = clf.predict(np.c_[xx.ravel(), yy.ravel()])
Z = Z.reshape(xx.shape)
plt.pcolormesh(xx, yy, Z, cmap=plt.cm.Pastel1)
plt.scatter(X[:, 0], X[:, 1], c=y, cmap=plt.cm.spring, edgecolor='k')
plt.xlim(xx.min(), xx.max())
plt.ylim(yy.min(), yy.max())
plt.title("Classifier:KNN")
plt.scatter(6.75,4.82, marker='*',c='red', s=200)
plt.show()


#%%

二、K最近邻算法在回归分析中的应用

下面实现K最近邻算法回归可视化效果图如下

from sklearn.neighbors import KNeighborsRegressor
reg = KNeighborsRegressor()
reg.fit(X,y)
z = np.linspace(-3,3,200).reshape(-1,1)
plt.scatter(X,y,c='orange',edgecolor='k')
plt.plot(z, reg.predict(z),c='k',linewidth=3)
plt.title('KNN Regressor')
plt.show()

 对模型进行评分

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

算法笔记(5)-K最近邻算法及python代码实现 的相关文章

随机推荐

  • java获取随机时间,在Java中生成随机日期时间(约达时间)

    Is it possible to generate a random datetime using Jodatime such that the datetime has the format yyyy MM dd HH MM SS an
  • 项目经理面试中可能遇到的问题(持续更新)

    1 范围 时间 成本 这三项中哪些是可以由客户控制的 范围 时间 成本 是项目管理中常说的三角关系 任何一方改变都可能牵扯到其他两方的变动 项目管理的本质 就是在保证质量的前提下 寻求这三者之间的最佳平衡 因为客户是需求方和投资方 客户有权
  • kafka 详细入门指南

    kafka 详细入门指南 避免浪费时间 gt 本篇定义Kafka 安装及入门实操 不涉及原理 后续会另一篇详解 kafka标签 开源的消息系统 scala和java是实现的 kafka最初由LinkedIn开发 2012年10月Apache
  • 上传图片到七牛云

    本文介绍后端如何将图片上传到七牛云 如有需要 可以参考 如有帮助 不忘点赞 预热准备 1 首先打开七牛云的官网 七牛云 2 注册一个人账号 新用户有优惠 具体可以查看官网通讯 3 进入个人控制台 打开 对象存储 gt 空间管理 然后我们新建
  • 【ffmpeg基础】ffmpeg视频编码

    一 ffmpeg编码H264 输入为YUV输出为H264 ffmpeg s 416x240 pix fmt yuv420p i BlowingBubbles 416x240 50 yuv r 50 vcodec libx264 Blowin
  • 【机器学习】pycm--史上最强多分类性能评估库

    0 博主介绍 博主介绍 大家好 我是可可卷 很高兴和大家见面 主攻领域 数据分析 机器学习 深度学习 数据可视化 欢迎关注 点赞 收藏 评论 作者水平很有限 欢迎各位大佬指点 一起学习进步 文章目录 0 博主介绍 1 情景引入 2 pycm
  • E5 CPU内存条数影响

    E5 v4 可支持4通道 双E5服务器8条内存即达到内存带宽 如果主板是16条 剩余的8条只增加容量 不再增加带宽 即只有在内存消耗很大 用到剩余8条内存时 内存才进行读写 写可能不完全是这样 总之 对性能的影响不大 以2697Av4为例
  • Window10下解决弹出兼容性助手对话框的方法

    注 Win7或其他版本可以参考这个 Win10下亲测可用 Window10下安装运行一些旧版的软件后 经常在运行或退出时弹出程序兼容性助手对话框 解决方法如下 1 关闭Windows服务下的程序兼容性服务 设置为禁用 2 在策略中设置 关闭
  • 1+X 云计算运维与开发(中级)案例实战——ZooKeeper集群部署

    传送门 教育部 职业教育将启动 1 X 证书制度改革 职业教育改革1 X证书制度试点启动 1 X成绩 证书查询入口 文章目录 什么是zookeeper 1 案例目标 2 案例分析 2 1 规划节点 2 2 基础准备 3 案例实施 3 1 基
  • 利用IDEA 进行debug发现错误的一次经历

    利用IDEA debug发现错误的一次经历 今天在做实训项目的时候遇到了一个问题 就是在进行添加学生信息的时 发现总是提示手机号码格式不正确 可是明明是以正确的格式输入的却总是提示格式错误 于是在这里打上断点并且按右上角的虫子按钮 同样输入
  • vue项目怎么安装依赖

    安装node js 从node js官网下载并安装node 安装过程很简单 一路 下一步 就可以了 傻瓜式安装 安装完成之后 打开命令行工具 输入 node v 如下图 如果出现相应的版本号 则说明安装成功 npm包管理器 是集成在node
  • 不想学习的时候如何逼迫自己去学习?(长文预警)

    尼采曾用酒神和日神来比喻人类艺术活动的两种方式 一种是日神的 走向世界 追求成功 类的理性 一种是酒神的 走向内心 寻求超越 类的情感 而从学习上来看 由于中国特殊的教育环境 几乎不可能有后者的闲情逸致 家长们送孩子们上学 除了超一线城市确
  • Hive概论、架构和基本操作

    Hive是一个构建在Hadoop上的数据仓库框架 最初 Hive是由Facebook开发 后台移交由Apache软件基金会开发 并做为一个Apache开源项目 Hive是基于Hadoop的一个数据仓库工具 可以将结构化的数据文件映射为一张数
  • vue简单实现查询排序功能

  • Jenkins与SonarQube配置

    Jenkins与SonarQube Jenkins 配置 SonarQube 在 SonarQube 中生成 Server authentication token 登录 SonarQube 后 在 My Account gt Securi
  • 2020年蓝桥杯B组个人题解(热的,不知道对错)

    文章目录 A B C D E F G H I J 总结 结果 现在是蓝桥杯刚结束 趁着有记忆 写下这篇博客 不知道对错 如果我错了 请指出 A 因为是到0就结束了 那么每次看看 600是否结束 如果没有结束就 300 然后时间 2 60 最
  • 抗渗等级p6是什么意思_混凝土抗渗等级w4是什么意思?

    混凝土抗渗等级可按28d龄期的标准试件测定 混凝土抗渗等级分为 W2 W4 W6 W8 W10 W12六级 根据建筑物开始承受水压力的时间 也可利用60d或90d龄期的试件测定抗渗等级 抗渗等级是以28d龄期的标准试件 按标准试验方法进行试
  • jeeplus-js-获取table中复选框选中的列

    function getSelectedIds var str var ids contentTable tbody tr td input i checks checkbox each function if true this is c
  • 解决error C2065:"..."未声明的标识符,C2065:语法错误: 标识符“...”

    网狐项目工程中有时候会出现 C2065错误 一般情况下有可能是 项目工程配置出错 只需要选择 Visual Studio 2013 v120 就可以了
  • 算法笔记(5)-K最近邻算法及python代码实现

    K最近邻算法既可以用于分类又可以用于回归 K最近邻 k Nearest Neighbor KNN 算法分类的基本原理 如果一个样本在特征空间中的k个最相似 即特征空间中最邻近 的样本中的大多数属于某一个类别 则该样本也属于这个类别 K最近邻