深度学习 —— 梯度下降法的优化方法

目录

[一、梯度下降法 回顾](#一、梯度下降法 回顾)

二、梯度下降法的缺点

三、如何选择优化方法

[1.了解 ------ 指数移动加权平局](#1.了解 —— 指数移动加权平局)

[1.1 公式](#1.1 公式)

[1.2 图例说明](#1.2 图例说明)

[1.3 结论](#1.3 结论)

2.优化方法:

[2.1 图解](#2.1 图解)

[2.2 如何选择优化方法](#2.2 如何选择优化方法)

[2.3 对应API](#2.3 对应API)

[动量法 Momentum](#动量法 Momentum)

[AdaGrad 自适应学习率](#AdaGrad 自适应学习率)

[RMSprop 自适应学习率](#RMSprop 自适应学习率)

[Adam 自适应矩估计](#Adam 自适应矩估计)

[AdamW 自适应矩估计](#AdamW 自适应矩估计)

[2.4 梯度下降法优化方法总结](#2.4 梯度下降法优化方法总结)


一、梯度下降法 回顾

W新 = W旧 - 学习率 * 梯度

假设 学习率 lr = 0.1.

① 6.4 = 8.0 - 0.1 * 16.0

② 5.12 = 6.4 - 0.1 * 12.8

③ 4.01 = 5.12 - 0.1 * 10.24

...

二、梯度下降法的缺点

1.碰到平缓区间,梯度值较小,参数优化变慢

2.碰到"鞍点",梯度为0,参数无法优化

3.碰到局部最小值,参数不是最优。无法跳出

比如 y = x ^ 3 。x = 0的时候 就是"鞍点" 导数为0

三、如何选择优化方法

1.了解 ------ 指数移动加权平局

1.1 公式
1.2 图例说明

β = beta 一组散点天气数据

beta = 0 beta = 0.5

beta = 0.9 beta = 1

1.3 结论

1.对于指数移动加权平均值

β 值(调节系数)越大,移动加权平均值越平缓,越考虑历史数据。

β 值 越小,移动加权平均值越接近当前数据。

2.特例:β 值 = 0,就是当前数据的原始值

β 值 = 1,就是第一天的初始值

2.优化方法:

2.1 图解
2.2 如何选择优化方法

++* Adam / AdamW (推荐) -> RMSprop -> 动量法 Momentum -> 原始SGD,AdaGrad (不建议)++

++对比 Adam 和 AdamW++

Adam:

① 同时调整 学习率 和 梯度

② 使用梯度一阶矩来调整梯度,二阶矩来调整学习率

AdamW:

① Adam的优化版

② 解耦了权重衰减

③ 原始Adam直接在梯度中添加了 权重衰减项,使得调整梯度和调整学习率藕合在一起,会造成模型训练后期不稳定。

④ AdaW 使用原始梯度,在更新参数时直接添加权重衰减项目,解耦了调整梯度和调整学习率

2.3 对应API
python 复制代码
# 优化器模块,实现梯度下降法以及梯度下降的优化方法
import torch.optim as optim 
动量法 Momentum
python 复制代码
optim.SGD([w],lr=0.01,momentum=0.95)
AdaGrad 自适应学习率
python 复制代码
optim.Adagrad([w],lr=0.01)
RMSprop 自适应学习率
python 复制代码
optim.RMSprop([w],lr=0.01)
Adam 自适应矩估计
python 复制代码
optim.Adam([w],lr=0.01)
AdamW 自适应矩估计
python 复制代码
optim.AdamW([w],lr=0.01)
2.4梯度下降法优化方法总结
  1. SGD原始梯度下降法:optim.SGD, 使用当前梯度直接更新参数,用于凸优化问题,容易陷入局部最优解

  2. 动量法Momentum: optim.SGD(momentum=0.9), 引入动量概念,利用历史梯度信息,加速收敛

  3. AdaGrad: optim.Adagrad, 自动调整学习率,学习率下降过快过早,导致模型更新慢

  4. RMSprop: optim.RMSprop, 自动调整学习率,对AdaGrad的改进

  5. Adam: optim.Adam, 结合 动量法和RMSprop,同时调整学习率和梯度,训练稳定

  6. AdamW: optim.AdamW, 对Adam的改进,解决权重衰减问题,推荐使用

相关推荐
人工智能AI技术2 小时前
梯度下降基础:AI 模型自我优化的核心方法
人工智能
2301_813599552 小时前
如何设计MongoDB的金融交易流水表_防篡改与精确金额存储Decimal128
jvm·数据库·python
MobotStone2 小时前
拼多多为什么弱化购物车?
人工智能
Rabbit_QL2 小时前
【权重】离线环境怎么用预训练权重
人工智能·pytorch
m0_676544382 小时前
MySQL报错Client does not support authentication_升级客户端
jvm·数据库·python
VBsemi-专注于MOSFET研发定制2 小时前
AI水稻插秧机器人功率器件选型方案——高效、可靠与精准驱动系统设计指南
人工智能·机器人
qyzm2 小时前
Educational Codeforces Round 189 (Rated for Div. 2)
数据结构·python·算法
z4424753262 小时前
SQL中GROUP BY与WHERE子句顺序_如何正确在聚合前过滤数据
jvm·数据库·python
mmWave&THz2 小时前
技术解析:Bolicom-mmWave高速毫米波通信设备赋能港口机械智能化升级
网络·人工智能·系统架构·信息与通信·智能硬件