CosineAnnealingWarmRestarts¶
- class torch.optim.lr_scheduler.CosineAnnealingWarmRestarts(optimizer, T_0, T_mult=1, eta_min=0.0, last_epoch=-1, verbose='deprecated')[source][source]¶
使用余弦退火计划设置每个参数组的学习率。
设置为初始 lr, 是自上次重启以来的 epoch 数, 是 SGDR 中两次热重启之间的 epoch 数
当 时,设置 。当 在重启后,设置 。
它已在 SGDR: Stochastic Gradient Descent with Warm Restarts 中提出。
- 参数
- load_state_dict(state_dict)[source]¶
加载调度器的状态。
- 参数
state_dict (dict) – 调度器状态。应为从调用
state_dict()
返回的对象。
- print_lr(is_verbose, group, lr, epoch=None)[source]¶
显示当前学习率。
Deprecated since version 2.4:
print_lr()
已弃用。请使用get_last_lr()
访问学习率。
- step(epoch=None)[source][source]¶
Step 可以在每次批次更新后调用。
示例
>>> scheduler = CosineAnnealingWarmRestarts(optimizer, T_0, T_mult) >>> iters = len(dataloader) >>> for epoch in range(20): >>> for i, sample in enumerate(dataloader): >>> inputs, labels = sample['inputs'], sample['labels'] >>> optimizer.zero_grad() >>> outputs = net(inputs) >>> loss = criterion(outputs, labels) >>> loss.backward() >>> optimizer.step() >>> scheduler.step(epoch + i / iters)
此函数可以以交错方式调用。
示例
>>> scheduler = CosineAnnealingWarmRestarts(optimizer, T_0, T_mult) >>> for epoch in range(20): >>> scheduler.step() >>> scheduler.step(26) >>> scheduler.step() # scheduler.step(27), instead of scheduler(20)