pytorch加载预训练模型或者自己的模型,并修改最后的分类输出层strict=False

参数是一个字典,所以可以按照字典的格式
去除键值对

        if args.pretrained:
            print("=> using pre-trained model '{}'".format(args.arch))
            model = models.__dict__[args.arch](pretrained=True)
            num_fc_ftr = model.fc.in_features ##重写分类输出层
            model.fc = torch.nn.Linear(num_fc_ftr, num_classes)
            ###############加载自己训练的模型
            print ("加载res34自己训练的模型")
            pretrained_dict = torch.load("day_label_smooth_resnet34_model_best.pth.tar")["state_dict"]
            
            for k,v in model.state_dict().items():
                print (k)
                print (v.shape)
            pretrained_dict.pop('fc.weight') # 加载的参数直接删除全连接层的参数,打印名字看看
            pretrained_dict.pop('fc.bias')
            model.load_state_dict(pretrained_dict, strict=False)
修改 模型名字,按照名字匹配

     model = DPN(num_init_features=64, k_R=96, G=32, k_sec=(3,4,20,3), inc_sec=(16,32,24,128), num_classes=1,decoder=args.decoder)
     http = {'url': 'http://data.lip6.fr/cadene/pretrainedmodels/dpn92_extra-b040e4a9b.pth'}
     pretrained_dict=model_zoo.load_url(http['url'])
     model_dict = model.state_dict()
     pretrained_dict = {k: v for k, v in pretrained_dict.items() if k in model_dict}#filter out unnecessary keys 
     model_dict.update(pretrained_dict)
     model.load_state_dict(model_dict)
     model = torch.nn.DataParallel(model).cuda()
  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值