L1和L2正则化

L1使矩阵更稀疏,L2使矩阵忽略对结果影响较小的特征值

L1

L1 regularization 时,只要 regularization 项的系数 C 大于原先费用函数在 0 点处的导数的绝对值,x = 0 就会变成一个极小值点。原因是我们可以对0两边进行求导分别得到f’(0) - C和f‘(0) + C,如果C > f’(0),那么左右两边就会异号,这样的话,0就成了极小值点了。

L2

在这里插入图片描述
在不使用L2正则化时,求导结果中w前系数为1,现在w前面系数为 1−ηλ/n ,因为η、λ、n都是正的,所以 1−ηλ/n小于1,它的效果是减小w,这也就是权重衰减(weight decay)的由来。当然考虑到后面的导数项,w最终的值可能增大也可能减小。
更小的权值w,从某种意义上说,表示网络的复杂度更低,对数据的拟合刚刚好(这个法则也叫做奥卡姆剃刀),而在实际应用中,也验证了这一点,L2正则化的效果往往好于未经正则化的效果。
过拟合的时候,拟合函数的系数往往非常大,为什么?如下图所示,过拟合,就是拟合函数需要顾忌每一个点,最终形成的拟合函数波动很大。在某些很小的区间里,函数值的变化很剧烈。这就意味着函数在某些小区间里的导数值(绝对值)非常大,由于自变量值可大可小,所以只有系数足够大,才能保证导数值很大。
在这里插入图片描述
而正则化是通过约束参数的范数使其不要太大,所以可以在一定程度上减少过拟合情况。
L1和L2详述

### L1L2正则化的概念及其在机器学习中的应用 #### 一、L1正则化 L1正则化通过向损失函数中添加参数的绝对值之作为惩罚项,促使模型倾向于生成稀疏解。这意味着某些特征的权重会被精确地缩减为零,从而实现特征选择的效果[^5]。这种特性使得L1正则化非常适合用于高维数据集,其中许多特征可能是冗余或无关紧要的。 L1正则化的数学形式如下: ```python Loss = MSE + λ * Σ|w_i| ``` 其中 \(MSE\) 是均方误差,\(λ\) 是正则化强度,\(w_i\) 是模型参数。 由于L1正则化的约束区域是多边形,交点更可能出现在坐标轴上,这导致了某些参数被精确设置为零[^4]。 #### 二、L2正则化 L2正则化通过向损失函数中添加参数平方的一半作为惩罚项,迫使模型参数保持较小的值,但不会将其缩减至零。这种方法有助于减少模型的过拟合风险,同时生成更平滑的权重分布[^3]。 L2正则化的数学形式如下: ```python Loss = MSE + (λ / 2) * Σ(w_i^2) ``` 其中 \(MSE\) 是均方误差,\(λ\) 是正则化强度,\(w_i\) 是模型参数。 L2正则化的约束区域是一个圆形(或多维球体),因此交点通常位于非零位置,这使得所有特征都会保留下来,但其权重会被均匀减小[^4]。 #### 三、区别与应用场景 - **稀疏性**:L1正则化倾向于生成稀疏解,适合于需要进行特征选择的任务,例如在基因表达数据分析中,可能只有少数几个基因对疾病预测有重要影响[^5]。 - **稳定性**:L2正则化具有更好的求解特性,因为它没有不可微的点,适合于需要稳定性连续性的场景,例如图像识别或语音处理任务[^2]。 - **计算复杂度**:L2正则化通常比L1正则化更容易优化,因为它的目标函数是处处可微的[^2]。 - **适用场景**:如果数据集包含大量噪声特征或需要自动特征选择,则L1正则化更为合适;如果希望模型更加稳健且不需要显著减少特征数量,则L2正则化更为合适[^5]。 #### 四、代码示例 以下是一个使用Python实现L1L2正则化的线性回归模型的例子: ```python from sklearn.linear_model import Ridge, Lasso import numpy as np # 模拟数据 X = np.array([[1, 2], [2, 3], [3, 4], [4, 5]]) y = np.dot(X, np.array([1, 2])) + np.random.randn(4) # L2正则化(Ridge回归) ridge = Ridge(alpha=0.1) ridge.fit(X, y) print("Ridge Coefficients:", ridge.coef_) # L1正则化(Lasso回归) lasso = Lasso(alpha=0.1) lasso.fit(X, y) print("Lasso Coefficients:", lasso.coef_) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值