L1和L2正则

L1和L2的区别

L1范数(L1 norm)是指向量中各个元素绝对值之和,也有个美称叫“稀疏规则算子”(Lasso regularization)。 

比如 向量A=[1,-1,3], 那么A的L1范数为 |1|+|-1|+|3|.

简单总结一下就是: 
L1范数: 为x向量各个元素绝对值之和。 
L2范数: 为x向量各个元素平方和的1/2次方,L2范数又称Euclidean范数或者Frobenius范数 

Lp范数: 为x向量各个元素绝对值p次方和的1/p次方.

在支持向量机学习过程中,L1范数实际是一种对于成本函数求解最优的过程,因此,L1范数正则化通过向成本函数中添加L1范数,使得学习得到的结果满足稀疏化,从而方便人类提取特征。 
L1范数可以使权值稀疏,方便特征提取。 
L2范数可以防止过拟合,提升模型的泛化能力。

@AntZ: L1和L2的差别,为什么一个让绝对值最小,一个让平方最小,会有那么大的差别呢?看导数一个是1一个是w便知, 在靠进零附近, L1以匀速下降到零, 而L2则完全停下来了. 这说明L1是将不重要的特征(或者说, 重要性不在一个数量级上)尽快剔除, L2则是把特征贡献尽量压缩最小但不至于为零. 两者一起作用, 就是把重要性在一个数量级(重要性最高的)的那些特征一起平等共事(简言之, 不养闲人也不要超人)。

L1和L2正则先验分别服从什么分布

@齐同学:面试中遇到的,L1和L2正则先验分别服从什么分布,L1是拉普拉斯分布,L2是高斯分布。

@AntZ: 先验就是优化的起跑线, 有先验的好处就是可以在较小的数据集中有良好的泛化性能,当然这是在先验分布是接近真实分布的情况下得到的了,从信息论的角度看,向系统加入了正确先验这个信息,肯定会提高系统的性能。


对参数引入高斯正态先验分布相当于L2正则化, 这个大家都熟悉:




对参数引入拉普拉斯先验等价于 L1正则化, 如下图:


从上面两图可以看出, L2先验趋向零周围, L1先验趋向零本身。

正则化

L2正则化:目标函数中增加所有权重w参数的平方之和, 逼迫所有w尽可能趋向零但不为零. 因为过拟合的时候, 拟合函数需要顾忌每一个点, 最终形成的拟合函数波动很大, 在某些很小的区间里, 函数值的变化很剧烈, 也就是某些w非常大. 为此, L2正则化的加入就惩罚了权重变大的趋势.

L1正则化:目标函数中增加所有权重w参数的绝对值之和, 逼迫更多w为零(也就是变稀疏. L2因为其导数也趋0, 奔向零的速度不如L1给力了). 大家对稀疏规则化趋之若鹜的一个关键原因在于它能实现特征的自动选择。一般来说,xi的大部分元素(也就是特征)都是和最终的输出yi没有关系或者不提供任何信息的,在最小化目标函数的时候考虑xi这些额外的特征,虽然可以获得更小的训练误差,但在预测新的样本时,这些没用的特征权重反而会被考虑,从而干扰了对正确yi的预测。稀疏规则化算子的引入就是为了完成特征自动选择的光荣使命,它会学习地去掉这些无用的特征,也就是把这些特征对应的权重置为0。


先这么着吧,以后再补充,最近时间好紧啊。;)

参考:https://blog.youkuaiyun.com/v_JULY_v/article/details/78121924

### L1与L2正则化的定义及主要区别 #### 定义 L1正则化是指在损失函数中加入权重向量的L1范数作为惩罚项。这种正则化方式倾向于使部分权重变为零,从而实现特征选择的效果[^2]。 L2正则化则是指在损失函数中加入权重向量的L2范数平方作为惩罚项。这种方式会促使权重值趋向于较小数值,但通常不会完全为零,因此其作用在于防止过拟合并提高模型稳定性[^4]。 --- #### 主要区别 1. **稀疏性** L1正则化更容易获得稀疏解,即某些权重会被精确缩减至零,从而使对应的特征被自动排除在外。而L2正则化虽然也能减少权重大小,但它并不会将任何权重降为绝对意义上的零,而是使其趋近于零,因而不具备真正的稀疏效果。 2. **对异常值敏感程度** 由于L1正则基于绝对值计算,相比起依赖平方运算的L2正则而言,前者对于较大的权值变化更加鲁棒;后者因为涉及平方操作,在面对较大偏离时可能会放大这些偏差的影响[^1]。 3. **几何解释** 在高维空间下观察约束区域形状时发现:采用L1正则形成的边界呈现多面体形态(菱形或其他棱角分明图形),这样的结构更可能接触到坐标轴上的点——对应着某个特定方向上参数全为零的情形;相反地,应用L2正则产生的单位球表面较为圆润光滑,难以触及确切坐标的原点位置[^3]。 4. **适用场景** 如果目标数据集存在许多冗余或者无关紧要的输入变量,则推荐优先考虑使用L1方法来进行建模训练过程中的简化处理。而对于那些希望维持整体平稳表现且不存在明显孤立重要因子的数据集合来说,选用L2策略往往更为合适一些。 5. **优化特性** 加入L2正则后的二次型目标函数通常是严格凸的,有助于梯度下降算法更快收敛到全局最优解附近。然而当引入L1成分之后,尽管依旧保持局部最优点的存在唯一性,但由于非可微性质的缘故,寻找最终答案的过程或许变得稍微复杂一点。 --- ```python import torch from torch import nn, optim class Model(nn.Module): def __init__(self): super(Model, self).__init__() self.linear = nn.Linear(10, 1) def forward(self, x): return self.linear(x) def l1_regularization(model, lambda_l1=0.01): l1_loss = 0 for param in model.parameters(): l1_loss += torch.sum(torch.abs(param)) return lambda_l1 * l1_loss model = Model() criterion = nn.MSELoss() # Example of applying both regularizations during training loop for data, target in dataloader: output = model(data) loss = criterion(output, target) + l1_regularization(model) + (lambda_l2 / 2) * sum([torch.norm(p)**2 for p in model.parameters()]) optimizer.zero_grad() loss.backward() optimizer.step() ``` 上述代码展示了如何在PyTorch框架里手动添加L1L2正则化项到神经网络模型之中去执行相应的训练流程。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值