学习笔记: 机器学习经典算法-模型正则化

本文涉及的产品
云原生网关 MSE Higress,422元/月
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 机器学习经典算法-个人笔记和学习心得分享

模型正则化 Regularization 是通过 约束模型参数值的大小 实现解决模型方差过大(过拟合)问题的一种 标准处理手段。通过模型正则化处理可以在保持模型具有较高复杂度的前提下 提高模型的泛化能力

关于向量的Lp范数

Lp范数: 数学上表达为向量各个元素绝对值p次方和的1/p次方 $\|\vec x\|_{p} = (\sum_{i=1}^{n}|x_{i}|^{p})^{\frac {1}{p}}$;
该数学形式与 明可夫斯基距离 :$(\sum_{i=1}^{n}{|X_i^{(a)} - X_i^{(b)}|^{p }})^{\frac{1}{p}}$ 一致,当$p$取不同值时明可夫斯基距离可以具体化为不同的类型。

对于向量的Lp范数,其实度量的是 空间中向量到坐标原点的距离:

  • 当 $p=1$ 时,L1范数 度量了向量到原点的 曼哈顿距离
  • 当 $p=2$ 时,L2范数 度量了向量到原点的 欧氏距离

一般数据分析领域几乎不会涉及 $p \gt 2$ 的距离。

1、L2正则项-岭回归 Ridge Regression

在线性回归任务中,寻找最优参数的优化目标为
$$\small {\bf 使得}\ \ \sum _{i= 1 }^{m}{(y^{(i) - \hat y^{(i)}})} \rightarrow \sum _{i= 1 }^{m}{(y^{(i)}{ - \theta _{0} - \theta _{1}x^{(i)}_{1} -...- \theta _{n}x^{(i)}_{n} })} \rightarrow MSE(y^{(i)},\hat y^{(i)};\theta) \ \ \small {\bf 尽可能小。}$$

加入模型正则化 约束模型参数值大小的 L2正则项 $ \alpha\frac {1}{2}\sum_{i=1}^{n}{\theta^2_i}$ 使得优化目标变为 :
$$\small {\bf 使得}\ \ J(\theta)= MSE(y^{(i)},\hat y^{(i)};\theta) + \alpha\frac {1}{2}\sum_{i=1}^{n}{\theta^2_i} \ \ \small {\bf 尽可能小。}$$
参数值约束条件里的常量 $\alpha $ 代表在模型正则化下模型参数的约束强度; 当$\alpha = 0 $ ,表示不对模型参数值大小进行任何约束;当$\alpha \to \infty $,模型正则化的任务将使得每一个$\theta_{i}$都尽可能小,极端情况下所有$\theta$ 将取零。 在实际情况中,$\alpha $作为模型的超参数,可通过搜索获得。优化目标使用这种添加了参数大小约束的 线性回归 又称 岭回归 Ridge Regression

1.2 scikit-learn 框架下的岭回归

岭回归 Ridge Regression 是一种添加了模型参数值大小约束的 线性回归方法 Linear Regression

### Prepare datasets
import numpy as np
x = np.random.uniform(-3,3,size = 100).reshape((-1,1))
y = .5 * x ** 2 + 1*x + 2 + np.random.normal(size =(100,1))

### PolynomialFeatures
from sklearn.preprocessing import PolynomialFeatures ### 特征构造
poly = PolynomialFeatures(degree=3) ### 构造三次幂样本特征
poly.fit(x)
X = poly.transform(x) ### 返回添加了构造特征的特征矩阵,分别是 x^0,x^1,X^2 钩爪

### Ridge Regression - 参数值大小约束下的线性回归
from sklearn.linear_model import Ridge
ridge_reg = Ridge(alpha= .00001) ### 多项式回归得到的特征系数Θ 通常会非常大,约束值α可以选个小一些的值;α 越大会使得拟合曲线变得平滑。
ridge_reg.fit(X,y)
ridge_reg.coef_

1.3 sklearn 岭回归 管道封装

### 岭回归 流程管道
from sklearn.pipeline import Pipeline
from sklearn.preprocessing import PolynomialFeatures  
from sklearn.preprocessing import StandardScaler
from sklearn.linear_model import Ridge
from sklearn.metrics import mean_squared_errorn
def RidgeRegressor(degree,alpha):
    return Pipeline([
        ("poly",PolynomialFeatures(degree=degree)), ### 格式为 管道名,当前管道需执行的函数
        ("std_scaler",StandardScaler()),
        ("ridge_reg",Ridge(alpha = alpha))
    ])

#### Usage of scikit-learn Pipline
ridge_reg = RidgeRegressor(degree=3,alpha=0.0001)
ridge_reg.fit(x,y)
y_predict = ridge_reg.predict(x)
mean_squared_errorn(y,y_predict) ### MSE

2、L1正则项-LASSO 回归

LASSO 模型正则化 (Least Absolute Shrinkage and Selection Operator Regression) 的本质与 岭回归 一样,区别在于使得模型参数值最小化的约束条件的描述方式为 L1正则项 $ \alpha \sum_{i=1}^{n}{|\theta_i|}$ 。

LASSO Regression 的优化目标:
$$\small {\bf 使得}\ \ J(\theta)= MSE(y^{(i)},\hat y^{(i)};\theta) + \alpha \sum_{i=1}^{n}{|\theta_i|}\ \ \small {\bf 尽可能小。}$$

2.1 Lasso 的特征选择作用

对于岭回归 ,当参数值约束$\alpha$趋于无穷的时候,目标函数 $J(\theta) = MSE(y^{(i)},\hat y^{(i)};\theta) + \alpha\frac {1}{2}\sum_{i=1}^{n}{\theta^2_i} $ 中的约束 $\alpha\frac {1}{2}\sum_{i=1}^{n}{\theta^2_i}$ 的权重将变的无穷大,寻找最优$\theta$ 的目标函数变为 $f(\theta) = \alpha\frac {1}{2}\sum_{i=1}^{n}{\theta^2_i}$ 。对于函数 $\theta ^2$ 在梯度下降的过程中,很难使得 $\theta$ 完全落在函数中心点 $0$ ,通常只能落在一个趋近于$0$ 的区间上。

对于Lasso 回归 ,同样当参数值约束$\alpha$趋于无穷的时候,目标函数变为 $f(\theta) = \alpha\frac {1}{2}\sum_{i=1}^{n}{|\theta_i|}$ 。使用梯度下降法搜索绝对值函数的极小值的时候,由于绝对值函数上的导数仅分为三种情况 $(\frac {\partial \theta}{\partial J} = 1,\theta \gt 0; \frac {\partial \theta}{\partial J} = 0,\theta =0; \frac {\partial \theta}{\partial J} = -1,\theta \lt0; )$;所以 Lasso 回归的时候,很容易搜索到 $\theta = 0$ 的参数结果。


因此用绝对值的方式作为$\theta$ 的约束衡量,使得LASSO 趋向于使得一部分 $\theta_{i}$ 的值变为 0,实现在多项式-线性回归中的 特征选择 作用。但是这种特征选择,很可能会错误的丢弃原本有用的特征,从计算准确度而言 Ridge Regression会更准确些。

2.2 scikit-learn 框架下的 LASSO 回归流程管道封装

### lasso回归 流程管道
from sklearn.pipeline import Pipeline
from sklearn.preprocessing import PolynomialFeatures
from sklearn.preprocessing import StandardScaler
from sklearn.linear_model import Lasso
from sklearn.metrics import mean_squared_error
def LassoRegressor(degree,alpha):
    return Pipeline([
        ("poly",PolynomialFeatures(degree=degree)), ### 格式为 管道名,当前管道需执行的函数
        ("std_scaler",StandardScaler()), 
        ("lasso_reg",Lasso(alpha = alpha))
    ])

#### Usage of scikit-learn Pipline
lasso_reg = RidgeRegressor(degree=3,alpha=0.01)
lasso_reg.fit(x,y)
y_predict = lasso_reg.predict(x)
mean_squared_error(y,y_predict) ### MSE

3、L0 正则项

线性回归的 L0 正则项 约束条件表达为尽量使得非零 $\theta$ 参数的个数尽可能小:

$$\small {\bf 使得}\ \ J(\theta)= MSE(y^{(i)},\hat y^{(i)};\theta) +min \{number-of-non-zero-\theta \}\ \ \small {\bf 尽可能小。}$$

L0正则化 一般使用也非常少,$min \{number-of-non-zero-\theta \}$ 本身是一个离散项,从而求解该目标函数的最优化结果需要通过穷举组合所有的 $\theta_i$ 来计算 $J(\theta)$ 才能判断最优组合。实际使用由L1 正则项 代替。

4、弹性网 Elastic Net

联合使用了参数约束项 L1 正则项和L2正则项 ,由超参数 $r$ 指定 L1 正则项L2 正则项 的约束强度。结合了岭回归和Lasso 回归的优势)。如果计算资源充足,并且特征数目不算特别膨胀的时候优选考虑使用计算精度有保障的岭回归 ;只有在特征数特别膨胀的时候考虑使用 弹性网,一定程度上实现了 特征选择和精度 的保证。

$$\small {\bf 使得}\ \ J(\theta)= MSE(y^{(i)},\hat y^{(i)};\theta) + r\alpha\sum_{i=1}^{n}{|\theta _{i}|} + (1-r)\frac{1}{2}\alpha\sum_{i=1}^{n}{\theta_i^2} \ \ \small {\bf 尽可能小。}$$

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
3月前
|
机器学习/深度学习 算法 数据挖掘
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构。本文介绍了K-means算法的基本原理,包括初始化、数据点分配与簇中心更新等步骤,以及如何在Python中实现该算法,最后讨论了其优缺点及应用场景。
172 4
|
28天前
|
机器学习/深度学习 人工智能 算法
机器学习算法的优化与改进:提升模型性能的策略与方法
机器学习算法的优化与改进:提升模型性能的策略与方法
159 13
机器学习算法的优化与改进:提升模型性能的策略与方法
|
18天前
|
机器学习/深度学习 算法 网络安全
CCS 2024:如何严格衡量机器学习算法的隐私泄露? ETH有了新发现
在2024年CCS会议上,苏黎世联邦理工学院的研究人员提出,当前对机器学习隐私保护措施的评估可能存在严重误导。研究通过LiRA攻击评估了五种经验性隐私保护措施(HAMP、RelaxLoss、SELENA、DFKD和SSL),发现现有方法忽视最脆弱数据点、使用较弱攻击且未与实际差分隐私基线比较。结果表明这些措施在更强攻击下表现不佳,而强大的差分隐私基线则提供了更好的隐私-效用权衡。
45 14
|
2月前
|
算法
PAI下面的gbdt、xgboost、ps-smart 算法如何优化?
设置gbdt 、xgboost等算法的样本和特征的采样率
69 2
|
2月前
|
算法
基于模糊PI控制算法的龙格库塔CSTR模型控制系统simulink建模与仿真
本项目基于MATLAB2022a,采用模糊PI控制算法结合龙格-库塔方法,对CSTR模型进行Simulink建模与仿真。通过模糊控制处理误差及变化率,实现精确控制。核心在于将模糊逻辑与经典数值方法融合,提升系统性能。
|
2月前
|
存储 算法
基于HMM隐马尔可夫模型的金融数据预测算法matlab仿真
本项目基于HMM模型实现金融数据预测,包括模型训练与预测两部分。在MATLAB2022A上运行,通过计算状态转移和观测概率预测未来值,并绘制了预测值、真实值及预测误差的对比图。HMM模型适用于金融市场的时间序列分析,能够有效捕捉隐藏状态及其转换规律,为金融预测提供有力工具。
|
3月前
|
机器学习/深度学习 算法 数据挖掘
C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出
本文探讨了C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出。文章还介绍了C语言在知名机器学习库中的作用,以及与Python等语言结合使用的案例,展望了其未来发展的挑战与机遇。
69 1
|
3月前
|
机器学习/深度学习 自然语言处理 算法
深入理解机器学习算法:从线性回归到神经网络
深入理解机器学习算法:从线性回归到神经网络
|
3月前
|
机器学习/深度学习 人工智能 算法
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型
手写数字识别系统,使用Python作为主要开发语言,基于深度学习TensorFlow框架,搭建卷积神经网络算法。并通过对数据集进行训练,最后得到一个识别精度较高的模型。并基于Flask框架,开发网页端操作平台,实现用户上传一张图片识别其名称。
161 0
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型
|
3月前
|
机器学习/深度学习 人工智能 算法
基于深度学习的【蔬菜识别】系统实现~Python+人工智能+TensorFlow+算法模型
蔬菜识别系统,本系统使用Python作为主要编程语言,通过收集了8种常见的蔬菜图像数据集('土豆', '大白菜', '大葱', '莲藕', '菠菜', '西红柿', '韭菜', '黄瓜'),然后基于TensorFlow搭建卷积神经网络算法模型,通过多轮迭代训练最后得到一个识别精度较高的模型文件。在使用Django开发web网页端操作界面,实现用户上传一张蔬菜图片识别其名称。
145 0
基于深度学习的【蔬菜识别】系统实现~Python+人工智能+TensorFlow+算法模型