亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 開發技術 > 
  • 如何解決Pytorch在測試與訓練過程中的驗證結果不一致問題

如何解決Pytorch在測試與訓練過程中的驗證結果不一致問題

發布時間:2021-06-04 09:57:05 來源:億速云 閱讀:978 作者:小新 欄目:開發技術

小編給大家分享一下如何解決Pytorch在測試與訓練過程中的驗證結果不一致問題,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

引言

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

現象

此前的錯誤代碼是

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,選取訓練好的值,否則則會取平均,可能導致生成的圖片顏色失真。

PyTorch進行訓練和測試時一定注意要把實例化的model指定train/eval

使用PyTorch進行訓練和測試時一定注意要把實例化的model指定train/eval,eval()時,框架會自動把BN和DropOut固定住,不會取平均,而是用訓練好的值,不然的話,一旦test的batch_size過小,很容易就會被BN層導致生成圖片顏色失真極大!!!!!!

eg:

Class Inpaint_Network()
......
Model = Inpaint_Nerwoek()

#train:
Model.train(mode=True)
.....

#test:
Model.eval()

看完了這篇文章,相信你對“如何解決Pytorch在測試與訓練過程中的驗證結果不一致問題”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

上林县| 巫溪县| 松潘县| 波密县| 潍坊市| 富锦市| 雅江县| 彩票| 浏阳市| 四子王旗| 桂东县| 静宁县| 平邑县| 巴青县| 迁西县| 通州市| 闽清县| 祁门县| 马鞍山市| 田林县| 惠东县| 武陟县| 清水县| 海淀区| 托里县| 通许县| 丹东市| 榆树市| 安塞县| 大埔区| 电白县| 阆中市| 昆明市| 济南市| 广水市| 吐鲁番市| 凯里市| 色达县| 上林县| 招远市| 普陀区|