解決Tensorflow2.0 tf.keras.Model.load_weights() 報錯處理問題
錯誤描述:
1、保存模型:model.save_weights('./model.h5')
2、腳本重啟
3、加載模型:model.load_weights('./model.h5')
4、模型報錯:ValueError: You are trying to load a weight file containing 12 layers into a model with 0 layers.
問題分析:
模型創(chuàng)建后還沒有編譯,一般是在模型加載前調(diào)用model.build(input_shape), 但我通過Dataset將輸入已經(jīng)變?yōu)閐ict格式了,暫時沒找這樣輸入怎么匹配input_shape參數(shù)
解決方法:
model.fit(train_dataset, epochs=0)
將epochs設(shè)為0,這樣模型在編譯的同時不會訓練數(shù)據(jù),減少耗費的時間,之后就可以正常加載保存的參數(shù)了
補充知識:調(diào)用Kears中kears.model.load_model方法遇到的問題和解決方法
之前一直使用tf和pytorch,就算是tf也是tf.estimator用得比較多,很少使用keras,最近嘗試使用kears快速訓練和部署一些分類任務(wù),在使用load_model的時候遇到一些問題
問題1:
SystemError: unknown opcode
原因是因為模型定義用到了lambda
gap = Lambda(lambda x: x[0]/x[1], name = 'RescaleGAP')([gap_features, gap_mask])
我在python3.5的環(huán)境訓練的模型,python3.6的環(huán)境load模型。兩個環(huán)境的lambda有差異,這個問題。
問題2:
ValueError: Unknown metric function:****
我的錯誤是
ValueError: Unknown metric function:top_2_accuracy
因為在構(gòu)建模型時,使用了自己定義的top_2_accuracy方法,所以在load_model時需要將top_2_accuracy做為參數(shù)傳進去
from keras.models import load_model
from keras.metrics import top_k_categorical_accuracy
def top_2_accuracy(in_gt, in_pred):
return top_k_categorical_accuracy(in_gt, in_pred, k=2)
model = load_model("model.h5",custom_objects={'top_2_accuracy': top_2_accuracy})
以上這篇解決Tensorflow2.0 tf.keras.Model.load_weights() 報錯處理問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用Python opencv實現(xiàn)視頻與圖片的相互轉(zhuǎn)換
這篇文章主要介紹了使用Python opencv實現(xiàn)視頻與圖片的相互轉(zhuǎn)換,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
Python獲取list中指定元素索引的兩種方法小結(jié)
本文主要介紹了兩種在Python中獲取列表中指定元素索引的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-01-01
pytorch教程實現(xiàn)mnist手寫數(shù)字識別代碼示例
這篇文章主要講解了pytorch教程中如何實現(xiàn)mnist手寫數(shù)字識別,文中附有詳細的代碼示例,test準確率98%,有需要的朋友可以借鑒參考下2021-09-09
python批量實現(xiàn)Word文件轉(zhuǎn)換為PDF文件
這篇文章主要為大家詳細介紹了python批量實現(xiàn)Word文件轉(zhuǎn)換為PDF文件的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03

