K近邻(KNN)

news/2024/12/23 3:16:05/

算法原理

KNN是监督学习的一种,K近邻法假设给定一个训练数据集,其中的实例类别已定。分类时对新的实例,根据其K个最近邻的训练实例的类别,通过多数表决等方式进行预测。K值的选择、距离度量及分类决策规则是K近邻法的三个基本要素。
具体来说KNN算法分为以下几步:

  1. 计算已知类别的数据集中的每个点与当前点之间的距离
  2. 按照距离递增的顺序将这些已知类别的点排序
  3. 选取与当前点距离最小的K个点
  4. 确定前K个点所在类别的出现频率
  5. 返回前K个点出现频率最高的类别作为当前点的预测分类

K值的选择

K值的选择会对KNN算法的结果产生重大影响,如果选择较小的K,学习的近似误差会减小,只有与输入实例较接近的训练实例才会对预测结果起作用,缺点是“学习”估计误差会增大,预测结果会对邻居的实例点非常敏感,如果邻近点恰好是噪声,预测结果就会出错。
同理,如果选择较大的K值,可以减少估计误差,但是近似误差会增大。

距离的度量

KNN一般选择欧氏距离,当然其他的距离也可以使用。

决策规则

KNN中的决策规则是多数表决,即前K个点出现频率最高的类别作为当前点的预测分类

实现

使用KNN算法改进了约会网站的配对效果(使用KNN算法分析约会对象的相关特征,将约会对象划分到确切的分类中,从而为用户提供匹配度更高的约会对象)。实验结果表明,KNN算法处理约会数据集的错误率为6.6%,取得了一个不错的结果。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

总结

(1)k近邻法是基本且简单的分类与回归方法。K近邻的基本做法是:对给定的训练实例点和输入实例占,首先确定输入实例上的K个最近邻训练实例点,然后利用这k个训练实例点的类的多数来预测输入实例点的类。
(2)k近邻模型对应于基于训练数据集特征空间的一个划分。k近邻法中,当训练集、距离度量、k值及分类决策规则确定后,其结果唯一确定。
(3)k近邻法三要素:距离度量、k值的选择和分类决策规则。常用的距离度量是欧氏距离及更一般的Lp距离。k值小时,k近邻模型更复杂;k值大时,k近邻模型更简单。k值的选择反映了对近似误差与估计误差之间的权衡,通常由交叉验证选择最优的k。常用的分类决策规则是多数表决,对应于经验风险最小化。
(4)k近邻法的实现需要考虑如何快速搜索k个最近邻点。kd树是一种便于对k维空间中的数据进行快速检索的数据结构。kd树是二叉树,表示对k维空间的一个划分,其每个结点对应于k维空间划分中的一个超矩形区域。利用 kd树可以省去对大部分数据点的搜索,从而减少搜索的计算量。


http://www.ppmy.cn/news/162041.html

相关文章

loading out-of-tree module taints kernel

调IMC42686驱动时,遇到此问题,加载的树外模块污染了内核。 insmod driver_icm42686.ko [ 21.047635] driver_icm42686: loading out-of-tree module taints kernel. 这种错误可以不用理会,但看见此提示,不解决它又觉得不适。 解…

kni

当dpdk不想在用户态实现协议栈的还,可以采用KNI 调用内核实现的协议栈 kni分为用户态和内核态 其内核态的入口为lib/librte_eal/linuxapp/kni/kni_misc.c中 #可以看这是个标准的ko的实现,其入口函数是kni_initmodule_init(kni_init); static int __init …

KNN(K近邻)

物以类聚,人以群分;近朱者赤,近墨者黑。这两句话的大概意思就是,你周围大部分朋友是什么人,那么你大概率也就是这种人,这句话其实也就是KNN算法的核心思想。 所谓的物以类聚,人以群分&#xff0…

KNN(k近邻详解)

KNN(k近邻详解) 详细链接一 详细链接二 一句话说明白KNN算法原理 下面我们只讲关于分类的KNN,回归的不讲。 其实很简单,就是计算你要预测的点的周围最近的K个点,然后取这k个点中最多的类定义为你要预测的这个点所属…

Kibana

Kibana Kibana 是一款开源的数据分析和可视化平台,它是 Elastic Stack 成员之一,设计用于和 Elasticsearch 协作。您可以使用 Kibana 对 Elasticsearch 索引中的数据进行搜索、查看、交互操作。您可以很方便的利用图表、表格及地图对数据进行多元化的分析…

电子发票(PDF)识别信息提取(JAVA)电子专票(OFD)在线预览

网上也有资料,有的只有jar包没有源码,整理好网上的资源,把源码开放出来。 https://gitee.com/kanen/invoice 欢迎使用和交流。 内容介绍 电子发票(PDF)识别与验真 1、支持电子发票(PDF)的读取…

Conan

# 环境 ubuntu:bionic的docker image shell docker run -it ubuntu:bionic 预装工具 shell apt-get install cmake # 安装conan shell # pip3 install conan Collecting conan # conan -v Conan version 1.33.0 # 使用conan >官方文档:https://docs.conan.io/…

Koin

Dagger 的麻烦 如果还不清楚什么是依赖注入,那么请参考之前写的 Dagger2 in Android(一)通俗基础开头部分。如果你不了解 Dagger 倒也无妨,本文会进行一定的对比,但仅针对接触过 Dagger 的同学,否则大可以忽…