深度学习基础22(数值稳定性)

数值稳定性和模型初始化

初始化方案的选择在神经网络学习中起着举足轻重的作用, 它对保持数值稳定性至关重要。

此外,这些初始化方案的选择可以与非线性激活函数的选择有趣的结合在一起。

选择哪个函数以及如何初始化参数可以决定优化算法收敛的速度有多快。 糟糕选择可能会导致我们在训练时遇到梯度爆炸或梯度消失

梯度消失和梯度爆炸

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Fi01ld4Y-1649135524240)(C:\Users\Lenovo\Documents\Tencent Files\850604703\FileRecv\MobileFile\Image\EY48TH32YQ3Q1H4QB@D3IEC.png)]

不稳定梯度带来的风险不止在于数值表示; 不稳定梯度也威胁到我们优化算法的稳定性。 我们可能面临一些问题。

要么是梯度爆炸(gradient exploding)问题: 参数更新过大,破坏了模型的稳定收敛;

要么是梯度消失(gradient vanishing)问题: 参数更新过小,在每次更新时几乎不会移动,导致模型无法学习。

梯度消失

曾经sigmoid函数1/(1+exp(−𝑥)) 很流行, 因为它类似于阈值函数

  • 梯度值变为0,对16为浮点数尤为严重
  • 训练没有进展,不管如何选择学习率
  • 对底部层尤为严重
    • 仅仅顶部层训练的较好
    • 无法让神经网络更深

由于早期的人工神经网络受到生物神经网络的启发, 神经元要么完全激活要么完全不激活(就像生物神经元)的想法很有吸引力。

然而,它却是导致梯度消失问题的一个常见的原因, 让我们仔细看看sigmoid函数为什么会导致梯度消失。

%matplotlib inline
import torch
from d2l import torch as d2l

x = torch.arange(-8.0, 8.0, 0.1, requires_grad=True)
y 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NDNPOMDFLR

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值