IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 降维与特征选择 -> 正文阅读

[人工智能]降维与特征选择

内容简介

  • 主成分分析
  • 主成分分析建模
  • 偏最小二乘法
  • 偏最小二乘法建模
  • Fisher LDA
  • 特征选择方法

主成分分析(Principle Component Analysis, PCA)

  • 主成分分析是一种线性、非监督、全局的降维算法

  • PCA的目的是找到数据中的主成分,并利用这些主成分表征原始数据从而达到降维的目的

    具体讲就是:用少数的若干新变量(原变量的线性组合)替代原变量,新变量要尽可能多地反映原变量的数据信息,同时,新变量之间相互正交,可以消除原变量中相互重叠的信息

主成分分析过程推导

设样本的标准化输入变量矩阵为:

在这里插入图片描述
构造一个变量 P 1 P_1 P1?,且变量 P 1 P_1 P1?能携带标准化输入变量矩阵 X n ? k X_{n*k} Xn?k?的信息,满足以下公式:
在这里插入图片描述
在信号处理领域,认为信号具有较大的方差,噪声具有较小的方差,信号与噪声之比称为信噪比。信噪比越大意味着数据质量越好,反之,信噪比越小;
如下图,黄线所处的轴数据分布更为分散,数据在这个方向上方差更大;显然,黄线就是主成分所在的轴
在这里插入图片描述

从概率统计观点可知,变量的方差越大,该变量包含的信息越多;因此,上述问题可以转化为要求变量 P 1 P_1 P1?的方差最大。 P 1 P_1 P1?的方差为
在这里插入图片描述
构造拉格朗日函数:
在这里插入图片描述
其中, λ 1 \lambda_1 λ1?为拉格朗日系数,分别计算 L L L λ 1 \lambda_1 λ1? t 1 \bm t_1 t1?的偏导数,并令其为零,则有:
在这里插入图片描述
由上式知, t 1 \bm t_1 t1? V V V的一个标准化特征向量, λ 1 \lambda_1 λ1?为其对应的特征值,故:
在这里插入图片描述
显然, t 1 \bm t_1 t1?是矩阵 V V V的最大特征值 λ 1 \lambda_1 λ1?所对应的标准化特征向量,对应的构造变量 P 1 = X t 1 P_1=X\bm t_1 P1?=Xt1?称为第一主成分,且第一主成分包含的特征信息最多;同理可以求出 X X X的第 m m m个主成分 P m = X t 1 P_m=X\bm t_1 Pm?=Xt1?,且第 m m m个主成分包含的特征信息少于第 m ? 1 m-1 m?1个主成分特征信息,第 m + 1 m+1 m+1个主成分包含的特征信息远远小于第一主成分包含的特征信息;

m m m个主成分携带的信息综合为:
在这里插入图片描述

主成分分析建模

%% I. 清空环境变量
clear all
clc

%% II. 导入数据
load spectra;

%% III. 随机划分训练集与测试集
temp = randperm(size(NIR, 1));
% temp = 1:60;
%%
% 1. 训练集——50个样本
P_train = NIR(temp(1:50),:);
T_train = octane(temp(1:50),:);
%%
% 2. 测试集——10个样本
P_test = NIR(temp(51:end),:);
T_test = octane(temp(51:end),:);

%% IV. 主成分分析
%%
% 1. 主成分贡献率分析
[PCALoadings,PCAScores,PCAVar] = pca(NIR);
figure
percent_explained = 100 * PCAVar / sum(PCAVar);
pareto(percent_explained)
xlabel('主成分')
ylabel('贡献率(%)')
title('主成分贡献率')

%%
% 2. 第一主成分vs.第二主成分
[PCALoadings,PCAScores,PCAVar] = pca(P_train);
figure
plot(PCAScores(:,1),PCAScores(:,2),'r+')
hold on
[PCALoadings_test,PCAScores_test,PCAVar_test] = pca(P_test);
plot(PCAScores_test(:,1),PCAScores_test(:,2),'o')
xlabel('1st Principal Component')
ylabel('2nd Principal Component')
legend('Training Set','Testing Set','location','best')

%% V. 主成分回归模型
%%
% 1. 创建模型
k = 4;
betaPCR = regress(T_train-mean(T_train),PCAScores(:,1:k));
betaPCR = PCALoadings(:,1:k) * betaPCR;
betaPCR = [mean(T_train)-mean(P_train) * betaPCR;betaPCR];
%%
% 2. 预测拟合
N = size(P_test,1);
T_sim = [ones(N,1) P_test] * betaPCR;

%% VI. 结果分析与绘图
%%
% 1. 相对误差error
error = abs(T_sim - T_test) ./ T_test;
%%
% 2. 决定系数R^2
R2 = (N * sum(T_sim .* T_test) - sum(T_sim) * sum(T_test))^2 / ((N * sum((T_sim).^2) - (sum(T_sim))^2) * (N * sum((T_test).^2) - (sum(T_test))^2)); 
%%
% 3. 结果对比
result = [T_test T_sim error]

%% 
% 4. 绘图
figure
plot(1:N,T_test,'b:*',1:N,T_sim,'r-o')
legend('真实值','预测值','location','best')
xlabel('预测样本')
ylabel('辛烷值')
string = {'测试集辛烷值含量预测结果对比';['R^2=' num2str(R2)]};
title(string)

偏最小二乘法(Partial Least Squares, PLS)

  • 线性判别分析(Linear Discriminant Analysis,LDA)是一种有监督学习算法,经常被用来对数据进行降维,偏最小二乘法是其中一种分类器准测。

  • PLS的核心思想是逐步回归,逐步分解输入变量矩阵和输出变量矩阵,并综合考虑提取的主成分对输入变量矩阵和输出变量矩阵的解释能力,直到满足性能要求为止

    PCA方法提取出的前若干个主成分携带了原输入变量矩阵的大部分信息,消除了相互重叠部分的信息。并没有考虑主成分对输出变量的解释能力嘛,方差贡献率很小但对输出变量有很强解释能力的主成分将会被忽略掉,这无疑会对校正模型的性能产生一定的影响。偏最小二乘法(PLS)可以很好地解决这个问题。

PLS公式推导

设标准化的输入变量矩阵和输出变量矩阵分别为:

在这里插入图片描述
要求构造变量 t 1 \bm t_1 t1? u 1 \bm u_1 u1?满足:
在这里插入图片描述

且,变量 t 1 \bm t_1 t1? u 1 \bm u_1 u1?满足以下三个条件:

  • ① 应尽可能大地携带输入变量矩阵 的信息;
  • ② 应尽可能大地携带输出变量矩阵 的信息;
  • ③ 和 应具有尽可能大的相关程度;

由主成分分析原理可知,条件①和条件②等价于要求 t 1 \bm t_1 t1? u 1 \bm u_1 u1?的方差尽可能地大,即
在这里插入图片描述
根据典型相关分析,条件③可以转换为使得 t 1 \bm t_1 t1? u 1 \bm u_1 u1?的相关系数尽可能地大,即
在这里插入图片描述
上述问题可以转化为计算 t 1 \bm t_1 t1? u 1 \bm u_1 u1?的协方差的最大值,即
在这里插入图片描述
构造拉格朗日函数并求解:
在这里插入图片描述
在这里插入图片描述
由上式可知, w 1 \text w_1 w1?是矩阵 X ′ Y Y ′ X X'YY'X XYYX的特征向量,对应的特征值为 θ 2 \theta ^2 θ2,使 t 1 \bm t_1 t1? u 1 \bm u_1 u1?的协方差最大的 w 1 \text w_1 w1?是对应矩阵 X ′ Y Y ′ X X'YY'X XYYX最大特征值的单位特征向量;
同理, c 1 \bm c_1 c1?是矩阵 Y ′ X X ′ Y Y'XX'Y YXXY的特征向量,对应的特征值为 θ 2 \theta ^2 θ2,使 t 1 \bm t_1 t1? u 1 \bm u_1 u1?的协方差最大的 c 1 \bm c_1 c1?是对应矩阵 Y ′ X X ′ Y Y'XX'Y YXXY最大特征值的单位特征向量;
在这里插入图片描述
若回归方程的精度已经满足要求,则停止;否则,利用残差矩阵 X ? X^* X? Y ? Y^* Y?,计算第二主成分,并重新建立回归方程;以此类推,直到回归方程的精度满足要求为止。

偏最小二乘法建模

%% I. 清空环境变量
clear all
clc

%% II. 导入数据
load spectra;

%% III. 随机划分训练集与测试集
temp = randperm(size(NIR, 1));
% temp = 1:60;
%%
% 1. 训练集——50个样本
P_train = NIR(temp(1:50),:);
T_train = octane(temp(1:50),:);
%%
% 2. 测试集——10个样本
P_test = NIR(temp(51:end),:);
T_test = octane(temp(51:end),:);

%% IV. PLS回归模型
%%
% 1. 创建模型
k = 2;
[Xloadings,Yloadings,Xscores,Yscores,betaPLS,PLSPctVar,MSE,stats] = plsregress(P_train,T_train,k);

%%
% 2. 主成分贡献率分析
figure
percent_explained = 100 * PLSPctVar(2,:) / sum(PLSPctVar(2,:));
pareto(percent_explained)
xlabel('主成分')
ylabel('贡献率(%)')
title('主成分贡献率')

%%
% 3. 预测拟合
N = size(P_test,1);
T_sim = [ones(N,1) P_test] * betaPLS;

%% V. 结果分析与绘图
%%
% 1. 相对误差error
error = abs(T_sim - T_test) ./ T_test;
%%
% 2. 决定系数R^2
R2 = (N * sum(T_sim .* T_test) - sum(T_sim) * sum(T_test))^2 / ((N * sum((T_sim).^2) - (sum(T_sim))^2) * (N * sum((T_test).^2) - (sum(T_test))^2)); 
%%
% 3. 结果对比
result = [T_test T_sim error]

%% 
% 4. 绘图
figure
plot(1:N,T_test,'b:*',1:N,T_sim,'r-o')
legend('真实值','预测值','location','best')
xlabel('预测样本')
ylabel('辛烷值')
string = {'测试集辛烷值含量预测结果对比';['R^2=' num2str(R2)]};
title(string)

Fisher LDA(Fisher’s Linear Discriminant Analysis)

  • 线性判别分析(Linear DiscriminantAnalysis,LDA)是一种有监督学习算法,由于线性模型对于噪声的鲁棒性比较好,LDA被证明是非常有效的一种降维方法;Fisher 是其中一种分类器准测,

  • Fisher LDA的核心思想是最大化类间距离和最小化类内距离

假设有 C 1 C_1 C1? C 2 C_2 C2?两个不同标签的数据,
在这里插入图片描述

根据PCA算法进行处理,两个不同类别数据会混合在一起,很难区分开;
在这里插入图片描述
因此提出了Fisher LDA,我们希望处理后的样本尽可能的按照原始类别分开(即,处理后类别之间的距离尽可能大),同时优化样本类别内的方差(即,样本类内方差尽可能小);
在这里插入图片描述
由于Fisher LDA模型简单,表达能力有一定局限性,还可以通过引入核函数扩展LDA方法以处理分布较为复杂的数据

特征选择方法

Filter vs. Wrapper

  • Filter无需利用学习模型的性能,即可进行特征选择,主要依赖一些评价准则,如:相关系数、互信息、信息熵等
  • Wrapper需要建立学习模型,通过模型的性能进行评价特征的优劣

搜索法

  • 随机搜索,如:遗传算法,粒子群算法

    • 遗传算法特征选择
      • 将N个输入变量用一个长度为N的染色体表示,染色体的每一位代表一个输入变量;
      • 每一位的基因取值只能是“1”和“0”两种情况;
      • 如果染色体的某一位值为“1”,表示该位对应的输入变量被选中,参与模型建立;
      • 反之,如果染色体的某一位值为“0”,则表示对应的输入变量未被选中,不参与模型建立;
  • 启发式搜索,如:前向选择法、后向选择法

    • 前向选择法

      • 自下而上的选择方法,又称集合增加法;
      • 特征集合初始化为一个空集;
      • 每次向特征集合中添加一个输入变量,当新加入的变量致使模型性能更优时,则保留该输入变量,否则不保留
    • 后向选择法

      • 自上而下的选择方法,又称集合缩减法;
      • 特征集合初始化为全部的输入变量;
      • 每次从特征集合中剔除一个输入变量,当剔除后致使模型性能更优时,则剔除该输入变量,否则保留该 输入变量

正则化方法

  • L 1 范 数 L_1范数 L1?

  • L 2 L_2 L2?范数

特征变量选择的评价

在这里插入图片描述

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-07-30 22:43:54  更:2021-07-30 22:43:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/22 10:54:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码