解决多卡加载预训练模型0卡内存占用大的问题

在进行多卡训练模型时遇到显存不足的错误,特别是第一张卡占用显著。文章提到,通过将预训练模型的参数加载到CPU上而非直接在GPU上,可以缓解这一问题,从而避免显存溢出。修改后的代码示例展示了如何使用`torch.load`时指定`map_location=cpu`来实现这一方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、问题描述

在多卡加载与训练模型的时候,出现显卡内存不足的错误,batchsize放到很小以后观察发现第一张卡占用内存比其他几张大了很多。

在这里插入图片描述

     #迁移学习
    if cfg.feature_extract:
        #print("feature_extract")
        backbone_weight_path=cfg.backbone_weight_path

        load_model = torch.load(backbone_weight_path)
        backbone.load_state_dict(load_model, strict=False)

解决方法:
把预训练模型参数map到cpu上去。

修改代码

     #迁移学习
    if cfg.feature_extract:
        #print("feature_extract")
        backbone_weight_path=cfg.backbone_weight_path

        load_model = torch.load(backbone_weight_path,map_location='cpu')
        backbone.load_state_dict(load_model, strict=False)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值