LDA算法原理及matlab实现

注:本文非笔者原创,原文转载自:http://blog.csdn.net/porly/article/details/8020696


1. LDA是什么

线性判别式分析(Linear Discriminant Analysis),简称为LDA。也称为Fisher线性判别(Fisher Linear Discriminant,FLD),是模式识别的经典算法,在1996年由Belhumeur引入模式识别和人工智能领域。

基本思想是将高维的模式样本投影到最佳鉴别矢量空间,以达到抽取分类信息和压缩特征空间维数的效果,投影后保证模式样本在新的子空间有最大的类间距离最小的类内距离,即模式在该空间中有最佳的可分离性。

LDA与前面介绍过的PCA都是常用的降维技术。PCA主要是从特征的协方差角度,去找到比较好的投影方式LDA更多的是考虑了标注即希望投影后不同类别之间数据点的距离更大,同一类别的数据点更紧凑

下面给出一个例子,说明LDA的目标。

 

       可以看到两个类别,一个绿色类别,一个红色类别。左图是两个类别的原始数据,现在要求将数据从二维降维到一维。直接投影到x1轴或者x2轴,不同类别之间会有重复,导致分类效果下降。右图映射到的直线就是用LDA方法计算得到的,可以看到,红色类别和绿色类别在映射之后之间的距离是最大的,而且每个类别内部点的离散程度是最小的(或者说聚集程度是最大的)。

这里还有一个LDA的例子:

 

下图是一个LDA和PCA区别的例子:

       两个类别,class1的点都是圆圈,class2的点都是十字。图中有两条直线,斜率在1左右的这条直线是PCA选择的映射直线,斜率在 -1左右的这条直线是LDA选择的映射直线。其余不在这两条直线上的点是原始数据点。可以看到由于LDA考虑了“类别”这个信息(即标注),映射后,可以很好的将class1和class2的点区分开。也就是说,LDA是以分类为导向的,考虑的是如何选择投影方向使得分类更好,是有监督的;而PCA是一种无监督的降维方式,它只是单纯的降维,它考虑的是如何选择投影面才能使得降维以后的样本信息保留的最大(而这是通过方差大来体现的)。

2. LDA的一些说明

   第一,降维后的维度是多少?

     PCA降维是直接和数据维度相关的,比如原始数据是n维的,那么PCA后,可以任意选取1维、2维,一直到n维都行(当然是对应特征值大的那些)。LDA 降维是直接和类别的个数相关的,与数据本身的维度没关系,比如原始数据是n维的,一共有C个类别,那么LDA降维之后,一般就是1维,2维到C-1维进行选择(当然对应的特征值也是最大的一些),举个例子,假设图象分类,两个类别正例反例,每个图象10000维特征,那么LDA之后,就只有1维特征,并且这维特征的分类能力最好。
PS:对于很多两类分类的情况,LDA之后就剩下1维,找到分类效果最好的一个阈值貌似就可以了。

   第二,投影的坐标系是否正交

    PCA投影的坐标系都是正交的,而LDA根据类别的标注,关注分类能力,因此不保证投影到的坐标系是正交的(一般都不正交)。

3. LDA计算过程(两个类别)

这一节,主要讨论只有两个类别的数据,LDA的计算。现在要找到一个向量w,将数据x投影到w上去之后,得到新的数据y。第一,为了实现投影后的两个类别的距离较远,用映射后两个类别的均值差的绝对值来度量。第二,为了实现投影后,每个类内部数据点比较聚集,用投影后每个类别的方差来度量。

类别i的均值:


   


    类别i投影后的均值(实际上等于mi的投影):


    


    投影后均值差的绝对值:


    


    投影后的方差(这里的y是类别i中数据投影后的数据,即y=w_t * x):


    


    目标优化函数为:


    


    下面通过展开m'和s',定义S_B和S_W:

  

 

    

优化目标J(w)改写如下,这样是为了方便推导出计算w的方法。


    


    推导过程忽略了,最后推导结果如下:


    

 

假设数据是n维特征,m个数据,分类个数为2。那么Sw实际上是每个类别的协方差矩阵之和,每个类别的协方差矩阵都是n*n的,因此Sw是n*n的,m1-m2是n*1的。计算得到的w是n*1的,即w将维特征映射为1维。

PS:这里不用纠结与Sw的协方差矩阵形式,实际上这是拆拆开来w和w_t后的结果,实际上w*Sw*w_t后,仍旧是一个数值,即表示两个类的投影后方差之和。

4. LDA计算过程(多个类别)

     对于S_w,就是“两个类别的协方差矩阵之和”变成了“多个类别的协方差矩阵之和”。


     

      对于S_b,以前是“两个类别的均值之差的绝对值”,现在多个类别了,怎么计算呢?计算任意两个类别之间的均值之差的绝对值之和?这样对于N个类别,需要 C(N,2)次计算,这可能是一个方法,不过LDA使用的方法,计算每个类别的均值与所有类别均值的差异,并且对每个类别的数据量进行加权处理。下式中,m为所有类别的均值,m_i为类别i的均值,n_i为类别i的数据量。


    

        对于n维特征、C个类别、m个样本的数据,是将n维数据映射为C-1维。即所求的w是一个n*(c-1)的矩阵。S_w是一个n*n的矩阵(没有除以样本数的协方差矩阵之和),S_B是一个C*C的矩阵,实际上S_B矩阵的的秩最多是C-1,这是因为n_i*(m_i-m)这c向量实际上是线性相关的,因为他们的和是均值m的常数倍。这导致后面求解w,实际上是求出C-1个向量一个构成的一个w。

具体计算忽略。

下面就是一个三个类别的例子: 

4. LDA其他变种

如果原始数据投影后,仍旧不能很好的分开,那么Kernel LDA是一个解决方法。

LDA在计算量上与数据的维度有关,2DLDA能够大大减小LDA计算量。

5. LDA的一些问题

第一,LDA最多投影出C-1维特征,如果需要更多特征,则要引入其他方法。

第二,LDA假设数据服从单峰高斯分布,比如下面的复杂数据结构。

5. 参考

Introduction to LDA
Linear Discriminant Analysis - A Brief Tutorial
  http://www.aiaccess.net/English/Glossaries/GlosMod/e_gm_fisher_discriminant.htm

线性判别分析(Linear Discriminant Analysis, LDA)算法分析


转载自:http://blog.csdn.net/jnulzl/article/details/49894041http://blog.csdn.net/jnulzl/article/details/49894041

一、前言

最近由于研究需要,要用到线性判别分析(LDA)。于是找了很多资料来看,结果发现大部分讲的都是理论知识,因此最后还是看的一知半解,后来终于找到了个英文的文档,作者由PCA引入LDA,看过后豁然开朗,主要是文档中有详细的例子,为了保持原版在此就直接粘贴过来了——后面的例子是结合MATLAB实现的!

二、LDA理论详解

LDA算法原理及matlab实现_第1张图片
LDA算法原理及matlab实现_第2张图片
LDA算法原理及matlab实现_第3张图片
LDA算法原理及matlab实现_第4张图片
LDA算法原理及matlab实现_第5张图片
LDA算法原理及matlab实现_第6张图片
LDA算法原理及matlab实现_第7张图片
LDA算法原理及matlab实现_第8张图片
LDA算法原理及matlab实现_第9张图片
LDA算法原理及matlab实现_第10张图片
LDA算法原理及matlab实现_第11张图片
LDA算法原理及matlab实现_第12张图片

三、LDA实例详解

下面是作者文档中配的一个具体例子,其中的代码是MATLAB代码。

LDA算法原理及matlab实现_第13张图片
LDA算法原理及matlab实现_第14张图片
LDA算法原理及matlab实现_第15张图片
LDA算法原理及matlab实现_第16张图片
LDA算法原理及matlab实现_第17张图片
LDA算法原理及matlab实现_第18张图片
LDA算法原理及matlab实现_第19张图片
LDA算法原理及matlab实现_第20张图片
LDA算法原理及matlab实现_第21张图片
LDA算法原理及matlab实现_第22张图片
LDA算法原理及matlab实现_第23张图片

四、相关的中文LDA资料

除了上面英文版的LDA外,我感觉以下关于LDA的中文文章讲的也是挺不错的:

1、线性判别分析(Linear Discriminant Analysis)(一);

2、线性判别分析(Linear Discriminant Analysis, LDA)算法分析;

3、LDA 线性判别分析;

4、机器学习中的数学(4)-线性判别分析(LDA), 主成分分析(PCA)。


LDA详细推导:LDA算法原理及matlab实现_第24张图片LDA算法原理及matlab实现_第25张图片

你可能感兴趣的:(数据降维)