文章主要内容:
本文旨在为读者提供不同算法的原理以及效果的直观展示,并希望读者能够在实际问题中更合理地选用梯度下降法。
文章结构:
1. 简介:梯度下降法
2. 随机梯度下降法
3. 随机梯度下降的问题与挑战
4. 随机梯度下降的优化算法(主要内容)
5. 并行与分布式架构
6. 随机梯度下降的其他优化方法
正文
1 梯度下降法
如果 J(θ) 是一个多元函数,在 θ0 点附近对 J(θ) 做线性逼近
2 随机梯度下降法
随机梯度下降法主要是为了解决第一个问题:梯度计算。
由于随机梯度下降法的引入,我们通常将梯度下降法分文三种类型:
(1)批梯度下降法(batch-GD)
原始的梯度下降法
(2)随机梯度下降法(SGD)
每次梯度计算只使用一个样本
(3)小批量随机梯度下降法(mini-batch GD)
每次梯度计算使用一个小批量样本
注意:神经网络训练的文献中经常把 mini-batch GD称为SGD。
随机梯度下降法的主要困难在于前述的第二个问题:学习率的选取。
(1)局部梯度的反方向不一定是函数整体下降的方向
(2)预定学习率衰减的问题
(3)对不同参数采取不同的学习率的问题
(4)神经网络训练中梯度下降法容易被困在鞍点附近的问题
注:为什么不用牛顿法?
3 动量法(Momentum)(适用于隧道型曲面)
梯度下降法在狭长的隧道型函数上表现不佳,如下图所示:
4 Nesterov accelerated gradient (动量法的改进算法)
动量法的一个问题在于:从山顶推下的铁球会越滚越快,以至于到了山底下停不下来。我们希望算法更加聪明一些,可以到达底部之前就自己刹车。
利用主体下降方向提供的先见之明,预判自己下一步的位置,并到预判位置计算梯度。
5 Adagrad (自动调整学习率,适用于稀疏数据)
梯度下降法在每一步对每一个参数使用相同的学习率,这种一刀切的做法不能有效地利用每一个数据自身的特点。
Adagrad是一种自动调整学习率的方法:
为了实现对于更新频繁的参数使用较小的学习率,Adagrad对每一个参数历史上的每次更新进行叠加,并以此来做下一次更新的惩罚系数。
梯度: gt,i=∇θJ(θi)
梯度历史矩阵: Gt对角矩阵,其中Gt,ii=∑kg2k,i
参数更新:
6 Adadelta (Adagrad的改进算法)
Adagrad的一个问题在于随着训练的进行,学习率快速单调衰减。
Adadelta则使用梯度平方的移动平均来取代全部历史平方和。
定义移动平均: E[g2]t=γE[g2t−1]+(1−γ)g2t
于是就得到参数更新法则:
Adadelta以及一般的梯度下降法的另一个问题在于,梯度与参数的单位不匹配。
Adadelta使用参数更新的移动平均来取代学习率 η 。于是参数更新法则变为:
7 Adam (结合了动量法和Adadelta算法)
如果把Adadelta里面梯度的平方和看成是梯度的二阶矩,那么梯度自身的求和就是一阶矩。Adam算法在Adadelta的二阶矩基础上又引入了一阶矩。
而一阶矩,其实就类似于动量法里面的动量。
8 如何选择算法?
目前为止,Adam可能是几种算法中综合表现最好的。