陈丹琦团队提出低内存高效零阶优化器MeZO,单卡A100可训练300亿参数模型

8755f99947ade3dbacfd36e16b1cfa1b.png

深度学习自然语言处理 原创
作者:辰宜

今天下午突然发现了一篇陈丹琦大佬的巨作~ 大家一起来简单瞅瞅。

本文旨在介绍一种用于fine-tuning语言模型(LM)的低内存优化器——MeZO,内存减少多达12倍。使用单个A100 800G GPU,MeZO可以训练一个300亿参数的模型。

7c32bae52048472e71a4d62595d683dd.png

论文:Fine-Tuning Language Models with Just Forward Passes
地址:https://arxiv.org/abs/2305.17333
代码:https://github.com/princeton-nlp/MeZO

过去的方法存在的问题,用于优化大型LM的反向传播算法需要大量的内存,因此需要一种低内存优化器。

本文提出的MeZO算法是一种低内存零阶优化器,通过SPSA算法来计算梯度估计,仅需要两次前向传递。MeZO算法可以在不影响LM性能的情况下,大幅减少内存占用,优化各种模型和下游任务。

bdceeb47ab63faeaa64ca738f000c0a4.png
图 1:OPT-13B 使用零样本、上下文学习 (ICL)、MeZO和 Adam (FT) 微调的结果

方法与实验

本文的MeZO算法是基于零阶优化的理论基础。

0fa3e5b8e3a11eab5dc2ff08079b9ed7.png
MeZO伪代码

MeZO算法基于SPSA算法的低内存优化器,通过同时扰动每个权重矩阵来节省计算时间,并且可以与其他梯度优化器结合使用,例如SGD with momentum和Adam。

其在各种模型和下游任务中表现出色,相比于Adam的完全fine-tuning,性能相当,并大幅降低了内存成本。MeZO还可以优化非可微分目标,并且适用于全参数调整和前缀调整。

下面看下所有的实验情况:

f0f86db6e2e7b73d6e5bb42d65f89b7d.png
在RoBERTa-large上的实验
d4bf4aa375bd813fdce7218643a57e13.png
OPT-13B上的实验(有1000个例子)
73adebcc71bccb40f0f8f5713cb90726.png
OPT-30B和OPT-66B上的实验(有1000个例子)
ae9d0be100d8ef4b7e3070a2fe2891e5.png
具有不可微分目标的 MeZO
feb99c09532ccde05b6e61f5024b2608.png
MultiRC上不同OPT模型和调优方法的GPU内存消耗
562f6dffc23c09ec90fb36581683d710.png
可以使用特定硬件和算法进行调整的最大 OPT 模型

做个总结

最后总结下本文的所有内容:

  1. MeZO算法可以极大的减少内存的使用,并不影响LM性能。

  2. 用零阶优化理论可以优化具有高维参数的大型LM。

  3. 基于全局和局部有效秩,可以证明零阶随机梯度下降的收敛速度,以及全局收敛速度会因有效秩而变慢。

  4. 接下来需要将MeZO和其他低内存方法相结合,并研究MeZO在其他领域(如精简和数据集选择)中的适用性。

这可是个大创新,又向人人都能训练大模型迈进一大步,好开心~


进NLP群—>加入NLP交流群

猜你喜欢

转载自blog.csdn.net/qq_27590277/article/details/130960015