相似性和相异性地度量.docx
《相似性和相异性地度量.docx》由会员分享,可在线阅读,更多相关《相似性和相异性地度量.docx(23页珍藏版)》请在冰豆网上搜索。
相似性和相异性地度量
相似性和相异性的度量
相似性和相异性是重要的概念,因为它们被许多数据挖掘技术所使用,如聚类、最近邻分类和异常检测等。
在许多情况下,一旦计算出相似性或相异性,就不再需要原始数据了。
这种方法可以看作将数据变换到相似性(相异性)空间,然后进行分析。
首先,我们讨论基本要素--相似性和相异性的高层定义,并讨论它们之间的联系。
为方便起见,我们使用术语邻近度(proximity)表示相似性或相异性。
由于两个对象之间的邻近度是两个对象对应属性之间的邻近度的函数,因此我们首先介绍如何度量仅包含一个简单属性的对象之间的邻近度,然后考虑具有多个属性的对象的邻近度度量。
这包括相关和欧几里得距离度量,以及Jaccard和余弦相似性度量。
前二者适用于时间序列这样的稠密数据或二维点,后二者适用于像文档这样的稀疏数据。
接下来,我们考虑与邻近度度量相关的若干重要问题。
本节最后简略讨论如何选择正确的邻近度度量。
1)基础
1.定义
两个对象之间的相似度(similarity)的非正式定义是这两个对象相似程度的数值度量。
因而,两个对象越相似,它们的相似度就越高。
通常,相似度是非负的,并常常在0(不相似)和1(完全相似)之间取值
两个对象之间的相异度(dissimilarity)是这两个对象差异程度的数值度量。
对象越类似,它们的相异度就越低。
通常,术语距离(distance)用作相异度的同义词,正如我们将介绍的,距离常常用来表示特定类型的相异度。
有时,相异度在区间[0,1]中取值,但是相异度在0和之间取值也很常见。
2.变换通常使用变换把相似度转换成相异度或相反,或者把邻近度变换到一个特定区间,如[0,1]。
例如,我们可能有相似度,其值域从1到10,但是我们打
算使用的特定算法或软件包只能处理相异度,或只能处理[0,1]区间的相似度。
之所以在这里讨论这些问题,是因为在稍后讨论邻近度时,我们将使用这种变换。
此外,这些问题相对独立于特定的邻近度度量。
通常,邻近度度量(特别是相似度)被定义为或变换到区间[0,1]中的值。
这样做的动机是使用一种适当的尺度,由邻近度的值表明两个对象之间的相似(或相异)程度。
这种变换通常是比较直截了当的。
例如,如果对象之间的相似度在1(一点也不相似)和10(完全相似)之间变化,则我们可以使用如下变换将它变换到[0,1]区间:
s'=(s-1)/9,其中s和s'分别是相似度的原值和新值。
一般来说,相似度到[0,1]区间的变换由如下表达式给出:
s'=(s-min_s)/(max_s-min_s),其中max_s和min_s分别是相似度的最大值和最小值。
类似地,具有有限值域的相异度也能用d'=(d-min_d)/(max_d-min_d)映
射到[0,1]区间。
然而,将邻近度映射到[0,1]区间可能非常复杂。
例如,如果邻近度度量原来在区间[01000]上取值,则需要使用非线性变换,并且在新的尺度上,值之间不再具有相同的联系。
对于从0变化到1000的相异度度量,考虑变换d'=
d/(1+d),相异度0、0.5、2、10、100和1000分别被变换到0、0.33、
0.67、0.90、0.99和0.999。
在原来相异性尺度上较大的值被压缩到1附近,
但是否希望如此则取决于应用。
另一个问题是邻近度度量的含义可能会被改
变。
例如,相关性(稍后讨论)是一种相似性度量,在区间[-1,1]上取值,通过取绝对值将这些值映射到[0,1]区间丢失了符号信息,而对于某些应用,符号信息可能是重要的。
将相似度变换成相异度或相反也是比较直截了当的,尽管我们可能再次面临保持度量的含义问题和将线性尺度改变成非线性尺度的问题。
如果相似度
(相异度)落在[0,1]区间,则相异度(相似度)可以定义为d=1-s(或s=
1-d)。
另一种简单的方法是定义相似度为负的相异度(或相反)。
例如,相异度0,1,10和100可以分别变换成相似度0,-1,-10和-100。
负变换产生的相似度结果不必局限于[0,1]区间,但是,如果希望的话,则可以使用变换
七f.d-mmd
j=e_馬£二]-二
s=1/(d+1),…-■-O对于变换s=1/(d+1),
相异度0,1,10,100分别被变换到1,0.5,0.09,0.01;对于2厂,它们分别
td~mind
1——=
被变换到1.00,0.37,0.00,0.00;对于s二明公二-俱询一盘,它们分别被
变换到1.00,0.99,0.00,0.00。
在这里的讨论中,我们关注将相异度变换到相似度。
一般来说,任何单调减函数都可以用来将相异度转换到相似度(或相反)。
当然,在将相似度变换到相异度(或相反),或者在将邻近度的值变换到新的尺度时,也必须考虑一些其他因素。
我们提到过一些问题,涉及保持意义、扰乱标度和数据分析工具的需要,但是肯定还有其他问题。
2)简单属性之间的相似度和相异度
通常,具有若干属性的对象之间的邻近度用单个属性的邻近度的组合来定
义,因此我们首先讨论具有单个属性的对象之间的邻近度。
考虑由一个标称属性描述的对象,对于两个这样的对象,相似意味什么呢?
由于标称属性只携带了对象的相异性信息,因此我们只能说两个对象有相同的值,或者没有。
因而在这种情况下,如果属性值匹配,则相似度定义为1,否则为0;相异度用相
反的方法定义:
如果属性值匹配,相异度为0,否则为1。
对于具有单个序数属性的对象,情况更为复杂,因为必须考虑序信息。
考
虑一个在标度{poor,fair,OK,good,wonderful}上测量产品(例如,糖块)质
量的属性。
一个评定为wonderful的产品P1与一个评定为good的产品P2应当比它与一个评定为0K的产品P3更接近。
为了量化这种观察,序数属性
good=3,wonderful=4}。
于是,P1与P2之间的相异度d(P1,P2)=3-2=1,或者,如果我们希望相异度在0和1之间取值,d(P1,P2)=(3-2)/4=0.25;序数属性的相似度可以定义为s=1-d。
序数属性相似度(相异度)的这种定义可能使读者感到有点担心,因为这里我们定义了相等的区间,而事实并非如此。
如果根据实际情况,我们应该计算出区间或比率属性。
值fair与good的差真和OK与wonderful的差相同吗?
可能不相同,但是在实践中,我们的选择是有限的,并且在缺乏更多信息的情况下,这是定义序数属性之间邻近度的标准方法。
对于区间或比率属性,两个对象之间的相异性的自然度量是它们的值之差的绝对值。
例如,我们可能将现在的体重与一年前的体重相比较,说"我重了10磅。
"在这类情况下,相异度通常在0和x之间,而不是在0和1之间取值。
如前所述,区间或比率属性的相似度通常转换成相异度。
表2-7总结了这些讨论。
在该表中,x和y是两个对象,它们具有一个指明类型的属性,d(x,y)和s(x,y)分别是x和y之间的相异度和相似度(分别用d和s表示)。
其他方法也是可能的,但是表中的这些是最常用的。
表2-7简单属性的相似度和相异度
屢性粪型,
:
湘异鹿“
相似蔚j
5如枭弋门
1勿臬1丰j
S三1如果"JQ
0如臬X"
锄的鼻
⑴映射魏墩0到Jt-1康中如
是價的吓數)2
2[-曲
ElW
J1Y
s—9二=95=e-r=J=■-
l+amad-mih#
T—■
下面两节介绍更复杂的涉及多个属性的对象之间的邻近性度量:
(1)数据对
象之间的相异度;
(2)数据对象之间的相似度。
这样分节可以更自然地展示使用各种邻近度度量的基本动机。
然而,我们要强调的是使用上述技术,相似度可以变换成相异度,反之亦然。
3)数据对象之间的相异度
本节,我们讨论各种不同类型的相异度。
我们从讨论距离(距离是具有特
定性质的相异度)开始,然后给出一些更一般的相异度类型的例子。
距离
我们首先给出一些例子,然后使用距离的常见性质更正式地介绍距离。
一维、二维、三维或高维空间中两个点x和y之间的欧几里得距离(Euclideandistanee)d由如下熟悉的公式定义:
cu1S*«
其中,n是维数,而xk和yk分别是x和y的第k个属性值(分量)。
我们用
图2-15、表2-8和表2-9解释该公式,它们展示了这个点集、这些点的x和y
坐标以及包含这些点之间距离的距离矩阵(distaneematrix)。
€
pk
p沖
pk
0肿
2巴
ph
(V
ph
丄肘
0.C-
L畀
3J
1p
pl*
L4
3门
4^
阴卫
i.W
3加
^2-8ES卒戌却*和)坐掾
表吕§表2胡却舷几里缩卑蔭矩莊丿
公式(2-1)给出的欧几里得距离可以用公式(2-2)的闵可夫斯基距离
(Minkowskidistanee)来推广:
廻y)=£|兀-”|乂上母
\£—1丿
其中r是参数。
下面是闵可夫斯基距离的三个最常见的例子r=1,城市街区(也称曼哈顿、出租车、L1范数)距离。
一个常见的例子是汉明距离(Hammingdistanee),它是两个具有二元属性的对象(即两个二元向量)之间不同的二进制位个数。
r=2,欧几里得距离(L2范数)。
r=•,上确界(Lmax或L范数)距离。
这是对象属性之间的最大距离。
更
正式地,L距离由公式(2-3)定义:
注意不要将参数r与维数(属性数)n混淆。
欧几里得距离、曼哈顿距离
和上确界距离是对n的所有值(1,2,3,...)定义的,并且指定了将每个维(属性)上的差的组合成总距离的不同方法。
表2-10和表2-11分别给出表2-8数据的L1距离和L距离的邻近度矩
阵。
注意,所有的距离矩阵都是对称的,即第ij个表目与第ji个表目相同,例
如,在表2-9中,第4行第1列和第1行第4列都包含值5.1。
^2-1012-3fillOS阵表2-卄
pl*3
3
pl*3
p抄
F如
pl*3
4加
咖
ph
伽
23
53
ph
43
Q
P妇
畑
2肿
ZQP
:
诃
I.Op
0.(>.
2.0-
皿
0.0*
5.0*
:
與
C.0-'
距离(如欧几里得距离)具有一些众所周知的性质。
如果d(x,y)是两个点x和y之间的距离,则如下性质成立。
⑴非负性。
(a)对于所有x和y,d(x,y)M),(b)仅当x=y时d(x,y)=0。
(2)对称性。
对于所有x和y,d(x,y)=d(y,x)。
(3)三角不等式。
对于所有x,y和z,d(x,z)满足以上三个性质的测度称为度量(metric)。
有些人只对满足这三个性质的相异性度量使用术语距离,但在实践中常常违反这一约定。
这里介绍的三个性质是有用的,数学上也是令人满意的。
此外,如果三角不等式成立,则该性质可以用来提高依赖于距离的技术(包括聚类)的效率。
尽管如此,许多相异度都不满足一个或多个度量性质。
下面我们给出两个这种测度的例子。
例1非度量的相异度:
集合差。
基于集合论中定义的两个集合差的概念举例。
设有两个集合A和B,A-B是不在B中的A中元素的集合。
例如,如果A={1,2,3,4},而B={2,3,4},则A-B={1},而B-A=空集。
我们可以将两个集合A和B之间的距离定义为d(A,B)=size(A-B),其中size是一个函数,它返回集合元素的个数。
该距离测度是大于或等于零的整数值,但不满足非负性的第二部分,也不满足对称性,同时还不满足三角不等式。
然而,如果将相异度修改为d(A,B)=size(A-B)+size(B-A),则这些性质都可以成立。
例2非度量的相异度:
时间。
这里给出一个更常见的例子,其中相异性测
度并非度量,但依然是有用的。
定义时间之间的距离测度如下:
义的,例如,在回答如下问题时就体现了这种定义的意义:
"如果一个事件在每
天下午1点发生,现在是下午2点,那么我们还需要等待多长时间才能等到该事件再度发生?
"
4)数据对象之间的相似度
对于相似度,三角不等式(或类似的性质)通常不成立,但是对称性和非负性通常成立。
更明确地说,如果s(x,y)是数据点x和y之间的相似度,则相似度具有如下典型性质。
(1)仅当x=y时s(x,y)=1。
(0
⑵对于所有x和y,s(x,y)=s(y,x)。
(对称性)
对于相似度,没有与三角不等式对应的一般性质。
然而,有时可以将相似
度简单地变换成一种度量距离。
稍后讨论的余弦相似性度量和Jaccard相似性度量就是两个例子。
此外,对于特定的相似性度量,还可能在两个对象相似性上导出本质上与三角不等式类似的数学约束。
例3非对称相似性度量。
考虑一个实验,实验中要求人们对屏幕上快速闪过的一小组字符进行分类。
该实验的混淆矩阵(confusionmatrix)记录每个字符被分类为自己的次数和被分类为另一个字符的次数。
例如,假定"0"出现了200次,它被分类为"0"160次,而被分类为"o"40次。
类似地,"o"出现200次并且分类为"o"170次,但是分类为"0"只有30次。
如果取这些计数作为两个字符之间相似性的度量,则得到一种相似性度量,但这种相似性度量不是对称的。
在这种情况下,通过选取s'(x,y)=s'(y,x)=(s(x,y)+s(y,x))/2,相似性度量可以转换成对称的,其中s'是新的相似性度量。
5)邻近性度量的例子
本节给出一些相似性和相异性度量的具体例子。
1.二元数据的相似性度量
两个仅包含二元属性的对象之间的相似性度量也称为相似系数(similaritycoefficient),并且通常在0和1之间取值,值为1表明两个对象完全相似,
而值为0表明对象一点也不相似。
有许多理由表明在特定情形下,一种系数为何比另一种好。
设x和y是两个对象,都由n个二元属性组成。
这样的两个对象(即两个
二元向量)的比较可生成如下四个量(频率):
f00=x取0并且y取0的属性个数
f01=x取0并且y取1的属性个数
f10=x取1并且y取0的属性个数
f11=x取1并且y取1的属性个数
简单匹配系数(SimpleMatchingCoefficient,SMC),一种常用的相似性
系数是简单匹配系数,定义如下:
瞰卫宏肄性个机加/io51CTIUw|
属性彳喷人—
该度量对出现和不出现都进行计数。
因此,SMC可以在一个仅包含是非题的测验中用来发现回答问题相似的学生。
Jaccard系数(JaccardCoefficient)假定x和y是两个数据对象,代
表一个事务矩阵的两行(两个事务)。
如果每个非对称的二元属性对应于商店
的一种商品,则1表示该商品被购买,而0表示该商品未被购买。
由于未被顾客购买的商品数远大于被其购买的商品数,因而像SMC这样的相似性度量将
会判定所有的事务都是类似的。
这样,常常使用Jaccard系数来处理仅包含非对称的二元属性的对象。
Jaccard系数通常用符号J表示,由如下等式定义:
r匹配的个数fn
J——■4-
51CT(L^^II
不涉及0-0匹配的属性个数办-h-f.
■fife术想
例4SMC和Jaccard相似性系数。
为了解释这两种相似性度量之间的差别,
我们对如下二元向量计算SMC和J:
x=(1,0,0,0,0,0,0,0,0,0)
y=(0,0,0,0,0,0,1,0,0,1)
fO1=2x取0并且y取1的属性个数
f10=1x取1并且y取0的属性个数
f00=7x取0并且y取0的属性个数
f11=0x取1并且y取1的属性个数
SMC=£丄十张=°=07+J
亠2-1一'
J=fno0
f.c+/ii2亠】一°找术虛就霁想
2.余弦相似度
通常,文档用向量表示,向量的每个属性代表一个特定的词(术语)在文档中出现的频率。
当然,实际情况要复杂得多,因为需要忽略常用词,并使用各种技术处理同一个词的不同形式、不同的文档长度以及不同的词频。
尽管文档具有数以百千计或数以万计的属性(词),但是每个文档向量都是稀疏的,因为它具有相对较少的非零属性值。
(文档规范化并不对零词目创建非零词目,即文档规范化保持稀疏性。
)这样,与事务数据一样,相似性不能依赖共享0的个数,因为任意两个文档多半都不会包含许多相同的词,从而如果统计0-0匹配,则大多数文档都与其他大部分文档非常类似。
因此,文档的相似性度量不仅应当像Jaccard度量一样需要忽略0-0匹配,而且还必须能够处理非二元向量。
下面定义的余弦相似度(cosinesimilarity)就是文档相
似性最常用的度量之一。
如果x和y是两个文档向量,则
XV
cos(x.V)=!
——
II刑yII芬
水成
其中,"."表示向量点积,即:
心丫二工:
兀加工是冋董玉的长度.X二J工[一£二
。
例5两个文档向量的余弦相似度。
该例计算下面两个数据对象的余弦相似度,这些数据对象可能代表文档向量:
y二卩卫丄do卜
y—(1*0«OiQ0i0i0*LC'-2y
拭l+2xQ+Qx卜莎0+肿Q+0M+駆0+2冥l+QxQ+0x2二知I.
II=VJx3-2x2-0:
^0-5^-D>:
0-u>:
0-0x0-2x2-0x0-0>.0-648.
y=i/1>I-OxD-OxO-OxO-OxO-OxO*OkO*1x1^O*O*2>2=2.45
cos(i.y(=031
如图2-16所示,余弦相似度实际上是x和y之间夹角(余弦)的度量。
这样,如果余弦相似度为1,则x和y之间夹角为0,并且除大小(长度)之外,x和y是相同的;如果余弦相似度为0,则x和y之间夹角为90,并且它
们不包含任何相同的词(术语)
图2-16余弦度量的几何解释
公式(2-7)可以写成公式(2-8)的形式:
其中,=x/IIx||,而=y/||yII。
x和y被它们的长度除,将它们规范化成具有长度1。
这意味在计算相似度时,余弦相似度不考虑两个数据对象的量值。
(当量值是重要的时,欧几里得距离可能是一种更好的选择。
)对于长度
为1的向量,余弦度量可以通过简单地取点积计算。
从而,在需要计算大量对
象之间的余弦相似度时,将对象规范化,使之具有单位长度可以减少计算时
间。
3.广义Jaccard系数(Tanimoto系数)
广义Jaccard系数可以用于文档数据,并在二元属性情况下归约为
Jaccard系数。
广义Jaccard系数又称Tanimoto系数。
(然而,还有一种系
数也称Tanimoto系数。
)该系数用EJ表示,由下式定义:
4.相关性
两个具有二元变量或连续变量的数据对象之间的相关性是对象属性之间线性联系的度量。
(更一般属性之间的相关性计算可以类似地定义。
)更准确地,两个数据对象x和y之间的皮尔森相关(Pearson'scorrelation)系数
由下式定义:
CDITIX.V)=2如曲*打=—
xo&tandard_deviation'y
这里我们使用标准的统计学记号和定义:
coxaiisiicefx.y)-s?
.=
-nib:
-y)
IViUUl
成就.彗
乙挣急的均直
脅是曲均银
例6完全相关。
相关度总是在-1到1之间取值。
相关度为1(-1)意味x和y具有完全正(负)线性关系,即Xk=aYk+b,其中a和b是常数。
下面两个x和y的值集分别给出相关度为-1和+1的情况。
为简单起见,第一组中取x和y的均值为0。
x=(-3,6,0,3,-6)
y=(1,-2,0,-1,2)
x=(3,6,0,3,6)y=(1,2,0,1,2)
例7非线性关系。
如果相关度为0,则两个数据对象的属性之间不存在线性关
系。
然而,仍然可能存在非线性关系。
在下面的例子中,数据对象的属性之间
存在非线性关系yk=xkA2,但是它们的相关度为0。
x=(3,-2,-1,0,1,2,3)
o
a
0
%o
y=(9,4,1,0,1,4,9)
例8相关性可视化。
通过绘制对应属性值对可以很容易地判定两个数据对象x
和y之间的相关性。
图2-17给出了一些这种图,x和y具有30个属性,这些
属性的值随机地产生(服从正态分布),使得x和y的相关度从-1到1。
图中
每个小圆圈代表30个属性中的一个,其x坐标是x的一个属性的值,而其y
坐标是y的相同属性的值。
图2-17解释相关度从-1到1的散布图
如果通过减去均值,然后规范化使其长度为1来变换x和y,则它们的相关度可以通过求点积来计算。
注意,这与其他情况下使用的标准化不同,在其
=(「”-r)■■'s.
他情况下,我们使用变换和。
Bregman散度。
本节,我们简略介绍Bregman散度(Bregman
divergenee),它是一族具有共同性质的邻近函数。
这样,可以构造使用
Bregman发散函数的一般数据挖掘算法,如聚类算法,具体的例子是K均值
聚类算法。
注意,本节需要向量计算方面的知识。
Bregman散度是损失或失真函数。
为了理解损失函数,考虑如下情况:
设
x和y是两个点,其中y是原来的点,而x是它的某个失真或近似,例如,x可能是由于添加了一些随机噪声到y上而产生的。
损失函数的目的是度量用x近
似y导致的失真或损失。
当然,x和y越类似,失真或损失就越小,因而Bregman散度可以用作相异性函数。
有如下正式定义。
定义:
Bregman散度给定一个严格凸函数亠(连同一些通常满足的适度限
制),由该函数生成的Bregman散度(损失函数)D(x,y)通过下面的公式给出: