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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 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实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
8天前
|
机器学习/深度学习 人工智能 监控
算法金 | 奇奇怪怪的正则化
**摘要:** 本文深入浅出地介绍了正则化在机器学习中的作用,旨在防止过拟合,提高模型泛化能力。正则化通过添加惩罚项限制模型复杂度,包括L1(Lasso回归,产生稀疏解)、L2(Ridge回归,减少参数大小)、Elastic Net(结合L1和L2优点)以及Lp正则化等。其他方法如Early Stopping、Dropout和数据增强也是防止过拟合的有效手段。选择正则化方法要考虑数据特性、模型复杂性、计算资源和调参能力。正则化参数设置可通过交叉验证、网格搜索等方法优化。文章最后强调了正则化对控制模型复杂度和提升性能的重要性。
26 8
算法金 | 奇奇怪怪的正则化
|
3天前
|
算法 数据可视化 网络安全
清华等高校推出首个开源大模型水印工具包MarkLLM,支持近10种最新水印算法
【6月更文挑战第27天】清华大学等高校发布了开源工具MarkLLM,这是首个专注于大语言模型水印的工具包,支持近10种先进算法。该工具统一了水印实现,便于比较和使用,旨在促进水印技术在保障信息真实性和网络安全上的应用。MarkLLM提供直观界面、可视化及自动化评估,推动了大模型水印研究的进步。[论文链接:](https://arxiv.org/abs/2405.10051)**
10 5
|
5天前
|
机器学习/深度学习 数据采集 人工智能
人工智能:构建自定义机器学习模型的步骤与技巧
【6月更文挑战第25天】构建自定义机器学习模型涉及明确问题、数据收集预处理、特征工程、模型选择训练、评估优化及部署监控。关键技巧包括选择适配的算法、重视数据预处理、精巧的特征工程、有效评估优化和适时的模型更新。通过这些步骤和技巧,可提升模型性能与泛化能力。
|
4天前
|
机器学习/深度学习 算法 数据挖掘
Python机器学习10大经典算法的讲解和示例
为了展示10个经典的机器学习算法的最简例子,我将为每个算法编写一个小的示例代码。这些算法将包括线性回归、逻辑回归、K-最近邻(KNN)、支持向量机(SVM)、决策树、随机森林、朴素贝叶斯、K-均值聚类、主成分分析(PCA)、和梯度提升(Gradient Boosting)。我将使用常见的机器学习库,如 scikit-learn,numpy 和 pandas 来实现这些算法。
|
10天前
|
机器学习/深度学习 人工智能 算法
【机器学习】RLHF:在线方法与离线算法在大模型语言模型校准中的博弈
【机器学习】RLHF:在线方法与离线算法在大模型语言模型校准中的博弈
219 6
|
10天前
|
机器学习/深度学习 人工智能 自然语言处理
【机器学习】Transformer模型大小与性能探究
【机器学习】Transformer模型大小与性能探究
282 5
|
10天前
|
机器学习/深度学习 人工智能 自然语言处理
【机器学习】集成语音与大型语音模型等安全边界探索
【机器学习】集成语音与大型语音模型等安全边界探索
218 5
|
10天前
|
机器学习/深度学习 人工智能 自然语言处理
【机器学习】Chameleon多模态模型探究
【机器学习】Chameleon多模态模型探究
154 5
|
15小时前
|
机器学习/深度学习 算法 Python
使用Python实现深度学习模型:演化策略与遗传算法
使用Python实现深度学习模型:演化策略与遗传算法
5 0
|
1天前
|
机器学习/深度学习 自然语言处理 算法
扩散模型在机器学习中的应用及原理
扩散模型在机器学习中的应用及原理