PCA(principal Component Analysis),主成分分析法。顾名思义,就是提取出数据中主要的成分,是一种数据压缩方法,常用于去除噪声、数据预处理,也是机器学习中常见的降维方法。
专业一点讲,PCA就是用一个超平面(直线的高维推广)对所有样本进行恰当的表达。
例如一个三维图形(特征数为3),我们想将它降低到二维(特征数为2),最容易想到的就是投影到一个平面上,但这个平面不一定恰好就是平面或者其他坐标轴平面,而是一个能尽量接近原始数据信息的平面(由于总是不可避免的会丢失一些信息,所以这也是PCA的缺点)。
这个超平面应该具有以下性质:
但根据这两种性质最终会得到等价的推导,见西瓜书P230.
此外,PCA与线性回归的区别:PCA是无监督学习,线性回归是监督学习。
对于样本集,有个特征,即维数为,每个特征有m个样本。我们想降低维数到.
表示特征的第个样本。
即将每个元素减去它的平均值,这样可以增加基向量的正交性。
协方差矩阵是一个的矩阵,且满足对称正定,矩阵内的每个元素
其中是因为无偏估计。
协方差:
协方差衡量了两属性之间的关系,
当时,表示X与Y正相关;
当时,代表X与Y负相关;
当时,代表X与Y不相关。
对于协方差矩阵,其特征值(可能有多个)计算方法为
再带入求得每个特征值对应的特征向量。
选取最大的d个特征值对应的特征向量.
投影为矩阵,完成数据压缩。
通过特征值的计算我们可以得到 主成分所占的百分比,用来衡量模型的好坏。
对于前k个特征值所保留下的信息量计算方法如下:
此外,还可以通过交叉验证的方法进行评价。
基于python带有功能强大的sklearn库,非常适合做机器学习,所以在此以python为例实现。
本人的python刚刚入门,很多函数不了解,所以参考了以下几篇文章:
https://blog.csdn.net/puredreammer/article/details/52255025
https://blog.csdn.net/u012102306/article/details/52294726
http://www.cnblogs.com/pinard/p/6243025.html
首先,训练集有6组数据,每组数据有4个特征,我们的目的是将其降到2维,也就是2个特征。
#coding=utf-8
import numpy as np
from sklearn.decomposition import PCA
X = np.array([[-1,2,66,-1], [-2,6,58,-1], [-3,8,45,-2], [1,9,36,1], [2,10,62,1], [3,5,83,2]]) #导入数据,维度为4
pca = PCA(n_components=2) #降到2维
pca.fit(X) #训练
newX=pca.fit_transform(X) #降维后的数据
# PCA(copy=True, n_components=2, whiten=False)
print(pca.explained_variance_ratio_) #输出贡献率
print(newX) #输出降维后的数据
参数解释:
结果分析:
[0.95713353 0.03398198]
[[ 7.96504337 4.12166867]
[ -0.43650137 2.07052079]
[-13.63653266 1.86686164]
[-22.28361821 -2.32219188]
[ 3.47849303 -3.95193502]
[ 24.91311585 -1.78492421]]
第一行为各主成分的贡献率,可以看出第一个特征占了很大比重 ,后面几行是降维后的数据。