[pytorch、学习] - 4.5 读取和存储
生活随笔
收集整理的這篇文章主要介紹了
[pytorch、学习] - 4.5 读取和存储
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
參考
4.5 讀取和存儲
到目前為止,我們介紹了如何處理數據以及如何構建、訓練和測試深度學習模型。然而在實際中,我們有時需要把訓練好的模型部署到很多不同的設備。在這種情況下,我們可以把內存中訓練好的模型參數存儲在硬盤上供后續讀取使用。
4.5.1 讀寫tensor
我們可以直接使用save函數和load函數分別存儲和讀取Tensor。
下面的例子創建了Tensor變量x,并將其存儲在文件名為x.pt的文件里.
import torch import torch.nn as nnx = torch.ones(3) torch.save(x, 'x.pt')然后我們將數據從存儲的文件讀回內存
x2 = torch.load('x.pt') x2
存儲一個Tensor列表并返回
存儲并讀取一個從字符串映射到Tensor的字典
4.5.2 讀寫模型
4.5.2.1 state_dict
static_dict是一個從參數名稱映射到參數Tensor的字典對象
class MLP(nn.Module):def __init__(self):super(MLP, self).__init__()self.hidden = nn.Linear(3, 2)self.act = nn.ReLU()self.output = nn.Linear(2, 1)def forward(self, x):a = self.act(self.hidden(x))return self.output(a)net = MLP() net.state_dict()注意,只有具有可學習參數的層(卷積層、線性層)才有 state_dict中的條目
optimizer = torch.optim.SGD(net.parameters(), lr= 0.001, momentum=0.9) optimizer.state_dict()4.5.2.2 保存和加載模型
PyTorch中保存和加載訓練模型有兩種常見的方法:
1. 保存加載static_dict(推薦方式)
torch.save(model.state_dict(), PATH)
2. 保存和加載整個模型
# 保存 torch.save(model, PATH)# 加載 model = torch.load(PATH)采用第一種方法來試驗一下:
X = torch.randn(2, 3) Y = net(X)PATH = "./net.pt" torch.save(net.state_dict(), PATH)net2 = MLP() net2.load_state_dict(torch.load(PATH)) Y2 = net2(X)Y2 ==Y總結
以上是生活随笔為你收集整理的[pytorch、学习] - 4.5 读取和存储的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: threejs- z-fighting
- 下一篇: 中文语料库