Pytorch保存和加载模型的两种方式

与Tensorflow、Keras等框架一样,Pytorch也提供了两种保存模型的方式,这两种方式都是通过调用pickle序列化方法实现的:

1、只保存模型参数

2、保存完整模型

下面我们依次对这两种方式进行实现,以以下多层感知机模型为例:

def create_net():
    net = nn.Sequential()
    net.add_module('linear1', nn.Linear(15, 20))
    net.add_module('relu1', nn.ReLU())
    net.add_module('linear2', nn.Linear(20, 15))
    net.add_module('relu2', nn.ReLU())
    net.add_module('linear3', nn.Linear(15, 1))
    net.add_module('sigmoid', nn.Sigmoid())
    return net


net = create_net()

模型的基本信息如下:

 

----------------------------------------------------------------
        Layer (type)               Output Shape         Param #
================================================================
            Linear-1                   [-1, 20]             320
              ReLU-2                   [-1, 20]               0
            Linear-3                   [-1, 15]             315
              ReLU-4                   [-1, 15]               0
            Linear-5                    [-1, 1]              16
           Sigmoid-6                    [-1, 1]               0
================================================================
Total params: 651
Trainable params: 651
Non-trainable params: 0
----------------------------------------------------------------
Input size (MB): 0.000057
Forward/backward pass size (MB): 0.000549
Params size (MB): 0.002483
Estimated Total Size (MB): 0.003090
----------------------------------------------------------------
None

1、只保存模型参数

保存模型参数:

torch.save(net.state_dict(), 'net_parameter.pkl')

 加载模型参数:

# 定义模型结构
net_clone = create_net()
# 加载模型参数
net_clone.load_state_dict(torch.load('net_parameter.pkl'))

 而后我们就可以微调模型或调用模型进行预测。

2、保存完整模型

保存完整模型指既保存模型结构又保存模型参数:

torch.save(net, 'net_model.pkl')

加载模型:

net_loaded = torch.load('net_model.pkl')

从上图我们可以看到,只保存模型参数的文件大小为4kb,而保存整个模型的文件大小为12kb,对于一些复杂的模型而言,保存整个模型可能需要占用大量的存储空间。所以推荐保存模型参数,在实际预测时再重新定义模型结构即可。

  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch 中,保存模型两种主要的方式保存整个模型保存模型的参数。下面分别介绍这两种方式的实现方法。 1. 保存整个模型 保存整个模型时,需要将模型的结构和参数都保存下来。这可以通过使用 PyTorch 的 `torch.save()` 函数来实现。 ```python # 定义模型 model = MyModel() # 保存整个模型 torch.save(model, 'model.pth') ``` 上面代码中,`MyModel()` 是自定义的模型类,`model.pth` 是保存整个模型的文件名。 加载整个模型时,可以使用 PyTorch 的 `torch.load()` 函数来加载模型。 ```python # 加载整个模型 model = torch.load('model.pth') ``` 注意,加载模型时需要保证相应的模型代码已经被定义。 2. 保存模型的参数 保存模型的参数时,只需要将模型的参数保存下来,而不需要保存模型的结构。这可以通过使用 PyTorch 的 `state_dict()` 函数来实现。 ```python # 定义模型 model = MyModel() # 保存模型的参数 torch.save(model.state_dict(), 'model_params.pth') ``` 上面代码中,`model.state_dict()` 返回模型的参数字典,`model_params.pth` 是保存模型参数的文件名。 加载模型参数时,需要先定义模型加载相应的参数。 ```python # 定义模型 model = MyModel() # 加载模型的参数 model.load_state_dict(torch.load('model_params.pth')) ``` 注意,加载模型参数时需要保证相应的模型代码已经被定义,并且模型的结构要与保存参数时的模型结构相同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值