【问题标题】:how to use model after trained in tensorflow (save/load graph)在张量流中训练后如何使用模型(保存/加载图)
【发布时间】:2016-12-04 06:23:21
【问题描述】:

我的 tensorflow 版本是 0.11。 我想在训练后保存图表或保存 tensorflow 可以加载的其他内容。

我/使用导出和导入元图

我已经阅读了这篇文章: Tensorflow: how to save/restore a model?

我的Save.py 文件:

X = tf.placeholder("float", [None, 28, 28, 1], name='X')
Y = tf.placeholder("float", [None, 10], name='Y')

tf.train.Saver()
with tf.Session() as sess:
     ...run something ...
     final_tensor = tf.nn.softmax(py_x, name='final_result')
     tf.add_to_collection("final_tensor", final_tensor)

     predict_op = tf.argmax(py_x, 1)
     tf.add_to_collection("predict_op", predict_op)

saver.save(sess, 'my_project') 

然后我运行 load.py:

with tf.Session() as sess:
   new_saver = tf.train.import_meta_graph('my_project.meta')
   new_saver.restore(sess, 'my_project')
   predict_op = tf.get_collection("predict_op")[0]
   for i in range(2):
        test_indices = np.arange(len(teX)) # Get A Test Batch
        np.random.shuffle(test_indices)
        test_indices = test_indices[0:test_size]

        print(i, np.mean(np.argmax(teY[test_indices], axis=1) ==
                         sess.run(predict_op, feed_dict={"X:0": teX[test_indices],
                                                         "p_keep_conv:0": 1.0,
                                                         "p_keep_hidden:0": 1.0})))

但它返回错误

Traceback (most recent call last):
  File "load_05_convolution.py", line 62, in <module>
    "p_keep_hidden:0": 1.0})))
  File "/home/khoa/tensorflow/local/lib/python2.7/site-packages/tensorflow/python/client/session.py", line 717, in run
    run_metadata_ptr)
  File "/home/khoa/tensorflow/local/lib/python2.7/site-packages/tensorflow/python/client/session.py", line 894, in _run
    % (np_val.shape, subfeed_t.name, str(subfeed_t.get_shape())))
ValueError: Cannot feed value of shape (256, 784) for Tensor u'X:0', which has shape '(?, 28, 28, 1)'

我真的不知道为什么?

如果我添加final_tensor = tf.get_collection("final_result")[0]

它返回另一个错误:

Traceback (most recent call last):
  File "load_05_convolution.py", line 46, in <module>
    final_tensor = tf.get_collection("final_result")[0]
IndexError: list index out of range

是不是因为 tf.add_to_collection 只包含一个占位符?

II/ 使用 tf.train.write_graph

我将此行添加到 save.py 的末尾 tf.train.write_graph(graph, 'folder', 'train.pb')

它成功创建了文件'train.pb'

我的load.py

with tf.gfile.FastGFile('folder/train.pb', 'rb') as f:
    graph_def = tf.GraphDef()
    graph_def.ParseFromString(f.read())
    _ = tf.import_graph_def(graph_def, name='')

with tf.Session() as sess:
  predict_op = sess.graph.get_tensor_by_name('predict_op:0')
  for i in range(2):
        test_indices = np.arange(len(teX)) # Get A Test Batch
        np.random.shuffle(test_indices)
        test_indices = test_indices[0:test_size]

        print(i, np.mean(np.argmax(teY[test_indices], axis=1) ==
                         sess.run(predict_op, feed_dict={"X:0": teX[test_indices],
                                                         "p_keep_conv:0": 1.0,
                                                         "p_keep_hidden:0": 1.0})))

然后返回错误:

Traceback (most recent call last):
  File "load_05_convolution.py", line 22, in <module>
    graph_def.ParseFromString(f.read())
  File "/home/khoa/tensorflow/lib/python2.7/site-packages/google/protobuf/message.py", line 185, in ParseFromString
    self.MergeFromString(serialized)
  File "/home/khoa/tensorflow/lib/python2.7/site-packages/google/protobuf/internal/python_message.py", line 1085, in MergeFromString
    raise message_mod.DecodeError('Unexpected end-group tag.')
google.protobuf.message.DecodeError: Unexpected end-group tag.

您介意分享保存/加载模型的标准方法、代码或教程吗?我真的很困惑。

【问题讨论】:

  • 是错字吗?? new_saver.restore(sess, 'my_projec') 在 load.py 中。正确检查路径。
  • 对不起。只是打字的时候打错了。在 load.py 中,它命名为“tich_chap”,但我改为“project”以便于理解
  • @AayushKumarSingha,你有什么想法

标签: python machine-learning neural-network tensorflow deep-learning


【解决方案1】:

您的第一个解决方案(使用 MetaGraph)几乎可以工作,但出现错误是因为您将一批 扁平化 MNIST 训练示例提供给 tf.placeholder(),该tf.placeholder() 期望将一批 MNIST 训练示例作为一个形状为batch_size x height (= 28) x width (= 28) x channels (= 1) 的 4-D 张量。解决此问题的最简单方法是重塑您的输入数据。而不是这个声明:

print(i, np.mean(np.argmax(teY[test_indices], axis=1) ==
                 sess.run(predict_op, feed_dict={
                     "X:0": teX[test_indices],
                     "p_keep_conv:0": 1.0,
                     "p_keep_hidden:0": 1.0})))

...尝试以下语句,它会适当地重塑您的输入数据:

print(i, np.mean(np.argmax(teY[test_indices], axis=1) ==
                 sess.run(predict_op, feed_dict={
                     "X:0": teX[test_indices].reshape(-1, 28, 28, 1),
                     "p_keep_conv:0": 1.0,
                     "p_keep_hidden:0": 1.0})))

【讨论】:

  • @ZHANGJuenjie 能说的更具体一点吗?您是否尝试运行相同的代码并遇到错误?如果有,是哪一个?
猜你喜欢
  • 2017-09-22
  • 1970-01-01
  • 2021-12-04
  • 1970-01-01
  • 1970-01-01
  • 2021-03-12
  • 2023-03-12
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多