pytorch 笔记:torch.optim.Adam

  •  torch.optim.Adam 是一个实现 Adam 优化算法的类。
  • Adam 是一个常用的梯度下降优化方法,特别适合处理大规模数据集和参数的深度学习模型
torch.optim.Adam(
    params, 
    lr=0.001, 
    betas=(0.9, 0.999), 
    eps=1e-08, 
    weight_decay=0, 
    amsgrad=False, 
    *, 
    foreach=None, 
    maximize=False, 
    capturable=False, 
    differentiable=False, 
    fused=None)
params待优化参数的可迭代对象,或定义参数组的字典
lr学习率,默认为 1e-3
betas用于计算梯度及其平方的移动平均的系数,默认为 (0.9, 0.999)
eps为了提高数值稳定性而添加到分母的项,默认为 1e-8
weight_decay权重衰减(L2惩罚),默认为 0
amsgrad是否使用 AMSGrad 变种,该变种来源于论文 "On the Convergence of Adam and Beyond",默认为 False
foreach是否使用优化器的 foreach 实现。默认情况下,如果未指定,则在 CUDA 上尝试使用 foreach 而不是循环实现,因为它通常性能更好。
maximize是否最大化目标函数,默认为 False(即最小化目标函数)
differentiable训练中的优化器步骤是否可以进行自动微分。否则,step() 函数将在 torch.no_grad() 上下文中运行。如果不打算通过此实例运行自动微分,请将其设置为 False,默认为 False。
fused是否使用融合实现(仅限 CUDA)。目前支持 torch.float64、torch.float32、torch.float16 和 torch.bfloat16,默认为 None。

 

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
torch.optim.Adam 和 torch.optim.SGD 是 PyTorch 中两种不同的优化器,它们在优化算法和使用方式上存在一些区别。 1. 优化算法: - Adam(Adaptive Moment Estimation)是一种基于梯度的优化算法,它结合了 AdaGrad 和 RMSProp 的优点。它使用动量和自适应学习率来更新参数,能够更快地收敛,并且对于稀疏梯度和噪声较大的问题有较好的表现。 - SGD(Stochastic Gradient Descent)是一种基本的随机梯度下降算法,每次更新参数时仅使用一个样本或一小批样本的梯度。它通过迭代地更新参数来最小化损失函数,适用于大规模数据集和较简单的模型。 2. 学习率调整: - Adam 使用自适应学习率,每个参数都有自己的学习率,根据梯度的历史信息来自动调整学习率。 - SGD 需要手动设置全局学习率,并且可以通过学习率衰减策略进行调整,如按照固定时间表衰减或根据验证集的性能进行衰减。 3. 参数更新方式: - Adam 通过存储每个参数的历史梯度平方的指数衰减平均来计算自适应学习率,使用动量项来加速参数更新。 - SGD 使用每个参数的梯度和学习率来更新参数,可以选择添加动量项来加速收敛。 选择 Adam 还是 SGD 取决于问题的性质和数据集的规模。在大多数情况下,Adam 通常能够更快地收敛,特别是对于复杂的模型和大规模数据集。然而,在某些情况下,SGD 可能会更好地适应局部最优解,并且具有更低的内存使用量。 需要根据具体问题和实验结果来选择合适的优化器。可以尝试不同的优化器并根据模型性能和训练速度进行比较,以确定最佳选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

UQI-LIUWJ

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

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

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

打赏作者

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

抵扣说明:

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

余额充值