zoukankan      html  css  js  c++  java
  • 机器学习算法之降维

      在机器学习的过程中,我们经常会遇见过拟合的问题。而输入数据或features的维度过高就是导致过拟合的问题之一。。维度越高,你的数据在每个特征维度上的分布就越稀疏,这对机器学习算法基本都是灾难性的。所有出现了很多降维的方法。今天我们要讨论的就是LDA降维。

    LDA降维的思路是:如果两类数据线性可分,即:存在一个超平面,将两类数据分开。则:存在模旋转向量,将两类数据投影到一维上,并且依然是线性可分的。

    提出问题

    假设未定一组N个带标记的数据(Xi,Ci),其中,标记C分两类,即:Ci =0 或Ci=1,设计分类器,将数据分开。如果x的维度很高,甚至比N还多,这时候就需要降维了。

    解题过程

    1、根据线性变换,将X降成一维的

    假定旋转向量为W,将数据X投影到一维y,得到 y =WTX ,其中输入数据X,旋转向量W。

    如此就将原来我x维的向量转换为一维,利用分类算法将数据分类为C。从而,可以找到阈值W0,如果y>W0为一类,y<W0为一类。

     2、计算每个分类的类内均值和方差

    令C1类有N1个元素,C2有N2个元素,计算投影前的类内均值和投影后的类内均值和松散度(方差):

    3、寻找Fisher判别准则

    4、对目标函数进行优化

    也就是对目标函数求导后取极值。

    倒数为:

     推导得到, 三者同方向。

    主题模型------主成分分析PCA

    PCA和LDA的区别

    LDA:分类性能最好的方向

    PCA:样本点投影具有最大方差的方向

    实际问题往往需要研究多个特征,而这些特征就有一定的相关性。

    将多个特征综合为少数几个代表性特征。组合后的特征既能够代表原始特征的绝大部分信息,又互不相关,降低相关性。这种提取原始特征的主成分的方法就叫主成分分析。

    问题的提出:

    对于包含n个特征的m个样本的数据,将每个样本标记成行向量,得到了矩阵A:

    解题的思路:

    寻找样本的主方向U:将m个样本的值投影到某直线L上,得到m个位于直线L上的点,计算m个投影点的方差。认为方差最大的直线方向为主方向。   

     假设样本去均值了

    求方差,PCA的核心推导过程

    取投影的直线L的延伸方向u,计算AXu的值

    求向量A X u的方差

    目标函数:J(u)= uTATAu

    目标函数求驻点:

    由于u数乘得到的方向和u相同,因此,增加u是单位向量的约束,即:||u||2=1 = uTu

     建立Lagrange的方程:

    L(u)=  uTATAu -λ (uTu-1)

    求导:

    分析ATAu = λu

    若A中的样本都是去均值化的,则ATA与A的协方差矩阵仅仅相差系数n-1

    u是ATA的特征向量,λ的值的大小为原始观测数据的特征向量在向量u的方向上投影值的方差

    PCA的重要应用

    去噪、降维 、模式识别、分析数据胡相关性以及多源融合等

  • 相关阅读:
    同表自更新
    C#数据层添加事务功能
    Mysql 索引 分区 面试题
    Spring 循环依赖
    Zipkin初探 + 与SpringBoot的集成+ 使用HTTP方式传送数据给zipkin server
    Web调优之IBM JDK+liberty(二),原来都是UUID惹得祸
    Web调优之IBM JDK+liberty(一): Jmeter pod里压,50个线程并发测试,调整 -Xms -Xms, Log原来是大问题
    Linux使用jstat命令查看jvm的GC情况
    VM内存回收System.gc()
    prometheus 文档合集
  • 原文地址:https://www.cnblogs.com/zuoshoushizi/p/9242050.html
Copyright © 2011-2022 走看看