PCA和LDA

作者: 三方斜阳 | 来源:发表于2021-06-09 08:13 被阅读0次

在机器学习领域,PCA和LDA都可以看成是数据降维的一种方式。但是PCA是无监督的,也就是说不需要知道sample对应的label,而LDA是监督的,需要知道每一个数据点对应的label。下面分别解释PCA和LDA的基本原理

image

PCA:

  • PCA又称为主成分分析,这种方法可以有效的找出数据中最“主要”的元素和结构,去除噪音和冗余,将原有的复杂数据降维,揭示隐藏在复杂数据背后的简单结构。

  • 从线形代数的角度来看,PCA的目标就是使用另一组基去重新描述得到的数据空间。而新的基要能尽量揭示原有的数据间的关系。PCA本质上就是向量换基。PCA通过对投影的距离方差的运用将降维问题转换为了求最值的问题。

LDA(Linear Discriminant Analysis):

  • 线性判别分析,是一种监督学习的降维技术,也就是说它的数据集的每个样本是有类别输出的,这点和PCA不同。PCA是不考虑样本类别输出的无监督降维技术。LDA的思想可以用一句话概括,就是“投影后类内方差最小,类间方差最大”,如下图所示。 我们要将数据在低维度上进行投影,投影后希望每一种类别数据的投影点尽可能的接近,而不同类别的数据的类别中心之间的距离尽可能的大。

  • 对新样本进行分类时,将其投影到同样的一条直线上,再根据投影点的位置来确定样本的类别。


  • 再看一个例子,假设有两类数据,分别为红色和蓝色,如下图所示,这些数据特征是二维的,希望将这些数据投影到一维的一条直线,让每一种类别数据的投影点尽可能的接近,而红色和蓝色数据中心之间的距离尽可能的大。
  • 从直观上可以看出,右图要比左图的投影效果好,因为右图的黑色数据和蓝色数据各个较为集中,且类别之间的距离明显

  • LDA算法既可以用来降维,又可以用来分类,但是目前来说,主要还是用于降维。在进行图像识别相关的数据分析时,LDA是一个有力的工具

两者比较:

相同点:

  • 两者均可以对数据进行降维。
  • 两者在降维时均使用了矩阵特征分解的思想。
    两者都假设数据符合高斯分布。

不同点:

  • PCA是无监督的,希望降维之后方差尽可能大
  • LDA是有监督的,希望降维之后组内方差小,组间方差大
  • LDA降维最多降到类别数k-1的维数,而PCA没有这个限制。
  • LDA除了可以用于降维,还可以用于分类。
  • LDA选择分类性能最好的投影方向,而PCA选择样本点投影具有最大方差的方向。这点可以从下图形象的看出,在某些数据分布下LDA比PCA降维较优。


相关文章

  • 用线性判别分析 LDA 降维

    本文结构: 什么是 LDA 和 PCA 区别 LDA 投影的计算过程 LDA 降维的例子 1. 什么是 LDA 先...

  • PCA和LDA

    在机器学习领域,PCA和LDA都可以看成是数据降维的一种方式。但是PCA是无监督的,也就是说不需要知道sample...

  • 绝境逆生

    1.过拟合的解决办法2.L1/L2正则化3.特征如何降维 (pca lda)4.pca和lda的区别5.GBDT,...

  • 超级简单LDA和GDA

    LDA和PCA最大的区别是,PCA找的是方差最大的方向,LDA找的是分类分的最开的方向。也就是说mean要分得最开...

  • 机器学习面试之数据降维

    PCA(主成分分析)和LDA(线性判别分析,Fisher Linear Discriminant Analysis...

  • 2021-03-29

    LDA与PCA降维思想不同,对数据的要求也不同。 LDA需要数据有标记有分类,便于后面对类内类外的区分,而PCA则...

  • LDA线性判别分析

    LDA线性判别分析 PCA不考虑label,属于unsupervised,那么LDA就是考虑了y的label。 对...

  • [Face Rec]人脸识别的算法

    1 基于图像 大约有十四种算法目前被广泛运用于人脸识别,譬如PCA、ICA、LDA和EP。 1.1 PCA 从卡洛...

  • PCA LDA SVD

    https://www.cnblogs.com/pinard/p/6243025.html http://d0ev...

  • PCA &LDA比较

    PCA是unsupervised,也就是说不需要知道sample对应的label,而LDA是supervised,...

网友评论

    本文标题:PCA和LDA

    本文链接:https://www.haomeiwen.com/subject/kajjeltx.html