mirror of https://github.com/hpcaitech/ColossalAI
2.6 KiB
2.6 KiB
梯度裁剪(旧版本)
作者: Boxiang Wang, Haichen Huang, Yongbin Li
前置教程
示例代码
相关论文
引言
为了加快训练过程和寻求全局最优以获得更好的性能,越来越多的学习率调度器被提出。人们通过控制学习率来调整训练中的下降速度。这使得梯度向量在每一步都能更好地统一。在这种情况下,下降速度可以按预期被控制。 因此,梯度裁剪,一种可以将梯度向量归一化,以将其限制在统一长度的技术,对于那些希望模型性能更好的人来说是不可或缺的。
在使用 Colossal-AI 时,你不必担心实现梯度剪裁,我们以一种有效而方便的方式支持梯度剪裁。你所需要的只是在你的配置文件中增加一个命令。
为什么应该使用 Colossal-AI 中的梯度裁剪
我们不建议用户自己编写梯度剪裁,因为朴素的梯度剪裁在应用张量并行、流水线并行、MoE 等功能时可能会失败。
根据下图,每个 GPU 只拥有线性层中权重的一部分参数。为了得到线性层权重的梯度向量的正确范数,每个 GPU 中的每个梯度向量的范数应该相加。更复杂的是,偏置的分布不同于权重的分布。通信组在求和运算中有所不同。
(注: 这种情况是旧版本的 2D 并行,在代码中的实现是不一样的。但这是一个很好的例子,能够说明在梯度剪裁中统一所有通信的困难。)
不用担心它,因为 Colossal-AI 已经为你处理好。
使用
要使用梯度裁剪,只需在配置文件中添加梯度裁剪范数即可。
clip_grad_norm = 1.0
实例
我们提供了一个展现梯度裁剪的运行实例 。在本例中,我们将梯度裁剪范数设置为1.0,你可以使用以下命令运行脚本:
python -m torch.distributed.launch --nproc_per_node 1 --master_addr localhost --master_port 29500 train_with_engine.py