最邻近搜索

✍ dations ◷ 2025-07-02 11:26:31 #人工智能,算法

最邻近搜索(Nearest Neighbor Search, NNS)又称为“最近点搜索”(Closest point search),是一个在尺度空间中寻找最近点的优化问题。问题描述如下:在尺度空间中给定一个点集和一个目标点 ∈ ,在中找到距离最近的点。很多情况下,为多维的欧几里得空间,距离由欧几里得距离或曼哈顿距离决定。

高德纳在《计算机程序设计艺术》(1973)一书的第三章中称之为邮局问题,即居民寻找离自己家最近的邮局。

最邻近搜索问题在很多领域中都有应用,包括:

最邻近搜索问题有若干种解决方案,这些算法的优劣决定于他们求解的时间复杂度和用来查找的数据结构的空间复杂度。一种通常的说法表述为“维数灾难”(curse of dimensionality),指对于在大维数的欧几里得空间里用最邻近搜索的话,无法找到多项式的算法和多对数的查找时间。

最简单的最邻近搜索便是遍历整个点集,计算它们和目标点之间的距离,同时记录目前的最近点。这样的算法较为初级,可以为较小规模的点集所用,但是对于点集的尺寸和空间的维数稍大的情况不适用。线性查找所需时间为O(),其中N是的势,是的维。由于不需要建立数据结构,所以线性查找没有存储空间复杂度的问题。

从七十年代起分支限界方法被应用于这个问题。对欧几里得空间来说,这个方法被称为空间索引或者空间访问方法。目前已发展出好几种分支限界方法。恐怕最简单的当属K-d树,它将查找空间不断将父节点包含的区域分为相邻的两部分,每部分包含原来区域中的一半点。求解时,从根节点开始在每个分叉点上对目标点进行计算,直到叶节点。对于给定的维度,查找时间复杂度为O(log )。R树数据结构能高效插入和删除节点,用来解决动态环境下的最邻近搜索。

对于一般的度量空间,分支限界方法被称为度量树,特别的例子有VP树和Bk树。

LSH(Locality sensitive hashing)通过对点进行某种度量操作后将点分组散列在不同的次点集中。在这种度量下相互间距离较近的点被分在同一个次点集的可能性较高。

覆盖树有一个基于点集倍常量的理论界限。这个查找时间的界限是O(c12 log n),其中是点集的膨胀常数。

在最邻近搜索的几个变化中,最著名的是KNN(K-nearest neighbor algorithm)和ε近似最邻近查找(ε-approximate nearest neighbor search)。

KNN查找最邻近的K个点。这种方法常被用在预测分析中,用某点的一些临近点来对它估计和分类。

在一些应用中指需要有个对最邻近的猜测。这种情况下,我们可以用一个不保证能每次都返回绝对正确的最近点的算法,用来提高运算速度或节约存储空间。常常这样的算法大都能找到正确的最近点,但这大大取决于采用点集的分布。

采用近似查找的算法包括Best Bin First和Balanced Box-Decomposition Tree。

ε近似最邻近查找是目前流行的打破维数灾难的工具。

最邻近距离比不直接用目标点和邻近点的距离作为阈值,而是将与到前一个邻近点的距离相关的比值来作为阈值。这被用在基于内容的图像检索中,通过基于本地特征的相似性的“例子查找”来得到图像。更广泛的用途是在一些匹配问题中。

有时,我们需要找到在整个点集中距离所有点都最近的那个点。把最邻近搜索在所有点上运行一次自然能解决问题,但改进的策略能避免点集中距离信息的冗余,从而更高效地查找。比如:当我们算出了X到Y的距离,我们也同时得到了Y到X的距离,于是结果就能被以后的一次求解直接利用。

相关

  • 龙骨龙骨在船、汽艇或是小舟的是最重要的承重结构。它位于船的底部。在龙骨的上面有横过的船肋加固。船首和船尾,龙骨绕过艏柱。龙骨通常是船壳第一个被建造的部分。龙骨的铺设是
  • 2012《2012年欧洲歌唱大赛》(法语:"Concours Eurovision de la chanson 2012",英语:"Eurovision Song Contest 2012")是第57届《欧洲歌唱大赛》,于阿塞拜疆首都巴库举办。在《2011年
  • 毫毛毫毛或称胎毛是一种只有婴儿才有的体毛,它的功能与头发类似,但在婴孩八个月时就会逐渐消失,因为毫毛有此特性,故有家长把孩子带到订做毛笔的地方,把毫毛刮下制成毛笔,作为送给孩子
  • 里霍博斯人巴斯特人(英语:Basters),是纳米比亚共和国中一个由荷兰男人与布须曼人和黑人妇女混血产生的族群,说南非语。他们通常被认为是纳米比亚阿非利卡人一个次群体,更偏远的有色人。自19
  • 鳐科见内文。鳐科(学名)是鳐形目的典型科,本科鱼身体扁平,胸鳍宽大,腹鳍有一个明显的缺刻,几乎将腹鳍分为两叶,两个背鳍非常小,紧靠尾部,尾细小,通常无尾鳍,如有也没有鳍条支持。鳐科鱼生活
  • 董晨董晨(1968年-),中国免疫学家,清华大学医学院教授、院长。2019年当选为中国科学院院士。1968年生于中国湖北武汉。1989年毕业于武汉大学细胞生物学专业,获学士学位。1996年毕业于美
  • getty (Unix)getty是“get teletype”的缩写,它是一个Unix程序,用来连接物理的或虚拟终端。在PDP-7时代(1970年),video display terminal还没有成熟,用的最多的terminal是ASR-33 teletype。AS
  • JuKJuK JuK是一个KDE下的自由音频播放器,也是KDE 3.2以后默认的音频播放器 ,kdemultimedia 软件包的一部分。JuK支持MP3、Ogg Vorbis和FLAC文件。JuK开发是由Scott Wheeler在2000
  • 狄葆贤狄葆贤 (1873年-?)字楚青(又作楚卿),号平子、慈石,斋名平等阁。江苏溧阳人。中国学者、书画家、红学家、政治活动家。狄葆贤生于同治十二年(1873年)。他早年曾和谭嗣同、唐才常来往,拥
  • 武卡欣·约万诺维奇武卡欣·约万诺维奇(塞尔维亚语:Vukašin Jovanović;1996年5月17日-)是一位塞尔维亚足球运动员。在场上的位置是中后卫。现时效力于法甲球队波尔多,曾效力于塞尔维亚足球超级联赛