python-3.x - 运行时错误 : Error(s) in loading state_dict for ResNet:

标签 python-3.x deep-learning pytorch resnet

我正在使用以下代码加载我的模型。

def load_model(checkpoint_path):
  '''
  Function that loads a checkpoint and rebuilds the model
  '''

  checkpoint = torch.load(checkpoint_path, map_location = 'cpu')

  if checkpoint['architecture'] == 'resnet18':
    model = models.resnet18(pretrained=True)

  # Freezing the parameters
    for param in model.parameters():
        param.requires_grad = False


  else:
    print('Wrong Architecture!')
    return None

  model.class_to_idx = checkpoint['class_to_idx']

  classifier = nn.Sequential(OrderedDict([
                            ('fc1', nn.Linear(512, 1024)),
                            ('relu1', nn.ReLU()),
                            ('dropout', nn.Dropout(0.2)),
                            ('fc2', nn.Linear(1024, 102))
                            ]))


  model.fc = classifier

  model.load_state_dict(checkpoint['state_dict'])

  return model

并且在运行时
# Load your model to this variable
model = load_model('checkpoint.pt')

我收到以下错误,

RuntimeError Traceback (most recent call last) in () 1 # Load your model to this variable ----> 2 model = load_model('checkpoint.pt') 3 4 # If you used something other than 224x224 cropped images, set the correct size here 5 image_size = 224

<ipython-input-11-81aef50793cb> in load_model(checkpoint_path)
     30   model.fc = classifier
     31 
---> 32   model.load_state_dict(checkpoint['state_dict'])
     33 
     34   return model

/opt/conda/lib/python3.6/site-packages/torch/nn/modules/module.py in 
load_state_dict(self, state_dict, strict)
    719         if len(error_msgs) > 0:
    720             raise RuntimeError('Error(s) in loading state_dict for 
{}:\n\t{}'.format(
--> 721                                self.__class__.__name__, 
"\n\t".join(error_msgs)))
    722 
    723     def parameters(self):

RuntimeError: Error(s) in loading state_dict for ResNet:
  Unexpected key(s) in state_dict: "bn1.num_batches_tracked", 
"layer1.0.bn1.num_batches_tracked", "layer1.0.bn2.num_batches_tracked", 
"layer1.1.bn1.num_batches_tracked", "layer1.1.bn2.num_batches_tracked", 
"layer2.0.bn1.num_batches_tracked", "layer2.0.bn2.num_batches_tracked", 
"layer2.0.downsample.1.num_batches_tracked", 
"layer2.1.bn1.num_batches_tracked", "layer2.1.bn2.num_batches_tracked", 
"layer3.0.bn1.num_batches_tracked", "layer3.0.bn2.num_batches_tracked", 
"layer3.0.downsample.1.num_batches_tracked", 
"layer3.1.bn1.num_batches_tracked", "layer3.1.bn2.num_batches_tracked", 
"layer4.0.bn1.num_batches_tracked", "layer4.0.bn2.num_batches_tracked", 
"layer4.0.downsample.1.num_batches_tracked", 
"layer4.1.bn1.num_batches_tracked", "layer4.1.bn2.num_batches_tracked".

最佳答案

我使用的是 Pytorch 0.4.1,但我加载的 Jupyter Notebook 使用的是 0.4.0。所以我将 strict=False 属性添加到 load_state_dict()

model.load_state_dict(checkpoint['state_dict'], strict=False)

关于python-3.x - 运行时错误 : Error(s) in loading state_dict for ResNet:,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54058256/

相关文章:

machine-learning - 如何使用tflearn深度学习进行文档分类

python - 嵌入pytorch

python - 将python模块输出写入toml文件的方法

python - 有没有一种简单的方法可以将一个环境中的相同 Python 库安装到新的 Python 环境中?

python - Python 3 中嵌套 For 循环的最大深度是多少?

python - 试图通过自定义损失,但它不允许我这样做。属性错误: 'float' object has no attribute 'backward'

python - pytorch PIP和CONDA错误?

python - 从 Windows 命令行 : script starts, 启动 Python 脚本失败

python - 如何创建一个能够根据假设做出决策的深度神经网络?

python - 如何从 tensorflow 检查点文件正确恢复网络训练?