佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > PyTorch dropout設置訓練和測試模式的實現(xiàn)

PyTorch dropout設置訓練和測試模式的實現(xiàn)

熱門標簽:企業(yè)做大做強 Win7旗艦版 硅谷的囚徒呼叫中心 電話運營中心 客戶服務 百度AI接口 語音系統(tǒng) 呼叫中心市場需求

看代碼吧~

class Net(nn.Module):
…
model = Net()
…
model.train() # 把module設成訓練模式,對Dropout和BatchNorm有影響
model.eval() # 把module設置為預測模式,對Dropout和BatchNorm模塊有影響

補充:Pytorch遇到的坑——訓練模式和測試模式切換

由于訓練的時候Dropout和BN層起作用,每個batch BN層的參數(shù)不一樣,dropout在訓練時隨機失效點具有隨機性,所以訓練和測試要區(qū)分開來。

使用時切記要根據(jù)實際情況切換:

model.train()
model.eval()

補充:Pytorch在測試與訓練過程中的驗證結(jié)果不一致問題

引言

今天在使用Pytorch導入此前保存的模型進行測試,在過程中發(fā)現(xiàn)輸出的結(jié)果與驗證結(jié)果差距甚大,經(jīng)過排查后發(fā)現(xiàn)是forward與eval()順序問題。

現(xiàn)象

此前的錯誤代碼是

    input_cpu = torch.ones((1, 2, 160, 160))
    target_cpu =torch.ones((1, 2, 160, 160))
    target_gpu, input_gpu = target_cpu.cuda(), input_cpu.cuda()
    model.set_input_2(input_gpu, target_gpu)
    model.eval()
    model.forward()

應該改為

    input_cpu = torch.ones((1, 2, 160, 160))
    target_cpu =torch.ones((1, 2, 160, 160))
    target_gpu, input_gpu = target_cpu.cuda(), input_cpu.cuda()
    model.set_input_2(input_gpu, target_gpu)
    # 先forward再eval
    model.forward()
    model.eval()

當時有個疑慮,為什么要在forward后面再加eval(),查了下相關資料,主要是在BN層以及Dropout的問題。當使用eval()時,模型會自動固定BN層以及Dropout,選取訓練好的值,否則則會取平均,可能導致生成的圖片顏色失真。

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

您可能感興趣的文章:
  • pytorch Dropout過擬合的操作
  • 淺談pytorch中的dropout的概率p
  • PyTorch 實現(xiàn)L2正則化以及Dropout的操作
  • pytorch 實現(xiàn)在測試的時候啟用dropout
  • pytorch 中nn.Dropout的使用說明
  • Pytorch之如何dropout避免過擬合

標簽:安康 山西 山西 濟南 崇左 海南 長沙 喀什

巨人網(wǎng)絡通訊聲明:本文標題《PyTorch dropout設置訓練和測試模式的實現(xiàn)》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    沂水县| 土默特右旗| 大石桥市| 龙海市| 鄂尔多斯市| 林甸县| 朝阳市| 吕梁市| 扎囊县| 重庆市| 民权县| 延安市| 临桂县| 乐清市| 涪陵区| 页游| 宣威市| 堆龙德庆县| 湘潭县| 建始县| 股票| 花莲县| 肇源县| 潍坊市| 龙山县| 临夏市| 安仁县| 揭西县| 五指山市| 桃江县| 广昌县| 抚顺市| 肥东县| 佛学| 平武县| 崇仁县| 丰原市| 桂东县| 外汇| 杭州市| 电白县|