在跑分类网络EfficientNet遇到如下问题:
RuntimeError: Error(s) in loading state_dict for EfficientNet:
Missing key(s) in state_dict: “_conv_stem.weight”, “_bn0.weight”, “_bn0.bias”, “_bn0.running_mean”,…
Unexpected key(s) in state_dict: “tem.weight”, “ight”, “as”, “nning_mean”, “nning_var”, “m_batches_tracked”,…
原因在于训练和测试的时候用到的参数不一致,通过网上的方案:
model = torch.nn.parallel.DataParallel(model).cuda()
model.load_state_dict(model_para, False) #
可解决不报错问题,但是,在测试的时候效果非常差,甚至无法分类出来。
究其原因,是由于我在训练的时候设置了GPU的ID,设置如下:
parser.add_argument('--gpu', default=None, type=int, help='GPU id to use.') # 正确
parser.add_argument('--gpu', default=0, type=int, help='GPU id to use.') # 错误
因为我电脑只有一张卡,所以不需要设置GPU ID,对上述代码再次进行修改训练得出相应模型再测试,可达到预期效果。