LDA(线性判别分析)基本原理
LDA思想
LDA是监督学习的降维、分类技术,可以用一句话概括思想:投影后类内方差最小,类间方差最大。
如下图所示,给定数据样例集,设法将样例投影到直线上,使得同类样例投影点尽可能近、异类样例的投影点尽可能远离:
下图的两种投影方式,那一种满足我们的标准?
右图,原因是投影后,蓝色和红色数据各自较为集中,且类别之间的距离明显。(左图在边界处数据混杂
LDA如何用来分类?
在对新的样本进行分类时,将其投影到同样的投影线上,再根据投影点的位置来确定样本的类别。
LDA原理及流程
对于具体数据的实例
目标:求解投影向量 ,二维情况下,
,shape:(2,m)表示样本矩阵,即2个维度,m个样本。每一列表示一个样本,每一行表示该样本在这一维度上的取值。例如:中的第一列表示第一个样本在第一个维度上的取值,在第二个维度上的取值为,以此类推。
对第个样本:
图中的y可计算,对于样本在投影向量上的投影结果的值为:,可以理解为这条过原点直线的单位方向向量,为的夹角。
给定两个类别:
X1 : shape:(m,2)一般将样本按行排列,每列表示维度,可以理解为的转置,表示m个样本,2两个维度,图中每个点表示
X2 : 描述同X1
均值向量: shape:(2,1) 将m个样本取每个维度的均值,按列排列,得到均值均值向量
协方差矩阵: shape:(2,2) (维度x维度)
样本中心在直线上的投影 :shape:(1,2)x(2,1)= (1,1)常量
同类样本投影点的协方差::shape:(1,2)x(2,2)x(2,1) = (1,1)常量 ,表示将同类样本投影后,两个维度的协方差。
对于n维情况,由于我们是多维向低维投影,则此时投影到的低维空间就不是一条直线,而是一个超平面了。假设我们投影到的低维空间的维度为d,对应的基向量为,基向量组成的矩阵为
此时同类样本投影点的协方差 shape: (d,n)x(n,n)x(n,d)=(d,d) ,表示投影后dxd的协方差矩阵。
算法流程总结
输入:数据集,,其中任意样本为n维向量,为样本对应的标签,降维到的维度d。
输出:降维后的样本集
1) 计算类内散度矩阵
2) 计算类间散度矩阵
3) 计算矩阵
4) 计算的最大的个特征值对应的个特征向量,得到投影矩阵
5) 对样本集中的每一个样本特征,转换为新的样本
6) 得到输出样本集
实际上LDA除了可以用于降维以外,还可以用于分类。一个常见的LDA分类基本思想是假设各个类别的样本数据符合高斯分布,这样利用LDA进行投影后,可以利用极大似然估计计算各个类别投影数据的均值和方差,进而得到该类别高斯分布的概率密度函数。当一个新的样本到来后,我们可以将它投影,然后将投影后的样本特征分别带入各个类别的高斯分布概率密度函数,计算它属于这个类别的概率,最大的概率对应的类别即为预测类别。
PCA、LDA区别
相同点:
1)两者均可以对数据进行降维。
2)两者在降维时均使用了矩阵特征分解的思想。
3)两者都假设数据符合高斯分布
不同点
1.LDA是有监督的降维方法,而PCA是无监督的降维方法n
2.LDA降维最多降到类别数k-1的维数,而PCA没有这个限制。
3.LDA除了可以用于降维,还可以用于分类。
4.LDA选择分类性能最好的投影方向,而PCA选择样本点投影具有最大方差的方向。这点可以从下图形象的看出,在某些数据分布下LDA比PCA降维较优。
当然,某些某些数据分布下PCA比LDA降维较优,如下图所示: