好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PyTorch梯度裁剪避免訓練loss nan的操作

PyTorch梯度裁剪避免訓練loss nan的操作

熱門標簽:電銷機器人的風險 河北防封卡電銷卡 開封自動外呼系統怎么收費 400電話辦理哪種 開封語音外呼系統代理商 應電話機器人打電話違法嗎 手機網頁嵌入地圖標注位置 天津電話機器人公司 地圖標注線上如何操作

近來在訓練檢測網絡的時候會出現loss為nan的情況,需要中斷重新訓練,會很麻煩。因而選擇使用PyTorch提供的梯度裁剪庫來對模型訓練過程中的梯度范圍進行限制,修改之后,不再出現loss為nan的情況。

PyTorch中采用torch.nn.utils.clip_grad_norm_來實現梯度裁剪,鏈接如下:

https://pytorch.org/docs/stable/_modules/torch/nn/utils/clip_grad.html

訓練代碼使用示例如下:

from torch.nn.utils import clip_grad_norm_
outputs = model(data)
loss= loss_fn(outputs, target)
optimizer.zero_grad()
loss.backward()
# clip the grad
clip_grad_norm_(model.parameters(), max_norm=20, norm_type=2)
optimizer.step()

其中,max_norm為梯度的最大范數,也是梯度裁剪時主要設置的參數。

備注:網上有同學提醒在(強化學習)使用了梯度裁剪之后訓練時間會大大增加。目前在我的檢測網絡訓練中暫時還沒有碰到這個問題,以后遇到再來更新。

補充:pytorch訓練過程中出現nan的排查思路

1、最常見的就是出現了除0或者log0這種

看看代碼中在這種操作的時候有沒有加一個很小的數,但是這個數數量級要和運算的數的數量級要差很多。一般是1e-8。

2、在optim.step()之前裁剪梯度

optim.zero_grad()
loss.backward()
nn.utils.clip_grad_norm(model.parameters, max_norm, norm_type=2)
optim.step()

max_norm一般是1,3,5。

3、前面兩條還不能解決nan的話

就按照下面的流程來判斷。

...
loss = model(input)
# 1. 先看loss是不是nan,如果loss是nan,那么說明可能是在forward的過程中出現了第一條列舉的除0或者log0的操作
assert torch.isnan(loss).sum() == 0, print(loss)
optim.zero_grad()
loss.backward()
# 2. 如果loss不是nan,那么說明forward過程沒問題,可能是梯度爆炸,所以用梯度裁剪試試
nn.utils.clip_grad_norm(model.parameters, max_norm, norm_type=2)
# 3.1 在step之前,判斷參數是不是nan, 如果不是判斷step之后是不是nan
assert torch.isnan(model.mu).sum() == 0, print(model.mu)
optim.step()
# 3.2 在step之后判斷,參數和其梯度是不是nan,如果3.1不是nan,而3.2是nan,
# 特別是梯度出現了Nan,考慮學習速率是否太大,調小學習速率或者換個優化器試試。
assert torch.isnan(model.mu).sum() == 0, print(model.mu)
assert torch.isnan(model.mu.grad).sum() == 0, print(model.mu.grad)

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

您可能感興趣的文章:
  • Pytorch訓練過程出現nan的解決方式
  • pytorch 權重weight 與 梯度grad 可視化操作
  • PyTorch 如何檢查模型梯度是否可導
  • 淺談pytorch中為什么要用 zero_grad() 將梯度清零
  • PyTorch 如何自動計算梯度
  • pytorch 梯度NAN異常值的解決方案

標簽:山東 常州 蘭州 駐馬店 六盤水 宿遷 江蘇 成都

巨人網絡通訊聲明:本文標題《PyTorch梯度裁剪避免訓練loss nan的操作》,本文關鍵詞  PyTorch,梯度,裁剪,避免,訓練,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PyTorch梯度裁剪避免訓練loss nan的操作》相關的同類信息!
  • 本頁收集關于PyTorch梯度裁剪避免訓練loss nan的操作的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 国精品产品?区二区三区小说| 调教张嘴主人喝尿| japanesexxxx日本中文字幕| 男和女全身脱了还亲嘴摸下面| 国产一区二区三区免费大片天美| 中国人免费观看高清完整| 麻豆国产精品无码视频桃花园| 亚洲gv猛男gv无码男同| 国产偷久久| 中文字幕欧美日韩一| 大学4年被男友啪了多久| 无圣光丨推女郎无圣光是什么意思| 久久嫩草精品久久久久精品的登录注册 | 久久99精品久久久久久学生| 东北老夫妇啪啪嗷嗷叫| 欧洲裸体XXXXX毛片D女| 亚洲美女啪啪自拍| 精品欧美成人高清视频在线观看 | 午夜免费直播| 香港午夜三级三级三点| 女生差差| 日韩免费一级毛片| 九九精品视频在线播放8| 色网站在线视频| 一级性生话片| chinese4p真实交换| 亚洲人成人77777线观看| 国产日韩秒拍久久久久精品| 少妇人妻人伦A片软件下载| 欧美人牝户毛茸茸| 农村性事偷窥| 欧美在线香蕉在线视频| 美女脱个精光视频秘?软件| 韩国yy漫画| 99久久夜色精品国产九九九九九九| 日本人妻中文无码毛茸茸的麦子| 日韩久久一区二区三区| 久久狠狠丁香婷婷综合| 国产丰满大乳奶水| 被闺蜜男友c翻了H陆晋元沈瑶| bdsm女同虐女最残忍bdsm|