【torch.optim】优化器的使用 / 学习率的调整 / SWA策略

作者:佚名    发布时间:2024-08-26 06:26:42    浏览:

[返回]

是实现各种优化算法的包。大多数常用的方法都已得到支持,而且接口足够通用,因此将来还可以轻松集成更复杂的方法。

为了使用一个优化器,必须构造一个优化器对象,它将保存当前状态,并将根据计算的梯度更新参数。

  • 构建优化器

要构造一个优化器,必须给它一个包含参数(所有的参数应该是)的可迭代对象来优化。然后,可以指定特定于优化器的选项,如学习率、权重衰减等。

 
  • Per-parameter

优化器还支持指定per-parameter options。要做到这一点,不是传递一个的迭代对象,而是传递一个 的迭代对象。它们每个都将定义一个单独的参数组,并且应该包含一个键,包含属于它的参数列表。其他键应该与优化器接受的关键字参数匹配,并将用作该组的优化选项。

例如,当你想指定每层的学习率时:

 

这意味****的参数将使用默认的学习率,模型。的参数将使用的学习率,所有参数将使用的。

  • optimization step

所有优化器都实现了一个方法,用于更新参数。它有两种用法:

(1) : 这是大多数优化器支持的简化版本。该函数可以在梯度计算完成后调用,例如。

 

(2)

一些优化算法(如Conjugate GradientLBFGS)需要多次重新计算函数,所以你必须传入一个闭包,允许它们重新计算你的模型。闭包应该清除梯度,计算损失并返回。

 
 
 
  • 参数
    • :指定应当被优化的张量,是 和 的迭代器类型。
    • : ****包含优化选项默认值的字典(当参数组没有指定这些值时使用)。
  • 方法
Optimizer.add_param_group在优化器的param_groups中添加一个参数组。
Optimizer.load_state_dict加载优化器状态。
Optimizer.state_dict以字典的形式返回优化器的状态。
Optimizer.step执行单个优化步骤(参数更新)。
Optimizer.zero_grad设置所有优化的 torch.Tensor 的梯度为零
AdadeltaAdadelta算法的实现
AdagradAdagrad 算法的实现
AdamAdam算法的实现
AdamWAdamW 算法的实现
SparseAdam适合稀疏张量的Adam算法的实现
AdamaxAdamax algorithm 算法的实现
ASGDAveraged Stochastic Gradient Descent. 算法的实现
LBFGSL-BFGS 算法的实现
NAdamNAdam 算法的实现
RAdamRAdam 算法的实现
RMSpropRMSprop 算法的实现
Rpropresilient backpropagation 算法的实现
SGDstochastic gradient descent (optionally with momentum). 算法的实现

****提供了几种基于epoch数量调整学习率的方法。

允许基于某些验证度量动态地降低学习率。

学习率调度应在优化器更新后应用 :

 

大多数学习率调度器可以称为back-to-back调度器(也称为链式调度器)。每个调度器一个接一个地应用于前一个调度器获得的学习率。

 

我们将使用以下模板来引用调度器算法。

 
 
lr_scheduler.LambdaLR将每个参数组的学习率设置为初始lr乘以给定函数。
lr_scheduler.MultiplicativeLR将每个参数组的学习率乘以指定函数中给定的因子。
lr_scheduler.StepLR每个step_size epoch将每个参数组的学习率衰减gamma。
lr_scheduler.MultiStepLR一旦epoch的数量达到一个里程碑,将每个参数组的学习率衰减为gamma。
lr_scheduler.ConstantLR将每个参数组的学习率衰减一个小的常数因子,直到epoch的数量达到预定义的里程碑:total_iters。
lr_scheduler.LinearLR通过线性改变小的乘法因子衰减每个参数组的学习率,直到epoch的数量达到预定义的里程碑:total_iters。
lr_scheduler.ExponentialLR每一个epoch衰减每个参数组的学习率gamma。
lr_scheduler.PolynomialLR在给定的total_iters中使用多项式函数衰减每个参数组的学习率。
lr_scheduler.CosineAnnealingLR使用余弦退火计划设置每个参数组的学习率
lr_scheduler.ChainedScheduler学习速率调度器的链表。
lr_scheduler.SequentialLR接收预计在优化过程和里程碑点期间顺序调用的调度器列表,该列表提供精确的间隔,以反映在给定时间段里应该调用哪个调度器。
lr_scheduler.ReduceLROnPlateau当metric停止改进时,降低学习率。
lr_scheduler.CyclicLR根据CLR (cycle learning rate policy)策略设置各参数组的学习率。
lr_scheduler.OneCycleLR按照1cycle学习率策略设置各参数组的学习率。
lr_scheduler.CosineAnnealingWarmRestarts使用余弦退火计划设置每个参数组的学习率

实现随机加权平均(SWA)。特别是, 类实现SWA模型, 实现了SWA学习率调度器和 是一个效用函数,用于在训练结束时更新SWA批归一化统计信息。

类用于计算SWA模型的权重。可以通过运行以下命令创建一个:

 

这里的模型可以是任意的对象。将跟踪模型参数的运行平均值。要更新这些平均值,你可以使用函数:

 
 

通常,在SWA中,学习率被设置为一个高常数值。SWALR是一个学习率调度器,它将学习率退火到一个固定的值,然后保持它不变。例如,下面的代码创建了一个调度器,它在每个参数组内的5个周期内将学习率从初始值线性退火到0.05 :

 

你也可以使用余弦退火到一个固定的值,而不是线性退火通过设置****

允许在训练结束时计算给定数据加载器上SWA模型的batchnorm统计数据:

 

将应用于数据加载器中的每个元素,并计算模型中每个批处理规范化层的激活统计信息。

默认情况下,****计算您提供的参数的平均值,但是您也可以使用带有avg_fn参数的自定义平均函数。在下面的例子中,ema_model计算一个指数移动平均。

 
 
 

搜索

平台注册入口