pytorch重载optimizer参数时报错:RuntimeError: expected device cpu but got device cuda:0的解决方法

1. 问题描述:

​ 我在使用torch.save()保存了optimizer的参数过后,

torch.save(
            {
                'state_dict':net.state_dict(),
                'optimizer':optimizer.state_dict(),
                'epochID':epoch,
            },
                filename
        )

再次利用optimizer.load_state_dict()加载参数,在optimizer.step()处报错:

RuntimeError: expected device cpu but got device cuda:0

2. 解决办法:

​ 重载optimizer的参数时将所有的tensor都放到cuda上(加载时默认放在cpu上了),代码片段如下:

checkpoint = torch.load(filename)
net.load_state_dict(checkpoint['state_dict'])
optimizer.load_state_dict(checkpoint['optimizer'])
for state in optimizer.state.values():
    for k, v in state.items():
        if torch.is_tensor(v):
            state[k] = v.cuda()
current_epoch = checkpoint['epochID'] + 1

顺利解决问题~

评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值