angularjs中state的参数4_pytorch储存读取模型参数

9f1729e567a8ef0a4e4274ecffda53b4.png

在用pytorch写代码的时候,经常遇到要临时储存模型参数,后续再加载该模型的情况。例如预训练模型之后,肯定要将预训练的模型存储一下,以便后续训练过程再载入该模型。这边常见的做法是利用torch.save load load_state_dict这三个函数进行处理。

torch.save({'model': model.state_dict()}, 'zhenghuo.model')
# 将model的参数储存到zhenghuo.model里面

config = torch.load('zhenghuo.model')
newmodel.load_state_dict(config['model'], strict=False)
# 假设我们新建了一个newmodel实例,将之前储存的参数加载进来

但是这里我产生了一个巨大疑问。假设我的模型里面有两个全连接层,那加载的时候怎么区分这两个线性层是不一样的呢。

这边我设置一个有两个全连接层的Model,直接读取其参数列表,看看会输出什么。

class Model(nn.Module):
    def __init__(self):
        super(Model, self).__init__()
        self.linear1 = nn.Linear(2, 2)
        self.linear2 = nn.Linear(3, 3)


a = Model()
print(a.state_dict())

28f9f9d6fc7df2b5aff8d6cf2529f09d.png

可以看到state_dict把我设置的全连接层的名字也存下来了,linear1和linear2分别储存各自的权重和偏移量,这样就避免了歧义的问题。

那研究中还可能遇到一种情况(真实经历):我辛辛苦苦用机子跑了一个礼拜,得到了一个很满意的模型。结果我突然发现我要改一下model结构。例如加一个全连接层或者删除一个全连接层。这样模型结构就发生了变化。不一样的model是否还可以加载参数呢。

这里举一个例子。我们假设一开始用的是newModel,里面只有一个全连接层linear1。后来我突发奇想要再加一个全连接层linear2,也就是Model。这样我拿newModel的参数加载给Model,会怎么样呢?

class Model(nn.Module):
    def __init__(self):
        super(Model, self).__init__()
        self.linear1 = nn.Linear(2, 2)
        self.linear2 = nn.Linear(3, 3)


class newModel(nn.Module):
    def __init__(self):
        super(newModel, self).__init__()
        self.linear1 = nn.Linear(2, 2)

5cc513df66c2e86acf3352cb74151b79.png
newModel的参数,只有linear1

可以看到newModel存下来的参数只有linear1。我把它存在了zhenghuo.model里面(整活)

a = Model()
print(a.state_dict())
c = torch.load('zhenghuo.model')
a.load_state_dict(c['model'], strict=False) # strict划重点
print(a.state_dict())

a是一个Model的实例,我们分别读取它在加载参数之前和之后的state_dict()

5b74014866acbced47e489f292379c0e.png
请和之前的结果图比较,看看发生了啥

结果是只有linear1的权重和偏移量被覆盖了,linear2保持随机初始化出来的数据(我的zhenghuo.model里面也根本没有关于linear2的任何信息)。其中load_state_dict有一个参数strict,将其设置成true则会报错,报错信息是没有linear2的参数。也就是说当strict=True的时候,只有之前保存的模型和新模型一模一样,才可以加载参数。

我再把Model的两个全连接层名字更改一下

class Model(nn.Module):
    def __init__(self):
        super(Model, self).__init__()
        self.linear2 = nn.Linear(2, 2)
        self.linear3 = nn.Linear(3, 3)


class newModel(nn.Module):
    def __init__(self):
        super(newModel, self).__init__()
        self.linear1 = nn.Linear(2, 2)

可以看到现在Model里面已经不包含linear1这个全连接层了,按我的理解,即使再读取newModel的参数,也不会对Model的参数产生影响。

1770ffc8e98effd237c85de53647663e.png

可以看到读取参数前后,模型参数确实没变。

也就是说,假设我预训练好了一个模型,储存了该模型的参数。后续当我想要对模型进行拓展,直接加载之前保存的参数也是没有问题的。需要注意的是原模型的部件不能再被修改,只能增加或者删除。如果更改了某个部件例如一个全连接层的名字,那么在加载过程中该部件将不会继承预训练模型的数据。如果真的不想要这个全连接层删除掉就好了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: segmentation_models_pytorch 是一个基于 PyTorch 的图像分割库,可以用来训练语义分割模型。下面是使用 segmentation_models_pytorch 实现单模型训练的基本步骤: 1. 安装 segmentation_models_pytorch 和其依赖项: ``` pip install segmentation-models-pytorch ``` 2. 加载数据集并进行预处理。可以使用 torchvision 或者其他图像处理库加载数据集,并对数据进行预处理,如裁剪、缩放、归一化等操作。 3. 定义模型。使用 segmentation_models_pytorch 提供的模型类(如 UNet、FPN、PSPNet 等)来定义模型。 ```python import segmentation_models_pytorch as smp model = smp.Unet( encoder_name="resnet34", # 使用 ResNet34 作为编码器 encoder_weights="imagenet", # 加载预训练权重 in_channels=3, # 输入通道数 classes=2, # 分类数 ) ``` 4. 定义损失函数和优化器。可以选择使用交叉熵损失函数和 Adam 优化器。 ```python import torch.nn as nn import torch.optim as optim criterion = nn.CrossEntropyLoss() optimizer = optim.Adam(model.parameters(), lr=0.001) ``` 5. 训练模型。使用 DataLoader 加载数据集,并对模型进行训练。 ```python from torch.utils.data import DataLoader train_loader = DataLoader(dataset, batch_size=4, shuffle=True) for epoch in range(num_epochs): running_loss = 0.0 for i, data in enumerate(train_loader, 0): inputs, labels = data optimizer.zero_grad() outputs = model(inputs) loss = criterion(outputs, labels) loss.backward() optimizer.step() running_loss += loss.item() print(f"Epoch {epoch+1}, Loss: {running_loss/len(train_loader)}") ``` 6. 保存模型。训练完毕后,可以使用 torch.save() 方法将模型保存到本地。 ```python torch.save(model.state_dict(), "model.pth") ``` ### 回答2: segmentation_models_pytorch是一个基于PyTorch实现的语义分割模型库。使用segmentation_models_pytorch实现单模型训练可以通过以下步骤完成。 首先,安装segmentation_models_pytorch库。可以通过pip install segmentation_models_pytorch命令来安装。 导入所需的库和模型。常用的库包括torch,torchvision和segmentation_models_pytorch。可以使用以下命令导入库: ```python import torch import torchvision.transforms as transforms import segmentation_models_pytorch as smp ``` 加载和预处理训练数据。可以使用torchvision的transforms来定义一系列的数据预处理操作,例如裁剪、缩放和标准化等。之后,使用torch.utils.data.DataLoader来加载和批量处理数据。 定义模型架构。可以选择使用segmentation_models_pytorch预定义的模型架构,例如UNet、PSPNet和DeepLab等。根据任务需求选择合适的模型,并初始化相关参数。 定义优化器和损失函数。常见的优化器有Adam和SGD等,损失函数常选择交叉熵损失函数。可以使用torch.optim的函数来定义优化器,使用torch.nn的损失函数来定义损失函数。 进行模型训练。使用torch.utils.data.DataLoader加载训练数据集,并迭代训练数据集的每个批次。将批次数据输入模型进行前向传播,获取模型的输出。计算损失,并进行反向传播更新模型参数。重复以上步骤直到达到预定的训练轮数或达到设定的训练目标。 保存和加载训练好的模型。可以使用torch.save函数将训练好的模型保存到指定的文件路径,使用torch.load函数加载保存的模型文件。 以上是使用segmentation_models_pytorch实现单模型训练的基本步骤。根据具体任务和数据的不同,可能还需要进行一些细节操作,例如数据增强、学习率调整和模型评估等。 ### 回答3: segmentation_models_pytorch是一个基于PyTorch的分割模型训练库,可以应用于图像分割任务。下面我将介绍如何使用segmentation_models_pytorch实现单模型训练。 首先,我们需要安装segmentation_models_pytorch库。可以使用pip命令进行安装: ``` pip install segmentation-models-pytorch ``` 在训练之前,我们需要准备好训练数据和标签。通常情况下,训练数据是一些图像,标签则是对应每个像素点的分类或分割结果。 接下来,我们需要导入所需的库: ``` import segmentation_models_pytorch as smp import torch import torch.nn as nn import torch.optim as optim from torch.utils.data import DataLoader, Dataset ``` 然后,我们需要创建一个自定义的数据集类,该类继承自torch.utils.data.Dataset类,并实现__len__和__getitem__方法,用于加载和处理数据。 接着,我们可以选择一个合适的分割模型,比如Unet、FPN等。这些模型可以通过调用smp库的函数进行初始化,比如: ``` model = smp.Unet( encoder_name="resnet34", encoder_weights="imagenet", classes=1, activation='sigmoid' ) ``` 在这里,我们选择了一个使用ResNet-34作为编码器、预训练权重为ImageNet数据集、分类数为1(二分类问题)的Unet模型。 然后,我们可以定义损失函数和优化器: ``` criterion = nn.BCELoss() optimizer = optim.Adam(model.parameters(), lr=0.001) ``` 接着,我们可以进行训练循环,依次迭代数据进行训练和优化: ``` for epoch in range(num_epochs): for batch in dataloader: inputs, labels = batch optimizer.zero_grad() outputs = model(inputs) loss = criterion(outputs, labels) loss.backward() optimizer.step() ``` 最后,我们可以保存模型并在需要预测时加载模型进行测试: ``` torch.save(model.state_dict(), "segmentation_model.pt") model.load_state_dict(torch.load("segmentation_model.pt")) ``` 以上就是使用segmentation_models_pytorch实现单模型训练的过程。根据具体任务需求,你也可以调整模型、损失函数、优化器等参数来进行更灵活的训练。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值