解決Tensorflow 內存泄露問題
使用tensorflow進行編程時,經常遇到操作不當,帶來的內存泄露問題,這里有一個可以幫助debug問題所在方法:
使用tf.Graph.finalize()把運算圖變成只讀的,從而對圖的修改都會報錯,從而找到內存泄露的定點。
目前我出現(xiàn)過內存泄露問題的有兩處:
1.
session和graph沒有釋放內存。按照資料的說法,使用了with關鍵字可以在session異常退出時也釋放內存,否則要用session.close()關閉session。代碼如下:
with tf.Session() as session: #codes #一般使用with以后就會釋放內存,否則運行如下釋放 session.close() del session
另一方面,我是在session中加載graph(訓練好的模型),導致每次關閉程序再運行,graph出現(xiàn)重復加載的現(xiàn)象。錯誤代碼示例:
with tf.Seesion() as session: # 在session內部加載保存好的graph saver = tf.train.import_meta_graph('./CNN_cracks.meta') saver.restore(session, "./CNN_cracks") # codes
此處,在一次運行session時會加載一次graph,一次運行的時候沒問題,但多次運行(調試時),每次graph都會加載到內存而不被釋放,因而造成內存泄露。
正確的做法如下:
# 用with新建一個graph,這樣在運行完以及異常退出時就會釋放內存 graph = tf.Gragh() with graph.as_default(): saver = tf.train.import_meta_graph('./CNN_cracks.meta') with tf.Session(graph=graph) as session: saver.restore(session, "./CNN_cracks")
2.
一些tensorflow的運算似乎也會修改圖,原因未明。所以在在訓練里面把所有屬于tensorflow的運算都寫進去,運行session.run返回的只能是只讀。
##錯誤代碼 #訓練 graph = tf.Graph() with graph.as_default(): #codes predict = tf.nn.softmax(model(data)) #預測,這里訓練文件與預測文件是分離的 with tf.Session(graph=graph) as session: #codes predict = session.run(predict, feed_dict={data: block}) prediction = tf.argmax(predict, -1) #這里會對圖進行修改
##正確代碼 #訓練 graph = tf.Graph() with graph.as_default(): #codes predict = tf.argmax(tf.nn.softmax(model(data)), -1) #預測 with tf.Session(graph=graph) as session: #codes prediction = session.run(predict, feed_dict={data: block})
以上這篇解決Tensorflow 內存泄露問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
使用python快速實現(xiàn)不同機器間文件夾共享方式
今天小編就為大家分享一篇使用python快速實現(xiàn)不同機器間文件夾共享方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12Django使用mysqlclient服務連接并寫入數(shù)據(jù)庫的操作過程
這篇文章主要介紹了Django使用mysqlclient服務連接并寫入數(shù)據(jù)庫,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07Pycharm運行程序時,控制臺輸出PyDev?console:starting問題
Pycharm運行程序時,控制臺輸出PyDev?console:starting問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05Jupyter Notebook內使用argparse報錯的解決方案
這篇文章主要介紹了在Jupyter Notebook內使用argparse報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06