【Pytorch学习笔记】12.修改预训练模型权重参数的方法(用于对单通道灰度图使用预训练模型)


我们在训练单通道图像,即灰度图(如医学影像数据)时,常会使用预训练模型进行训练。
但是一般的预训练模型是以ImageNet数据集预训练的,训练的对象是三通道的彩色图片。
这需要对模型的参数进行修改,让第一个卷积层的参数从3通道卷积改成1通道卷积。
(比如下图是将三通道改成单通道后卷积层的变化)

在这里插入图片描述

我们知道灰度图是三通道图各个通道的加权平均,所以我们可以假设改成单通道后,将3个通道对应的卷积矩阵对应位置相加(sum)得到1通道的卷积矩阵,再去卷积灰度图,这样几乎不折损对图像的特征提取能力。

下面以Resnet50预训练模型为例来修改第1个卷积层的参数,使其能用于单通道图片的训练。

1.导出模型参数,修改参数

Pytorch中修改模型的参数,如果涉及网络结构的变化,需要先修改网络结构再赋予参数值。
即导出预训练模型参数→修改预训练模型参数→修改模型的网络结构→导回修改后的模型

from torchvision.models import resnet50
net = resnet50(pretrained=True)
print(net.conv1)  # 查看第一个卷积层的结构

weights = net.state_dict()  # state_dict()以 有序字典 罗列参数
print(weights.keys())  # 查看参数的key
weights['conv1.weight'].shape  # 根据key取到参数,查看形状

在这里插入图片描述

修改模型参数

weights['conv1.weight'] = weights['conv1.weight'].sum(1, keepdim=True)  # 修改第一个卷积层的参数,从3通道卷积改成1通道卷积
weights['conv1.weight'].shape  # 查看修改后的形状

在这里插入图片描述

2.修改模型结构,导回参数

import torch.nn as nn

# 修改第一个卷积层的结构
net.conv1 = nn.Conv2d(1, 64, kernel_size=(7, 7), stride=(2, 2), padding=(3, 3), bias=False)
# 导入修改后的参数
net.load_state_dict(weights)
net

在这里插入图片描述

修改成功!
接下去就可以用你自己的灰度图数据集来微调这个预训练模型了。

  • 6
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,我可以帮你解答这个问题。 首先,PyTorch提供了许多预训练模型,包括图像分类、目标检测、语义分割等任务的模型。这些预训练模型在大规模数据集上进行了训练,可以用来进行迁移学习,快速实现新的任务。我们可以使用其中的图像分类模型,来对单张数字图像进行预测。 以下是使用PyTorch自带的预训练图像分类模型,实现对单张数字图像的图像分类预测的示例代码: ```python import torch import torchvision import torchvision.transforms as transforms from PIL import Image # 加载预训练模型 model = torchvision.models.resnet18(pretrained=True) # 设置模型为评估模式 model.eval() # 定义转换 transform = transforms.Compose([ transforms.Resize(256), transforms.CenterCrop(224), transforms.ToTensor(), transforms.Normalize( mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225] ) ]) # 加载图像并进行转换 image = Image.open('test.jpg') image = transform(image) # 增加一个维度,使其变成一个batch的形式 image = image.unsqueeze(0) # 对图像进行预测 with torch.no_grad(): outputs = model(image) _, predicted = torch.max(outputs.data, 1) print('预测结果为:', predicted.item()) ``` 这段代码使用了ResNet-18作为预训练模型,对输入的图像进行了预测,并输出了预测结果。需要注意的是,这里的图像需要进行预处理,包括缩放、裁剪、标准化等操作,这些操作可以通过PyTorch的transforms模块进行实现。同时,由于预训练模型在训练时使用的是RGB格式的图像,因此需要将输入图像转换为RGB格式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值