- 原文地址:9 Distance Measures in Data Science
- 原文作者:Maarten Grootendorst
- 译文出自:掘金翻译计划
- 本文永久链接:github.com/xitu/gold-m…
- 译者:chzh9311
- 校对者:samyu2000、PassionPenguin
数据科学中的 9 种距离度量
很多机器学习算法,包括有监督的和无监督的,都会使用距离度量这一概念。例如,在 k-NN、UMAP、HDBSCAN 等算法中就有这种情况,它们使用了欧几里德距离和余弦值相似度这两种距离度量。
理解距离度量可能比你想象的更加重要。以常用于监督学习的 k-NN 算法为例,它默认使用欧氏距离作为距离度量。这本身就是一种很棒的距离度量方式。
然而,如果你的数据有很高的维度,情况会如何?此时使用欧氏距离仍然能解决问题吗?如果数据包含了地理空间信息呢?显然不能。在这种情况下,使用半正矢距离也许更加合适!
你应该掌握每种距离度量在何种情况下使用,因为它可以帮你把一个糟糕的分类器转化成一个精确的模型。
在这篇文章中,我们会介绍多种距离度量,并探讨使用它们的最佳方式和最适合使用的场景。更重要的是,我会介绍它们的不足,以便你了解某些算法在何种情况下不适合使用。
注意:一些长篇论文已经详细介绍了大多数距离度量的使用场景和它们各自的优缺点。我也会尽可能全面地介绍这些内容,但不可能面面俱到。所以,本文应当视作这些距离度量的概述。
1. 欧式距离(Euclidean Distance)
我们从最常用的距离度量,也就是欧式距离开始。对它最恰当的解释就是两点间的直线距离。
欧氏距离的计算公式相当直接,已知两个点的笛卡尔坐标,根据勾股定理即可计算出来。
不足
即使作为一种常用的距离度量,欧氏距离也不具备缩放不变性。这就意味着计算出来的距离可能会随着单位的变化而变化。一般地,在使用距离度量前需要对数据进行标准化。
而且,随着数据维度的上升,欧氏距离的适用性会下降。这和维度诅咒有关,也就是高维空间的表现并不符合我们直觉上从 2 维或 3 维空间类比得出的推断。相关内容的总结可以参考这篇问答。
适用情景
在数据维度较低,而且需要重点测量向量大小时,使用欧氏距离比较合适。欧氏距离应用于低维度数据时,像 k-NN 和 HDBSCAN 这类方法能得到比较理想的结果。
欧式距离固然存在一定的局限性,人们也为此发明了很多其他距离度量,但它仍然是最常用的。它完美契合我们的直觉,实现起来十分简单并且在多种使用情景中都得到了很好的结果。
2. 余弦相似度(Cosine Similarity)
余弦相似度常常用于弥补欧氏距离在高维空间中的不足。其定义就是两个向量夹角的余弦。它也等于将两个向量归一化为单位向量后的内积。
如果两个向量方向完全相同,其余弦相似度就为 1,而如果两个向量平行但方向相反,其余弦相似度就是 -1。注意,余弦相似度体现的是方向的差异,而非大小。
不足
余弦相似度的一个首要缺点是忽略了向量的长度,仅仅考察其方向。这在实际应用中就意味着数值差异没有纳入考察。以推荐系统为例,余弦相似度就无法体现不同用户的评分量表的差异。
适用情境
当我们的数据维度较高而且向量的长度并不重要时,我们通常可以使用余弦相似度。在文本分析领域,当我们用单词计数作为数据时,这种度量就使用得非常频繁。例如,某个单词在一篇文章中频繁出现,这并不一定意味着这篇文章的内容与该单词相关度较高。也有可能是这样的情况:不同的文章长度不同,所以单词计数向量的长度并不影响最终统计结果。于是,忽略长度的余弦相似度就成了我们最优的选择。
3. 汉明距离(Hamming Distance)
汉明距离指两个向量间数值不同的位数。它通常用于比较两个长度相同的二进制字符串。它也可以通过计算两个等长字符串间同位置不同字符的个数,来表示这两个字符串的相似度。
不足
你应该能考虑到,当两个向量维度不相同时,汉明距离就难以应用。你需要比较同等维度的向量来发现哪些位置不同。
而且,汉明距离不考虑实际数值而只关心它们是否相等。因此,在需要重点考察数值大小的情况下,不建议使用汉明距离。
适用情景
汉明距离的一个典型案例是计算机网络中传输数据时的错误检测和校正。它可以用于表示传输错误的比特位数,以此估计误差。
并且,你也可以用汉明距离来衡量分类型变量之间的距离。
4. 曼哈顿距离
曼哈顿距离,通常又称出租车距离或城市街区距离,用于实值向量之间的距离计算。想象一下单位网格上的点所表示的向量。曼哈顿距离表示的是只能沿水平或垂直方向移动的情况下,两个向量之间的路径长度。在计算这种距离时,不涉及对角线。
不足
虽然曼哈顿距离似乎可以处理高维数据,但与欧氏距离相比,这种度量方式就不够直观,尤其是用于高维数据的时候。
况且,它的计算结果可能比欧氏距离要大,毕竟它测量的并不是可能的最短路径。虽然这并不一定会带来问题,但你必须考虑这些因素。
适用情景
当你的数据集中的属性是离散的或二元的,曼哈顿距离似乎很合适,因为它计量的路径是在这些属性取值范围内可以实现的。相反,欧氏距离会在两个向量间创造一条直线段,而这条直线实际上可能并不存在。
5. 切比雪夫距离(Chebyshev)
切比雪夫距离的定义是两个向量对应维的数据差值中的最大值。换言之,它可以简单理解为沿着坐标轴计算的最大距离。切比雪夫距离经常被称作棋盘距离,因为在国际象棋中,国王要从一格走到另一格所需的最少步数就等于切比雪夫距离。
不足
一般来说,切比雪夫距离适用的场景是比较特殊的,所以它难以像欧氏距离或余弦相似度那样作为通用的距离度量。因此,除非确实适合,一般不推荐使用它。
适用情景
前面提到过,切比雪夫距离可以用于表示国王从一格走到另一格所需的最少步数。进一步,它可以在允许八向移动的游戏中作为一个很好的度量手段。
实际中,切比雪夫距离常用于仓储物流,因为它可以很好地描述桥式吊车移动物体所需的时间。
6. 闵可夫斯基距离(Minkowski Distance)
闵可夫斯基距离比大多数度量都要复杂一些。它用于赋范向量空间(n 维实空间),也就是说如果一个向量空间内的距离被表示成可计算长度的向量,那么闵可夫斯基距离就可以被用于这个空间。
这个度量方式有三点要求:
- 零向量 —— 零向量的长度是 0 而所有其它向量的长度都是正值。假如我们从一个地点到另一个地点,那么距离始终是正的。然而,假如我们从这个地点到它本身,那么距离就是 0。
- 数乘因子 —— 当你将向量乘以一个正数的时候,向量的长度变化而方向不变。比如,如果我们在某个特定方向上走了一段距离,然后再加上同样的距离,其方向是不会改变的。
- 三角不等式 —— 两点之间直线最短。
下面是闵可夫斯基距离的公式:
关于这种距离度量,最有趣的是参数 的使用。我们可以调整这个参数来将闵可夫斯基距离变成其它的距离度量。
常用的 取值有:
- —— 曼哈顿距离
- —— 欧氏距离
- —— 切比雪夫距离
不足
闵可夫斯基距离和它所代表的距离度量有着同样的缺点,所以需要对诸如曼哈顿距离、欧氏距离和切比雪夫距离的度量方式有深入的理解,这是十分重要的。
而且,参数 实际上可能带来一些麻烦。取决于你的使用情景,寻找正确的 值可能会造成计算上的低效。
适用情景
参数 的优势是它可以被迭代更新从而找到最适合当前问题的距离度量。这给你的距离度量带来了相当大的自由,如果你熟悉 和很多距离度量方式,这将是一个很大的优势。
7. 雅卡尔指数(Jaccard Index)
雅卡尔系数(或者 IoU)是用于计算采样集合的相似性和差异性的度量方式。它的计算是用交集的大小除以并集的大小。
实际应用中,它代表相似实例的数量除以所有实例的总数。例如,假如两个集合有一个共同的实例,而问题中总共有 5 个不同的实例,那么雅卡尔指数就是 。
要计算雅卡尔距离,我们直接用 1 减去雅卡尔指数即可:
不足
雅卡尔指数的一个主要的缺点是受数据量大小影响严重。大数据集可以对这一指数有很大影响,因为它可以在明显增大并集的同时,保持交集基本不变。
适用情景
雅卡尔指数经常用于数据是二进制或者二值化的情形。当你有一个用于图像分割的深度学习模型(例如分割汽车),利用真实可信的标注,雅卡尔系数就可以被用于计算分割的精度。
类似地,在文档相似性分析中,它可以计量文档之间有多少单词的选择是重合的。因此,它可以用于模式集合的比较。
8. 半正矢距离(Haversine)
半正矢距离指根据球面上两点的经纬度计算出的距离。它计算的是两点的最短路径长度,这一点和欧氏距离很相似。主要的区别是两点在球面上,不可能有直线路径。
不足
这种距离度量的其中一个不足是它假设两点都在球面上。实际上很少有这种情况,比如地球就不是完美的球体,这就让一些情形下的计算变得十分困难。作为代替,你可以看看 Vincenty 距离,它假设的载体是椭球面而不是球面。
适用范围
你可能已经意识到了,半正矢距离经常被用于导航。例如,你可以用它计算两国之间的航班飞行距离。注意,如果两点本身的距离并不远,半正矢距离就不是很合适了。路径的弯曲将不会有很大的影响。
9. Sørensen-Dice 指数
Sørensen-Dice 指数和雅卡尔系数很相似,它也可以衡量采样集合之间的相似性和差异性。即使他们的计算方式很相似,Sørensen-Dice 指数也要比雅卡尔系数更符合直觉一些,因为它可以被视为两个集合重合的比率,数值在 0 到 1 之间:
不足
类似于雅卡尔指数,它们都过分强调了那些只包含很少真值或者没有真值的集合的重要性。结果就是这种集合会主导多个集合的平均分数。这种度量方式为集合赋予的权重与集合的大小成反比,而不是将权重均等划分。
适用情景
Sørensen-Dice 指数的适用情景和雅卡尔指数非常类似。它通常用于图像分割任务或者文本相似性分析。
注意:距离度量的种类远比上面提到的 9 种要多。如果你想了解更多有趣的度量方式,我建议你在下面这些度量方式中选一个调查一下:马氏距离(Mahalanobis)、堪培拉距离(Canberra)、Bray-Curtis 距离和相对熵(KL-divergence)。
如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。
掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 Android、iOS、前端、后端、区块链、产品、设计、人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划、官方微博、知乎专栏。