Pytorch ddp切换forward函数 验证ddp是否生效

DDP及其在pytorch中应用

ddp默认调用forward函数,有些模型无法使用forward函数,可以对模型包装一下。

python 复制代码
class modelWraper(nn.Module):
    def __init__(self, model):
        super().__init__()
        self.model = model

    def forward(self, *args, **kwargs):
        return self.model.rlhf(*args, **kwargs)

有时ddp跑起来,不确定是否生效,loss backward后不同rank进程的梯度应该一样的,可以通过print 梯度确认。

python 复制代码
loss.backward()
grad_flag = raw_model.lm_head.weight.grad[0,:3]
print(f"grad {ddp_rank} {grad_flag}")


grad 1 tensor([2.9296e-04, 6.2223e-05, 1.0089e-03], device='cuda:1')
grad 0 tensor([2.9296e-04, 6.2223e-05, 1.0089e-03], device='cuda:0')

pytorch分布式系列2------DistributedDataParallel是如何做同步的?

相关推荐
程序趣谈1 小时前
算法随笔_74: 不同路径_1
数据结构·python·算法
乱世刀疤1 小时前
AI绘画软件Stable Diffusion详解教程(11):图生图进阶篇(局部用上传蒙版重绘)
人工智能·ai作画·stable diffusion
love you joyfully1 小时前
生成对抗网络——pytorch与paddle实现生成对抗网络
pytorch·生成对抗网络·paddle
Cheng_08291 小时前
LLM自动化评测
python
朱剑君2 小时前
用Python打造AI玩家:挑战2048,谁与争锋
人工智能·python
东临碣石823 小时前
【AI论文】MM-Eureka:基于规则的大规模强化学习探索视觉“啊哈”时刻
人工智能
JM丫3 小时前
python基础
笔记·python
陌陌6233 小时前
Prompt优化 COT/COD
人工智能·prompt
訾博ZiBo4 小时前
AI日报 - 2025年3月17日
人工智能
树莓集团4 小时前
树莓科技集团董事长:第五代产业园运营模式的深度剖析与展望
大数据·人工智能·科技·物联网·百度