统计学习方法笔记-K近邻法

2024-05-29 17:32

本文主要是介绍统计学习方法笔记-K近邻法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

k近邻法是一种基本分类与回归方法,这儿只讨论分类问题中的k近邻法。k近邻法输入为实例的特征向量,输出为实例的类别,可以取多类。
K近邻算法
简介:
给定一个训练数据集,对新输入的实例,在训练数据集中找到与其最近邻的k个实例,这k个实例的多数属于某个类,就把该输入实例分为这个类。
算法:
1、根据给定的距离度量,在训练集中找出实例x最邻近的k个实例,涵盖这k个实例的x的领域记作
2、在 中根据分类决策规则(如多数表决)决定x的类别y:

其中I()为指示函数,即yi = cj时,I()为1,否则为0

k近邻模型
模型:
特征空间中,对每个训练实例点xi,距离该点比其他点更近的区域,叫作单元。所有实例点的单元构成对特征区域的划分。最近邻法讲实例xi的类yi作为其单元中所有点的类标记。

距离度量:
特征空间中两个实例点的距离是两个实例点相似度的反映。k近邻法一般使用的距离是欧氏距离,但也可以是其他距离。


k值的选择:
选择较小的k值,学习的近似误差减小,但学习的估计误差会增大,预测结果对近邻的实例点非常敏感,如果近邻的实例点恰好是噪声,预测就会出错。也就是说k值减小,意味着模型变得复杂,更容易发生过拟合。
选择小的k值,可以减小估计误差,但是会增大近似误差,k值的增大意味着模型变得简单。
在应用中,k值一般去一个比较小的值,通常采用交叉验证法来选取最优k值。

分类决策规则:
k近邻法中分类决策规则往往是多数表决。误分类率是:
    
要使误分类率最小即经验风险最小,就得让     最大,所以多数表决等价于经验风险最小。

kd树

构造kd树:
1、开始:构造根结点,根结点对应于包含T(T为训练数据集)的k维空间的超矩形区域。
选择x¹为坐标轴,以T中所有x¹的中位数为切分点,将根结点对应的超矩形区域切分成两个子区域,切分由通过切分点并与坐标轴x¹垂直的超平面实现。
由根结点生成深度为1的左、右子结点:
2、重复:对深度为j的结点,选择 x ( l ) 为切分的坐标轴,l = j(mod k) + 1,以该结点的区域中所有实例的x( l )坐标的中位数为切分点(如果是偶数个,也可以最中间二者选其一),将该结点对应的超矩形区域切分为两个子区域。切分由通过切分点并且与坐标轴x( l )垂直的超平面实现。
    由该结点生成深度为j + 1的左、右子结点:左子结点对应坐标x( l )小于切分点的子区域,右子结点对应坐标x( l )大于切分点的子区域。
将落在切分超平面上的实例点保存在该结点。


搜索kd树:
1、在kd树中找出包含目标点x的叶结点:从根节点出发,递归向下访问kd树。若目标点x当前维的坐标小于切分点坐标,则移动到左子结点,否则移动到右子结点,直到子结点为叶结点为止。
(之所以上面这个过程没有判断等于(即目标点正好为某个父结点的特例),是因为单个维度等于不足以确定就是某个类,而目标点和训练点所有特征值相等的可能性太低,而单一特征值相等的可能性要高些,要是每出现某个纬度一样就对比所有特征值效率太低,所以干脆往右移,最终确定的一个叶结点。就算此时目标点正好是某个父节点甚至根节点这样的特例(可能性太低太低),最终也会找出这个父节点就是最近点,不会出现找出错误最近点的情况,总的来说不判断特殊情况利大于弊)
(我之前的观点:如果目标点当前维大于切分点坐标,且当前所在子结点只有左子结点并没有右子结点,那么就停留在当前结点。
这个观点有点问题,如果按照接下来的算法,这个观点不会在当前结点的区域下遍历找最近点,而是直接跳到父节点,所以具体实现还是得我找时间看kd树搜索算法的实现!)

2、以此叶结点为“当前最近点”

3、递归的向上回退,在每个结点执行以下操作:
a、如果该结点保存的实例点比当前最近点距离目标点更近,则以该实例为“当前最近点”(父结点在这个时候进行距离比较)
b、当前最近点一定存在于该结点一个子结点对应的区域。检查该子结点的父结点的另一个子结点对应的区域是否有更近的点。具体的,检查另一个子结点对应的区域是否与以目标点为球心,以目标点与“当前最近点”的距离为半径的超球体相交。
如果相交,可能在另一个子结点对应的区域存在距目标点更近的点,移动到另一个子结点,接着,递归地进行最近邻搜索(自解释:如果这个子结点的度不为0,则从选择叶结点步骤开始,否则直接比较此节点保存的唯一实例点);
如果不相交,向上回退。(子结树的所有点都不用比较了,这个时候效率就体现出来的)

4、当回到根节点时,搜索结束,最后的“当前最近点”即为x的最近邻点

这篇关于统计学习方法笔记-K近邻法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1014177

相关文章

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间