TensorFlow固化模型的实现操作


Posted in Python onMay 26, 2020

前言

TensorFlow目前在移动端是无法training的,只能跑已经训练好的模型,但一般的保存方式只有单一保存参数或者graph的,如何将参数、graph同时保存呢?

生成模型

主要有两种方法生成模型,一种是通过freeze_graph把tf.train.write_graph()生成的pb文件与tf.train.saver()生成的chkp文件固化之后重新生成一个pb文件,这一种现在不太建议使用。另一种是把变量转成常量之后写入PB文件中。我们简单的介绍下freeze_graph方法。

freeze_graph

这种方法我们需要先使用tf.train.write_graph()以及tf.train.saver()生成pb文件和ckpt文件,代码如下:

with tf.Session() as sess:
 saver = tf.train.Saver()
 saver.save(session, "model.ckpt")
 tf.train.write_graph(session.graph_def, '', 'graph.pb')

然后使用TensorFlow源码中的freeze_graph工具进行固化操作:

首先需要build freeze_graph 工具( 需要 bazel ):

bazel build tensorflow/python/tools:freeze_graph

然后使用这个工具进行固化(/path/to/表示文件路径):

bazel-bin/tensorflow/python/tools/freeze_graph --input_graph=/path/to/graph.pb --input_checkpoint=/path/to/model.ckpt --output_node_names=output/predict --output_graph=/path/to/frozen.pb
convert_variables_to_constants

其实在TensorFlow中传统的保存模型方式是保存常量以及graph的,而我们的权重主要是变量,如果我们把训练好的权重变成常量之后再保存成PB文件,这样确实可以保存权重,就是方法有点繁琐,需要一个一个调用eval方法获取值之后赋值,再构建一个graph,把W和b赋值给新的graph。

牛逼的Google为了方便大家使用,编写了一个方法供我们快速的转换并保存。

首先我们需要引入这个方法

from tensorflow.python.framework.graph_util import convert_variables_to_constants

在想要保存的地方加入如下代码,把变量转换成常量

output_graph_def = convert_variables_to_constants(sess, sess.graph_def, output_node_names=['output/predict'])

这里参数第一个是当前的session,第二个为graph,第三个是输出节点名(如我的输出层代码是这样的:)

with tf.name_scope('output'):
 w_out = tf.Variable(w_alpha * tf.random_normal([1024, MAX_CAPTCHA * CHAR_SET_LEN]))
 tf.summary.histogram('output/weight', w_out)
 b_out = tf.Variable(b_alpha * tf.random_normal([MAX_CAPTCHA * CHAR_SET_LEN]))
 tf.summary.histogram('output/biases', b_out)
 out = tf.add(tf.matmul(dense2, w_out), b_out)
 out = tf.nn.softmax(out)
 predict = tf.argmax(tf.reshape(out, [-1, 11, 36]), 2, name='predict')

由于我们采用了name_scope所以我们在predict之前需要加上output/

生成文件

with tf.gfile.FastGFile('model/CTNModel.pb', mode='wb') as f:
f.write(output_graph_def.SerializeToString())

第一个参数是文件路径,第二个是指文件操作的模式,这里指的是以二进制的方式写入文件。

运行代码,系统会生成一个PB文件,接下来我们要测试下这个模型是否能够正常的读取、运行。

测试模型

在Python环境下,我们首先需要加载这个模型,代码如下:

with open('./model/rounded_graph.pb', 'rb') as f:
 graph_def = tf.GraphDef()
 graph_def.ParseFromString(f.read())
 output = tf.import_graph_def(graph_def,
     input_map={'inputs/X:0': newInput_X},
     return_elements=['output/predict:0'])

由于我们原本的网络输入值是一个placeholder,这里为了方便输入我们也先定义一个新的placeholder:

newInput_X = tf.placeholder(tf.float32, [None, IMAGE_HEIGHT * IMAGE_WIDTH], name="X")

在input_map的参数填入新的placeholder。

在调用我们的网络的时候直接用这个新的placeholder接收数据,如:

text_list = sesss.run(output, feed_dict={newInput_X: [captcha_image]})

然后就是运行我们的网络,看是否可以运行吧。

以上这篇TensorFlow固化模型的实现操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现批量把SVG格式转成png、pdf格式的代码分享
Aug 21 Python
把项目从Python2.x移植到Python3.x的经验总结
Apr 20 Python
浅谈python socket函数中,send与sendall的区别与使用方法
May 09 Python
Python实现压缩和解压缩ZIP文件的方法分析
Sep 28 Python
取numpy数组的某几行某几列方法
Apr 03 Python
解决Matplotlib图表不能在Pycharm中显示的问题
May 24 Python
django利用request id便于定位及给日志加上request_id
Aug 26 Python
使用PyTorch将文件夹下的图片分为训练集和验证集实例
Jan 08 Python
Django REST Swagger实现指定api参数
Jul 07 Python
python报错TypeError: ‘NoneType‘ object is not subscriptable的解决方法
Nov 05 Python
python开发一个解析protobuf文件的简单编译器
Nov 17 Python
解决pytorch 损失函数中输入输出不匹配的问题
Jun 05 Python
Python 如何批量更新已安装的库
May 26 #Python
tensorflow 20:搭网络,导出模型,运行模型的实例
May 26 #Python
Python自定义聚合函数merge与transform区别详解
May 26 #Python
Python Tornado实现WEB服务器Socket服务器共存并实现交互的方法
May 26 #Python
tensorflow实现从.ckpt文件中读取任意变量
May 26 #Python
打印tensorflow恢复模型中所有变量与操作节点方式
May 26 #Python
tensorflow模型的save与restore,及checkpoint中读取变量方式
May 26 #Python
You might like
Zerg剧情介绍
2020/03/14 星际争霸
模仿OSO的论坛(三)
2006/10/09 PHP
PHP配置心得包含MYSQL5乱码解决
2006/11/20 PHP
PHP文件锁定写入实例解析
2014/07/14 PHP
PHP对象克隆clone用法示例
2016/09/28 PHP
thinkphp3.2框架中where条件查询用法总结
2019/08/13 PHP
通过身份证号得到出生日期和性别的js代码
2009/11/23 Javascript
JQuery Tips(2) 关于$()包装集你不知道的
2009/12/14 Javascript
js正则表达式中test,exec,match方法的区别说明
2014/01/29 Javascript
基于jQuery实现的图片切换焦点图整理
2014/12/07 Javascript
简介JavaScript中Boolean.toSource()方法的使用
2015/06/05 Javascript
Nodejs获取网络数据并生成Excel表格
2020/03/31 NodeJs
js实现股票实时刷新数据案例
2017/05/14 Javascript
解决html input验证只能输入数字,不能输入其他的问题
2017/07/21 Javascript
在Vue组件化中利用axios处理ajax请求的使用方法
2017/08/25 Javascript
vue.js路由mode配置之去掉url上默认的#方法
2019/11/01 Javascript
微信小程序实现二维码签到考勤系统
2020/01/16 Javascript
Python中字典和JSON互转操作实例
2015/01/19 Python
Python httplib模块使用实例
2015/04/11 Python
浅析Python中的序列化存储的方法
2015/04/28 Python
Python+matplotlib绘制不同大小和颜色散点图实例
2018/01/19 Python
python3.7+selenium模拟淘宝登录功能的实现
2020/05/26 Python
Python3开发环境搭建详细教程
2020/06/18 Python
在Mac中配置Python虚拟环境过程解析
2020/06/22 Python
全球领先的在线cosplay服装商店:RoleCosplay
2020/01/18 全球购物
新闻专业推荐信范文
2013/11/20 职场文书
化学实验员岗位职责
2013/12/28 职场文书
企业党的群众路线教育实践活动学习心得体会
2014/10/31 职场文书
合作意向协议书
2015/01/29 职场文书
2015年全民国防教育日活动总结
2015/03/23 职场文书
银行培训心得体会范文
2016/01/09 职场文书
如何做好工作总结!
2019/04/10 职场文书
2019银行员工个人工作自我鉴定
2019/06/27 职场文书
使用canvas实现雪花飘动效果的示例代码
2021/03/30 HTML / CSS
Redis如何一键部署脚本
2021/04/12 Redis
Java中多线程下载图片并压缩能提高效率吗
2021/07/01 Java/Android