训练元图的权重和偏差

Weights and Bias from Trained Meta Graph

我已成功将重新训练的 InceptionV3 NN 导出为 TensorFlow 元图。我已经成功地将这个 protobuf 读回 python,但我正在努力寻找一种方法来导出每一层的权重和偏差值,我假设这些值存储在元图 protobuf 中,以便在 TensorFlow 之外重新创建 nn .

我的工作流程是这样的:

Retrain final layer for new categories
Export meta graph tf.train.export_meta_graph(filename='model.meta')
Build python pb2.py using Protoc and meta_graph.proto
Load Protobuf:

import meta_graph_pb2
saved = meta_graph_pb2.CollectionDef()
with open('model.meta', 'rb') as f:
  saved.ParseFromString(f.read())

从这里我可以查看图表的大部分方面,例如节点名称等,但我认为我的经验不足使得很难找到访问每个相关层的权重和偏差值的正确方法。

MetaGraphDef 原型实际上并不包含权重和偏差的值。相反,它提供了一种将GraphDef与存储在一个或多个检查点文件中的权重相关联的方法,由tf.train.Saver. The MetaGraphDef tutorial编写的有更多详细信息,但大致结构如下:

  1. 在你的训练计划中,使用 tf.train.Saver 写出一个检查点。这也会将 MetaGraphDef 写入同一目录中的 .meta 文件。

    saver = tf.train.Saver(...)
    # ...
    saver.save(sess, "model")
    

    您应该在您的检查点目录中找到名为 model.metamodel-NNNN(对于某些整数 NNNN)的文件。

  2. 在另一个程序中,您可以导入刚刚创建的MetaGraphDef,并从检查点恢复。

    saver = tf.train.import_meta_graph("model.meta")
    saver.restore("model-NNNN")  # Or whatever checkpoint filename was written.
    

    如果你想得到每个变量的值,你可以(例如)在tf.all_variables()集合中找到变量并将它传递给sess.run()来获取它的值。例如,要打印所有变量的值,您可以执行以下操作:

    for var in tf.all_variables():
      print var.name, sess.run(var)
    

    您还可以过滤 tf.all_variables() 以查找您尝试从模型中提取的特定权重和偏差。