GPU训练完之后转移到CPU测试

1 保存模型

我们保存模型的方式通常有两种方式

1 torch.save(model,r'model.pkl')
2 torch.save(model.state_dict(),r'model.pkl')   

推荐第二种,在这次示例当中,我们采用第二种方式,保存文件。

2 开始操作

1 首先看一下,原本的model 字典 key

for param_tensor in model.state_dict():        # param_tensor 为参数名称
    print(param_tensor, "\t", model.state_dict()[param_tensor].size())

在这里插入图片描述
2 加载模型

model = My_model()

checkpoint = torch.load(r'model_best4.pkl',map_location='cpu')

查看此时加载后的模型 key
在这里插入图片描述
要比我们原本的模型多了module. 总共7位,所以我们需要一个新的字典重新加载模型参数。

new_state_dict = OrderedDict()
for k,v in checkpoint.items() :
    name = k[7:]
    new_state_dict[name] = v

新的字典构造后 ,我们看一下构造对没。

for k,v in new_state_dict.items():
    print(k)

在这里插入图片描述
完全没问题!现在就可以把这个字典保存,再加载了。

torch.save(new_state_dict,'new.pkl')
model.load_state_dict(torch.load(r'new.pkl',map_location='cpu'))

问题:
1 为什么我们不能把新建好的字典直接给模型加载,还得保存再加载?
答:
因为使用 model.load_state_dicr(torch.load(r’new.pkl’,map_location=‘cpu’))
只能加载二进制文件,我们保存模型参数的时候经常使用 .th 和 .pkl 后缀就是二进制文件。所以我们需要把新构成的字典转换成二进制文件,最后再加载。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值