解決Pytorch修改預(yù)訓(xùn)練模型時(shí)遇到key不匹配的情況
一、Pytorch修改預(yù)訓(xùn)練模型時(shí)遇到key不匹配
最近想著修改網(wǎng)絡(luò)的預(yù)訓(xùn)練模型vgg.pth,但是發(fā)現(xiàn)當(dāng)我加載預(yù)訓(xùn)練模型權(quán)重到新建的模型并保存之后。
在我使用新賦值的網(wǎng)絡(luò)模型時(shí)出現(xiàn)了key不匹配的問(wèn)題
#加載后保存(未修改網(wǎng)絡(luò)) base_weights = torch.load(args.save_folder + args.basenet) ssd_net.vgg.load_state_dict(base_weights) torch.save(ssd_net.state_dict(), args.save_folder + 'ssd_base' + '.pth')
# 將新保存的網(wǎng)絡(luò)代替之前的預(yù)訓(xùn)練模型 ssd_net = build_ssd('train', cfg['min_dim'], cfg['num_classes']) net = ssd_net ... if args.resume: ... else: base_weights = torch.load(args.save_folder + args.basenet) #args.basenet為ssd_base.pth print('Loading base network...') ssd_net.vgg.load_state_dict(base_weights)
此時(shí)會(huì)如下出錯(cuò)誤:
Loading base network…
Traceback (most recent call last):
File “train.py”, line 264, in
train()
File “train.py”, line 110, in train
ssd_net.vgg.load_state_dict(base_weights)
…
RuntimeError: Error(s) in loading state_dict for ModuleList:
Missing key(s) in state_dict: “0.weight”, “0.bias”, … “33.weight”, “33.bias”.
Unexpected key(s) in state_dict: “vgg.0.weight”, “vgg.0.bias”, … “vgg.33.weight”, “vgg.33.bias”.
說(shuō)明之前的預(yù)訓(xùn)練模型 key參數(shù)為"0.weight", “0.bias”,但是經(jīng)過(guò)加載保存之后變?yōu)榱?vgg.0.weight", “vgg.0.bias”
我認(rèn)為是因?yàn)楸旧淼哪P投x文件里self.vgg = nn.ModuleList(base)這一句。
現(xiàn)在的問(wèn)題是因?yàn)樽约憾x保存的模型key參數(shù)多了一個(gè)前綴。
可以通過(guò)如下語(yǔ)句進(jìn)行修改,并加載
from collections import OrderedDict #導(dǎo)入此模塊 base_weights = torch.load(args.save_folder + args.basenet) print('Loading base network...') new_state_dict = **OrderedDict()** for k, v in base_weights.items(): name = k[4:] # remove `vgg.`,即只取vgg.0.weights的后面幾位 new_state_dict[name] = v ssd_net.vgg.load_state_dict(new_state_dict)
此時(shí)就不會(huì)再出錯(cuò)了。
參考了這個(gè)篇。修改一下就可以應(yīng)用到自己的模型啦。
//www.dbjr.com.cn/article/214214.htm
二、pytorch加載預(yù)訓(xùn)練模型遇到的問(wèn)題:KeyError: ‘bn1.num_batches_tracked‘
最近在使用pytorch1.0加載resnet預(yù)訓(xùn)練模型時(shí),遇到的一個(gè)問(wèn)題,在此記錄一下。
KeyError: 'layer1.0.bn1.num_batches_tracked'
其實(shí)是使用的版本的問(wèn)題,pytorch0.4.1之后在BN層加入了track_running_stats這個(gè)參數(shù),
這個(gè)參數(shù)的作用如下:
訓(xùn)練時(shí)用來(lái)統(tǒng)計(jì)訓(xùn)練時(shí)的forward過(guò)的min-batch數(shù)目,每經(jīng)過(guò)一個(gè)min-batch, track_running_stats+=1
如果沒(méi)有指定momentum, 則使用1/num_batches_tracked 作為因數(shù)來(lái)計(jì)算均值和方差(running mean and variance).
其實(shí),這個(gè)參數(shù)沒(méi)啥用.但因?yàn)楣俜教峁┑念A(yù)訓(xùn)練模型是pytorch0.3版本訓(xùn)練出來(lái)的,因此沒(méi)有這個(gè)參數(shù).
所以,只要過(guò)濾一下預(yù)訓(xùn)練權(quán)重字典中的關(guān)鍵字即可,‘num_batches_tracked'.代碼例子,如下.
有問(wèn)題的代碼:
def load_specific_param(self, state_dict, param_name, model_path): param_dict = torch.load(model_path) for i in state_dict: key = param_name + '.' + i state_dict[i].copy_(param_dict[key]) del param_dict
對(duì)'num_batches_tracked進(jìn)行過(guò)濾:
def load_specific_param(self, state_dict, param_name, model_path): param_dict = torch.load(model_path) param_dict = {k: v for k, v in param_dict.items() if 'num_batches_tracked' not in k} for i in state_dict: key = param_name + '.' + i if 'num_batches_tracked' in key: continue state_dict[i].copy_(param_dict[key]) del param_dict
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python3.4下django集成使用xadmin后臺(tái)的方法
本篇文章主要介紹了python3.4下django集成使用xadmin后臺(tái)的方法,具有一定的參加價(jià)值,有興趣的可以了解一下2017-08-08python實(shí)現(xiàn)多線程并得到返回值的示例代碼
這篇文章主要介紹了python實(shí)現(xiàn)多線程并得到返回值的相關(guān)知識(shí),包括帶有返回值的多線程及實(shí)現(xiàn)過(guò)程解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05python實(shí)現(xiàn)對(duì)文件進(jìn)行MD5校驗(yàn)
這篇文章主要為大家詳細(xì)介紹了如何使用python對(duì)文件進(jìn)行MD5校驗(yàn)并比對(duì)文件重復(fù),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01Python實(shí)現(xiàn)將doc轉(zhuǎn)化pdf格式文檔的方法
這篇文章主要介紹了Python實(shí)現(xiàn)將doc轉(zhuǎn)化pdf格式文檔的方法,結(jié)合實(shí)例形式分析了Python實(shí)現(xiàn)doc格式文件讀取及轉(zhuǎn)換pdf格式文件的操作技巧,以及php調(diào)用py文件的具體實(shí)現(xiàn)方法,需要的朋友可以參考下2018-01-01pytorch加載語(yǔ)音類自定義數(shù)據(jù)集的方法教程
這篇文章主要給大家介紹了關(guān)于pytorch加載語(yǔ)音類自定義數(shù)據(jù)集的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11舉例講解Python的Tornado框架實(shí)現(xiàn)數(shù)據(jù)可視化的教程
這篇文章主要介紹了舉例講解Python的Tornado框架實(shí)現(xiàn)數(shù)據(jù)可視化的教程,Tornado是一個(gè)異步的高人氣開(kāi)發(fā)框架,需要的朋友可以參考下2015-05-05python實(shí)現(xiàn)輸入的數(shù)據(jù)在地圖上生成熱力圖效果
今天小編就為大家分享一篇python實(shí)現(xiàn)輸入的數(shù)據(jù)在地圖上生成熱力圖效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12Python中斷點(diǎn)調(diào)試pdb包的用法詳解
pdb(python debugger) 是 python 中的一個(gè)命令行調(diào)試包,為 python 程序提供了一種交互的源代碼調(diào)試功能,下面就跟隨小編一起學(xué)習(xí)一下它的具體使用吧2024-01-01