zoukankan      html  css  js  c++  java
  • cs229_part7

    PCA

    问题背景

    回顾一下我们特征选择中的问题。如果特征非常多,而且有一些特征是重复的,那么我们可以想办法剔除掉一些无用的特征。那里我们提到一个计算互信息的方法。那么这里换一种降维方法。

    比如说这样的一种比较极端的情况,我们数据是二维的,但是很明显能看的出来有一个维度对于分类是没有任何作用的,那我们可以把这个数据投影到x轴上面,变成这样:

    这样我们就把二维的数据降到了一维。
    当然这只是一种比较极端的情况,但是对于任意情况也是可以推广的。比如上面这个情况,投到x轴是最好的情况,而投到y轴上是最差的情况。因为投到y轴上就变成了一个点,还怎么分类。
    那么主要的想法就是,我们找到一个超平面,然后把特征投到超平面上面,那要怎么投呢,就是投完之后使得点之间的距离越大越好。

    形式描述

    如果我们的样本在超平面上的投影是(mathbf { W } ^ { T } x _ { i })那么投影后样本的方差就是(sum _ { i } mathbf { W } ^ { T } x _ { i } x _ { i } ^ { T } mathbf { W })
    那么优化目标就是:

    [left.egin{array} { c } { max _ { mathbf { W } } operatorname{tr} left( mathbf { W } ^ { ext{T} } mathbf { X } mathbf { X } ^ { ext{T} } mathbf { W } ight) } \ { mathbf { s .t .} mathbf { W } ^ { ext{T} } mathbf { W } = mathbf { I } } end{array} ight. ]

    利用拉格朗日算子可得:

    [mathbf { X } mathbf { X } ^ { ext{T} } mathbf { W } = lambda mathbf { W } ]

    于是对(mathbf { X } mathbf { X })做特征分解取所需要的特征即可。

    过程就是:

    1. 对样本集进行中心化处理:(x _ { i } leftarrow x _ { i } - frac { 1} { m } sum _ { i = 1} ^ { m } x _ { i })
    2. 计算协方差矩阵:$$mathbf { X } mathbf { X }$$
    3. 对协方差矩阵进行特征分解
    4. 取最大的d个特征作为所需要的特征向量(w _ { 1} ,w _ { 2} ,dots ,w _ { d })
    5. 得到投影矩阵(mathbf { W } = left( w _ { 1} ,w _ { 2} ,ldots ,w _ { d } ight))

    如果这个推导过程看不懂的话请翻阅参考。

    参考

    1. PCA的数学原理
  • 相关阅读:
    【每日日报】第五十三天安装My SQL
    【每日日报】第五十一天jsp
    【每日日报】第五十四天
    JDK安装和卸载
    JDK的卸载和安装
    【每日日报】第五十二天
    【每日日报】第五十六天
    基于图书管理系统的查
    Android学习——day5
    每日日报2020.7.26 1905
  • 原文地址:https://www.cnblogs.com/nevermoes/p/cs229_part7.html
Copyright © 2011-2022 走看看