LDA和PCA降维的区别

这里主要介绍LDA和PCA的区别:

相同点:

1)两者均可以对数据进行降维。

2)两者在降维时均使用了矩阵特征分解的思想。

3)两者都假设数据符合高斯分布。

不同点:

1)LDA是有监督的降维方法,而PCA是无监督的降维方法

2)LDA降维最多降到类别数k-1的维数,而PCA没有这个限制。

3)LDA除了可以用于降维,还可以用于分类。

4)LDA选择分类性能最好的投影方向,而PCA选择样本点投影具有最大方差的方向。

LDA和PCA所用库:

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D  # 用来绘制3D图
from sklearn.decomposition import PCA
from pca_my import loaddataset
from sklearn.discriminant_analysis import LinearDiscriminantAnalysis as LDA

lda代码如下:

def lda_():
    data = loaddataset('txt/10/all/500_all.txt')
    x = data[:, 1:]
    y = data[:, 0].astype(int)
    y = np.array(y).reshape(-1, 1)
    lda1 = LDA(n_components=2)
    x_r = lda1.fit(x, y).transform(x)
    fig2 = plt.figure()
    ax2 = fig2.add_subplot(111)
    ax2.scatter(x_r[:, 0], x_r[:, 1], marker='o', c=y)

    fig2.savefig('picture/f_lda.png', bbox_inches='tight')

由于lda只可以最多降维到k-1类特征,我的数据集只有3类,所以我设置n_components=2,最后结果如下:
lda
pca代码如下:

def pca_():
	datamat = loaddataset('txt/10/all/0_all.txt')
    x = datamat[:, 1:]
    y = datamat[:, 0].astype(int)
    y = np.array(y).reshape(-1, 1)
    datamat = x
    pca1 = PCA(n_components=2)  # n_components表示保留主成分个数
    pca1.fit(datamat)  # 用数据datamet来训练PCA模型
    lowdata = pca1.transform(datamat)  # 对数据归一化
    """
    fig = plt.figure()
    ax1 = Axes3D(fig)
    #ax1.scatter(reconmat1[:, 0], reconmat1[:, 1], reconmat1[:, 2], cmap='Blues')
    #ax1.scatter(reconmat4[:, 0], reconmat4[:, 1], reconmat4[:, 2], cmap='red')
    #ax1.scatter(reconmat7[:, 0], reconmat7[:, 1], reconmat7[:, 2], cmap='#bcbd22')
    fig.savefig('picture/f3D.png', bbox_inches='tight')
    """

    fig1 = plt.figure()
    ax = fig1.add_subplot(111)
    ax.scatter(lowdata[:, 0], lowdata[:, 1], marker='o', c=y)
    # fig1.show()
    fig1.savefig('picture/f2D.png', bbox_inches='tight')

pca
可以看出我这里的实验,使用LDA比PCA效果要好一点,对于数据有类别的,建议使用LDA进行降维。

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小Aer

走过路过给个赏钱

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值