tensorflow模型的save与restore,及checkpoint中读取变量方式


Posted in Python onMay 26, 2020

创建一个NN

import tensorflow as tf
import numpy as np

#fake data
x = np.linspace(-1, 1, 100)[:, np.newaxis] #shape(100,1)
noise = np.random.normal(0, 0.1, size=x.shape)
y = np.power(x, 2) + noise  #shape(100,1) + noise
tf_x = tf.placeholder(tf.float32, x.shape) #input x
tf_y = tf.placeholder(tf.float32, y.shape) #output y
l = tf.layers.dense(tf_x, 10, tf.nn.relu) #hidden layer
o = tf.layers.dense(l, 1)     #output layer
loss = tf.losses.mean_squared_error(tf_y, o ) #compute loss
train_op = tf.train.GradientDescentOptimizer(learning_rate=0.5).minimize(loss)

1.使用save对模型进行保存

sess= tf.Session()
sess.run(tf.global_variables_initializer())  #initialize var in graph
saver = tf.train.Saver() # define a saver for saving and restoring
for step in range(100):   #train
 sess.run(train_op,{tf_x:x, tf_y:y})
saver.save(sess, 'params/params.ckpt', write_meta_graph=False) # mate_graph is not recommend

生成三个文件,分别是checkpoint,.ckpt.data-00000-of-00001,.ckpt.index

2.使用restore对提取模型

在提取模型时,需要将模型结构再定义一遍,再将各参数加载出来

#bulid entire net again and restore
tf_x = tf.placeholder(tf.float32, x.shape)
tf_y = tf.placeholder(tf.float32, y.shape)
l_ = tf.layers.dense(tf_x, 10, tf.nn.relu)
o_ = tf.layers.dense(l_, 1)
loss_ = tf.losses.mean_squared_error(tf_y, o_)
 
sess = tf.Session()
# don't need to initialize variables, just restoring trained variables
saver = tf.train.Saver() # define a saver for saving and restoring
saver.restore(sess, './params/params.ckpt')

3.有时会报错Not found:b1 not found in checkpoint

这时我们想知道我在文件中到底保存了什么内容,即需要读取出checkpoint中的tensor

import os
from tensorflow.python import pywrap_tensorflow
checkpoint_path = os.path.join('params','params.ckpt')
# Read data from checkpoint file
reader = pywrap_tensorflow.NewCheckpointReader(checkpoint_path)
var_to_shape_map = reader.get_variable_to_shape_map()
# Print tensor name and value
f = open('params.txt','w')
for key in var_to_shape_map: # write tensors' names and values in file
 print(key,file=f)
 print(reader.get_tensor(key),file=f)
f.close()

运行后生成一个params.txt文件,在其中可以看到模型的参数。

补充知识:TensorFlow按时间保存检查点

一 实例

介绍一种更简便地保存检查点功能的方法——tf.train.MonitoredTrainingSession函数,该函数可以直接实现保存及载入检查点模型的文件。

演示使用MonitoredTrainingSession函数来自动管理检查点文件。

二 代码

import tensorflow as tf
tf.reset_default_graph()
global_step = tf.train.get_or_create_global_step()
step = tf.assign_add(global_step, 1)
with tf.train.MonitoredTrainingSession(checkpoint_dir='log/checkpoints',save_checkpoint_secs = 2) as sess:
 print(sess.run([global_step]))
 while not sess.should_stop():
  i = sess.run( step)
  print( i)

三 运行结果

1 第一次运行后,会发现log文件夹下产生如下文件

tensorflow模型的save与restore,及checkpoint中读取变量方式

2 第二次运行后,结果如下:

INFO:tensorflow:Create CheckpointSaverHook.
INFO:tensorflow:Restoring parameters from log/checkpoints\model.ckpt-15147
INFO:tensorflow:Saving checkpoints for 15147 into log/checkpoints\model.ckpt.
[15147]
15148
15149
15150
15151
15152
15153
15154
15155
15156
15157
15158
15159

四 说明

本例是按照训练时间来保存的。通过指定save_checkpoint_secs参数的具体秒数,来设置每训练多久保存一次检查点。

可见程序自动载入检查点是从第15147次开始运行的。

五 注意

1 如果不设置save_checkpoint_secs参数,默认的保存时间是10分钟,这种按照时间保存的模式更适合用于使用大型数据集来训练复杂模型的情况。

2 使用该方法,必须要定义global_step变量,否则会报错误。

以上这篇tensorflow模型的save与restore,及checkpoint中读取变量方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python远程登录代码
Apr 29 Python
9种python web 程序的部署方式小结
Jun 30 Python
你真的了解Python的random模块吗?
Dec 12 Python
JavaScript中的模拟事件和自定义事件实例分析
Jul 27 Python
值得收藏,Python 开发中的高级技巧
Nov 23 Python
Python 中 function(#) (X)格式 和 (#)在Python3.*中的注意事项
Nov 30 Python
Python 图像处理: 生成二维高斯分布蒙版的实例
Jul 04 Python
pandas读取CSV文件时查看修改各列的数据类型格式
Jul 07 Python
Python判断字符串是否xx开始或结尾的示例
Aug 08 Python
python中用logging实现日志滚动和过期日志删除功能
Aug 20 Python
python如何实现递归转非递归
Feb 25 Python
用python开发一款操作MySQL的小工具
May 12 Python
tensorflow从ckpt和从.pb文件读取变量的值方式
May 26 #Python
Pytorch转keras的有效方法,以FlowNet为例讲解
May 26 #Python
Django+Celery实现动态配置定时任务的方法示例
May 26 #Python
python删除某个目录文件夹的方法
May 26 #Python
Pytorch使用PIL和Numpy将单张图片转为Pytorch张量方式
May 25 #Python
Pytorch转onnx、torchscript方式
May 25 #Python
使用pandas库对csv文件进行筛选保存
May 25 #Python
You might like
PHP - Html Transfer Code
2006/10/09 PHP
php cookie 作用范围?不要在当前页面使用你的cookie
2009/03/24 PHP
PHP数据类型之整数类型、浮点数的介绍
2013/04/28 PHP
简单实用的.net DataTable导出Execl
2013/10/28 PHP
php+xml结合Ajax实现点赞功能完整实例
2015/01/30 PHP
PHP安装memcache扩展的步骤讲解
2019/02/14 PHP
浅谈PHP无限极分类原理
2019/03/14 PHP
Jquery 组合form元素为json格式,asp.net反序列化
2009/07/09 Javascript
js 自定义个性下拉选择框示例
2013/08/20 Javascript
JS实现六位字符密码输入器功能
2016/08/19 Javascript
jQuery实现的自适应焦点图效果完整实例
2016/08/24 Javascript
在React中如何优雅的处理事件响应详解
2017/07/24 Javascript
详解nuxt sass全局变量(公共scss解决方案)
2018/06/27 Javascript
Vue+abp微信扫码登录的实现代码示例
2020/01/06 Javascript
微信小程序图片自适应实现解析
2020/01/21 Javascript
jQuery实现倒计时功能完整示例
2020/06/01 jQuery
Vue实现input宽度随文字长度自适应操作
2020/07/29 Javascript
[03:20]次级联赛厮杀超职业 现超级兵对拆世纪大战
2014/10/30 DOTA
Python实现国外赌场热门游戏Craps(双骰子)
2015/03/31 Python
在Python中处理时间之clock()方法的使用
2015/05/22 Python
Python嵌套列表转一维的方法(压平嵌套列表)
2018/07/03 Python
Python基于多线程实现ping扫描功能示例
2018/07/23 Python
flask session组件的使用示例
2018/12/25 Python
代码实例讲解python3的编码问题
2019/07/08 Python
Python实现Restful API的例子
2019/08/31 Python
win10环境下配置vscode python开发环境的教程详解
2019/10/16 Python
python字符串,元组,列表,字典互转代码实例详解
2020/02/14 Python
Python3.7在anaconda里面使用IDLE编译器的步骤详解
2020/04/29 Python
澳大利亚宠物食品和用品商店:PETstock
2020/01/02 全球购物
递归计算如下递归函数的值(斐波拉契)
2012/02/04 面试题
计算机专业毕业生求职信分享
2013/12/24 职场文书
大学优秀班主任事迹材料
2014/05/02 职场文书
信息员培训方案
2014/06/12 职场文书
2015年全国助残日活动方案
2015/05/04 职场文书
小学教师见习总结
2015/06/23 职场文书
2016年七夕情人节宣传语
2015/11/25 职场文书