在某些任务中,我们需要针对不同的情况训练多个不同的神经网络模型,这时候,在测试阶段,我们就需要调用多个预训练好的模型分别来进行预测。

弄明白了如何调用单个模型,其实调用多个模型也就顺理成章。我们只需要建立多个图,然后每个图导入一个模型,再针对每个图创建一个会话,分别进行预测即可。

import tensorflow as tf
import numpy as np # 建立两个 graph
g1 = tf.Graph()
g2 = tf.Graph() # 为每个 graph 建创建一个 session
sess1 = tf.Session(graph=g1)
sess2 = tf.Session(graph=g2) X_1 = None
tst_1 = None
yhat_1 = None X_2 = None
tst_2 = None
yhat_2 = None def load_model(sess):
"""
Loading the pre-trained model and parameters.
"""
global X_1, tst_1, yhat_1
with sess1.as_default():
with sess1.graph.as_default():
modelpath = r'F:/resnet/model/new0.25-0.35/'
saver = tf.train.import_meta_graph(modelpath + 'model-10.meta')
saver.restore(sess1, tf.train.latest_checkpoint(modelpath))
graph = tf.get_default_graph()
X_1 = graph.get_tensor_by_name("X:0")
tst_1 = graph.get_tensor_by_name("tst:0")
yhat_1 = graph.get_tensor_by_name("tanh:0")
print('Successfully load the model_1!') def load_model_2():
"""
Loading the pre-trained model and parameters.
"""
global X_2, tst_2, yhat_2
with sess2.as_default():
with sess2.graph.as_default():
modelpath = r'F:/resnet/model/new0.25-0.352/'
saver = tf.train.import_meta_graph(modelpath + 'model-10.meta')
saver.restore(sess2, tf.train.latest_checkpoint(modelpath))
graph = tf.get_default_graph()
X_2 = graph.get_tensor_by_name("X:0")
tst_2 = graph.get_tensor_by_name("tst:0")
yhat_2 = graph.get_tensor_by_name("tanh:0")
print('Successfully load the model_2!') def test_1(txtdata):
"""
Convert data to Numpy array which has a shape of (-1, 41, 41, 41, 3).
Test a single axample.
Arg:
txtdata: Array in C.
Returns:
The normal of a face.
"""
global X_1, tst_1, yhat_1
data = np.array(txtdata)
data = data.reshape(-1, 41, 41, 41, 3)
output = sess1.run(yhat_1, feed_dict={X_1: data, tst_1: True}) # (100, 3)
output = output.reshape(-1, 1)
ret = output.tolist()
return ret def test_2(txtdata):
"""
Convert data to Numpy array which has a shape of (-1, 41, 41, 41, 3).
Test a single axample.
Arg:
txtdata: Array in C.
Returns:
The normal of a face.
"""
global X_2, tst_2, yhat_2 data = np.array(txtdata)
data = data.reshape(-1, 41, 41, 41, 3)
output = sess2.run(yhat_2, feed_dict={X_2: data, tst_2: True}) # (100, 3)
output = output.reshape(-1, 1)
ret = output.tolist() return ret

最后,本程序只是为了说明问题,抛砖引玉,代码有很多冗余之处,不要模仿!

获取更多精彩,请关注「seniusen」!

TensorFlow 同时调用多个预训练好的模型的更多相关文章

  1. 在 C/C++ 中使用 TensorFlow 预训练好的模型—— 直接调用 C++ 接口实现

    现在的深度学习框架一般都是基于 Python 来实现,构建.训练.保存和调用模型都可以很容易地在 Python 下完成.但有时候,我们在实际应用这些模型的时候可能需要在其他编程语言下进行,本文将通过直 ...

  2. 在 C/C++ 中使用 TensorFlow 预训练好的模型—— 间接调用 Python 实现

    现在的深度学习框架一般都是基于 Python 来实现,构建.训练.保存和调用模型都可以很容易地在 Python 下完成.但有时候,我们在实际应用这些模型的时候可能需要在其他编程语言下进行,本文将通过 ...

  3. TensorFlow 调用预训练好的模型—— Python 实现

    1. 准备预训练好的模型 TensorFlow 预训练好的模型被保存为以下四个文件 data 文件是训练好的参数值,meta 文件是定义的神经网络图,checkpoint 文件是所有模型的保存路径,如 ...

  4. 【猫狗数据集】使用预训练的resnet18模型

    数据集下载地址: 链接:https://pan.baidu.com/s/1l1AnBgkAAEhh0vI5_loWKw提取码:2xq4 创建数据集:https://www.cnblogs.com/xi ...

  5. tensorflow如何正确加载预训练词向量

    使用预训练词向量和随机初始化词向量的差异还是挺大的,现在说一说我使用预训练词向量的流程. 一.构建本语料的词汇表,作为我的基础词汇 二.遍历该词汇表,从预训练词向量中提取出该词对应的词向量 三.初始化 ...

  6. tensorflow 使用预训练好的模型的一部分参数

    vars = tf.global_variables() net_var = [var for var in vars if 'bi-lstm_secondLayer' not in var.name ...

  7. 深度学习tensorflow实战笔记 用预训练好的VGG-16模型提取图像特征

    1.首先就要下载模型结构 首先要做的就是下载训练好的模型结构和预训练好的模型,结构地址是:点击打开链接 模型结构如下: 文件test_vgg16.py可以用于提取特征.其中vgg16.npy是需要单独 ...

  8. 从Word Embedding到Bert模型—自然语言处理中的预训练技术发展史(转载)

    转载 https://zhuanlan.zhihu.com/p/49271699 首发于深度学习前沿笔记 写文章   从Word Embedding到Bert模型—自然语言处理中的预训练技术发展史 张 ...

  9. 【译】深度双向Transformer预训练【BERT第一作者分享】

    目录 NLP中的预训练 语境表示 语境表示相关研究 存在的问题 BERT的解决方案 任务一:Masked LM 任务二:预测下一句 BERT 输入表示 模型结构--Transformer编码器 Tra ...

随机推荐

  1. iOS之报错“Cannot create __weak reference in file using manual reference counting”解决办法

    解决的办法:在Build Settings--------->Aplle LLVM8.0 - Language - Objectibe-C------------->Weak Refere ...

  2. vs2017中的scanf_s

    在visual studio 2017中格式化输入函数不同于其他c/c++编译器使用scanf,而是使用scanf_s. scanf_s相比较于scanf来说更安全,因为使用scanf_s函数需要有一 ...

  3. ABAP术语-ALE

    ALE 原文:http://www.cnblogs.com/qiangsheng/archive/2007/12/13/993351.html Application Link Enabling (A ...

  4. JAVAOOP多线程

    进程每个独立运行的任务对应一个进程,每个进程可以产生多个线程 特点:1,进程是系统运行程序的基本单位 2,每一个进程都有自己独立的一块内存空间,一组系统资源 3,每一个进程的内部数据和状态都是完全独立 ...

  5. 【mysql学习-1】

    part-1: #use mysql;/*show tables;select * from user;use mysql;show databases;#create database db1; # ...

  6. djangorestframework怎么这么好用!

    一年前就已经用过restframework, 当时觉得这个只是给web框架打辅助的, 他能实现的我也都实现(可能没有那么好用, 嘿嘿) 但是我有一种东西叫做效率, 时间就是金钱, 别人造好的就直接用就 ...

  7. 46.VUE学习之--组件之使用动态组件灵活设置页面布局

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. SpringMVC+Mybatis框架搭建

    一.新建javaweb项目,并建好相应的包结构 二.添加项目jar到lib目录下 三.在config包中新建配置文件 sping-mvc.xml,内容如下: <?xml version=&quo ...

  9. 2.5 进程控制之wait函数

    一.绪论 一个进程在终止时会关闭所有文件描述符,释放在用户空间分配的内存,但它的PCB还保留着,内核在其中保存了一些信息:如果 是正常终止则保存着退出状态,如果是异常终止则保存着导致该进程终止的信号是 ...

  10. 5.Python的语言特点

    前言   Python有哪些语言特点?可以列出的特点很多,例如,<Python核心编程>第二版列出了十多条特点.本文的三个特点是笔者学习Python的体会,其他特点有体会之后再写,笔者是这 ...