Manifold Learning详解
第四十四次写博客,本人数学基础不是太好,如果有幸能得到读者指正,感激不尽,希望能借此机会向大家学习。本文承接上一篇《Low-dimension Embedding详解(附带MDS算法)》,继续介绍某些降维手段。
Manifold Learning(流行学习)
在《Low-dimension Embedding》这篇文章中,我们介绍了一种称为MDS的降维方法,这种方法需要的输入是原始样本空间的距离矩阵,矩阵中的每个元素代表空间中两点之间的距离,在距离矩阵未知而且欧氏距离在原始空间中无效时,就需要一种新的度量距离的方法。“流行学习”(Manifold Learning)是一种借鉴了拓扑流行概念的降维方法,“流行”是指在“局部”与欧式空间同胚的空间,换言之,他在局部有欧式空间的性质,能用欧式距离来进行距离计算。下面分别介绍两种基于流行学习的降维方法:ISOmap和LLE,他们都使用了“邻域”的概念,但是原理不同。
Isometric Mapping(等度量映射)
等度量映射(Isometric Mapping,简称ISOmap)认为,将低维空间嵌入到高维空间后,在高维空间中直接使用直线(欧式)距离来代表本真距离会有误差,因为高维空间中的两个样本点之间的直线距离在低维空间中是“不可达的”。如下图所示,图1(a)中的3000个样本点是从图1(b)所示的二维矩形区域(“本真”空间)采样后并以S形曲面嵌入到三维空间中的。图1(a)中的红线被称为“测地线”(geodesic),是高维空间中两个样本点之间的“本真”(Intrinsic)距离,而黑线代表的是这两个点的直线距离,显然这两条线代表的距离并不一致。图1(b)中的红线则是低维空间中两个点的本真距离,黑线是这两点通过近邻点之间的直线连接起来的距离,因此这条黑线可以直接通过欧式距离来计算,可以看出这两条线代表的距离比较相似,ISOmap正是利用了流行在局部上与欧式空间同胚这个性质,来计算样本空间中两个样本点之间的本真距离,因此我们可以认为ISOmap的目标是保持近邻样本间的本真距离。
在使用上述方法计算距离之前,需要对近邻连接图进行初始化,这里提供两种初始化的方法,一种是指定近邻点的个数,例如选择欧氏距离最近的 k k k个点作为近邻点,这种方法构造出来的图称为“ k k k个近邻图”,另外一种方法是指定距离阈值 ε \varepsilon ε,所有距离小于 ε \varepsilon ε的点被认为是近邻点,这种方法构造出来的图称为“ ε \varepsilon ε近邻图”。不过,无论使用上述哪种方法都会面临如下的问题,如果 k k k或 ε \varepsilon ε指定的比较小时,图中两个点之间可能并不存在一条连通的曲线,这被称为“断路”,反之 k k k或 ε \varepsilon ε指定的比较大,则有可能使得距离较远的两个点成为近邻,这被称为“短路”。
在得到近邻图后,计算图上两点之间的最短距离可以采用Dijkstra算法或Floyd算法,在得到任意两点之间的距离后,就可以根据之前介绍过的MDS方法得到这些点在降维后的低维空间中对应的坐标了,ISOmap算法伪代码如下图所示。
“在得到训练样本在低维空间中的投影后,如何将新读入的样本点也投影到这个空间中呢?”在MDS算法中会面临这么一个问题,解决方法是根据这些训练样本在高维空间中的表示和低维空间中的投影,训练出一个回归模型来对新加入的样本点进行低维投影。
Locally Linear Embedding(局部线性嵌入)
局部线性嵌入(Locally Linear Embedding,简称LLE)认为假如样本点可以通过他邻域内的近邻样本点的线性组合表示出来,即
(1) x i = w i j x j + w i k x k + w i l x l { {\bf{x}}_{i}}=w_{ij}{\bf{x}}_{j}+w_{ik}{\bf{x}}_{k}+w_{il}{\bf{x}}_{l} \tag{1} xi=wijxj+wikxk+wilxl(1)
那么这种线性关系仍然会在降维后的低维空间中得到保持,因此可以认为LLE的目标是保持近邻样本间的线性关系,下面对该算法进行详细推导。
对于样本点 x i {\bf{x}}_{i} xi,LLE首先找到其近邻点的下标集合 Q i Q_{i} Qi,然后基于 Q i Q_{i} Qi中的样本点计算式(1)中的线性组合系数 w i ⋅ w_{i\cdot} wi⋅,该步骤的目标函数可以表示为
(2) min w 1