Tensorflow 2 錯誤處理

  1. RuntimeError: loss passed to Optimizer.compute_gradients should be a function when eager execution is enabled.
optimizer = tf.compat.v1.train.GradientDescentOptimizer(0.5)
train = optimizer.minimize(loss)

關(guān)于tf.compat.v1.train.GradientDescentOptimizer的介紹參考https://tensorflow.google.cn/api_docs/python/tf/compat/v1/train/GradientDescentOptimizer?hl=en
Methods中minimize

When eager execution is enabled, loss should be a Python function that takes no arguments and computes the value to be minimized.

當(dāng)eager execution開啟的時候,loss應(yīng)該是一個Python函數(shù)。

關(guān)于eager execution的介紹,參考https://tensorflow.google.cn/guide/eager?hl=en

In Tensorflow 2.0, eager execution is enabled by default.
在Tensorflow 2.0 中,eager execution 是默認(rèn)開啟的。

所以,需要先關(guān)閉eager execution

tf.compat.v1.disable_eager_execution()
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容