解決Tensorflow 內(nèi)存泄露問(wèn)題
使用tensorflow進(jìn)行編程時(shí),經(jīng)常遇到操作不當(dāng),帶來(lái)的內(nèi)存泄露問(wèn)題,這里有一個(gè)可以幫助debug問(wèn)題所在方法:
使用tf.Graph.finalize()把運(yùn)算圖變成只讀的,從而對(duì)圖的修改都會(huì)報(bào)錯(cuò),從而找到內(nèi)存泄露的定點(diǎn)。
目前我出現(xiàn)過(guò)內(nèi)存泄露問(wèn)題的有兩處:
1.
session和graph沒有釋放內(nèi)存。按照資料的說(shuō)法,使用了with關(guān)鍵字可以在session異常退出時(shí)也釋放內(nèi)存,否則要用session.close()關(guān)閉session。代碼如下:
with tf.Session() as session: #codes #一般使用with以后就會(huì)釋放內(nèi)存,否則運(yùn)行如下釋放 session.close() del session
另一方面,我是在session中加載graph(訓(xùn)練好的模型),導(dǎo)致每次關(guān)閉程序再運(yùn)行,graph出現(xiàn)重復(fù)加載的現(xiàn)象。錯(cuò)誤代碼示例:
with tf.Seesion() as session:
# 在session內(nèi)部加載保存好的graph
saver = tf.train.import_meta_graph('./CNN_cracks.meta')
saver.restore(session, "./CNN_cracks")
# codes
此處,在一次運(yùn)行session時(shí)會(huì)加載一次graph,一次運(yùn)行的時(shí)候沒問(wèn)題,但多次運(yùn)行(調(diào)試時(shí)),每次graph都會(huì)加載到內(nèi)存而不被釋放,因而造成內(nèi)存泄露。
正確的做法如下:
# 用with新建一個(gè)graph,這樣在運(yùn)行完以及異常退出時(shí)就會(huì)釋放內(nèi)存
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的運(yùn)算似乎也會(huì)修改圖,原因未明。所以在在訓(xùn)練里面把所有屬于tensorflow的運(yùn)算都寫進(jìn)去,運(yùn)行session.run返回的只能是只讀。
##錯(cuò)誤代碼
#訓(xùn)練
graph = tf.Graph()
with graph.as_default():
#codes
predict = tf.nn.softmax(model(data))
#預(yù)測(cè),這里訓(xùn)練文件與預(yù)測(cè)文件是分離的
with tf.Session(graph=graph) as session:
#codes
predict = session.run(predict, feed_dict={data: block})
prediction = tf.argmax(predict, -1) #這里會(huì)對(duì)圖進(jìn)行修改
##正確代碼
#訓(xùn)練
graph = tf.Graph()
with graph.as_default():
#codes
predict = tf.argmax(tf.nn.softmax(model(data)), -1)
#預(yù)測(cè)
with tf.Session(graph=graph) as session:
#codes
prediction = session.run(predict, feed_dict={data: block})
以上這篇解決Tensorflow 內(nèi)存泄露問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 解決Tensorflow sess.run導(dǎo)致的內(nèi)存溢出問(wèn)題
- 解決TensorFlow訓(xùn)練內(nèi)存不斷增長(zhǎng),進(jìn)程被殺死問(wèn)題
- 淺談tensorflow之內(nèi)存暴漲問(wèn)題
- TensorFlow內(nèi)存管理bfc算法實(shí)例
- Tensorflow 實(shí)現(xiàn)釋放內(nèi)存
- 解決tensorflow訓(xùn)練時(shí)內(nèi)存持續(xù)增加并占滿的問(wèn)題
- tensorflow 打印內(nèi)存中的變量方法
- Tensorflow 訓(xùn)練自己的數(shù)據(jù)集將數(shù)據(jù)直接導(dǎo)入到內(nèi)存
相關(guān)文章
使用python快速實(shí)現(xiàn)不同機(jī)器間文件夾共享方式
今天小編就為大家分享一篇使用python快速實(shí)現(xiàn)不同機(jī)器間文件夾共享方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
詳解運(yùn)行Python的神器Jupyter Notebook
如果我們想要運(yùn)行Python,就是在Python或者IPython的解釋器環(huán)境中進(jìn)行交互式運(yùn)行,或者程序員最喜歡的編寫.py文件,在文件中編寫python代碼,然后運(yùn)行。如果想寫一篇Python的文章,里面有代碼,還希望代碼在當(dāng)前頁(yè)面運(yùn)行,那就是使用我們今天要介紹的Jupyter Notebook。2021-06-06
Python自動(dòng)化辦公之創(chuàng)建PPT文件
python-pptx模塊是Python中用于PPT操作的模塊。本文將利用這一模塊實(shí)現(xiàn)創(chuàng)建PPT文件。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-05-05
pytorch和numpy默認(rèn)浮點(diǎn)類型位數(shù)詳解
這篇文章主要介紹了pytorch和numpy默認(rèn)浮點(diǎn)類型位數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
Django使用mysqlclient服務(wù)連接并寫入數(shù)據(jù)庫(kù)的操作過(guò)程
這篇文章主要介紹了Django使用mysqlclient服務(wù)連接并寫入數(shù)據(jù)庫(kù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
Pycharm運(yùn)行程序時(shí),控制臺(tái)輸出PyDev?console:starting問(wèn)題
Pycharm運(yùn)行程序時(shí),控制臺(tái)輸出PyDev?console:starting問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
Jupyter Notebook內(nèi)使用argparse報(bào)錯(cuò)的解決方案
這篇文章主要介紹了在Jupyter Notebook內(nèi)使用argparse報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06

