赞
踩
PyTorch提供了三种方式来保存和加载模型,在这三种方式中,加载模型的代码和保存模型的代码必须相匹配,才能保证模型的加载成功。通常情况下,使用第一种方式(保存和加载模型状态字典)更加常见,因为它更轻量且不依赖于特定的模型类。
- import torch
- import torch.nn as nn
-
- model = nn.Sequential(nn.Linear(128, 16), nn.ReLU(), nn.Linear(16, 1))
-
- # 保存整个模型
- torch.save(model.state_dict(), 'sample_model.pt')
- import torch
- import torch.nn as nn
-
- # 下载模型参数 并放到模型中
- loaded_model = nn.Sequential(nn.Linear(128, 16), nn.ReLU(), nn.Linear(16, 1))
- loaded_model.load_state_dict(torch.load('sample_model.pt'))
- print(loaded_model)
显示如下:
- Sequential(
- (0): Linear(in_features=128, out_features=16, bias=True)
- (1): ReLU()
- (2): Linear(in_features=16, out_features=1, bias=True)
- )
state_dict:PyTorch中的state_dict是一个python字典对象,将每个层映射到其参数Tensor。state_dict对象存储模型的可学习参数,即权重和偏差,并且可以非常容易地序列化和保存。
- import torch
- import torch.nn as nn
-
- net = nn.Sequential(nn.Linear(128, 16), nn.ReLU(), nn.Linear(16, 1))
-
- # 保存整个模型,包含模型结构和参数
- torch.save(net, 'sample_model.pt')
- import torch
- import torch.nn as nn
-
- # 加载整个模型,包含模型结构和参数
- loaded_model = torch.load('sample_model.pt')
- print(loaded_model)
显示如下:
- Sequential(
- (0): Linear(in_features=128, out_features=16, bias=True)
- (1): ReLU()
- (2): Linear(in_features=16, out_features=1, bias=True)
- )
- import torch
- import torch.nn as nn
-
- model = nn.Sequential(nn.Linear(128, 16), nn.ReLU(), nn.Linear(16, 1))
-
- input_sample = torch.randn(16, 128) # 提供一个输入样本作为示例
- torch.onnx.export(model, input_sample, 'sample_model.onnx')
- import torch
- import torch.nn as nn
- import onnx
- import onnxruntime
-
- loaded_model = onnx.load('sample_model.onnx')
- session = onnxruntime.InferenceSession('sample_model.onnx')
- print(session)
保存模型函数torch.save
将对象序列化保存到磁盘中,该方法原理是基于python中的pickle
来序列化,各种Models
,tensors
,dictionaries
都可以使用该方法保存。保存的模型文件名可以是.pth
, .pt
, .pkl
。
- def save(
- obj: object,
- f: FILE_LIKE,
- pickle_module: Any = pickle,
- pickle_protocol: int = DEFAULT_PROTOCOL,
- _use_new_zipfile_serialization: bool = True
- ) -> None:
备注:关于模型的后缀.pt、.pth、.pkl它们并不存在格式上的区别,只是后缀名不同而已。 torch.save()语句保存出来的模型文件没有什么不同。
加载模型函数torch.load
- def load(
- f: FILE_LIKE,
- map_location: MAP_LOCATION = None,
- pickle_module: Any = None,
- *,
- weights_only: bool = False,
- **pickle_load_args: Any
- ) -> Any:
torch.device
对象加载模型参数torch.nn.Module.load_state_dict
序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。 在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。
- def load_state_dict(self, state_dict: 'OrderedDict[str, Tensor]',
- strict: bool = True):
函数作用是“获取优化器当前状态信息字典”,在神经网络中模型上训练出来的模型参数,也就是权重和偏置值。在Pytorch中,定义网络模型是通过继承torch.nn.Module来实现的。其网络模型中包含可学习的参数(weights, bias, 和一些登记的缓存如batchnorm’s running_mean 等)。模型内部的可学习参数可通过两种方式进行调用:
def state_dict(self, destination=None, prefix='', keep_vars=False):
除模型外,优化器对象(torch.optim)同样也有一个状态字典,包含的优化器状态信息以及使用的超参数。由于状态字典属于Python 字典,因此对 PyTorch 模型和优化器的保存、更新、替换、恢复等操作都比较便捷。
采用仅加载模型参数的方式,指定设备类型进行模型加载,代码如下:
- model_path = '/opt/sample_model.pth'
-
- device = torch.device("cuda" if torch.cuda.is_available() else "cpu")
- map_location = torch.device(device)
-
- model.load_state_dict(torch.load(self.model_path, map_location=self.map_location))
我们在使用pytorch构建模型并且训练完成后,下一步要做的就是把这个模型放到实际场景中应用,或者是分享给其他人学习、研究、使用。因此,我们开始思考一个问题,提供哪些模型信息,能够让对方能够完全复现我们的模型?
可以看到,根据我们提供的模型代码/模型参数/数据集/使用文档,别人就可以复现整个模型。
3.2 为什么要约定格式
根据上一段的思路,我们知道模型重现的关键是模型结构/模型参数/数据集,那么我们提供或者希望别人提供这些信息,需要一个交流的规范,这样才不会1000个人给出1000种格式,而 .pt .pth .bin 以及 .onnx 就是约定的格式。
torch.save
: Saves a serialized object to disk. This function uses Python’s pickle
utility for serialization. Models, tensors, and dictionaries of all kinds of objects can be saved using this function.
不同的后缀只是用于提示我们文件可能包含的内容,但是具体的内容需要看模型提供者编写的README.md才知道。而在使用torch.load()方法加载模型信息的时候,并不是根据文件的后缀进行的读取,而是根据文件的实际内容自动识别的,因此对于torch.load()方法而言,不管你把后缀改成是什么,只要文件是对的都可以读取。
torch.load
: Uses pickle
’s unpickling facilities to deserialize pickled object files to memory. This function also facilitates the device to load the data into
“一切皆文件”的思维才是正确打开计算机世界的思维方式,文件后缀只作为提示作用,在Windows系统中也会用于提示系统默认如何打开或执行文件,除此之外,文件后缀不应该成为我们认识和了解文件阻碍。
下面是一个整理了 .pt
、.pth
、.bin
、ONNX 和 TorchScript 等 PyTorch 模型文件格式的表格:
格式 | 解释 | 适用场景 | 可对应的后缀 |
---|---|---|---|
.pt 或 .pth | PyTorch 的默认模型文件格式,用于保存和加载完整的 PyTorch 模型,包含模型的结构和参数等信息。 | 需要保存和加载完整的 PyTorch 模型的场景,例如在训练中保存最佳的模型或在部署中加载训练好的模型。 | .pt 或 .pth |
.bin | 一种通用的二进制格式,可以用于保存和加载各种类型的模型和数据。 | 需要将 PyTorch 模型转换为通用的二进制格式的场景。 | .bin |
ONNX | 一种通用的模型交换格式,可以用于将模型从一个深度学习框架转换到另一个深度学习框架或硬件平台。在 PyTorch 中,可以使用 torch.onnx.export 函数将 PyTorch 模型转换为 ONNX 格式。 | 需要将 PyTorch 模型转换为其他深度学习框架或硬件平台可用的格式的场景。 | .onnx |
TorchScript | PyTorch 提供的一种序列化和优化模型的方法,可以将 PyTorch 模型转换为一个序列化的程序,并使用 JIT 编译器对模型进行优化。在 PyTorch 中,可以使用 torch.jit.trace 或 torch.jit.script 函数将 PyTorch 模型转换为 TorchScript 格式。 | 需要将 PyTorch 模型序列化和优化,并在没有 Python 环境的情况下运行模型的场景。 | .pt 或 .pth |
.pt .pth格式
一个完整的Pytorch模型文件,包含了如下参数:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。