網站首頁 編程語言 正文
1.對網絡結構和模型參數的保存
有兩種方式:
1.1
保存整個神經網絡的結構信息和模型參數信息,save的對象是網絡模型。
我們假設訓練好的模型名為net0,則
#保存整個神經網絡結構和結構的模型參數
torch.save(net0,'net0.pth')
torch.save(net0,'net0.pkl')
這種方式消耗的內存較大
1.2
只保存神經網絡的訓練模型參數,save的對象是net.state_dict()。
我們假設訓練好的模型名為net0,則
#只保存神經網絡的模型參數
torch.save(net0.state_dict(),'net0.pth')
torch.save(net0.state_dict(),'net0.pkl')
保存的是一個collections.OrderedDict()字典形式。
字典是key值對應參數層的名稱,value值對key層相應的參數值。
2. 不同后綴名的pytorch模型文件的區別與聯系
pth是path的縮寫,pkl是pickle的縮寫。
.pkl和.pth文件都是以二進制形式存儲的,用pickle這個庫加載.pkl和.pth文件,效果相同。
如果你是使用torch.save方法來進行模型參數的保存,那保存文件的后綴其實沒什么區別,結果都是一樣的,只是.pth用的更多一些。
但如果應用場景不在這里這兩種(.pkl、.pth)格式的文件還是有區別的:
①.pkl文件是python里保存文件的一種格式,如果直接打開會顯示序列化內容,其實是以二進制形式存儲的,若要閱讀文件,需要用’rb’而不是’r’。
②.pth文件有不同的應用,python在遍歷已知庫文件目錄過程中,如果見到一個.pth文件,就會將文件中所記錄的路徑加入到sys.path設置中,于是.pth文件指明的庫也就可以被python運行環境找到。
原文鏈接:https://blog.csdn.net/weixin_45928096/article/details/122397876
相關推薦
- 2022-07-08 一文詳解C++中運算符的使用_C 語言
- 2023-10-10 前端的多種克隆方式和注意事項
- 2022-11-06 python?pandas?數據排序的幾種常用方法_python
- 2022-09-09 Python利用Turtle繪畫簡單圖形_python
- 2022-07-12 git同步fork倉庫同步upstream倉庫
- 2022-12-27 React生命周期函數圖解介紹_React
- 2022-05-24 Python函數之zip函數的介紹與實際應用_python
- 2022-07-17 SQL實現查詢某字段的值為空的記錄_MsSql
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支