pytorch加载模型时报错

[转自]https://www.lizenghai.com/archives/4610.html

pytorch加载模型时报错

RuntimeError: Error(s) in loading state_dict for DataParallel:

Missing key(s) in state_dict: “module.backbone.layers.0.stage_1.layers.0.weight”,

这是因为加载的预训练模型之前使用了torch.nn.DataParallel(),而此时没有使用,所以可以加上该模块或者去掉。

加上torch.nn.DataParallel()模块

model = torch.nn.DataParallel(model)

cudnn.benchmark = True

创建一个没有module.的新字典,即将原来字典中module.删除掉

model.load_state_dict = torch.load(‘model/path’)
create new OrderedDict that does not contain module.

from collections import OrderedDict

new_state_dict = OrderedDict()

for k, v in state_dict.items():
	 # remove `module.
	 name = k[7:] 
     new_state_dict[name] = v
model.load_state_dict(torch.load(new_state_dict))

model.load_state_dict({k.replace(‘module.’,”):v for k,v in torch.load(‘model/path’).items()})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch加载模型模型名称不一样,主要有两个方面的原因: 1. 模型名称本身不同:PyTorch加载模型,通过提供模型的名称或路径来加载模型。如果提供的模型名称不一样,就无法找到相应的模型文件进行加载。因此,需要确保提供的模型名称正确且一致。 2. 模型文件缺失或变动:如果模型文件发生了变动,例如更改了模型的保存路径、重新训练模型生成了新的模型文件等,那么在加载模型必须使用与模型文件一致的名称。如果模型文件缺失或名称不一致,PyTorch将无法找到相应的模型文件进行加载。 解决这个问题的方法如下: 1. 检查模型名称:确保提供的模型名称与模型文件的名称一致,包括大小写、后缀等。可以使用文件管理工具(如文件资源管理器)或代码中的路径函数(如`os.path`)来精确获取模型文件的名称。 2. 检查模型文件所在路径:确保模型文件位于正确的路径下,或使用正确的路径字符串来指示模型文件所在的目录。如果模型文件被移动或重新保存,请确保提供的路径与实际路径一致。 3. 检查模型文件:检查模型文件是否存在,包括确保模型文件没有被删除或移动到其他位置。如果模型文件丢失,重新训练或找回原来的模型文件,然后使用正确的名称进行加载。 总之,通过仔细检查模型名称、路径和文件的一致性,可以解决PyTorch加载模型名称不一样的问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值