美文网首页
[机器学习算法]k近邻和kd树

[机器学习算法]k近邻和kd树

作者: TOMOCAT | 来源:发表于2019-06-23 23:41 被阅读0次

引言

k近邻算法(k-Nearest Neighbor,简称kNN):给定一个训练数据集,对于新的输入实例,在训练数据集中找到与该实例最接近的k个实例,通过这k个实例投票决定该输入实例的类别。

k近邻算法

输入: 熟练集T=\{(x_1,y_1),(x_2,y_2),...,(x_N,y_N)\}
输出: 实例x所对应的类别y

  1. 根据给定的距离度量方式,在训练数据集中找到距离输入样例x最近的k个点,将包含这k个点的x邻域记作N_k(x)
  2. N_k(x)中根据分类决策规则(如多数表决)将x划分到某个类别y

特殊地,当k等于1时,相当于将输入实例x划分到训练数据集中与x距离最近点所属的类别。

k近邻模型

唯一确定一个k近邻模型由三方面构成:距离度量方式、k值的选取和分类决策规则

一、距离度量方式

我们用两个点的距离远近来度量它们的相似程度,k近邻模型的特征空间是n维实数向量空间R^n,我们常使用欧式距离来衡量两个点的距离,但也可以是更一般的L_p距离:

L_p(x_i,x_j)=(\sum_{i=1}^{N}(|x_i^{(l)}-x_j^{(l)}|^p))^{\frac{1}{p}}

二、k值的选择

当选取的k值较小时,相当于用较小邻域的训练实例进行预测,更容易受噪声干扰(比如邻近的实例点恰好是噪声就会出错),即k越小则模型过拟合的风险越大。
当选取的k较大时,相当于用较小邻域的训练实例进行预测,这时候与输入实例较远(相似度较小)的训练实例也会对预测产生影响,从而降低模型准确率。

特别的,k等于1时相当于用离输入样例x最近的训练实例做预测;k等于N时无论输入实例是什么,都简单地用训练实例中样本数最多的类别作为预测类别。

在应用中,k值在比较小的数值范围内取,并且结合交叉验证方法确定最优k值。

三、分类决策规则

k近邻方法中的分类决策规则往往是多数表决,即由输入实例的k个邻近实例中的多数类作为预测类别。

套用监督学习中的损失函数和风险函数知识,多数表决规则等价于经验风险最小化,推导如下:

给定输入实例x,其邻近k个训练实例构成集合N_k(x),如果涵盖N_k(x)区域的类别是c_j,那么误分类率为:

\frac{1}{k}\sum_{x_i\in N_k(x)}I(y_i!=c_j)=1-\frac{1}{k}\sum_{x_i\in N_k(x)}I(y_i=c_j)
要令误分类率即经验风险最小,相当于最大化\sum_{x_i\in N_k(x)}I(y_i=c_j),也就是多数表决。因此在k近邻中多数表决规则等价于经验风险最小化。

kd树

当训练集很大时,计算输入实例和每一个训练实例的距离相当耗时。为了提高k近邻搜索的效率,我们使用特殊的结构存储训练数据来减少计算距离的次数,比如kd树方法。
kd树(k-dimension tree)是一种对k维空间中的实例点进行存储以便对其进行快速检索的二叉树形数据结构。构造kd树相当于不断用垂直于坐标轴的超平面将k维空间切分,构成一系列的k维超矩形区域,kd树上的每一个结点对应于一个k超矩形区域。该超矩形区域垂直于当前划分维度的坐标轴,并在该维度上将空间划分为两部分。

一、构造kd树

输入: k维空间数据集T={x_1,x_2,...,x_N},其中x_i=(x_i^{(1)},x_i^{(2)},...,x_i^{(k)})^T
输出:kd

  1. 构造对应包含Tk维空间的超矩形区域:以x^{(1)}为坐标轴,T中所有实例的x^{(1)}坐标的中位数为切分点将超矩形区域划分为两个子区域。此步生成深度为1的左、右结点:左子结点对应坐标x^{(1)}小于切分点的子区域,右子结点对应于坐标x^{(1)}大于切分点的子区域。正好落在划分超平面上的实例点保存在根结点。
  2. 同样地,对深度为j的结点,选择x^{(l)}为切分的坐标轴(l=j(mod\quad k)+1,因为可能存在对同个维度进行多次划分),以该结点的区域中所有实例的x^{(1)}坐标的中位数为切分点划分结点对应的超矩形区域。
  3. 直到两个子区域没有实例存在时停止

注意到没,kd树的思想和二分法很像,并且都能提高搜索的效率。

二、搜索kd树

注意kd树中的k指特征维度数,但k近邻算法中的k表示最邻近的k个点。
搜索方法如下:
输入: 已知的kd树,目标点x
输出: x的最近邻

  1. 先找到kd树中包含目标点x的叶结点(即包含输入样例的超矩形区域):从根结点出发,递归地向下访问直到子结点为叶结点
  2. 以该叶结点为“当前最近点”
  3. 在该叶子结点递归回退,在每个结点进行如下操作:
  • 如果该结点保存的实例点比“当前最近点”更距离目标点更近,则以该实例点为“当前最近点”
  • 当前最近点一定存在于该结点一个子结点对应的区域。检查该子结点的父结点的另一子结点对应的区域是否有更近的点。(即检查另一子结点对应的区域是否与该目标点为球心,以目标点与“当前最近点”间的距离为半径的超球体相交)
  • 如果相交,可能在另一个子结点对应的区域内存在距目标点更近的点,移动到另一个子结点,接着,递归地进行最近邻搜索
  • 如果不相交,向上回退
  1. 当回退到根结点时,搜索结束,最后的“当前最近点”即为x的最近邻点。

需要注意的点

  1. 如果实例点是随机分布的,那么kd树的平均计算复杂度是O(logN)
  2. kd树更适用于训练实例数远大于空间维数的k近邻搜索,当空间维数接近训练实例数时,它的效率会迅速下降,几乎接近于线性扫描(即挨个计算训练数据集每个点和输入样例的距离)
  3. k近邻算法既能用于分类,也能用于回归,比较简单的回归就是用k近邻点的平均值来预测输入样例的预测值。
  4. k近邻模型由三个因素决定:距离度量方法、k值选取和分类决策规则

参考

李航 《统计学习方法》

相关文章

  • k 近邻法

    k 近邻法 k 近邻算法 k 近邻模型 k 近邻法的实现:kd 树 搜索 kd 树 k 近邻模型实现 k 近邻模型...

  • [机器学习算法]k近邻和kd树

    引言 k近邻算法(k-Nearest Neighbor,简称kNN):给定一个训练数据集,对于新的输入实例,在训练...

  • 机器学习算法-KNN算法

    机器学习算法-K近邻算法 本文中介绍的机器学习中最基础的一个算法:k-近邻算法,将从如下方面展开: 算法概述 k近...

  • 机器学习常用算法

    机器学习常用算法总结如下:决策树随机森林算法逻辑回归SVM朴素贝叶斯K最近邻算法K均值算法Adaboost 算法神...

  • 统计学习方法之kNN算法

    k 近邻是什么 k 近邻法是机器学习中最基本的分类和回归方法,也称为kNN算法。通常k近邻法用于分类问题。k近邻法...

  • 机器学习算法—KNN(K近邻)3

    kd树 k近邻算法最简单的实现方式线性扫描 linear scan。需要计算每个输入实例和每个训练实例之间的距离;...

  • 机器学习实战之K-近邻算法(二)

    机器学习实战之K-近邻算法(二) 2-1 K-近邻算法概述 简单的说,K-近邻算法采用测量不同特征值之间的距离方法...

  • k近邻算法

    1、k近邻简介 1-1、算法思路 k近邻(K-Nearest Neighbor)可能是最简单的机器学习算法,它基于...

  • kNN算法

    一. kNN算法 kNN(k-NearestNeighbor),即k最近邻算法,是机器学习算法中最基础的入门算法。...

  • BAT机器学习面试1000题系列(第21~30题)

    21.KNN中的K如何选取的?关于什么是KNN,可以查看此文:《从K近邻算法、距离度量谈到KD树、SIFT+BBF...

网友评论

      本文标题:[机器学习算法]k近邻和kd树

      本文链接:https://www.haomeiwen.com/subject/mpdgqctx.html