- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要在构造后将输入更改为 tesor。以下面的简化示例:x
(constant=42.0)
、s
(x^2)
和 x_new
(constant=4.0)
。
我想将 s
的输入从 x
更改为 x_new
。执行此操作后,我期望 s.eval() == 16.0
x = tf.constant(42.0, name='x')
s = tf.square(x, name='s')
x_new = tf.constant(4.0, name='x_new')
tf.get_default_graph().as_graph_def()
Out[6]:
node {
name: "x"
op: "Const"
attr {
key: "dtype"
value {
type: DT_FLOAT
}
}
attr {
key: "value"
value {
tensor {
dtype: DT_FLOAT
tensor_shape {
}
float_val: 42.0
}
}
}
}
node {
name: "s"
op: "Square"
input: "x"
attr {
key: "T"
value {
type: DT_FLOAT
}
}
}
node {
name: "x_new"
op: "Const"
attr {
key: "dtype"
value {
type: DT_FLOAT
}
}
attr {
key: "value"
value {
tensor {
dtype: DT_FLOAT
tensor_shape {
}
float_val: 4.0
}
}
}
}
versions {
producer: 24
}
我尝试过使用 tf.contrib.graph_editor.reroute_inputs
,但我终究无法弄清楚如何处理它返回的子图。
我也试过使用 tf.import_graph_def
,正如这个 git issue ( https://github.com/tensorflow/tensorflow/issues/1758 ) 中模糊描述的那样,但无论我尝试了多少种方法,我都没有得到s
将输入从 x
更改为 x_new
。
有人知道如何使用这两种方法中的任何一种来完成这个简单的示例吗?
最佳答案
所以这是我在尝试使用预训练网络时经常遇到的问题。正如您在问题中提到的,一种方法是“import_graph_def”,如 Github issue 中所述。 . Google 一直将我指向此处,但该问题缺少一个干净的示例,因此我将在此处发布一个最小的解决方案。
import tensorflow as tf
with tf.compat.v1.Session() as sess:
x = tf.constant(42.0, name="x")
s = tf.square(x, name="s")
print(sess.run(s))
scope = "test"
x_new = tf.constant(4.0, name="{}/x".format(scope))
tf.import_graph_def(tf.get_default_graph().as_graph_def(), name=scope, input_map={'x': x_new})
print(sess.run("{}/s:0".format(scope)))
请注意,如果您不提供范围,则根据 docs 默认为“导入” .
相反,如果您需要保留一个图表然后对其进行编辑(或从其他人那里加载一个保留的图表),您可以保存该图表并重新加载它(基于此 answer )
import tensorflow as tf
scope = "test"
graph_filename = "test.pb"
with tf.compat.v1.Session() as sess:
x = tf.constant(42.0, name="x")
s = tf.square(x, name="s")
print(sess.run(s))
with tf.gfile.GFile(graph_filename, 'wb') as outfile:
outfile.write(tf.get_default_graph().as_graph_def().SerializeToString())
with tf.compat.v1.Session() as sess:
x_new = tf.constant(4.0, name="{}/x".format(scope))
with tf.gfile.GFile(graph_filename, 'rb') as infile:
graph_def = tf.GraphDef()
bytes_read = graph_def.ParseFromString(infile.read())
tf.import_graph_def(graph_def, name=scope, input_map={'x': x_new})
print(sess.run("{}/s:0".format(scope)))
@Moshe 在评论中询问了有关使用 import_meta_graph 的问题,因此我将添加一个简单示例。如果您想对 import_meta_graph 进行替换(在我看来,这是最好的,因为您跳过所有导入/导出)然后使用方法 1。否则使用方法 2(导入/导出技巧)以编程方式添加输入。
导出示例(请注意,对于这样一个简单的示例,我们至少需要创建一个变量以避免 Saver 抛出异常):
import tensorflow as tf
scope = "test"
model_name = 'my-model'
with tf.compat.v1.Session() as sess:
#Create a toy network
x = tf.constant(42.0, name="x")
s = tf.square(x, name="s")
print(sess.run(s))
#Save the network
w = tf.Variable(2.0, name="w") #Need at least one variable to make saver happy
sess.run(tf.global_variables_initializer()) #Need to initialize variables before saving
saver = tf.compat.v1.train.Saver()
tf.compat.v1.add_to_collection('s', s) #Select the network pieces to save
saver.save(sess, model_name)
导入示例(取消注释标有方法 2 的行以创建动态输入):
import tensorflow as tf
scope = "test"
model_name = 'my-model'
with tf.compat.v1.Session() as sess:
x_new = tf.placeholder(tf.float32, name="{}/x".format(scope))
saver = tf.compat.v1.train.import_meta_graph('{}.meta'.format(model_name), import_scope=scope, input_map={'x': x_new}) #Method 1
# saver = tf.compat.v1.train.import_meta_graph('{}.meta'.format(model_name)) #Method 2
saver.restore(sess, model_name)
# tf.import_graph_def(tf.get_default_graph().as_graph_def(), name=scope, input_map={'x': x_new}) #Method 2
s = tf.compat.v1.get_collection('s')[0]
for i in range(4):
print(sess.run("{}/s:0".format(scope), {"{}/x:0".format(scope): i}))
关于tensorflow - 如何在tensorflow中将输入更改为OP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47256160/
我正在KERAS CNN中工作,以检测视网膜图像中的糖尿病性视网膜病变。但是,当我尝试使用此代码预处理图像..: def estimate_radius(img): mx = img[img.
为什么这样实现: T& T::operator+=(const T&) { // ... implementation ... return *this; } T operator+(cons
这是我的图像混合代码,但 cv2.addweighted() 函数有问题: import cv2 import numpy as np img1 = cv2.imread('1.png') img2
我正在设置一个搜索API,就是搜索; id、type、originCity、destinationCity、departmentDate、reason、accommodation、approvalSt
这两个特征(std::ops::Add,core::ops::Add)提供相同的功能,并且它们都使用相同的示例(都使用std::ops::Add)。他们的实现者集有所不同。 应该默认使用std::op
我要提出条件 (A 和 B)和(C 或 D 或 E 或 F) 当我尝试做的时候 where: { [Op.and]: [{ A, B, [Op.or]: [{
我对 Sequelize 有这个问题: 我正在尝试进行 3 参数研究,如果其中一个参数为空,则不应考虑该参数。 const users = await User.findAll({ where:
Herb Sutter 的 Guru of the Week #4, "Class Mechanics" ,教导重载运算符的“a op b”形式应该根据“a op= b”形式实现(参见解决方案中的第
基准代码: func BenchmarkSth(b *testing.B) { var x []int b.ResetTimer() for i := 0; i < b.N;
我在使用 sequelize 获取正确的查询时遇到问题。 我有一个表示条目 id 的数组,可以这样说 - userVacationsIds = [1,2,3] 我做了这样的第一个查询
这两个特征(std::ops::Add,core::ops::Add)提供相同的功能,并且它们都使用相同的示例(都利用 std::ops::Add)。他们的一组实现者有些不同。 是否应该默认使用 st
为什么 std::numeric 算法似乎更喜欢 op 而不是 op=?例如,这里是 std::accumulate 在 LLVM 中的实现: template inline _LIBCPP_INL
这是基准测试的代码片段: // bench_test.go package main import ( "testing" ) func BenchmarkHello(b *testing.B
我使用 Sequelize 来查询我的数据库。 我在查询中使用 Op.and 和 Op.ne: const Op = require('sequelize'); let subLevels = awa
我有一个关于链表和模板的作业,其中有带有奇怪参数的函数,这些参数是强制性的。我找不到关于它的在线文档,感谢任何提供的 Material 。 我曾尝试为 op 分配另一个地址,然后它编译得很好,但我无法
cppreference说: the behavior of every builtin compound-assignment expression E1 op= E2 (where E1 is a
当我使用 go test -v -bench=. -benchmem 运行基准测试时,我看到以下结果。 f1 10000 120860 ns/op 2433 B/o
假设我有一个sympy 表达式 e1 op e2 哪里op是任何算术比较运算符,例如 , >> from sympy import symbols, Piecewise, ccode >>> x, y
在我的玩具包中,我定义了 %+%运算符作为 paste0() 的别名.试图减少与其他包的干扰,我通过以下方式实现: `%+%` <- function(...) UseMethod("%+%") `%
我正在尝试遵循 Scott Meyers 在 More Effective C++ 的第 22 项中的建议:“考虑使用 op= 而不是独立的 op”。他建议我们可以为 operator+ 创建一个模板
我是一名优秀的程序员,十分优秀!