Pytorch迁移学习加载部分预训练权重

迁移学习在图像分类中常用,通过加载预训练权重能节省训练时间并减少过拟合风险。当网络结构改变时,直接加载会报错。本文介绍了在Pytorch中如何部分加载预训练权重以应对网络结构变化的问题。
摘要由CSDN通过智能技术生成

迁移学习在图像分类领域非常常见,利用在超大数据集上训练得到的网络权重,迁移到自己的数据上进行训练可以节约大量的训练时间,降低欠拟合/过拟合的风险。

如果用原生网络进行迁移学习非常简单,其核心是

model.load_state_dict()

以Pytorch中官方提供的Resnet加载预训练权重的代码为例:

model = ResNet(Bottleneck, [3, 4, 6, 3], **kwargs)
    if pretrained:
        model.load_state_dict(model_zoo.load_url(model_urls['resnet34']))

但很多时候,我们可能需要对原生网络做一些修改,比如自定义地增加一些网络层,改变某些网络层的结构等等,这时候如果直接像上面那样直接加载就会报错。

AttributeError: 'dict' object has no attribute 'seek'. You can only torch.load from a file that is seekable. Please pre-load the data into a buffer like io.BytesIO and try to load from it instead.

因为网络结构发生了变化,预训练权重是以字典的形式存储的,它会和当前网络结构的字典对应不上。

因此,我们需要通过加载部分预训练权重的方式来进行初始化。


                
  • 16
    点赞
  • 121
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值