Heim  >  Artikel  >  Backend-Entwicklung  >  Beispiele für TensorFlow-Modellspeicher- und Extraktionsmethoden

Beispiele für TensorFlow-Modellspeicher- und Extraktionsmethoden

不言
不言Original
2018-04-26 16:34:112352Durchsuche

In diesem Artikel werden hauptsächlich Beispiele für Methoden zum Speichern und Extrahieren von TensorFlow-Modellen vorgestellt. Jetzt teile ich sie mit Ihnen und gebe ihnen eine Referenz. Schauen wir uns das gemeinsam an

1. Methoden zum Speichern und Extrahieren von TensorFlow-Modellen

1. TensorFlow implementiert neuronale Netze über den tf.train.Saver Speichern und Abrufen von Klassenmodellen. Die save-Methode des tf.train.Saver-Objektschoners speichert das TensorFlow-Modell im angegebenen Pfad saver.save(sess, „Model/model.ckpt“). Tatsächlich werden in diesem Dateiverzeichnis 4 persönliche Dateien generiert:

Die Checkpoint-Datei speichert eine Liste von Modelldateien, model.ckpt.meta speichert die Strukturinformationen des TensorFlow-Berechnungsdiagramms und model.ckpt speichert den Wert jeder Variablen . Die Art und Weise, wie der Dateiname hier geschrieben wird, hängt von den Einstellungen verschiedener Parameter ab, aber der Dateipfadname beim Laden der Wiederherstellung wird durch den Wert „model_checkpoint_path“ in der Prüfpunktdatei bestimmt.

2. Die Methode zum Laden dieses gespeicherten TensorFlow-Modells ist saver.restore(sess, „./Model/model.ckpt“). Alle Vorgänge im TensorFlow-Berechnungsdiagramm müssen auch im zu ladenden Code definiert werden Das Modell. Und deklarieren Sie eine tf.train.Saver-Klasse. Der Unterschied besteht darin, dass die Variablen beim Laden des Modells nicht initialisiert werden müssen Schreiben des Ladepfades. Wenn Sie Operationen im Berechnungsdiagramm nicht wiederholt definieren möchten, können Sie das persistente Diagramm direkt laden, saver =tf.train.import_meta_graph("Model/model.ckpt.meta").

3.tf.train.Saver-Klasse unterstützt auch das Umbenennen von Variablen beim Speichern und Laden. Wenn Sie das Saver-Klassenobjekt deklarieren, verwenden Sie ein Wörterbuch-Dikt, um die Variable umzubenennen, {"Der Name des gespeicherten Variablennamens": Benennen Sie den Variablennamen um}, saver = tf.train.Saver({"v1":u1, "v2": u2}), das heißt, die ursprüngliche Variable mit dem Namen v1 wird jetzt in die Variable u1 (mit dem Namen other-v1) geladen. .

4. Einer der Zwecke des vorherigen Artikels besteht darin, die Verwendung des gleitenden Durchschnitts von Variablen zu erleichtern. Wenn die Schattenvariable beim Laden des Modells direkt der Variablen selbst zugeordnet wird, ist es nicht erforderlich, die Funktion aufzurufen, um den gleitenden Durchschnitt der Variablen zu erhalten, wenn das trainierte Modell verwendet wird. Laden Sie beim Laden beim Deklarieren des Saver-Klassenobjekts den gleitenden Durchschnitt über ein Wörterbuch, saver = tf.train.Saver({"v/ExponentialMovingAverage": v}) und über tf.train.ExponentialMovingAverage direkt in eine neue Variable Die Funktion „variables_to_restore()“ ruft das Variablenumbenennungswörterbuch ab.

Darüber hinaus werden die Variablen im Berechnungsdiagramm und ihre Werte über die Funktion „convert_variables_to_constants“ als Konstanten in einer Datei gespeichert.

2. TensorFlow-Programmimplementierung

# 本文件程序为配合教材及学习进度渐进进行,请按照注释分段执行 
# 执行时要注意IDE的当前工作过路径,最好每段重启控制器一次,输出结果更准确  
# Part1: 通过tf.train.Saver类实现保存和载入神经网络模型  
# 执行本段程序时注意当前的工作路径 
import tensorflow as tf  
v1 = tf.Variable(tf.constant(1.0, shape=[1]), name="v1") 
v2 = tf.Variable(tf.constant(2.0, shape=[1]), name="v2") 
result = v1 + v2  
saver = tf.train.Saver()  
with tf.Session() as sess: 
  sess.run(tf.global_variables_initializer()) 
  saver.save(sess, "Model/model.ckpt")  
 
# Part2: 加载TensorFlow模型的方法  
import tensorflow as tf  
v1 = tf.Variable(tf.constant(1.0, shape=[1]), name="v1") 
v2 = tf.Variable(tf.constant(2.0, shape=[1]), name="v2") 
result = v1 + v2  
saver = tf.train.Saver()  
with tf.Session() as sess: 
  saver.restore(sess, "./Model/model.ckpt") # 注意此处路径前添加"./" 
  print(sess.run(result)) # [ 3.] 
  
# Part3: 若不希望重复定义计算图上的运算,可直接加载已经持久化的图  
import tensorflow as tf  
saver = tf.train.import_meta_graph("Model/model.ckpt.meta")  
with tf.Session() as sess: 
  saver.restore(sess, "./Model/model.ckpt") # 注意路径写法 
  print(sess.run(tf.get_default_graph().get_tensor_by_name("add:0"))) # [ 3.] 
  
# Part4: tf.train.Saver类也支持在保存和加载时给变量重命名  
import tensorflow as tf  
# 声明的变量名称name与已保存的模型中的变量名称name不一致 
u1 = tf.Variable(tf.constant(1.0, shape=[1]), name="other-v1") 
u2 = tf.Variable(tf.constant(2.0, shape=[1]), name="other-v2") 
result = u1 + u2  
# 若直接生命Saver类对象,会报错变量找不到 
# 使用一个字典dict重命名变量即可,{"已保存的变量的名称name": 重命名变量名} 
# 原来名称name为v1的变量现在加载到变量u1(名称name为other-v1)中 
saver = tf.train.Saver({"v1": u1, "v2": u2})  
with tf.Session() as sess: 
  saver.restore(sess, "./Model/model.ckpt") 
  print(sess.run(result)) # [ 3.] 
  
# Part5: 保存滑动平均模型  
import tensorflow as tf  
v = tf.Variable(0, dtype=tf.float32, name="v") 
for variables in tf.global_variables(): 
  print(variables.name) # v:0  
ema = tf.train.ExponentialMovingAverage(0.99) 
maintain_averages_op = ema.apply(tf.global_variables()) 
for variables in tf.global_variables(): 
  print(variables.name) # v:0 
             # v/ExponentialMovingAverage:0  
saver = tf.train.Saver()  
with tf.Session() as sess: 
  sess.run(tf.global_variables_initializer()) 
  sess.run(tf.assign(v, 10)) 
  sess.run(maintain_averages_op) 
  saver.save(sess, "Model/model_ema.ckpt") 
  print(sess.run([v, ema.average(v)])) # [10.0, 0.099999905]  
 
# Part6: 通过变量重命名直接读取变量的滑动平均值  
import tensorflow as tf  
v = tf.Variable(0, dtype=tf.float32, name="v") 
saver = tf.train.Saver({"v/ExponentialMovingAverage": v}) 
 with tf.Session() as sess: 
  saver.restore(sess, "./Model/model_ema.ckpt") 
  print(sess.run(v)) # 0.0999999 
  
# Part7: 通过tf.train.ExponentialMovingAverage的variables_to_restore()函数获取变量重命名字典  
import tensorflow as tf  
v = tf.Variable(0, dtype=tf.float32, name="v") 
# 注意此处的变量名称name一定要与已保存的变量名称一致 
ema = tf.train.ExponentialMovingAverage(0.99) 
print(ema.variables_to_restore()) 
# {&#39;v/ExponentialMovingAverage&#39;: <tf.Variable &#39;v:0&#39; shape=() dtype=float32_ref>} 
# 此处的v取自上面变量v的名称name="v"  
saver = tf.train.Saver(ema.variables_to_restore()) 
 with tf.Session() as sess: 
  saver.restore(sess, "./Model/model_ema.ckpt") 
  print(sess.run(v)) # 0.0999999 
 
# Part8: 通过convert_variables_to_constants函数将计算图中的变量及其取值通过常量的方式保存于一个文件中  
import tensorflow as tf 
from tensorflow.python.framework import graph_util  
v1 = tf.Variable(tf.constant(1.0, shape=[1]), name="v1") 
v2 = tf.Variable(tf.constant(2.0, shape=[1]), name="v2") 
result = v1 + v2  
with tf.Session() as sess: 
  sess.run(tf.global_variables_initializer()) 
  # 导出当前计算图的GraphDef部分,即从输入层到输出层的计算过程部分 
  graph_def = tf.get_default_graph().as_graph_def() 
  output_graph_def = graph_util.convert_variables_to_constants(sess, 
                            graph_def, [&#39;add&#39;])  
  with tf.gfile.GFile("Model/combined_model.pb", &#39;wb&#39;) as f: 
    f.write(output_graph_def.SerializeToString()) 
  
# Part9: 载入包含变量及其取值的模型  
import tensorflow as tf 
from tensorflow.python.platform import gfile  
with tf.Session() as sess: 
  model_filename = "Model/combined_model.pb" 
  with gfile.FastGFile(model_filename, &#39;rb&#39;) as f: 
    graph_def = tf.GraphDef() 
    graph_def.ParseFromString(f.read())  
  result = tf.import_graph_def(graph_def, return_elements=["add:0"]) 
  print(sess.run(result)) # [array([ 3.], dtype=float32)]

Verwandte Empfehlungen:

Detaillierte Erläuterung der drei Möglichkeiten, wie Tensorflow Daten lädt

Tensorflow verwendet Flags, um Befehlszeilenparameter zu definieren

Das obige ist der detaillierte Inhalt vonBeispiele für TensorFlow-Modellspeicher- und Extraktionsmethoden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn