首页 > 其他分享 >warm-up原理和训练技巧

warm-up原理和训练技巧

时间:2022-10-11 11:00:16浏览次数:59  
标签:技巧 训练 up 学习 rate warm learning

原理

训练神经网络的一个重要 trick 是 warm up,它被广泛应用在各种模型的训练中。它的命名大概是类比了我们参加体育锻炼前的热身运动。warm up 通过操作训练初始阶段的 learning rate,可以使模型参数更快地收敛,并达到更高的精度。

众所周知,learning rate 如果设置的过大,有可能会导致梯度爆炸,同时也有可能会导致难以收敛到更好的 local minima;反之,如果 learning rate 过小,会导致网络训练得太慢。

在训练初期,由于网络参数是随机初始化的, loss 很大,导致 gradient 很大,此时我们希望 learning rate 小一点,防止梯度爆炸;而在训练中期,我们希望 learning rate 大一点,加速网络训练,在训练末期我们希望网络收敛到 local minima,此时 learning rate 也应该小一点。warm up 的一套流程正好迎合了这种需求。

训练初始,warm up 把学习率设置得很小,随着训练的进行,学习率逐渐上升,最终达到正常训练的学习率。这个阶段就是 warm up 的核心阶段。接着,随着训练的进行,我们希望逐渐减小学习率,(learning rate decay),训练完成时,learning rate 降为 0 。

公式

warm up 有几个重要的参数:

  • n_{wm}:warm up 阶段训练多少步
  • \eta_{wm}:warm up 开始时的 learning rate
  • \eta_0:正式训练初始 learning rate

事实上,任何一种满足第一部分设计需求的 learning rate 更新策略都可以叫 warm up,这里只实现一种。


其中 t 为训练步数,t\leq n_{wm}。我们可以看到,当 t=0 时,初始学习率为 \eta_{wm};随着 t 的增加,学习率逐渐上升,当 t=n_{wm} 时,学习率为 \eta_0,即正式训练的初始学习率。

warm up 阶段结束后,下一步是随着训练的进行,让学习率逐渐降低到 0。这里需要用到两个新的参数:

  • n_{ttl}:总共训练的步数
  • p:power,控制学习率降低的速率

 

从 (2) 可以看到,当 t=n_{wm} 时,\eta_0 前面的参数为 1,学习率就是 \eta_0;当 t=n_{ttl} 时,\eta_0 前面的参数为 0,学习率为 0 。再观察 p ,当 p=1 时,学习率线性降低到 0;当 p<1时,括号里面的底数始终是大于 0 小于 1 的,因此它的 p 次方应该比它本身要大,因此 p<1 会让学习率比同时期线性 decay 得到的学习率更大一点;当 p>1 时,学习率比同时期线性 decay 的学习率要小。由于学习率最终都是降到了 0,显然应该设置 p<1,让正式训练初期学习率降得慢一点,而正式训练末期,学习率迅速降低到 0,而不是 p>1 导致正式训练初期学习率就降得很快,而正式训练末期学习率降得很慢,拖慢训练进程。

代码

参数:

  • warmup_stepsn_{wm},warm up 阶段训练多少步
  • warmup_start_lr\eta_{wm},warm up 开始时的 learning rate
  • lr0\eta_0,正式训练初始 learning rate
  • max_itern_{ttl},总共训练的步数
  • powerp,控制学习率降低的速率
# 设置参数,一般应该写在类里,这里为了方便演示,将其提取出来。
warmup_start_lr = 1e-5
warmup_steps = 1000
max_iter = 80000
lr0 = 1e-2
power = 0.9

warmup_factor = (lr0/warmup_start_lr)**(1/warmup_steps)

def get_lr(t):
    if t <= warmup_steps:
        lr = warmup_start_lr*(warmup_factor**t)
    else:
        factor = (1-(t-warmup_steps)/(max_iter-warmup_steps))**p
        lr = lr0*factor

    return lr

下面把不同 step 对应的 learning rate 画出来:

import matplotlib.pyplot as plt
import numpy as np

steps = np.arange(max_iter)
lrs = list(map(get_lr, steps))
plt.plot(steps, lrs)
plt.show()

 

  学习率变化图

可以发现,前 1000 步 warm up 阶段,学习率由 1e-5 迅速上升到正式训练的初始学习率 1e-2,接着,随着迭代步数的增加,学习率缓慢下降,最终降为0。学习率的变化率(斜率)也也很有意思,warm up 初始阶段,斜率很低,学习率增长缓慢,代表需要维持一段时间的低学习率,以让模型更好地热身。快接近 warmup 尾声时,斜率很高,代表学习率增长得很快,以达到正式训练的初始学习率。decay 的初始阶段,学习率下降得较慢,表示需要维持一段时间的高学习率,以加快模型收敛,训练快结束时,学习率迅速下降,以便模型收敛到更好的 local minima。

为了更好地展示上面描述的过程,这里调整一下参数(并非实际训练,实际训练时可参考上面的各种参数配置比例)。


 

  power=0.5, max_iter=2000, 其余不变

标签:技巧,训练,up,学习,rate,warm,learning
From: https://www.cnblogs.com/chentiao/p/16778453.html

相关文章

  • Windows技巧
    win11添加开机启动项win+r输入:shell:startup,会打开一个目录,把程序图标放进去即可。......
  • 使用element ui的el-upload组件上传图片,记录一下
    使用elementui的el-upload组件上传图片效果预览下面是实现效果,接口方面是把有两个接口,一个接口上传图片,传参是图片和路径,返回值是路径。另一个接口是上传表单内容(用户,......
  • 面试技巧之 STAR 法则 All In One
    面试技巧之STAR法则AllInOne简历、面试STARSituation,Task,Action,Result一.什么是STAR法则?TheSTAR(Situation,Task,Action,Result)formatisa......
  • 数据算法--Hadoop-Spark大数据处理技巧 pdf
    高清扫描版下载链接:https://pan.baidu.com/s/1SCA5hN-0ZbEK_uHZgpBkVg点击这里获取提取码 ......
  • rustup toolchains
    默认的toolchain是stable-x86_64-pc-windows-msvc也可以使用stable-x86_64-pc-windows-gnugnu结尾的需要mingw32默认的需要vsc++buildtoolrustupinstall<toolchai......
  • C# 7.0 新特性: 基于Tuple的“多”返回值方法
    C#7.0新特性1:基于Tuple的“多”返回值方法回顾首先,提出一个问题,C#中,如何使一个方法可返回"多个"返回值?我们先来回顾一下C#6.0及更早版本的做法。 在C#中,通常我们......
  • 辨别 Python 中 load 和 loads 的小技巧
      load和loads都是实现“反序列化”,load通过json.load(open('*.json'))这样的格式,从文件句柄中打开文件,加载到Python的变量中,并以字典的格式转换。而loads必须对......
  • Jupyter 安装使用
     Jupyter的官网:​​http://jupyter.org/index.html​​官方文档:​​https://jupyter-notebook.readthedocs.io/en/stable/​​​​https://github.com/jupyter/jupyter/wik......
  • day07 方法重写&super、this、static关键字&JVM的类加载顺序题目
    day07方法重写1)重写发生在子父类当中2)方法名、参数列表、返回值均相同3)重写的方法,方法体或者访问控制修饰符不同4)子类方法的访问权限不能缩小,比如父类是int,子类重写权......
  • C++多线程同步技巧(二) ---事件
    简介Windows在线程控制方面提供了多种信号处理机制,其中一种便是使用CreateEvent()函数创建事件,然后使用信号控制线程运行。其中将事件变为有信号可使用SetEvent()函数,将......