tensorflow没有output结点,存储成pb文件的例子


Posted in Python onJanuary 04, 2020

Tensorflow中保存成pb file 需要 使用函数

graph_util.convert_variables_to_constants(sess, sess.graph_def,

output_node_names=[]) []中需要填写你需要保存的结点。如果保存的结点在神经网络中没有被显示定义该怎么办?

例如我使用了tf.contrib.slim或者keras,在tf的高层很多情况下都会这样。

在写神经网络时,只需要简单的一层层传导,一个slim.conv2d层就包含了kernal,bias,activation function,非常的方便,好处是网络结构一目了然,坏处是什么呢?

tensorflow没有output结点,存储成pb文件的例子

在尝试保存pb的 output node names时,需要将最后的输出结点保存下来,与这个结点相关的,从输入开始,经过层层传递的嵌套函数或者操作的相关结点,都会被保存,但无效的例如 计算准确率,计算loss等,就可以省略了,因为保存的pb主要是用来做预测的。

在准备查看所有的结点名称并选取保存时,发现scope "local3"里面仅有相关的weights 和biases,这两个是单独存在的,即保存这两个参数并没有任何意义。

tensorflow没有output结点,存储成pb文件的例子

那么这时候有两种解决办法:

方法一:

graph_util.convert_variables_to_constants(sess, sess.graph_def, output_node_names=[var.name[:-2] for var in tf.global_variables()])

那么这个的意思是所有的variable的都被保存下来 但函数中要求的是 node name 我们通过 global_variables获得的是 变量名 并不是 节点名

(例如 output:0 就是变量名,又叫tensor name)

output就是 node name了。

在tensorboard中可以一窥究竟

tensorflow没有output结点,存储成pb文件的例子

通过这样 也可以将 所有的变量全部保存下来(但是你并不能使用,是因为你的output并没有名字,所以你不可以通过常用的sess.graph.get_tensor_by_name来使用)

方法二:

那就是直接改写神经网络了....当然了还是比较简单的,只要改写最后一个,改写成output即可,tensorflow中无论是 变量、操作op、函数、都可以命名,那么这个地方是一个简单的全连接,仅需要将weights*net(上一层的输出) +bias 即可,我们只要将bias相加的结果命名为 ouput即可:

with tf.name_scope('local3'):
 
  local3_weights = tf.Variable(tf.truncated_normal([4096, self.output_size], stddev=0.1))
 
  local3_bias = tf.Variable(tf.constant(0.1, shape=[self.output_size]))
 
result = tf.add(tf.matmul(net, local3_weights), local3_bias, name="output")

这样将上述的convert_variables_to_constants中的output_node_names只需要填写一个['output']即可,因为这一个output结点,需要从input开始,将所有的神经网络前向传播的操作和参数全部保存下来,因此保存的结点数量 和 方法一保存的结点数量是一样的(console显示都是 convert 24)。

完整的pb保存为:(我是将ckpt读入进来,然后存成pb的)

from tensorflow.python.platform import gfile
 
 
 
load_ckpt():
 
  path = './data/output/loss1.0/'
 
  print("read from ckpt")
 
  ckpt = tf.train.get_checkpoint_state(path)
 
  saver = tf.train.Saver()
 
  saver.restore(sess, ckpt.model_checkpoint_path)
 
 
 
def write2pb_file():
 
  constant_graph = graph_util.convert_variables_to_constants(sess, sess.graph_def,
 
    output_node_names=["output"])
 
  with tf.gfile.GFile(path+'loss1.0.pb', mode='wb') as f:
 
  f.write(constant_graph.SerializeToString())
 
  print("Model is saved as " + path+'loss1.0.pb')
 
 
 
def main():
 
  load_ckpt()
 
  write2pb_file()

如果是简单的直接保存,那就更简单了。

pb文件的read,很多人会将一个net写成一个类,在引入的时候会将新建这个类,然后读入ckpt文件,这完全没有问题,但是在读取pb时,就会发生问题,因为pb中已经包含了图与参数,引入时会创建一个默认的图,但是net类中自己也会创建一个图,那么这时候你运行程序,参数其实并没有使用.pb的文件。

所以我们不能创建net类,然后直接读入.pb文件,对.pb文件,通过如下代码,获取.pb的graph中的输入和输出。

self.output = self.sess.graph.get_tensor_by_name("output:0")
 
self.input = self.sess.graph.get_tensor_by_name("images:0")

注意此时要加:0 因为你获取的不再是结点了,而是一个真实的变量,我的理解是,结点相当于一个类,:0是对象,默认初始化值就是对象的初始化。

然后就可以通过self.sess.run(self.output(feed_dict={self.input: your_input})))运行你的网络了!

以上这篇tensorflow没有output结点,存储成pb文件的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
linux下安装easy_install的方法
Feb 10 Python
Python 检查数组元素是否存在类似PHP isset()方法
Oct 14 Python
Python素数检测的方法
May 11 Python
python实现给数组按片赋值的方法
Jul 28 Python
python使用webdriver爬取微信公众号
Aug 31 Python
Python设计模式之工厂方法模式实例详解
Jan 18 Python
python修改字典键(key)的方法
Aug 05 Python
基于Python+Appium实现京东双十一自动领金币功能
Oct 31 Python
让你的Python代码实现类型提示功能
Nov 19 Python
如何基于pythonnet调用halcon脚本
Jan 20 Python
Python操作MongoDb数据库流程详解
Mar 05 Python
Python中zipfile压缩文件模块的基本使用教程
Jun 14 Python
TensorFlow查看输入节点和输出节点名称方式
Jan 04 #Python
根据tensor的名字获取变量的值方式
Jan 04 #Python
将tensorflow.Variable中的某些元素取出组成一个新的矩阵示例
Jan 04 #Python
tensorflow实现tensor中满足某一条件的数值取出组成新的tensor
Jan 04 #Python
对tensorflow中的strides参数使用详解
Jan 04 #Python
tensorflow之获取tensor的shape作为max_pool的ksize实例
Jan 04 #Python
TensorFlow tf.nn.max_pool实现池化操作方式
Jan 04 #Python
You might like
中篇:安装及配置PHP
2006/12/13 PHP
PHP中Memcache操作类及用法实例
2014/12/12 PHP
关于取不到由location.href提交而来的上级页面地址的解决办法
2009/07/30 Javascript
JS 操作符整理[推荐收藏]
2011/11/15 Javascript
Jquery时间验证和转换工具小例子
2013/07/01 Javascript
原生Javascript封装的一个AJAX函数分享
2014/10/11 Javascript
Bootstrap每天必学之前端开发框架
2015/11/19 Javascript
浅谈javascript中的constructor
2016/06/08 Javascript
jQuery html表格排序插件tablesorter使用方法详解
2017/02/10 Javascript
BootstrapTable refresh 方法使用实例简单介绍
2017/02/20 Javascript
jQuery事件详解
2017/02/23 Javascript
js实时监控文本框输入字数的实例代码
2018/01/18 Javascript
简单的三步vuex入门
2018/05/20 Javascript
简单使用webpack打包文件的实现
2019/10/29 Javascript
JS求解两数之和算法详解
2020/04/28 Javascript
[02:03]风行者至宝清风环佩外观展示
2020/09/05 DOTA
python使用pil生成缩略图的方法
2015/03/26 Python
详解Python的Django框架中inclusion_tag的使用
2015/07/21 Python
Pythont特殊语法filter,map,reduce,apply使用方法
2016/02/27 Python
Python 比较两个数组的元素的异同方法
2017/08/17 Python
windows环境下tensorflow安装过程详解
2018/03/30 Python
Python编程在flask中模拟进行Restful的CRUD操作
2018/12/28 Python
Python基于Logistic回归建模计算某银行在降低贷款拖欠率的数据示例
2019/01/23 Python
python为什么会环境变量设置不成功
2020/06/23 Python
CSS3的 fit-content实现水平居中
2017/09/07 HTML / CSS
html5的canvas方法使用指南
2014/12/15 HTML / CSS
德国婴儿推车和儿童安全座椅商店:BABYSHOP
2016/09/01 全球购物
世界上最大的餐具公司:Oneida
2016/12/17 全球购物
实习评语
2013/12/16 职场文书
爱国卫生月活动总结范文
2014/04/25 职场文书
党委书记群众路线对照检查材料思想汇报
2014/10/04 职场文书
大学生暑期社会实践证明范本
2014/10/24 职场文书
成本会计岗位职责
2015/02/03 职场文书
2015年“我们的节日·重阳节”活动总结
2015/07/29 职场文书
百日宴上的祝酒词
2015/08/10 职场文书
Vue OpenLayer测距功能的实现
2022/04/20 Vue.js