将tensorflow的ckpt转换为pb


from tensorflow.python import pywrap_tensorflow
import tensorflow as tf
from tensorflow.python.framework import graph_util
'''
将节点名字打印出来
'''
def getAllNodes(checkpoint_path):
    reader = pywrap_tensorflow.NewCheckpointReader(checkpoint_path)
    var_to_shape_map = reader.get_variable_to_shape_map()
    # Print tensor name and values
    for key in var_to_shape_map:
        print("tensor_name: ", key)
        #print(reader.get_tensor(key))




def freeze_graph(ckpt, output_graph):
    #输出节点的名称,最直观的是从tensorboard里读,一般就是最后输出的节点,例如这里就是输出accuracy的节点
    output_node_names = 'FrameAccuracy/Cast'
    
    # saver = tf.train.import_meta_graph(ckpt+'.meta', clear_devices=True)
    saver = tf.compat.v1.train.import_meta_graph(ckpt + '.meta', clear_devices=True)
    graph = tf.get_default_graph()
    input_graph_def = graph.as_graph_def()

    with tf.Session() as sess:
        saver.restore(sess, ckpt)
        output_graph_def = graph_util.convert_variables_to_constants(
            sess=sess,
            input_graph_def=input_graph_def,
            output_node_names=output_node_names.split(',')
        )
        with tf.gfile.GFile(output_graph, 'wb') as fw:
            fw.write(output_graph_def.SerializeToString())
        print('{} ops in the final graph.'.format(len(output_graph_def.node)))

'''
把pb文件的节点读出来
'''
def print_tensors(pb_file):
    print('Model File: {}\n'.format(pb_file))
    # read pb into graph_def
    with tf.gfile.GFile(pb_file, "rb") as f:
        graph_def = tf.GraphDef()
        graph_def.ParseFromString(f.read())

    # import graph_def
    with tf.Graph().as_default() as graph:
        tf.import_graph_def(graph_def)

    # print operations
    for op in graph.get_operations():
        print(op.name + '\t' + str(op.values()))

'''
从ckpt中读取图结构,输出可以被tensorboard读取的图文件
'''
def showNetFromCkpt(path):
    from tensorflow.python.platform import gfile
    graph = tf.get_default_graph()
    graphdef = graph.as_graph_def()
    _ = tf.train.import_meta_graph(path)
    #tensorboard的图文件输出的位置
    #使用tensorboard --logdir=E:\\MachineLearningProjects\\ViolentDetection_JD\\savedModels\\graph 进入tensorboard
    summary_write = tf.summary.FileWriter("E:\\MachineLearningProjects\\ViolentDetection_JD\\savedModels", graph)
    summary_write.close()

if __name__ == '__main__':
    #注意这里的path必须是绝对路径!!
    ckpt_path='E:\\MachineLearningProjects\\ViolentDetection_JD\\savedModels\\save_epoch_38\\ViolenceNet.ckpt'

    #读取图文件,读完了就注释了就行,把输出节点写到上面的freeze_graph函数里
    #showNetFromCkpt(ckpt_path+".meta")
    #getAllNodes(ckpt_path)

    #将ckpt转换为pb,这里写pb的路径,也必须是绝对路径
    output_graph_path='E:\\MachineLearningProjects\\ViolentDetection_JD\\savedModels\\ViolenceNet.pb'
    freeze_graph(ckpt_path,output_graph_path)

    #将Pb文件的节点打印出来,看看有没有问题
    print_tensors(output_graph_path)

参考文献:

  1. https://blog.csdn.net/u014090429/article/details/93486721
  2. https://blog.csdn.net/guyuealian/article/details/82218092


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM