# 34 | 向量空间模型:如何让计算机理解现实事物之间的关系? 你好,我是黄申。 之前我们讲过如何让计算机理解现实世界中的事物,方法是把事物的各种特性转为机器所能理解的数据字段。而这些数据字段,在机器学习里通常被称为特征。有了特征,我们不仅可以刻画事物本身,还能刻画不同事物之间的关系。 上一个模块我们只是了解了监督式学习,重点考察了特征和分类标签之间的关系。但是在信息检索和非监督式学习中,我们更关注的是不同事物之间的相似程度。这就需要用到线性代数中的向量空间模型了。 提到向量空间模型,你可能对其中的概念有点陌生,所以我会从向量空间的基本概念开始说起,讲到向量空间模型的相关知识,最后再讲讲它是如何应用在不同的编程中的。 ## 什么是向量空间? 上一节,我讲到了向量和向量空间的一些基本概念。为了帮助你更好地理解向量空间模型,我这里给出向量和向量空间的严格定义。 首先假设有一个数的集合$F$,它满足“$F$中任意两个数的加减乘除法(除数不为零)的结果仍然在这个$F$中”,我们就可以称$F$为一个“域”。我们处理的数据通常都是实数,所以这里我只考虑实数域。而如果域$F$里的元素都为实数,那么$F$就是实数域。 如果$x\_{1},x\_{2},……,x\_{n}∈F$,那么$F$上的$n$维向量就是: ![](https://static001.geekbang.org/resource/image/d9/8b/d93900b041abe4a77690635691662e8b.png?wh=164*374) 或者写成转置的形式: ![](https://static001.geekbang.org/resource/image/96/db/961ed40b59d1c2664d688a9b10ab96db.png?wh=506*122) 向量中第$i$个元素,也称为第$i$个分量。$F\_{n}$是由$F$上所有$n$维向量构成的集合。 我们已经介绍过向量之间的加法,以及标量和向量的乘法。这里我们使用这两个操作来定义向量空间。 假设$V$是$F\_{n}$的非零子集,如果对任意的向量$x$、向量$y∈V$,都有$(x+y)∈V$,我们称为$V$对向量的加法封闭;对任意的标量$k∈V$,向量$x∈V$,都有$kx$属于$V$,我们称$V$对标量与向量的乘法封闭。 如果$V$满足向量的加法和乘法封闭性,我们就称$V$是$F$上的向量空间。向量空间除了满足这两个封闭性,还满足基本运算法则,比如交换律、结合律、分配律等等。这里介绍的定义和法则有点多,不过你可以不用都死记硬背下来。只要用的时候,知道有这些东西就可以了。 ## 向量空间的几个重要概念 有了刚才的铺垫,接下来我们来看几个重要的概念:向量的长度、向量之间的距离和夹角。 ### 向量之间的距离 有了向量空间,我们就可以定义向量之间的各种距离。我们之前说过,可以把一个向量想象为n维空间中的一个点。而向量空间中两个向量的距离,就是这两个向量所对应的点之间的距离。距离通常都是大于0的,这里我介绍几种常用的距离,包括曼哈顿距离、欧氏距离、切比雪夫距离和闵可夫斯基距离。 * **曼哈顿距离**(Manhattan Distance) 这个距离度量的名字由来非常有趣。你可以想象一下,在美国人口稠密的曼哈顿地区,从一个十字路口开车到另外一个十字路口,驾驶距离是多少呢?当然不是两点之间的直线距离,因为你无法穿越挡在其中的高楼大厦。你只能驾车绕过这些建筑物,实际的驾驶距离就叫作曼哈顿距离。由于这些建筑物的排列都是规整划一的,形成了一个个的街区,所以我们也可以形象地称它为“城市街区”距离。我这里画了张图方便你理解这种距离。 ![](https://static001.geekbang.org/resource/image/3c/f2/3c07f6da33999ebc41e53be90ba35af2.png?wh=240*226) 从图中可以看出,从A点到B点有多条路径,但是无论哪条,曼哈顿距离都是一样的。 在二维空间中,两个点(实际上就是二维向量)$x(x\_{1},x\_{2})$与$y(y\_{1},y\_{2})$间的曼哈顿距离是: ![](https://static001.geekbang.org/resource/image/9b/c0/9bb6b5eb558d5582456d19be80b300c0.png?wh=562*90) 推广到$n$维空间,曼哈顿距离的计算公式为: ![](https://static001.geekbang.org/resource/image/f8/e9/f81a89126f0a8adb7bb578fef17409e9.png?wh=426*124) 其中$n$表示向量维度,$x\_{i}$表示第一个向量的第$i$维元素的值,$y\_{i}$表示第二个向量的第$i$维元素的值。 * **欧氏距离**(Euclidean Distance) 欧氏距离,其实就是欧几里得距离。欧氏距离是一个常用的距离定义,指在n维空间中两个点之间的真实距离,在二维空间中,两个点$x(x\_{1},x\_{2})$与$y(y\_{1},y\_{2})$间的欧氏距离是: ![](https://static001.geekbang.org/resource/image/51/29/5182e68ae521212464a0c8a1dd26d829.png?wh=658*128) 推广到n维空间,欧氏距离的计算公式为: ![](https://static001.geekbang.org/resource/image/3b/2b/3b4b64fec423d02bb6b511ee37c4412b.png?wh=494*184) * **切比雪夫距离**(Chebyshev Distance) 切比雪夫其实是在模拟国际象棋里国王的走法。国王可以走临近8个格子里的任何一个,那么国王从格子$(x\_{1},x\_{2})$走到格子$(y\_{1},y\_{2})$最少需要多少步呢?其实就是二维空间里的切比雪夫距离。 一开始,为了走尽量少的步数,国王走的一定是斜线,所以横轴和纵轴方向都会减1,直到国王的位置和目标位置在某个轴上没有差距,这个时候就改为沿另一个轴每次减1。所以,国王走的最少格子数是$|x\_{1}-y\_{1}|$和$|x\_{2}-y\_{2}|$这两者的较大者。所以,在二维空间中,两个点$x(x\_{1},x\_{2})$与$y(y\_{1},y\_{2})$间的切比雪夫距离是: ![](https://static001.geekbang.org/resource/image/19/85/196f8f04a75ad0c48f0f425a6e13aa85.png?wh=654*104) 推广到n维空间,切比雪夫距离的计算公式为: ![](https://static001.geekbang.org/resource/image/ba/f6/ba2ddcb9a07dfe8bff595abf1fa68bf6.png?wh=518*120) 上述三种距离,都可以用一种通用的形式表示,那就是闵可夫斯基距离,也叫闵氏距离。在二维空间中,两个点$x(x\_{1},x\_{2})$与$y(y\_{1},y\_{2})$间的闵氏距离是: ![](https://static001.geekbang.org/resource/image/0f/db/0fdcaa63c585cb2b530f03e69dcab1db.png?wh=682*120) 两个$n$维变量$x(x\_{1},x\_{2},…,x\_{n})$与$y(y\_{1},y\_{2},…,y\_{n})$间的闵氏距离的定义为: ![](https://static001.geekbang.org/resource/image/6f/8f/6f201ca2a097b7763ae4bfbf545e9c8f.png?wh=528*172) 其中$p$是一个变参数,尝试不同的p取值,你就会发现: * 当$p=1$时,就是曼哈顿距离; * 当$p=2$时,就是欧氏距离; * 当$p$趋近于无穷大的时候,就是切比雪夫距离。这是因为当$p$趋近于无穷大的时候,最大的$|x\_{i}-y\_{i}|$会占到全部的权重。 距离可以描述不同向量在向量空间中的差异,所以可以用于描述向量所代表的事物之差异(或相似)程度。 ### 向量的长度 有了向量距离的定义,向量的长度就很容易理解了。向量的长度,也叫向量的模,是向量所对应的点到空间原点的距离。通常我们使用欧氏距离来表示向量的长度。 当然,我们也可以使用其他类型的距离。说到这里,我也提一下“范数”的概念。范数满足非负性、齐次性、和三角不等式。你可以不用深究这三点的含义,不过你需要知道范数常常被用来衡量某个向量空间中向量的大小或者长度。 $L\_{1}$范数$||x||$ ,它是为$x$向量各个元素绝对值之和,对应于向量$x$和原点之间的曼哈顿距离。 $L\_{2}$范数$||x||\_{2}$ ,它是$x$向量各个元素平方和的$\\frac{1}{2}$次方,对应于向量$x$和原点之间的欧氏距离。 $L\_{p}$范数$||x||\_{p}$ ,为$x$向量各个元素绝对值$p$次方和的1/p次方,对应于向量$x$和原点之间的闵氏距离。 $L\_{∞}$范数$||x||\_{∞}$ ,为$x$向量各个元素绝对值最大那个元素的绝对值,对应于向量$x$和原点之间的切比雪夫距离。 所以,在讨论向量的长度时,我们需要弄清楚是L几范数。 ### 向量之间的夹角 在理解了向量间的距离和向量的长度之后,我们就可以引出向量夹角的余弦,它计算了空间中两个向量所形成夹角的余弦值,具体的计算公式我列在了下面: ![](https://static001.geekbang.org/resource/image/47/58/47a3eb754bc98caab86dc554b4cf7558.png?wh=488*234) 从公式可以看出,分子是两个向量的点乘,而分母是两者长度(或L2范数)的乘积,而L2范数可以使用向量点乘自身的转置来实现。夹角余弦的取值范围在\[-1,1\],当两个向量的方向重合时夹角余弦取最大值1,当两个向量的方向完全相反夹角余弦取最小值-1。值越大,说明夹角越小,两点相距就越近;值越小,说明夹角越大,两点相距就越远。 ## 向量空间模型 理解了向量间距离和夹角余弦这两个概念,你再来看**向量空间模型**(Vector Space Model)就不难了。 向量空间模型假设所有的对象都可以转化为向量,然后使用向量间的距离(通常是欧氏距离)或者是向量间的夹角余弦来表示两个对象之间的相似程度。我使用下图来展示空间中向量之间的距离和夹角。 ![](https://static001.geekbang.org/resource/image/2b/ec/2b2fb28b3bfb8fc43831469f537068ec.png?wh=1044*898) 由于夹角余弦的取值范围已经在-1到1之间,而且越大表示越相似,所以可以直接作为相似度的取值。相对于夹角余弦,欧氏距离ED的取值范围可能很大,而且和相似度呈现反比关系,所以通常要进行1/(ED+1)这种归一化。 当ED为0的时候,变化后的值就是1,表示相似度为1,完全相同。当ED趋向于无穷大的时候,变化后的值就是0,表示相似度为0,完全不同。所以,这个变化后的值,取值范围是0到1之间,而且和相似度呈现正比关系。 早在上世纪的70年代,人们把向量空间模型运用于信息检索领域。由于向量空间可以很形象地表示数据点之间的相似程度,因此现在我们也常常把这个模型运用在基于相似度的一些机器学习算法中,例如K近邻(KNN)分类、K均值(K-Means)聚类等等。 ## 总结 为了让计算机理解现实世界中的事物,我们会把事物的特点转换成为数据,并使用多维度的特征来表示某个具体的对象。多个维度的特征很容易构成向量,因此我们就可以充分利用向量和向量空间,来刻画事物以及它们之间的关系。 我们可以在向量空间中定义多种类型的向量长度和向量间距离,用于衡量向量之间的差异或者说相似程度。此外,夹角余弦也是常用的相似度衡量指标。和距离相比,夹角余弦的取值已经控制在\[-1, 1\]的范围内,不会因为异常点所产生的过大距离而受到干扰。 向量空间模型充分利用了空间中向量的距离和夹角特性,来描述文档和查询之间的相似程度,或者说相关性。虽然向量空间模型来自信息检索领域,但是也被广泛运用在机器学习领域中。在接下来的文章里,我会结合具体的案例,分别来说说如何在这些领域使用向量空间模型。 ## 思考题 假设在三维空间中有两个点,它们的坐标分别是(3, -1, 8)和(-2, 3, -6),请计算这两个点之间的欧氏距离和夹角余弦。 欢迎留言和我分享,也欢迎你在留言区写下今天的学习笔记。你可以点击“请朋友读”,把今天的内容分享给你的好友,和他一起精进。