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

主頁 > 知識庫 > pytorch 預訓練模型讀取修改相關參數的填坑問題

pytorch 預訓練模型讀取修改相關參數的填坑問題

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

pytorch 預訓練模型讀取修改相關參數的填坑

修改部分層,仍然調用之前的模型參數。

resnet = resnet50(pretrained=False)
resnet.load_state_dict(torch.load(args.predir))
 
res_conv31 = Bottleneck_dilated(1024, 256,dilated_rate = 2)
print("---------------------",res_conv31)
print("---------------------",resnet.layer3[1])
 
res_conv31.load_state_dict(resnet.layer3[1].state_dict())

網絡預訓練模型與之前的模型對應不上,名稱差個前綴

model_dict = model.state_dict()
# print(model_dict)
pretrained_dict = torch.load("/yzc/reid_testpcb/se_resnet50-ce0d4300.pth")
keys = []
for k, v in pretrained_dict.items():
       keys.append(k)
i = 0
for k, v in model_dict.items():
    if v.size() == pretrained_dict[keys[i]].size():
         model_dict[k] = pretrained_dict[keys[i]]
         #print(model_dict[k])
         i = i + 1
model.load_state_dict(model_dict)

最后是修改參數名拿來用的,

from collections import OrderedDict
pretrained_dict = torch.load('premodel')
 
new_state_dict = OrderedDict()
 
# for k, v in mgn_state_dict.items():
#     name = k[7:]  # remove `module.`
#     new_state_dict[name] = v
# self.model = self.model.load_state_dict(new_state_dict)
 
for k, v in pretrained_dict.items():
    name = "model.module."+k   # remove `module.`
    # print(name)
    new_state_dict[name] = v
self.model.load_state_dict(new_state_dict)

pytorch:加載預訓練模型中的部分參數,并固定該部分參數(真實有效)

大家在學習pytorch時,可能想利用pytorch進行fine-tune,但是又煩惱于參數的加載問題。下面我將講訴我的使用心得。

Step1: 加載預訓練模型,并去除需要再次訓練的層

#注意:需要重新訓練的層的名字要和之前的不同。
model=resnet()#自己構建的模型,以resnet為例
model_dict = model.state_dict()
pretrained_dict = torch.load('xxx.pkl')
pretrained_dict = {k: v for k, v in pretrained_dict.items() if k in model_dict}
model_dict.update(pretrained_dict)
model.load_state_dict(model_dict)

Step2:固定部分參數

#k是可訓練參數的名字,v是包含可訓練參數的一個實體
#可以先print(k),找到自己想進行調整的層,并將該層的名字加入到if語句中:
for k,v in model.named_parameters():
    if k!='xxx.weight' and k!='xxx.bias' :
        v.requires_grad=False#固定參數

Step3:訓練部分參數

#將要訓練的參數放入優化器
optimizer2=torch.optim.Adam(params=[model.xxx.weight,model.xxx.bias],lr=learning_rate,betas=(0.9,0.999),weight_decay=1e-5)

Step4:檢查部分參數是否固定

debug之后,程序正常運行,最好檢查一下網絡的參數是否真的被固定了,如何沒固定,網絡的狀態接近于重新訓練,可能會導致網絡性能不穩定,也沒辦法得到想要得到的性能提升。

for k,v in model.named_parameters():
   if k!='xxx.weight' and k!='xxx.bias' :
   print(v.requires_grad)#理想狀態下,所有值都是False

需要注意的是,操作失誤最大的影響是,loss函數幾乎不會發生變化,一直處于最開始的狀態,這很可能是因為所有參數都被固定了。

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

您可能感興趣的文章:
  • Pytorch通過保存為ONNX模型轉TensorRT5的實現
  • pytorch_pretrained_bert如何將tensorflow模型轉化為pytorch模型
  • pytorch模型的保存和加載、checkpoint操作
  • PyTorch 如何檢查模型梯度是否可導
  • 解決Pytorch修改預訓練模型時遇到key不匹配的情況
  • PyTorch模型轉TensorRT是怎么實現的?

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

巨人網絡通訊聲明:本文標題《pytorch 預訓練模型讀取修改相關參數的填坑問題》,本文關鍵詞  pytorch,預,訓練,模型,讀取,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pytorch 預訓練模型讀取修改相關參數的填坑問題》相關的同類信息!
  • 本頁收集關于pytorch 預訓練模型讀取修改相關參數的填坑問題的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 云龙县| 荥经县| 乐东| 萨迦县| 策勒县| 唐河县| 镇雄县| 景德镇市| 湛江市| 清远市| 肥城市| 高安市| 景宁| 麟游县| 揭东县| 门源| 武汉市| 青神县| 郎溪县| 汉川市| 丹凤县| 军事| 疏附县| 交口县| 德江县| 乐东| 拜城县| 衡阳县| 纳雍县| 手游| 太保市| 石嘴山市| 江北区| 康平县| 台北市| 大石桥市| 虎林市| 石门县| 乌兰浩特市| 家居| 五华县|