LDA-linear discriminant analysis - webdancer's Blog

LDA-linear discriminant analysis

webdancer posted @ 2013年2月28日 20:41 in machine learning with tags Machine learning , 10585 阅读

分类问题也可以用降维来理解,比如一个$D$维的数据点$x$,我们可以采用下面的映射进行线性的降维,

\[
y=\theta^{T}x
\]

在计算出$y$后,就可以选择一个阈值$h$,来进行分类。正如我们在前面的PCA模型中看到的,降维会有信息的损失,可能会在降维过程中,丢失使数据可分的特征,导致分类的效果不理想。

那采用什么样的降维方式,可以尽量的在低维空间中保存原来数据在高维空间中的可分性(区分类别的特征)。一个常用的模型 linear discriminant analysis(LDA)就是用来做这个工作的,下面就具体的看一下LDA模型。

原理

LDA的基本原理就是最大化类间方差(between-class variance)和类内方差(within-class variance)的比率(注意这个variance用来理解,下面用到的定义实际上是variance的一个变形),使得降维后数据有最好的可分性。如果偷用软件工程里面用的术语的话,就是“高内聚,低耦合”,类内的数据内聚,方差小,而类间数据松散,方差大。通常来说,这要比只考虑类间的距离越大要好,如下图所示:

左边图只是考虑最大化每个类期望的最大距离,我们看到有很多点投影后重合了,丧失了标签信息;而右边是LDA投影,重合的点的数目减少了很多,能更好的保存标签信息。

模型

下面我们就来形式化这个过程,首先如何定义between-class variance和within-class variance?在Fisher提出的方法中,没有使用统计中标准的variance的定义,而是使用了一个称为scatter的概念,与variance时等价的,使用这个概念可能是为了后面的推导简洁。设数据集为$X={x_1,x_2,..,x_N}$,则scatter的定义为:

\[
s=\sum_{n=1}^{N}(x_n-m)^{T}(x_n-m)
\]

其中,$m=\frac{1}{N}\sum_{n=1}^{N}x_n$。

类内方差很容易形式化,可以直接使用scatter来定义,然后把所有类别的scatter连加;那么类间的方差如何定义才能很好的让类之间的数据分的更开呢?当然应该有很多的数学关系很描述,在LDA中使用了下面这种方式,计算每个类别的期望,求期望之间的距离。先从简单的两类情况开始,然后拓展到多类的情况。

两类

设数据集合为$X=\{x_1,x_2,..,x_N\}$,类别为$C_1,C_2$,则这两类的数据期望为$m_1,m_2$,计算公式如:

\[
m_k=\frac{1}{N_k}\sum_{i \in C_k}x_i
\]

$\mathbf m_k$表示投影后的数据点的期望,则between-class variance的形式化定义为:

\[
\mathbf m_2-\mathbf m_1=\theta^{T}(m_2-m_1)
\]

其中,$\mathbf m_k=\theta^{T}m_k$。within-class variance用within-scatter这个定义来表示,scatter是variance的变种(不用除以数据的数目),第$C_k$类的scatter定义为:

\[
S_k^2=\sum_{i \in C_k}(y_i-\mathbf m_i)^2
\]

其中,$y_i=\theta^{T}x_i$。这样就可以得到目标函数:

\[
J(\theta)=\frac{(\mathbf m_2-\mathbf m_1)^2}{s_1^2+s_2^2}
\]

将上面的定义代入上式,可以得到式子:

\[
maxarg_\theta J(\theta)=\frac{\theta^{T}S_B\theta}{\theta^{T}S_W\theta}
\]

其中,$S_B,S_W$分别称为between-class scatter和within-class scatter,表示如下:

\[
S_B=(m_2-m_1)(m_2-m_1)^{T};
S_W=S_1+S_2
\]

其中,$S_k=\sum_{i \in C_k}(x_i-m_k)(x_i-m_k)^{T}$。下面要做的就是最优化目标函数$(x-m_k)$,对上面的式子求导数,让导数为0,则可以得到:

\[
(\theta^{T}S_B\theta)S_W\theta=(\theta^{T}S_W\theta)S_B\theta
\]

由于投影操作,我们只关心$\theta$的方向,上面的式子,可以去掉$(\theta^{T}S_B\theta),(\theta^{T}S_W\theta)$,根据$S_B$的定义,$S_B\theta$的方向与$(m_2-m_1)$一致,我们可以得到:

\[
\theta^* \propto S_W^{-1}(m_2-m_1)
\]

这个式子称为Fisher’s linear discriminant[1936],尽管这个式子不是一个判别式,只是选择了投影方向,不过只要我们选择一个阈值,然后就可以根据这个阈值进行分类了。(ps:使用求解generalized eigenvalue problem的方法求解导数为零的等式,也可以得到这个判别式)

多类

在多类问题时,将$D$维的向量$x$投影到$M<D$维的$y$,投影矩阵方程为:

\[
y=\mathbf \Theta^{T} x
\]

可以参照PCA文章中提到投影公式,这里$\mathbf \Theta$是一个投影矩阵,每一个列向量表示一个投影方向$\Theta_k$。

设数据集合为$X=\{x_1,x_2,..,x_N\}$,类别为$C_1,C_2,..,C_K$。在多类的时候,过程与上面一样,不过由于between-class scatter 和within-class scatter不再是标量,需要更改一下我们需要优化的目标函数。首先看一下在原空间$x$的定义,然后就可以类比到$y$空间。

withinin-class scatter 与二类时的定义一样,如下表示:

\[
S_W=\sum_{k=1}^{K}\sum_{i \in C_k}(x_i-m_k)(x_i-m_k)^{T}
\]

$m_k$定义与上面一致。

between-class scatter的定义,这里我们根据PRML里面论述的,首先定义一个$S_T$,然后根据$S_T=S_B+S_W$,然后分解得到$S_B$。$S_T$的定义类似$S_k$,不过不在一个类别,而是在所有的数据集上进行计算。

\[
S_T=\sum_{n=1}^{N}(x_n-m)(x_n-m)^{T}\\
m=\frac{1}{N}\sum_{n=1}^{N}x_n=\frac{1}{N}\sum_{k=1}^{K} N_km_k
\]

所以得到:

\[
\begin{eqnarray}
S_B&=&S_T-S_W\\
&=&\sum_{n=1}^{N}(x_n-m)(x_n-m)^{T}-\sum_{k=1}^{K}\sum_{i \in C_k}(x_i-m_k)(x_i-m_k)^{T}\\
&=& \sum_{k=1}^{K}\sum_{i \in C_k}(x_i-m)(x_i-m)^{T}-\sum_{k=1}^{K}\sum_{i \in C_k}(x_i-m_k)(x_i-m_k)^{T}\\
&=& \sum_{k=1}^{K}\sum_{i \in C_k}\{(x_i-m)(x_i-m)^{T}-(x_i-m_k)(x_i-m_k)^{T}\}\\
&=& \sum_{k=1}^{K}\{\sum_{i \in C_k}-x_im^T+\sum_{i \in C_k}-mx_i^T+N_kmm^T+\sum_{i \in C_k}x_im_k^T+\sum_{i \in C_k}m_kx_i^T-N_km_km_k^T\}\\
&=& \sum_{k=1}^{K}\{-N_km_km^T-mN_km_k+N_kmm^T+N_km_km_k^T+N_km_km_k-N_km_km_k^T\}\\
&=&\sum_{k=1}^{K} N_k(m_k-m)(m_k-m)^T
\end{eqnarray}
\]

这样我们就可以类比得到在投影空间的between-class scatter与within-class scatter:

\[
\widetilde S_W=\sum_{k=1}^{K}\sum_{i \in C_k}(y_i-\mathbf m_k)(y_i-\mathbf m_k)^{T}\\
\widetilde S_B=S_T-S_W=\sum_{k=1}^{K} N_k(\mathbf m_k-\mathbf m)(\mathbf m_k-\mathbf m)^T
\]

这样就可以得到目标函数,由于$\widetilde S_W,\widetilde S_B$不是标量,在目标函数中使用它们的行列式,

\[
maxarg_{\mathbf \Theta}J(\mathbf \Theta)=\frac{|\widetilde S_B|}{|\widetilde S_W|}
\]

类似在二类推到中的式子,可以得出:

\[
maxarg_{\mathbf \Theta}J(\mathbf \Theta)=\frac{|\widetilde S_B|}{|\widetilde S_W|}=\frac{|\mathbf \Theta^{T}S_B\mathbf \Theta|}{|\mathbf \Theta^{T}S_W\mathbf \Theta|}
\]

然后优化上面的函数(很直接,但是这里就不推导了,可能比较麻烦),可以得出结论,投影矩阵由$S_W^{-1}S_B$的特征最大特征向量决定,这样我们就可到了一个很简洁的公式, 与PCA不同的是,这里考虑到了类别信息,得到的投影方向对一些数据集合来说,会有很大不同,如下图:

从上图中也可以看到,使用PCA投影后,数据在黑色的直线上基本不可分,而使用LDA投影,则可分性要比PCA好很多,这也说明了LDA在降维过程中保留了标签信息。

需要注意的地方是:

  1. 由于$S_B$的秩最大为$K-1$,所以$S_W^{-1}S_B$的特征向量数目不会超过$K-1$,所以我们投影后的$M<=(K-1)$。
  2. LDA也可以从normal class Density 通过最大似然估计得出。
  3. $S_W^{-1}S_B$中,用到了$S_W$的逆,但是$S_W$的最大秩为$N-K$,在很多计算中,特征数远大于样本数,使得$S_W$是奇异矩阵,所以这时候我们需要在LDA计算前,进行降维(采用PCA),使得$S_W$是非奇异的。

模型的局限性,主要体现在下面两个方面:

  1. 根据上面的分析,LDA投影后最多只能保留$K-1$个特征,可能对一些问题来说,特征数目太少。
  2. LDA本是参数估计方法,假设分布符合单峰的高斯分布,对于数据集合不符合的情况,没法保留标签信息。
  3. 对那些由方差,而不是均值来区分的数据来说,LDA同样也没法处理,如下图所示:

应用

在人脸识别中,使用LDA降维,是一种常用的方法,形成的特征向量,称为fisher-face;此外,LDA也可以用在破产预测等方面。

引用:

[1]prml

[2]http://research.cs.tamu.edu/prism/lectures/pr/pr_l10.pdf

[3]http://www.intechopen.com/books/speech-technologies/nonlinear-dimensionality-reduction-methods-for-use-with-automatic-speech-recognition

[4]http://en.wikipedia.org/wiki/Linear_discriminant_analysis

maids in dubai 说:
2021年9月14日 21:03

Brand new heard around foodborne disorder? Yes! One heard which will right, this not alone leads with the growth of parasites but moreover affects the healthiness of the over-all family. Allow us to produce a safe environment for everyone. With home cleaning Dubai services including kitchen bare floors mopping, dusting that cabinets, cleaning your kitchen appliances without use of harsh products. We be certain that your each individual expectation is without a doubt met. Being the most impressive home maintaining services Dubai you take maximum responsibility designed for cleaning and even sanitizing ones own kitchen.

HDFC Life Insurance 说:
2022年8月06日 17:18

HDFC Life is one of the top insurance providers in India which helps many subscribers with their benefited plans, and customers get easy avenues that make their online payment and other options very easy, where HDFC was established in 2000 and it has been growing in service that it provides to customers. HDFC Life Insurance Online Payment The insurance policy through HDFC Life does carry in every different stream which ensures customers get their desired policy for their purpose, and customers can get more information about the HDFC Life Insurance from the official website of HDFC and here we will let you know how to get the installments for the policy to be paid.


登录 *


loading captcha image...
(输入验证码)
or Ctrl+Enter
Host by is-Programmer.com | Power by Chito 1.3.3 beta | © 2007 LinuxGem | Design by Matthew "Agent Spork" McGee