- 在线时间
- 479 小时
- 最后登录
- 2026-5-9
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7813 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2931
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1173
- 主题
- 1188
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
梯度下降是最基本但使用最多的优化算法。它在线性回归和分类算法中大量使用。神经网络中的反向传播也使用梯度下降算法。
# U w0 O# ~6 f% G7 E) v& P) S4 t) g9 j+ O" I. X
梯度下降是一种一阶优化算法,它依赖于损失函数的一阶导数。它计算应该改变权重的方式,以便函数可以达到最小值。通过反向传播,损失从一层转移到另一层,模型的参数(也称为权重)根据损失进行修改,从而使损失最小化。
( @, n$ k) Z! R2 d6 \4 h, K/ O. y: |8 W6 T% q# s
优点:) t$ S% ~) d! L* j2 O
7 |3 f$ v8 M3 e# I0 j8 [
容易计算。
k9 M: N* B; d9 `易于实施。
- }: F! ?* P8 ^8 o' V: E& o容易理解。& W8 s0 @ c/ j
缺点:
8 @& d2 [. Y+ J) s; C# ?& E. n2 C. _* B+ h
可能陷入局部最小值。$ E8 ^" F0 V3 z- F9 w
在计算整个数据集的梯度后,权重会发生变化。因此,如果数据集太大,可能需要数年时间才能收敛到最小值。% ^* y5 r- f4 m9 ^
需要大内存来计算整个数据集的梯度
2 F9 ^" U1 f/ K# v随机梯度下降
/ h8 x: Z% u( [它是梯度下降的变体。它尝试更频繁地更新模型的参数。在这种情况下,模型参数在计算每个训练示例的损失后会发生变化。因此,如果数据集包含 1000 行,SGD 将在数据集的一个循环中更新模型参数 1000 次,而不是像梯度下降中那样更新一次。
. `( @# ^+ Q# D- p F) p Y2 X/ Q' b) E M' H
θ=θ−α⋅∇J(θ;x(i);y(i)) ,其中 {x(i) ,y(i)} 是训练样本
) w9 T( M, n) m: F1 E' E; s/ b, s4 i( N8 B- P( @3 I( _
由于模型参数更新频繁,参数在不同强度下具有较大的方差和损失函数波动。( `* E h6 U& ^! [8 `+ x7 @& P' g
% o: ]8 d* K) S/ m
优点:
6 U* g) B. `6 f9 K5 y% Y+ H' b3 k( K. [9 C1 Z9 C, u# [
因此,频繁更新模型参数可以在更短的时间内收敛。
0 V1 q9 Z# y; `7 S$ |需要更少的内存,因为不需要存储损失函数的值。
3 w1 E/ y0 Y2 |. S. o可能会得到新的最小值。
% P" j( _; L# n- P4 @, z' k* H缺点:" J$ z. L6 s0 q3 H" O2 q
6 U1 J; D/ t4 g: d* u3 b4 G: e3 `* D9 Y模型参数的高方差。
' H; {; d8 i8 Y r. B: a, T: a: [. y即使在达到全局最小值后也可能射击。
+ ~2 O1 o) Z N8 x# h7 M4 b8 ]要获得与梯度下降相同的收敛性,需要慢慢降低学习率的值。- Z& Q$ Z' T; V. [. B+ P+ e; K, d
小批量梯度下降7 Y- l# J$ O" v1 A
它是梯度下降算法所有变体中最好的。它是对 SGD 和标准梯度下降的改进。它在每批次后更新模型参数。因此,数据集被分成不同的批次,每批次之后,参数都会更新。
c! N4 f3 F$ U# q/ A3 b
( v. ^0 ?, D M6 ]% Iθ=θ−α⋅∇J(θ; B(i)),其中 {B(i)} 是训练样本的批次。
! ]4 L( [7 [4 u+ K5 D! |
6 T$ ?0 i {/ Y& K) E优点:) w: I; G z5 ?# l
6 E9 [7 f8 L0 K5 N; L, v" `! T经常更新模型参数并且方差也较小。
6 s T0 I1 @6 \4 S( }需要中等的内存 e+ l' Q, p0 {# r8 j2 S
所有类型的梯度下降都有一些挑战:
. F# _% _3 C3 U5 W: B) |
3 |6 e& X& E1 t- K/ i& ` k4 B7 M选择学习率的最佳值。如果学习率太小,梯度下降可能需要很长时间才能收敛。
3 _+ `0 y' f u% j9 ]' m对所有参数都有一个恒定的学习率。可能有一些参数我们不想以相同的速率改变。4 o; }) C D$ b' E2 @# i9 X
可能会陷入局部极小值。
I' A1 k1 I9 t+ @# s. R, v5 ?8 [; Q其它优化算法+ K. V+ V4 q% @9 r \9 h
具体我就不再详细介绍,其它优化器如下:
0 N8 Y, r. {& {0 z+ H$ @ ?
* D, j* ?; `* e o5 HMomentum) {- I2 T& g* i' j
Nesterov Accelerated Gradient0 q; T$ |, {, k, h0 n; Q) y0 H S
Adagrad( e) I8 W T$ K _' n7 Z$ l
AdaDelta
$ ]& k! P' H; G" H1 VAdam! h8 w* I- L; K$ D( _! H
各个优化算法比较动态图
: N! l D1 Q8 D
1 I# l, r: R/ S8 Y7 O" r: o+ |( W8 O2 E$ i. ~( g
- D2 ~7 b1 x, w" I% @1 Q: B |
zan
|