- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用了描述的模型 here在 0.6.0 分支上。代码可以在here中找到.我对链接的代码做了一些小的改动。
在我的代码中,我创建了两个模型,一个用于训练,一个用于验证,与 Tensorflow 教程中所做的非常相似。
with tf.variable_scope("model", reuse=None, initializer=initializer):
m = PTBModel_User(is_training=True, config=config, name='Training model')
with tf.variable_scope("model", reuse=True, initializer=initializer):
mtest = PTBModel_User(is_training=False, config=config_valid, name='Validation model')
output = tf.reshape(tf.concat(1, outputs), [-1, size])
output_shape = output.get_shape()
print("Model num_steps:", num_steps)
print("Model batch_size:", batch_size)
print("Output dims", output_shape[0], output_shape[1])
Model num_steps: 400
Model batch_size: 1
Output dims Dimension(None) Dimension(650)
Model num_steps: 400
Model batch_size: 2
Output dims Dimension(800) Dimension(650)
batch_size=1
而不是我用于训练模型的
batch_size=2
)
-1
作为
reshape
的输入功能,将自动计算出输出形状!但是为什么我得到 None 呢?输入模型的配置中没有任何内容具有 None 值。
最佳答案
TL;博士:维度是 None
只是意味着形状推断无法确定 output
的确切形状。张量,在图形构建时。运行图形时,张量将具有适当的运行时形状。
如果您对形状推断的工作原理不感兴趣,现在可以停止阅读。
形状推理基于“形状函数”应用局部规则,该“形状函数”采用操作的输入形状并计算操作输出的(可能不完整的)形状。找出原因 tf.reshape()
给出一个不完整的形状,我们必须查看它的输入,然后向后工作:
shape
论据 tf.reshape()
包括 [-1]
,这意味着“根据 tensor
的形状自动计算输出形状”输入。 tensor
输入是 tf.concat()
的输出在 same line . tf.concat()
的输入由 tf.mul()
计算在 BasicLSTMCell.__call__()
. tf.mul()
op 乘以 tf.tanh()
的结果和一个 tf.sigmoid()
操作。 tf.tanh()
op 产生大小为 [?, hidden_size]
的输出,以及 tf.sigmoid()
op 产生大小为 [batch_size, hidden_size]
的输出. tf.mul()
op执行
NumPy-style broadcasting .一个维度只有在大小为 1 时才会被广播。考虑我们计算
tf.mul(x, y)
的三种情况。 :
x
有形状[1, 10]
, 和 y
有形状[5, 10]
,然后广播将发生,输出形状将为 [5, 10]
. x
有形状[1, 10]
, 和 y
有形状[1, 10]
,则不会有广播,输出形状为 [1, 10]
. x
有形状[1, 10]
, 和 y
有形状[?, 10]
,没有足够的静态信息来判断广播是否会发生(即使我们碰巧知道情况 2 在运行时适用)。 batch_size
是 1,
tf.mul()
op 生成形状为
[?, hidden_size]
的输出;但是当
batch_size
大于 1,输出形状为
[batch_size, hidden_size]
.
Tensor.set_shape()
添加信息的方法。这在
BasicLSTMCell
中可能有用实现,我们知道的比推断输出形状的可能性要多。
关于Tensorflow reshape 张量给出无维度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36152571/
如何检查字符串是否被 reshape ?示例:“aab”返回 0,因为“a”无法 reshape 为该字符串或任何其他更短的字符串。 另一个例子是“aabbaab”返回 1,因为“aabb”可以被 r
我无法清楚地理解theano的reshape。我有一个形状的图像矩阵: [batch_size, stack1_size, stack2_size, height, width] ,其中有 s
如何检查字符串是否被 reshape ?示例:“aab”返回 0,因为“a”无法 reshape 为该字符串或任何其他更短的字符串。 另一个例子是“aabbaab”返回 1,因为“aabb”可以被 r
这是原始数据 a=[[1,2,3,4,5,6], [7,8,9,10,11,12]] 我想把它转换成这样的格式: b=[[1,2,3,7,8,9], [4,5,6,10,11,12]] a
我目前正在学习 CS231 作业,我意识到一些令人困惑的事情。在计算梯度时,当我第一次 reshape x 然后得到转置时,我得到了正确的结果。 x_r=x.reshape(x.shape[0],-1
这个问题在这里已经有了答案: Reshaping multiple sets of measurement columns (wide format) into single columns (lon
我有一个包含超过 1500 列的宽格式数据集。由于许多变量都是重复的,我想将其 reshape 为长形式。然而,r 抛出一个错误: Error in guess(varying) : Failed
我有一个长格式的数据框狗,我正在尝试使用 reshape() 函数将其重新格式化为宽格式。目前看起来是这样的: dogid month year trainingtype home scho
这个问题在这里已经有了答案: how to reshape an N length vector to a 3x(N/3) matrix in numpy using reshape (1 个回答)
我对 ndarray.reshape 的结构有疑问.我读过 numpy.reshape()和 ndarray.reshape是 python 中用于 reshape 数组的等效命令。 据我所知,num
所以这是我的麻烦:我想将一个长格式的数据文件改成宽格式。但是,我没有唯一的“j”变量;长格式文件中的每条记录都有几个关键变量。 例如,我想这样做: | caseid | gender | age |
Whis 这个数据框, df df id parameter visit value sex 1 01 blood V1 1 f 2 01 saliva V
我有一个列表,其中包含几个不同形状的 numpy 数组。我想将这个数组列表 reshape 为一个 numpy 向量,然后更改向量中的每个元素,然后将其 reshape 回原始数组列表。 例如: 输入
我有一个形状为 (1800,144) 的数组 (a) 其中 a[0:900,:] 都是实数,后半部分数组 a[900:1800,:] 全部为零。我想把数组的后半部分水平地放在前半部分旁边,然后将它们推
我有一个如下所示的数组: array([[0, 0, 0, 0, 0, 0, 0, 0], [1, 1, 1, 1, 1, 1, 1, 1], [2, 2, 2, 2, 2
我正在创建一个 tf.Variable(),然后使用该变量创建一个简单的函数,然后我使用 tf.reshape() 展平原始变量,然后我在函数和展平变量之间使用了 tf.gradients()。为什么
我有一个名为 data 的数据框,我试图从中识别任何异常价格。 数据框头部看起来像: Date Last Price 0 29/12/2017 487.74 1 28/
我有一个 float vec 数组,我想对其进行 reshape vec.shape >>> (3,) len(vec[0]) # all 3 rows of vec have 150 columns
tl;dr 我可以在不使用 numpy.reshape 的情况下将 numpy 数组的 View 从 5x5x5x3x3x3 reshape 为 125x1x1x3x3x3 吗? 我想对一个体积(大小
set.seed(123)data <- data.frame(ID = 1:10, weight_hus = rnorm(10, 0, 1),
我是一名优秀的程序员,十分优秀!