婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > pytorch模型的保存和加載、checkpoint操作

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

熱門標(biāo)簽:騰訊地圖標(biāo)注沒法顯示 海外網(wǎng)吧地圖標(biāo)注注冊(cè) 地圖標(biāo)注自己和別人標(biāo)注區(qū)別 南陽(yáng)打電話機(jī)器人 打電話機(jī)器人營(yíng)銷 ai電銷機(jī)器人的優(yōu)勢(shì) 孝感營(yíng)銷電話機(jī)器人效果怎么樣 聊城語(yǔ)音外呼系統(tǒng) 商家地圖標(biāo)注海報(bào)

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

pytorch的模型和參數(shù)是分開的,可以分別保存或加載模型和參數(shù)。所以pytorch的保存和加載對(duì)應(yīng)存在兩種方式:

1. 直接保存加載模型

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

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

(2)僅保存和加載模型參數(shù)(推薦使用,需要提前手動(dòng)構(gòu)建模型)

速度快,占空間少

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

state_dict() 是一個(gè)Python字典,將每一層映射成它的參數(shù)張量。注意只有帶有可學(xué)習(xí)參數(shù)的層(卷積層、全連接層等),以及注冊(cè)的緩存(batchnorm的運(yùn)行平均值)在state_dict 中才有記錄。state_dict同樣包含優(yōu)化器對(duì)象,存儲(chǔ)了優(yōu)化器的狀態(tài),所使用到的超參數(shù)。

然而,在實(shí)驗(yàn)中往往需要保存更多的信息,比如優(yōu)化器的參數(shù),那么可以采取下面的方法保存:

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')

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

# 定義模型
class TheModelClass(nn.Module):        #定義一個(gè)神經(jīng)網(wǎng)絡(luò)模型 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()

# 初始化優(yōu)化器
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 為參數(shù)名稱
    print(param_tensor, "\t", model.state_dict()[param_tensor].size())

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

輸出結(jié)果:

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上訓(xùn)練的權(quán)重加載到CPU上跑

torch.load('tensors.pt')
# 強(qiáng)制所有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 移動(dòng)到 GPU 0
torch.load('tensors.pt', map_location={'cuda:1':'cuda:0'})

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

因?yàn)榇藭r(shí)已經(jīng)使用模型保存了模型nn.DataParallel,該模型將模型存儲(chǔ)在該模型中module,而現(xiàn)在您正試圖加載模型DataParallel。您可以nn.DataParallel在網(wǎng)絡(luò)中暫時(shí)添加一個(gè)加載目的,也可以加載權(quán)重文件,創(chuàng)建一個(gè)沒有module前綴的新的有序字典,然后加載它??吹冢?)點(diǎn)

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

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

由此看出多個(gè)GPU時(shí)多了一個(gè)該模型中module,加載再cpu時(shí),創(chuàng)建一個(gè)沒有module前綴的新的有序字典,然后加載它。

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

2. 保存加載用于推理的常規(guī)Checkpoint/或繼續(xù)訓(xùn)練**

checkpoint檢查點(diǎn):不僅保存模型的參數(shù),優(yōu)化器參數(shù),還有l(wèi)oss,epoch等(相當(dāng)于一個(gè)保存模型的文件夾)

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()

注意:

在保存用于推理或者繼續(xù)訓(xùn)練的常規(guī)檢查點(diǎn)的時(shí)候,除了模型的state_dict之外,還必須保存其他參數(shù)。保存優(yōu)化器的state_dict也非常重要,因?yàn)樗四P驮谟?xùn)練時(shí)候優(yōu)化器的緩存和參數(shù)。除此之外,還可以保存停止訓(xùn)練時(shí)epoch數(shù),最新的模型損失,額外的torch.nn.Embedding層等。

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

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

同樣,評(píng)估模型的時(shí)候一定不要忘了調(diào)用model.eval()。

是不是很簡(jiǎn)單?。∫陨蠟閭€(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • pytorch 搭建神經(jīng)網(wǎng)路的實(shí)現(xiàn)
  • 手把手教你實(shí)現(xiàn)PyTorch的MNIST數(shù)據(jù)集
  • Python機(jī)器學(xué)習(xí)之基于Pytorch實(shí)現(xiàn)貓狗分類
  • 總結(jié)近幾年P(guān)ytorch基于Imgagenet數(shù)據(jù)集圖像分類模型

標(biāo)簽:揚(yáng)州 聊城 南寧 迪慶 六盤水 撫州 楊凌 牡丹江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《pytorch模型的保存和加載、checkpoint操作》,本文關(guān)鍵詞  pytorch,模型,的,保存,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《pytorch模型的保存和加載、checkpoint操作》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于pytorch模型的保存和加載、checkpoint操作的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩一区二区视频在线观看| 成人av动漫网站| 日韩视频免费观看高清完整版 | 亚洲一级电影视频| 在线亚洲免费视频| 国产在线日韩欧美| 亚洲精品久久久蜜桃| 精品国产污网站| 欧美在线看片a免费观看| 日韩国产一区二| 椎名由奈av一区二区三区| 日韩欧美国产小视频| 欧美三级日韩在线| 成人免费福利片| 精品一区二区三区香蕉蜜桃| 综合分类小说区另类春色亚洲小说欧美| 欧美丰满嫩嫩电影| 自拍偷拍国产亚洲| 亚洲国产精品成人综合| 欧美成人a∨高清免费观看| 欧美日韩视频第一区| av午夜一区麻豆| 国产美女视频91| 极品尤物av久久免费看| 奇米综合一区二区三区精品视频| 一区二区在线免费| 亚洲欧美另类图片小说| 欧美高清在线一区二区| 欧美日韩国产欧美日美国产精品| 91在线视频免费91| 国产成人精品免费在线| 国产真实精品久久二三区| 精品一区二区三区视频| 韩国精品在线观看| 国产精品99久久久久久久女警 | 欧美精品日韩一区| 欧美日韩亚洲综合在线 | 95精品视频在线| 日韩av中文在线观看| 日韩精品电影在线观看| 日韩福利电影在线观看| 亚洲成人免费观看| 蜜桃视频一区二区| 欧美日韩精品高清| 日韩成人av影视| 日本韩国欧美一区二区三区| 国产精品毛片大码女人| www.激情成人| 免费不卡在线视频| 欧美在线视频日韩| 国产精品青草综合久久久久99| 亚洲国产成人av好男人在线观看| 成人动漫一区二区三区| 成人国产在线观看| 在线观看三级视频欧美| 欧美日韩视频在线第一区| 亚洲嫩草精品久久| 亚洲欧美另类图片小说| 一区二区三区日韩精品| 亚洲激情男女视频| 亚洲专区一二三| 日本成人中文字幕| 粉嫩嫩av羞羞动漫久久久| 国产盗摄女厕一区二区三区| 欧美最新大片在线看| 6080国产精品一区二区| 国产日产欧产精品推荐色| 亚洲欧美日韩久久精品| 亚洲综合在线免费观看| 国内精品久久久久影院色| 99视频有精品| 欧美一级黄色录像| 夜色激情一区二区| 久久午夜老司机| 亚洲一区二区三区中文字幕在线| 国产精品一卡二卡| 欧美一级二级在线观看| 亚洲一区在线观看网站| 日韩一区精品字幕| 99综合电影在线视频| 日韩一区二区不卡| 一区二区日韩av| 成人精品小蝌蚪| 国产无一区二区| 亚洲精品成人精品456| 国产成人午夜视频| av午夜精品一区二区三区| 欧美videossexotv100| 6080国产精品一区二区| 91色|porny| 高清不卡一二三区| 成人白浆超碰人人人人| 91精品国产综合久久婷婷香蕉 | 日韩激情一二三区| 91丨九色丨尤物| 一本色道亚洲精品aⅴ| 欧美日韩免费高清一区色橹橹 | 精品美女一区二区三区| 蜜臀av性久久久久蜜臀aⅴ | 亚洲黄一区二区三区| av电影一区二区| 亚洲欧美日韩成人高清在线一区| 在线一区二区三区四区| 5566中文字幕一区二区电影| 欧美无砖砖区免费| 日韩激情在线观看| 久久综合九色综合欧美就去吻 | 国产1区2区3区精品美女| 日韩综合小视频| 国产精品拍天天在线| 精品少妇一区二区三区在线播放 | 亚洲国产成人91porn| 色综合天天综合给合国产| 91精品国产综合久久久久久久| 欧美一级日韩免费不卡| 69p69国产精品| 成人动漫中文字幕| 精品国产一二三| 99精品久久久久久| 国内精品免费**视频| 91美女视频网站| 成人午夜精品在线| 欧美成人国产一区二区| 韩国三级在线一区| 亚洲欧美综合另类在线卡通| 欧美日韩亚洲综合在线 | 日韩精品一区二区三区中文不卡 | 欧美精选午夜久久久乱码6080| 亚洲大型综合色站| 久久精品无码一区二区三区| 在线精品视频一区二区三四| 青青青爽久久午夜综合久久午夜| 欧美三电影在线| 色哦色哦哦色天天综合| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产精品私人影院| 91精品国产黑色紧身裤美女| 蜜乳av一区二区| 最新高清无码专区| 国产视频在线观看一区二区三区| 欧美系列日韩一区| caoporm超碰国产精品| 日韩1区2区3区| 国产精品二三区| 日韩三级中文字幕| 欧美日韩高清一区| 欧美性色黄大片手机版| 激情小说欧美图片| 久久综合给合久久狠狠狠97色69| 91同城在线观看| 国内精品久久久久影院薰衣草| 亚洲欧美日韩电影| 亚洲人成人一区二区在线观看| 国产精品电影院| 亚洲国产精品高清| 欧美日韩卡一卡二| 欧美午夜在线观看| 欧美又粗又大又爽| 91电影在线观看| 欧美优质美女网站| 欧洲在线/亚洲| 99re成人精品视频| 91网址在线看| 日本福利一区二区| 成人av在线播放网站| 岛国精品一区二区| 国产精品一区二区在线观看不卡| 青青草原综合久久大伊人精品| 日本欧美一区二区在线观看| 亚洲欧美色图小说| 亚洲精品菠萝久久久久久久| 中文欧美字幕免费| 亚洲一区二区三区三| 一区二区三区.www| 亚洲国产精品自拍| 日韩高清不卡一区| 精品中文字幕一区二区| 亚洲一区二区三区视频在线| 亚洲精品国产精品乱码不99| 亚洲黄色av一区| 不卡电影一区二区三区| 色伊人久久综合中文字幕| 欧美激情综合网| 色综合天天综合网天天看片| 成人精品亚洲人成在线| 91免费视频网| 日韩欧美一区二区三区在线| 久久久久久久久久看片| 国产视频911| 一区二区在线看| 国产黑丝在线一区二区三区| 91视频www| 日韩一区二区精品在线观看| 日韩伦理av电影| 麻豆一区二区三区| av亚洲精华国产精华| 欧美大尺度电影在线| 亚洲欧美日韩一区二区三区在线观看| 麻豆精品一二三| 国产成人精品一区二区三区网站观看|