大模型高效训练基础知识:梯度累积(Gradient Accumulationn)

梯度累积

梯度累积(Gradient Accumulation)的基本思想是将一次性的整批参数更新的梯度计算变为以一小步一小步的方式进行(如下图),具体而言该方法以小批次的方式进行模型前向传播和反向传播,过程中迭代计算多个小批次梯度并累加,当累积到足够多的梯度时,执行模型的优化步骤更新参数。这也是一种典型的时间换空间的做法,即我们可以实现在有限的GPU内存上更新大量参数,不过额外添加的小批次前向传播和后向传播会使得训练速度变慢一些。
在这里插入图片描述
参数更新方式可以使用随机梯度下降(Stochastic Gradient Descent)为例进行说明:

使用global batch(即全批次)训练时,参数更新公式为:
V t = V t − 1 − l r ∗ g r a d V_t=V_{t-1}-l_{r}*grad Vt=Vt1lrgrad
简化公式, V V V表示参数集, l r l_r lr表示学习率, g r a d grad grad表示全批次梯度。

使用梯度累积的mini-batch(即小批次)训练时,参数更新公式为:
V t = V t − 1 − l r ∗ ∑ i = 0 N g r a d i V_t=V_{t-1}-l_{r}*\sum_{i=0}^{N}grad_i Vt=Vt1lri=0Ngradi
g r a d i grad_i gradi表示第 i i i个批次反向传播时计算的梯度。

Transformers框架中开启梯度累积非常简单,仅需在TrainingArguments内指定累积步长即可:

training_args = TrainingArguments(
    per_device_train_batch_size=1, gradient_accumulation_steps=4, gradient_checkpointing=True, **default_args
)

trainer = Trainer(model=model, args=training_args, train_dataset=ds)
result = trainer.train()

参考文献

  1. Gradient Accumulation
  2. 聊聊梯度累加(Gradient Accumulation)
  3. 梯度累积算法
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch中的梯度累积是指在训练过程中,将多个小批量数据的梯度进行累加,而不是每次反向传播后自动清零梯度。这个特性可以通过调用`loss.backward()`来实现,但在梯度累积时需要手动将梯度清零。 梯度累积的好处在于可以在内存有限的情况下使用更大的批量大小,从而提高模型训练效果。另外,梯度累积还能够支持多任务训练,因为在多任务中共享的张量的梯度会自动累加。 具体实现梯度累积的代码示例如下: ``` optimizer.zero_grad() # 将梯度清零 for i, data in enumerate(train_loader): inputs, labels = data # 前向传播 outputs = model(inputs) loss = criterion(outputs, labels) # 反向传播 loss.backward() if (i+1) % accum_steps == 0: # 每经过 accum_steps 个小批量数据进行一次梯度更新 optimizer.step() # 更新参数 optimizer.zero_grad() # 将梯度清零 ``` 在这个示例中,我们在每经过 `accum_steps` 个小批量数据时进行一次参数更新,并在更新之后将梯度清零。这样就实现了梯度累积的效果。需要注意的是,`accum_steps`需要根据具体的情况进行调整,以平衡内存占用和训练效果。 参考资料: PyTorch默认会对梯度进行累加。即,PyTorch会在每一次backward()后进行梯度计算,但是梯度不会自动归零,如果不进行手动归零的话,梯度会不断累加。 梯度累积时,每个batch仍然正常前向传播以及反向传播,但是反向传播之后并不进行梯度清零,因为PyTorch中的backward()执行的是梯度累加的操作,所以当我们调用N次loss.backward()后,这N个batch的梯度都会累加起来。 在PyTorch的设计原理上,利用梯度累加可以在最多保存一张计算图的情况下进行多任务的训练。另外一个理由是在内存不足的情况下,可以叠加多个batch的梯度作为一个大batch进行迭代。由于PyTorch的动态图和autograd机制,设置梯度为0比较复杂。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值