CKPT->pb

Demo

解析

tensor name 和 node name 的区别

Pb 的恢复

CKPT->pb

tensorflow的模型保存有两种形式:

1. ckpt:可以恢复图和变量,继续做训练

2. pb : 将图序列化,变量成为固定的值,,只可以做inference;不能继续训练

Demo

  1 def freeze_graph(input_checkpoint,output_graph):
2
3 '''
4 :param input_checkpoint:
5 :param output_graph: PB模型保存路径
6 :return
7 void
8 '''
9
10 # checkpoint = tf.train.get_checkpoint_state(model_folder) #检查目录下ckpt文件状态是否可用
11 # input_checkpoint = checkpoint.model_checkpoint_path #得ckpt文件路径
12
13 # 指定输出的节点名称,该节点名称必须是原模型中存在的节点
14 output_node_names = "InceptionV3/Logits/SpatialSqueeze" # 如果是多个输出节点,使用 ‘,’号隔开
15
16 ############################ Step1: 从ckpt中恢复图: #############################################
17 saver = tf.train.import_meta_graph(input_checkpoint + '.meta', clear_devices=True)
18 graph = tf.get_default_graph() # 获得默认的图, 可以省略
19 input_graph_def = graph.as_graph_def() # 返回一个序列化的图代表当前的图,可以省略
20
21 with tf.Session() as sess: # 会使用默认的图 作为当前的图
22 saver.restore(sess, input_checkpoint) #恢复图并得到数据
23
24 ######################## Step2: 创建持久化对象,指定sess,图、以及输出的序列化节点信息 ##############
25 output_graph_def = graph_util.convert_variables_to_constants( # 模型持久化,将变量值固定
26 sess=sess,
27 input_graph_def=input_graph_def,# 等于:sess.graph_def
28 output_node_names=output_node_names.split(","))# 如果有多个输出节点,以逗号隔开
29 ######################### Step3: 模型持久化 #######################################################
30 with tf.gfile.GFile(output_graph, "wb") as f: #保存模型
31 f.write(output_graph_def.SerializeToString()) #序列化输出
32 print("%d ops in the final graph." % len(output_graph_def.node)) #得到当前图有几个操作节点
33 # for op in graph.get_operations():
34
35 # print(op.name, op.values())
36
37
38 ########################### 调用方式 ################################
39 # 输入ckpt模型路径
40 input_checkpoint='models/model.ckpt-10000'
41 # 输出pb模型的路径
42 out_pb_path="models/pb/frozen_model.pb"
43 # 调用freeze_graph将ckpt转为pb
44 freeze_graph(input_checkpoint,out_pb_path)解析函数freeze_graph中,最重要的就是要确定“指定输出的节点名称”,这个节点名称必须是原模型中存在的节点,对于freeze操作,我们需要定义输出结点的名字。freeze的时候就只把输出该结点所需要的子图都固化下来,其他无关的就舍弃掉。因为我们freeze模型的目的是接下来做预测。所以,output_node_names一般是网络模型最后一层输出的节点名称,或者说就是我们预测的目标。在保存pb的时候,通过convert_variables_to_constants函数来指定需要固化的节点名称; tensor name 和 node name 的区别node name 是 图 的节点,里面包含了很多操作和tensortensor 是 node 里面的一个组成部分;以input 为例,“input:0”是张量的名称,而"input"表示的是节点的名称PS:注意张量的名称,即为:节点名称+“:”+“id号”,如"input:0"

Tensorflow Learning1 模型的保存和恢复的更多相关文章

  1. TensorFlow笔记-模型的保存,恢复,实现线性回归

    模型的保存 tf.train.Saver(var_list=None,max_to_keep=5) •var_list:指定将要保存和还原的变量.它可以作为一个 dict或一个列表传递. •max_t ...

  2. 第六节,TensorFlow编程基础案例-保存和恢复模型(中)

    在我们使用TensorFlow的时候,有时候需要训练一个比较复杂的网络,比如后面的AlexNet,ResNet,GoogleNet等等,由于训练这些网络花费的时间比较长,因此我们需要保存模型的参数. ...

  3. tensorflow模型的保存与恢复

    1.tensorflow中模型的保存 创建tf.train.saver,使用saver进行保存: saver = tf.train.Saver() saver.save(sess, './traine ...

  4. [翻译] Tensorflow模型的保存与恢复

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

  5. tensorflow 1.0 学习:模型的保存与恢复(Saver)

    将训练好的模型参数保存起来,以便以后进行验证或测试,这是我们经常要做的事情.tf里面提供模型保存的是tf.train.Saver()模块. 模型保存,先要创建一个Saver对象:如 saver=tf. ...

  6. tensorflow 1.0 学习:模型的保存与恢复

    将训练好的模型参数保存起来,以便以后进行验证或测试,这是我们经常要做的事情.tf里面提供模型保存的是tf.train.Saver()模块. 模型保存,先要创建一个Saver对象:如 saver=tf. ...

  7. AI - TensorFlow - 示例05:保存和恢复模型

    保存和恢复模型(Save and restore models) 官网示例:https://www.tensorflow.org/tutorials/keras/save_and_restore_mo ...

  8. tensorflow模型的保存与恢复,以及ckpt到pb的转化

    转自 https://www.cnblogs.com/zerotoinfinity/p/10242849.html 一.模型的保存 使用tensorflow训练模型的过程中,需要适时对模型进行保存,以 ...

  9. Python之TensorFlow的模型训练保存与加载-3

    一.TensorFlow的模型保存和加载,使我们在训练和使用时的一种常用方式.我们把训练好的模型通过二次加载训练,或者独立加载模型训练.这基本上都是比较常用的方式. 二.模型的保存与加载类型有2种 1 ...

随机推荐

  1. JDBC实现最简单的增删改查

    好久没写博客了,今天刚进入一家公司实习,在实习这段期间想把自己所学的东西通过博客记录下来 今天上午简单回顾了一下用JDBC实现最简单的增删改查 废话不多说,接下来就说明怎么用JDBC实现最简单的增删改 ...

  2. mybatis 的 DefaultVFS 日志乱码问题

    mybatis 的 DefaultVFS 日志乱码问题 mybatis  DefaultVFS 乱码  1. 问题描述 今天在启动同事搭建的工程时,发现 console 中乱码,细看下,是 mybat ...

  3. 安装 mysql odbc连接器

    下载地址: https://dev.mysql.com/downloads/connector/odbc/ 可以选择旧版本的下载 一. 配置数据源 1. 安装后如果找不到软件可以按  win键 后 输 ...

  4. keep-alive 组件级缓存

    前言 在Vue构建的单页面应用(SPA)中,路由模块一般使用vue-router.vue-router不保存被切换组件的状态, 它进行push或者replace时,旧组件会被销毁,而新组件会被新建,走 ...

  5. 详解WebService开发中四个常见问题(2)

    详解WebService开发中四个常见问题(2)   WebService开发中经常会碰到诸如WebService与方法重载.循环引用.数据被穿该等等问题.本文会给大家一些很好的解决方法. AD:WO ...

  6. 初识Python,利用turtle画图

    目录 我的第三篇博客 一.初识Python 1.变量 2.注释 3.turtle库 我的第三篇博客 一.初识Python 1.变量 变量就是可变的的量,用来描述某个事物的属性.本质作用就是描述和接收变 ...

  7. 微信小程序-饮食日志_开发日志

    针对假期作业为父母或者身边的人做一款“小软件”这个课题,由于对 android 开发不熟悉 ,所以决定做一款微信小程序. 项目名称:饮食管理日志 目的:身边的人群对摄入食物热量及消耗不清楚,对健康需求 ...

  8. 安装nginx 以及nginx负载均衡

    a  安装 [root@localhost ~]# yum -y install gcc automake autoconf libtool make yum install gcc gcc-c++ ...

  9. 【BZOJ3684】大朋友和多叉树(拉格朗日反演)

    题目链接 题意 求满足如下条件的多叉树个数: 1.每一个点的儿子个数在给定的集合 \(S\) 内 2.总的叶子节点树为 \(s\) 儿子之间有顺序关系,但节点是没有标号的. Sol 拉格朗日反演板子题 ...

  10. 一些 sql 调优的总结

    一.sql 优化方案 1)列类型尽量定义成数值类型,且长度尽可能短,如主键和外键,类型字段等等   2)建立单列索引   3)根据需要建立多列联合索引.当单个列过滤之后还有很多数据,那么索引的效率将会 ...