校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > pytorch模型的保存和加載、checkpoint操作

pytorch模型的保存和加載、checkpoint操作

熱門標簽:騰訊地圖標注沒法顯示 海外網吧地圖標注注冊 地圖標注自己和別人標注區別 南陽打電話機器人 打電話機器人營銷 ai電銷機器人的優勢 孝感營銷電話機器人效果怎么樣 聊城語音外呼系統 商家地圖標注海報

其實之前筆者寫代碼的時候用到模型的保存和加載,需要用的時候就去度娘搜一下大致代碼,現在有時間就來整理下整個pytorch模型的保存和加載,開始學習把~

pytorch的模型和參數是分開的,可以分別保存或加載模型和參數。所以pytorch的保存和加載對應存在兩種方式:

1. 直接保存加載模型

(1)保存和加載整個模型

# 保存模型
torch.save(model, 'model.pth\pkl\pt')    #一般形式torch.save(net, PATH) 
# 加載模型
model = torch.load('model.pth\pkl\pt')   #一般形式為model_dict=torch.load(PATH)

(2)僅保存和加載模型參數(推薦使用,需要提前手動構建模型)

速度快,占空間少

# 保存模型參數
torch.save(model.state_dict(), 'model.pth\pkl\pt')  #一般形式為torch.save(net.state_dict(),PATH)
# 加載模型參數
model.load_state_dict(torch.load('model.pth\pkl\pt') #一般形式為model_dict=model.load_state_dict(torch.load(PATH))

state_dict() 是一個Python字典,將每一層映射成它的參數張量。注意只有帶有可學習參數的層(卷積層、全連接層等),以及注冊的緩存(batchnorm的運行平均值)在state_dict 中才有記錄。state_dict同樣包含優化器對象,存儲了優化器的狀態,所使用到的超參數。

然而,在實驗中往往需要保存更多的信息,比如優化器的參數,那么可以采取下面的方法保存:

torch.save({'epoch': epochID + 1, 'state_dict': model.state_dict(), 'best_loss': lossMIN,
        'optimizer': optimizer.state_dict(),'alpha': loss.alpha, 'gamma': loss.gamma},
        checkpoint_path + '/m-' + launchTimestamp + '-' + str("%.4f" % lossMIN) + '.pth.tar')

如下一個完整的使用model.state_dict()和optimizer.state_dict()例子:

# 定義模型
class TheModelClass(nn.Module):        #定義一個神經網絡模型 TheModelClass
    def __init__(self):
        super(TheModelClass, self).__init__()
        self.conv1 = nn.Conv2d(3, 6, 5)
        self.pool = nn.MaxPool2d(2, 2)
        self.conv2 = nn.Conv2d(6, 16, 5)
        self.fc1 = nn.Linear(16 * 5 * 5, 120)
        self.fc2 = nn.Linear(120, 84)
        self.fc3 = nn.Linear(84, 10)

    def forward(self, x):
        x = self.pool(F.relu(self.conv1(x)))
        x = self.pool(F.relu(self.conv2(x)))
        x = x.view(-1, 16 * 5 * 5)
        x = F.relu(self.fc1(x))
        x = F.relu(self.fc2(x))
        x = self.fc3(x)
        return x

# 初始化模型
model = TheModelClass()

# 初始化優化器
optimizer = optim.SGD(model.parameters(), lr=0.001, momentum=0.9)

# 打印模型的 state_dict
print("Model's state_dict:")
for param_tensor in model.state_dict():        # param_tensor 為參數名稱
    print(param_tensor, "\t", model.state_dict()[param_tensor].size())

# 打印優化器的 state_dict
print("Optimizer's state_dict:")
for var_name in optimizer.state_dict():
    print(var_name, "\t", optimizer.state_dict()[var_name])

輸出結果:

Model's state_dict:
conv1.weight torch.Size([6, 3, 5, 5])
conv1.bias torch.Size([6])
conv2.weight torch.Size([16, 6, 5, 5])
conv2.bias torch.Size([16])
fc1.weight torch.Size([120, 400])
fc1.bias torch.Size([120])
fc2.weight torch.Size([84, 120])
fc2.bias torch.Size([84])
fc3.weight torch.Size([10, 84])
fc3.bias torch.Size([10])

Optimizer's state_dict:
state {}
param_groups [{'lr': 0.001, 'momentum': 0.9, 'dampening': 0, 'weight_decay': 0, 'nesterov': False, 'params': [4675713712, 4675713784, 4675714000, 4675714072, 4675714216, 4675714288, 4675714432, 4675714504, 4675714648, 4675714720]}]

(3)load提供了很多重載的功能,其可以把在GPU上訓練的權重加載到CPU上跑

torch.load('tensors.pt')
# 強制所有GPU張量加載到CPU中
torch.load('tensors.pt', map_location=lambda storage, loc: storage)  #或者model.load_state_dict(torch.load('model.pth', map_location='cpu'))
# 把所有的張量加載到GPU 1中
torch.load('tensors.pt', map_location=lambda storage, loc: storage.cuda(1))
# 把張量從GPU 1 移動到 GPU 0
torch.load('tensors.pt', map_location={'cuda:1':'cuda:0'})

上述代碼只有在模型在一個GPU上訓練時才起作用。如果我在多個GPU上訓練模型并且保存它,然后嘗試在CPU上加載,會得到錯誤:KeyError: ‘unexpected key “module.conv1.weight” in state_dict' 如何解決?

因為此時已經使用模型保存了模型nn.DataParallel,該模型將模型存儲在該模型中module,而現在您正試圖加載模型DataParallel。您可以nn.DataParallel在網絡中暫時添加一個加載目的,也可以加載權重文件,創建一個沒有module前綴的新的有序字典,然后加載它。看第(4)點

(4)通過DataParalle使用多GPU時的保存和加載

odel=DataParalle(model)
#保存參數
torch.save(model.module.state_dict(), 'model.pth')

由此看出多個GPU時多了一個該模型中module,加載再cpu時,創建一個沒有module前綴的新的有序字典,然后加載它。

補充:一般來說,PyTorch的模型以.pt或者.pth文件格式保存。

2. 保存加載用于推理的常規Checkpoint/或繼續訓練**

checkpoint檢查點:不僅保存模型的參數,優化器參數,還有loss,epoch等(相當于一個保存模型的文件夾)

if (epoch+1) % checkpoint_interval == 0:

        checkpoint = {"model_state_dict": net.state_dict(),
                      "optimizer_state_dict": optimizer.state_dict(),
                      "epoch": epoch}
        path_checkpoint = "./checkpoint_{}_epoch.pkl".format(epoch)
        torch.save(checkpoint, path_checkpoint)
#或者
#保存
torch.save({
            'epoch': epoch,
            'model_state_dict': model.state_dict(),
            'optimizer_state_dict': optimizer.state_dict(),
            'loss': loss,
            ...
            }, PATH)
#加載
model = TheModelClass(*args, **kwargs)
optimizer = TheOptimizerClass(*args, **kwargs)

checkpoint = torch.load(PATH)
model.load_state_dict(checkpoint['model_state_dict'])
optimizer.load_state_dict(checkpoint['optimizer_state_dict'])
epoch = checkpoint['epoch']
loss = checkpoint['loss']

model.eval()
# - 或者 -
model.train()

注意:

在保存用于推理或者繼續訓練的常規檢查點的時候,除了模型的state_dict之外,還必須保存其他參數。保存優化器的state_dict也非常重要,因為它包含了模型在訓練時候優化器的緩存和參數。除此之外,還可以保存停止訓練時epoch數,最新的模型損失,額外的torch.nn.Embedding層等。

要保存多個組件,則將它們放到一個字典中,然后使用torch.save()序列化這個字典。一般來說,使用.tar文件格式來保存這些檢查點。

加載各個組件,首先初始化模型和優化器,然后使用torch.load()加載保存的字典,然后可以直接查詢字典中的值來獲取保存的組件。

同樣,評估模型的時候一定不要忘了調用model.eval()。

是不是很簡單!!以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • pytorch 搭建神經網路的實現
  • 手把手教你實現PyTorch的MNIST數據集
  • Python機器學習之基于Pytorch實現貓狗分類
  • 總結近幾年Pytorch基于Imgagenet數據集圖像分類模型

標簽:揚州 聊城 南寧 迪慶 六盤水 撫州 楊凌 牡丹江

巨人網絡通訊聲明:本文標題《pytorch模型的保存和加載、checkpoint操作》,本文關鍵詞  pytorch,模型,的,保存,和,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pytorch模型的保存和加載、checkpoint操作》相關的同類信息!
  • 本頁收集關于pytorch模型的保存和加載、checkpoint操作的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    夜色激情一区二区| 国产精品888| 国产成人欧美日韩在线电影| 97se狠狠狠综合亚洲狠狠| 91精品国产综合久久久蜜臀粉嫩| 中文字幕欧美日韩一区| 日本不卡一二三| 欧美亚洲自拍偷拍| 国产精品国产三级国产| 麻豆成人在线观看| 欧美日韩一区高清| 一区二区三区欧美激情| 国产成人精品一区二区三区网站观看| 欧美三级午夜理伦三级中视频| 久久精品视频网| 久久99国内精品| 91精品国产色综合久久不卡蜜臀| 成人欧美一区二区三区视频网页| 精品无人区卡一卡二卡三乱码免费卡 | 国产91高潮流白浆在线麻豆| 91精品国产综合久久蜜臀| 亚洲欧美精品午睡沙发| 国产米奇在线777精品观看| 欧美一区二区三区在线看| 亚洲自拍与偷拍| 99精品国产99久久久久久白柏| 欧美激情在线观看视频免费| 国产伦精品一区二区三区免费迷| 日韩一区二区三区精品视频| 国产精品久久久久久久久晋中| 极品少妇一区二区| 精品欧美乱码久久久久久| 视频一区国产视频| 欧美一二区视频| 蜜桃视频一区二区三区在线观看| 欧美精品一级二级三级| 午夜欧美一区二区三区在线播放| 欧美最猛黑人xxxxx猛交| 亚洲狠狠丁香婷婷综合久久久| 91丨porny丨蝌蚪视频| 亚洲精品国产一区二区精华液 | 中文字幕一区二区三区精华液| 国产成人亚洲综合色影视| 久久亚洲精品小早川怜子| 国产在线精品一区二区三区不卡 | 欧美一激情一区二区三区| 日本最新不卡在线| 2020国产精品自拍| 高清国产午夜精品久久久久久| 国产精品久久毛片a| 岛国精品一区二区| 一区二区三区四区乱视频| 欧洲亚洲国产日韩| 麻豆成人免费电影| 中文字幕日韩精品一区| 在线欧美日韩精品| 日本亚洲三级在线| 国产精品免费人成网站| 欧美中文字幕一区二区三区亚洲| 蜜臀精品一区二区三区在线观看 | 国产不卡视频在线观看| 国产精品国产a| 欧美日韩不卡在线| 国产一区二区久久| 亚洲在线中文字幕| 欧美一级二级三级乱码| 成人综合激情网| 亚洲成人激情综合网| 欧美精品一区二区三区在线播放| 成人a级免费电影| 日韩综合在线视频| 中文字幕日韩一区| 欧美电影精品一区二区| 99在线精品免费| 免费看黄色91| 亚洲综合一区在线| 日本一区二区视频在线| 欧美影院午夜播放| 国产成人免费在线观看| 午夜a成v人精品| 最好看的中文字幕久久| 26uuu精品一区二区在线观看| 不卡的av在线播放| 精品一区二区三区香蕉蜜桃| 亚洲卡通动漫在线| 久久亚洲一级片| 在线播放中文一区| 色综合久久久久久久久久久| 国产在线精品国自产拍免费| 午夜精品久久久久久| 亚洲欧洲av一区二区三区久久| 精品美女一区二区| 欧美日韩视频不卡| 色婷婷综合久色| 国产电影精品久久禁18| 国内精品在线播放| 奇米精品一区二区三区在线观看| 亚洲欧美日韩国产成人精品影院 | 成人精品gif动图一区| 美女一区二区三区| 日本视频在线一区| 午夜亚洲国产au精品一区二区| 中文字幕在线不卡一区二区三区| 日韩欧美一级二级三级| 色拍拍在线精品视频8848| 99视频精品全部免费在线| 国产精品1区2区| 久久不见久久见免费视频1| 青青草一区二区三区| 视频在线观看国产精品| 亚洲成人精品在线观看| 午夜欧美在线一二页| 视频一区二区中文字幕| 亚洲国产精品一区二区久久| 亚洲欧美成人一区二区三区| 亚洲天堂福利av| 亚洲欧美偷拍卡通变态| 亚洲另类春色国产| 亚洲国产美女搞黄色| 亚洲国产aⅴ成人精品无吗| 亚洲福利一二三区| 免费国产亚洲视频| 国产乱人伦偷精品视频不卡| 国产91清纯白嫩初高中在线观看| 国产成人激情av| 一本在线高清不卡dvd| 欧美日韩精品电影| 在线成人av网站| 欧美电视剧免费全集观看 | 日韩一区二区在线看| 日韩免费在线观看| 国产精品天干天干在观线| 亚洲啪啪综合av一区二区三区| 亚洲精品国产精华液| 成人网男人的天堂| 成人免费视频视频在线观看免费| 国产99精品国产| 成人h动漫精品一区二区| 色天天综合色天天久久| 欧美老肥妇做.爰bbww视频| 日韩一区二区在线播放| 久久久蜜桃精品| 亚洲午夜电影在线| 日本不卡免费在线视频| 国产成人在线看| 在线一区二区三区四区| 精品入口麻豆88视频| 国产精品久久久久一区| 亚洲成人中文在线| 国产成人高清在线| 欧美日韩日日夜夜| 久久久久久久久久看片| 亚洲狼人国产精品| 国内精品伊人久久久久av影院| 99精品国产99久久久久久白柏| 欧美日韩色一区| 欧美激情一区在线| 秋霞午夜鲁丝一区二区老狼| 成人国产精品免费观看视频| 欧美日韩久久不卡| 中文字幕免费不卡| 奇米影视在线99精品| 成人深夜在线观看| 宅男噜噜噜66一区二区66| 欧美激情一区二区三区四区| 首页综合国产亚洲丝袜| 懂色中文一区二区在线播放| 在线观看91精品国产入口| 久久久国产精品不卡| 日韩精品高清不卡| 99久久婷婷国产综合精品| 欧美一级在线观看| 悠悠色在线精品| 成人免费高清在线| 精品国产一区二区三区久久久蜜月| 亚洲最大的成人av| eeuss国产一区二区三区| 日韩精品一区二区三区在线| 亚洲一区二区精品3399| 91蜜桃视频在线| 国产欧美日韩在线视频| 韩国一区二区三区| 日韩精品一区二区在线| 日韩精品成人一区二区三区| 91色九色蝌蚪| 国产精品美女久久久久久久网站| 久久av资源网| 欧美刺激午夜性久久久久久久| 视频一区二区国产| 欧美日韩一区二区三区四区| 亚洲精品视频在线| 91蜜桃视频在线| 亚洲美女偷拍久久| 日本精品一级二级| 亚洲永久精品大片| 欧美探花视频资源| 日韩黄色在线观看| 91精品国产综合久久香蕉麻豆 | 欧美电影免费观看高清完整版在线| 亚洲一区二区三区四区不卡|