ch11 特征选择与稀疏学习
子集选择与评价
缓解维度灾难的另一种重要方法是进行特征筛选,同时它也能降低学习任务的难度,只留下关键特征。
对当前学习任务有用的属性称为“相关特征”,而对当前学习任务没有用的属性称为“无关特征”,包含信息能被其他特征表示的属性称为“冗余特征”。
如果想要从原始特征集中选择出一个子集,那么就是一个特征选择问题。特征选择通常包含以下两个环节
-
子集搜索:搜索最优特征子集
暴力搜索会遇见组合爆炸问题,所以需要一些启发式方法,如贪心法(前向、后向、双向) -
子集评价:评价特征子集的好坏
评价指标有很多,如信息增益、信息增益比、基尼指数、方差、相关系数等
常见的特征选择方法有:过滤法、包裹法、嵌入法
过滤法
先对数据集进行特征选择,再用特征子集训练模型,特征选择过程与学习过程无关
著名的算法有:Relief、Relief-F
Relief 设计了一个相关统计量用于度量特征的重要性
相关统计量:对于每一个样本点,寻找与其最近邻的样本点(同类)和(异类),于是我们可以定义如下的相关统计量
那么最终得到的一个统计量向量越大,说明子集选择的越好,分类性能越强
包裹法
直接利用学习器的性能来评价特征子集的好坏,通常效果更好,但计算开销也更大
著名的算法有:LVW 框架,在特征选择的过程中使用了随机算法
嵌入法
将特征选择过程与学习过程融为一体,直接在学习器上进行特征选择
著名的算法有: L1 正则化、L2 正则化
对于线性回归算法,我们通常认为有这样一条直线可以拟合数据
当不可逆时,我们使用最小二乘法,即
当列不满秩时,即不可逆,即样本特征多于样本数,此时我们可以使用正则化
保证了可逆,从而解决了多重共线性问题
这是一种罚函数法,即在目标函数中加入了一个罚函数,使得优化问题变得更加复杂
最直观的罚函数是 L0 范数,即非零元素的个数,但是 L0 范数是一个非凸函数,所以我们通常使用 L1 范数,L1 通常能获得稀疏解,即有些特征的权重为 0
因此可以说,L1 正则化是一种特征选择方法
L1 正则化的求解方法
可以使用近端梯度下降法(Proximal Gradient Descent),对于优化目标
如果满足 Lipschitz 连续梯度条件,希望不要变化太快,即
那么在处对目标函数进行二阶泰勒展开,有
那么我们可以得到
最小值可以通过如上的迭代方式求解,即梯度下降法是对 二次拟合函数的近似
那么应用到 L1 正则化的问题上,我们可以得到
这个问题不存在交叉项,因此可以使用坐标轴下降法(Coordinate Descent)求解,即
求导数,令导数为 0,即可得到
L1 正则化的求解方法
字典学习与稀疏表示
学习到整个数据矩阵的稀疏性
可以使用 PGD 类似的思想交替优化
- Step 1:固定, 求解
- Step 2:固定, 求解
这个问题可以通过 SVD 分解求解,即每一步固定其他中的列,求解中的一列,
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律