91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python使用tensorflow保存、加載和使用模型的方法

發布時間:2020-10-14 18:01:22 來源:腳本之家 閱讀:140 作者:LordofRobots 欄目:開發技術

使用Tensorflow進行深度學習訓練的時候,需要對訓練好的網絡模型和各種參數進行保存,以便在此基礎上繼續訓練或者使用。介紹這方面的博客有很多,我發現寫的最好的是這一篇官方英文介紹:

http://cv-tricks.com/tensorflow-tutorial/save-restore-tensorflow-models-quick-complete-tutorial/

我對這篇文章進行了整理和匯總。

首先是模型的保存。直接上代碼:

#!/usr/bin/env python 
#-*- coding:utf-8 -*- 
############################ 
#File Name: tut1_save.py 
#Author: Wang  
#Mail: wang19920419@hotmail.com 
#Created Time:2017-08-30 11:04:25 
############################ 
 
import tensorflow as tf 
 
# prepare to feed input, i.e. feed_dict and placeholders 
w1 = tf.Variable(tf.random_normal(shape = [2]), name = 'w1') # name is very important in restoration 
w2 = tf.Variable(tf.random_normal(shape = [2]), name = 'w2') 
b1 = tf.Variable(2.0, name = 'bias1') 
feed_dict = {w1:[10,3], w2:[5,5]} 
 
# define a test operation that will be restored 
w3 = tf.add(w1, w2) # without name, w3 will not be stored 
w4 = tf.multiply(w3, b1, name = "op_to_restore") 
 
#saver = tf.train.Saver() 
saver = tf.train.Saver(max_to_keep = 4, keep_checkpoint_every_n_hours = 1) 
sess = tf.Session() 
sess.run(tf.global_variables_initializer()) 
print sess.run(w4, feed_dict) 
#saver.save(sess, 'my_test_model', global_step = 100) 
saver.save(sess, 'my_test_model') 
#saver.save(sess, 'my_test_model', global_step = 100, write_meta_graph = False) 

需要說明的有以下幾點:

1. 創建saver的時候可以指明要存儲的tensor,如果不指明,就會全部存下來。在這里也可以指明最大存儲數量和checkpoint的記錄時間。具體細節看英文博客。

2. saver.save()函數里面可以設定global_step和write_meta_graph,meta存儲的是網絡結構,只在開始運行程序的時候存儲一次即可,后續可以通過設置write_meta_graph = False加以限制。

3. 這個程序執行結束后,會在程序目錄下生成四個文件,分別是.meta(存儲網絡結構)、.data和.index(存儲訓練好的參數)、checkpoint(記錄最新的模型)。

下面是如何加載已經保存的網絡模型。這里有兩種方法,第一種是saver.restore(sess, 'aaaa.ckpt'),這種方法的本質是讀取全部參數,并加載到已經定義好的網絡結構上,因此相當于給網絡的weights和biases賦值并執行tf.global_variables_initializer()。這種方法的缺點是使用前必須重寫網絡結構,而且網絡結構要和保存的參數完全對上。第二種就比較高端了,直接把網絡結構加載進來(.meta),上代碼:

#!/usr/bin/env python 
#-*- coding:utf-8 -*- 
############################ 
#File Name: tut2_import.py 
#Author: Wang  
#Mail: wang19920419@hotmail.com 
#Created Time:2017-08-30 14:16:38 
############################  
import tensorflow as tf 
sess = tf.Session() 
new_saver = tf.train.import_meta_graph('my_test_model.meta') 
new_saver.restore(sess, tf.train.latest_checkpoint('./')) 
print sess.run('w1:0') 

使用加載的模型,輸入新數據,計算輸出,還是直接上代碼:

#!/usr/bin/env python 
#-*- coding:utf-8 -*- 
############################ 
#File Name: tut3_reuse.py 
#Author: Wang 
#Mail: wang19920419@hotmail.com 
#Created Time:2017-08-30 14:33:35 
############################ 
 
import tensorflow as tf 
 
sess = tf.Session() 
 
# First, load meta graph and restore weights 
saver = tf.train.import_meta_graph('my_test_model.meta') 
saver.restore(sess, tf.train.latest_checkpoint('./')) 
 
# Second, access and create placeholders variables and create feed_dict to feed new data 
graph = tf.get_default_graph() 
w1 = graph.get_tensor_by_name('w1:0') 
w2 = graph.get_tensor_by_name('w2:0') 
feed_dict = {w1:[-1,1], w2:[4,6]} 
 
# Access the op that want to run 
op_to_restore = graph.get_tensor_by_name('op_to_restore:0') 
 
print sess.run(op_to_restore, feed_dict)   # ouotput: [6. 14.] 

在已經加載的網絡后繼續加入新的網絡層:

import tensorflow as tf 
sess=tf.Session()   
#First let's load meta graph and restore weights 
saver = tf.train.import_meta_graph('my_test_model-1000.meta') 
saver.restore(sess,tf.train.latest_checkpoint('./')) 

# Now, let's access and create placeholders variables and 
# create feed-dict to feed new data 
 
graph = tf.get_default_graph() 
w1 = graph.get_tensor_by_name("w1:0") 
w2 = graph.get_tensor_by_name("w2:0") 
feed_dict ={w1:13.0,w2:17.0} 
 
#Now, access the op that you want to run.  
op_to_restore = graph.get_tensor_by_name("op_to_restore:0") 
 
#Add more to the current graph 
add_on_op = tf.multiply(op_to_restore,2) 
 
print sess.run(add_on_op,feed_dict) 
#This will print 120. 

對加載的網絡進行局部修改和處理(這個最麻煩,我還沒搞太明白,后續會繼續補充):

...... 
...... 
saver = tf.train.import_meta_graph('vgg.meta') 
# Access the graph 
graph = tf.get_default_graph() 
## Prepare the feed_dict for feeding data for fine-tuning  
 
#Access the appropriate output for fine-tuning 
fc7= graph.get_tensor_by_name('fc7:0') 
 
#use this if you only want to change gradients of the last layer 
fc7 = tf.stop_gradient(fc7) # It's an identity function 
fc7_shape= fc7.get_shape().as_list() 
 
new_outputs=2 
weights = tf.Variable(tf.truncated_normal([fc7_shape[3], num_outputs], stddev=0.05)) 
biases = tf.Variable(tf.constant(0.05, shape=[num_outputs])) 
output = tf.matmul(fc7, weights) + biases 
pred = tf.nn.softmax(output) 
 
# Now, you run this with fine-tuning data in sess.run() 

有了這樣的方法,無論是自行訓練、加載模型繼續訓練、使用經典模型還是finetune經典模型抑或是加載網絡跑前項,效果都是杠杠的。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

那坡县| 兴海县| 石嘴山市| 四子王旗| 包头市| 临汾市| 莒南县| 翁牛特旗| 育儿| 京山县| 西畴县| 沁水县| 上林县| 吴堡县| 房产| 吉林省| 永泰县| 大姚县| 镇巴县| 北京市| 彭水| 琼中| 油尖旺区| 阳泉市| 宣化县| 玉屏| 茶陵县| 上杭县| 奈曼旗| 安西县| 长垣县| 垣曲县| 岚皋县| 新宁县| 昌图县| 利津县| 兴安盟| 明星| 高州市| 博湖县| 铜山县|