热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

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

k近邻法是一种基本分类与回归方法,这儿只讨论分类问题中的k近邻法。k近邻法输入为实例的特征向量,输出为实例的类别,可以取多类。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的最近邻点


推荐阅读
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 浏览器中的异常检测算法及其在深度学习中的应用
    本文介绍了在浏览器中进行异常检测的算法,包括统计学方法和机器学习方法,并探讨了异常检测在深度学习中的应用。异常检测在金融领域的信用卡欺诈、企业安全领域的非法入侵、IT运维中的设备维护时间点预测等方面具有广泛的应用。通过使用TensorFlow.js进行异常检测,可以实现对单变量和多变量异常的检测。统计学方法通过估计数据的分布概率来计算数据点的异常概率,而机器学习方法则通过训练数据来建立异常检测模型。 ... [详细]
  • 词袋模型的通俗介绍
    词,袋, ... [详细]
  • 背景应用安全领域,各类攻击长久以来都危害着互联网上的应用,在web应用安全风险中,各类注入、跨站等攻击仍然占据着较前的位置。WAF(Web应用防火墙)正是为防御和阻断这类攻击而存在 ... [详细]
  • 数据结构与算法的重要性及基本概念、存储结构和算法分析
    数据结构与算法在编程领域中的重要性不可忽视,无论从事何种岗位,都需要掌握数据结构和算法。本文介绍了数据结构与算法的基本概念、存储结构和算法分析。其中包括线性结构、树结构、图结构、栈、队列、串、查找、排序等内容。此外,还介绍了图论算法、贪婪算法、分治算法、动态规划、随机化算法和回溯算法等高级数据结构和算法。掌握这些知识对于提高编程能力、解决问题具有重要意义。 ... [详细]
  • 近年来,大数据成为互联网世界的新宠儿,被列入阿里巴巴、谷歌等公司的战略规划中,也在政府报告中频繁提及。据《大数据人才报告》显示,目前全国大数据人才仅46万,未来3-5年将出现高达150万的人才缺口。根据领英报告,数据剖析人才供应指数最低,且跳槽速度最快。中国商业结合会数据剖析专业委员会统计显示,未来中国基础性数据剖析人才缺口将高达1400万。目前BAT企业中,60%以上的招聘职位都是针对大数据人才的。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • Go语言实现堆排序的详细教程
    本文主要介绍了Go语言实现堆排序的详细教程,包括大根堆的定义和完全二叉树的概念。通过图解和算法描述,详细介绍了堆排序的实现过程。堆排序是一种效率很高的排序算法,时间复杂度为O(nlgn)。阅读本文大约需要15分钟。 ... [详细]
  • 本文详细介绍了商汤科技面试中涉及的CV算法面经内容,包括CornerNet的介绍与CornerPooling的解决方案、Mimic知识蒸馏的实现方式、MobileNet的特点、普通卷积和DW PW卷积的计算量推导、Residual结构的来源等。同时还讨论了在人脸关键点和检测中的mimic实现方式、pose对人脸关键点的提升作用、目标检测中可能遇到的问题以及处理检测类别冲突的方法。此外,还涉及了对机器学习的了解程度和相似度分析的问题。 ... [详细]
  • GPT-3发布,动动手指就能自动生成代码的神器来了!
    近日,OpenAI发布了最新的NLP模型GPT-3,该模型在GitHub趋势榜上名列前茅。GPT-3使用的数据集容量达到45TB,参数个数高达1750亿,训练好的模型需要700G的硬盘空间来存储。一位开发者根据GPT-3模型上线了一个名为debuid的网站,用户只需用英语描述需求,前端代码就能自动生成。这个神奇的功能让许多程序员感到惊讶。去年,OpenAI在与世界冠军OG战队的表演赛中展示了他们的强化学习模型,在限定条件下以2:0完胜人类冠军。 ... [详细]
  • Learning to Paint with Model-based Deep Reinforcement Learning
    本文介绍了一种基于模型的深度强化学习方法,通过结合神经渲染器,教机器像人类画家一样进行绘画。该方法能够生成笔画的坐标点、半径、透明度、颜色值等,以生成类似于给定目标图像的绘画。文章还讨论了该方法面临的挑战,包括绘制纹理丰富的图像等。通过对比实验的结果,作者证明了基于模型的深度强化学习方法相对于基于模型的DDPG和模型无关的DDPG方法的优势。该研究对于深度强化学习在绘画领域的应用具有重要意义。 ... [详细]
  • macOS Big Sur全新设计大版本更新,10+个值得关注的新功能
    本文介绍了Apple发布的新一代操作系统macOS Big Sur,该系统采用全新的界面设计,包括图标、应用界面、程序坞和菜单栏等方面的变化。新系统还增加了通知中心、桌面小组件、强化的Safari浏览器以及隐私保护等多项功能。文章指出,macOS Big Sur的设计与iPadOS越来越接近,结合了去年iPadOS对鼠标的完善等功能。 ... [详细]
  • 建立分类感知器二元模型对样本数据进行分类
    本文介绍了建立分类感知器二元模型对样本数据进行分类的方法。通过建立线性模型,使用最小二乘、Logistic回归等方法进行建模,考虑到可能性的大小等因素。通过极大似然估计求得分类器的参数,使用牛顿-拉菲森迭代方法求解方程组。同时介绍了梯度上升算法和牛顿迭代的收敛速度比较。最后给出了公式法和logistic regression的实现示例。 ... [详细]
  • 面试经验分享:华为面试四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试
    最近有朋友去华为面试,面试经历包括四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试。80%的人都在第一轮电话面试中失败,因为缺乏基础知识。面试问题涉及 ... [详细]
author-avatar
手机用户2502917325
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有