TensorFlow模型参数的保存和加载(含演示代码)

本文介绍了如何使用TensorFlow的tf.train.Saver模块保存和加载训练模型的参数。在构建网络时,为变量指定name属性,训练结束后通过save()函数保存模型。在后续使用时,利用get_tensor_by_name()恢复训练结果。完整代码示例中包含了MNIST数据集的处理流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当我们通过TensorFlow构建了一个训练模型,譬如人脸识别或场景分类网络,并且找到合适的数据集,经过较长时间的训练后,识别率令人满意,这时候我们希望把训练结果保存下来,下次使用时可以直接调用,而不需要重新训练。这就涉及到一个如何保存和加载TensorFlow训练参数的问题。


为方便使用者保存训练结果,TensorFlow提供了tf.train.Saver模块用于保存当前会话中所有的变量值(Variables)。当构建网络模型时,需要为待保存的变量指定name属性,如下所示:

W = tf.Variable(tf.zeros([784, 10]),name="var_W")


当后面进行加载恢复操作(restore)时,只需要指定变量名,就可以直接获取到上一次训练保存的变量值,代码如下:

W = sess.graph.get_tensor_by_name("var_W:0")


当训练结束时,只需要执行如下语句,即可保存训练结果到指定目录:

saver = tf.train.Saver()

saver_path = saver.save(sess,"%smodel.ckpt"%(SAVER_DIR))


上述操作可总结为:

1. 构建网络时为Variables指定名字;

2. 在完成训练迭代之后,调用tf.train.Saver()的save()函数,保存训练结果;

3. 在进行识别任务时,调用sess.graph.get_tensor_by_name()获取上一次训练结果。

 

完整演示代码如下:

#!/usr/bin/python3.5
# -*- coding: utf-8 -*-

import os
import sys

import tensorflow as tf
from tensorflow.examples.tu
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值