[英]TensorFlow dynamic_rnn state
我的问题是关于TensorFlow方法tf.nn.dynamic_rnn
。 它返回每个时间步和最终状态的输出。
我想知道返回的最终状态是否是最大序列长度的单元格状态,或者它是否由sequence_length
参数单独确定。
为了更好地理解一个例子:我有3个长度为[10,20,30]
序列并返回最终状态[3,512]
(如果单元的隐藏状态长度为512)。
三个序列的三个返回隐藏状态是时间步骤30中的单元状态还是我在时间步骤[10,20,30]
返回状态?
tf.nn.dynamic_rnn
返回两个张量: outputs
和states
。
outputs
保存批次中所有序列的所有单元格的输出。 因此,如果特定序列较短并用零填充,则最后一个单元格的outputs
将为零。
states
保持最后一个单元状态,或者等效于每个序列的最后一个非零输出(如果您使用的是BasicRNNCell
)。
这是一个例子:
import numpy as np
import tensorflow as tf
n_steps = 2
n_inputs = 3
n_neurons = 5
X = tf.placeholder(dtype=tf.float32, shape=[None, n_steps, n_inputs])
seq_length = tf.placeholder(tf.int32, [None])
basic_cell = tf.nn.rnn_cell.BasicRNNCell(num_units=n_neurons)
outputs, states = tf.nn.dynamic_rnn(basic_cell, X, sequence_length=seq_length, dtype=tf.float32)
X_batch = np.array([
# t = 0 t = 1
[[0, 1, 2], [9, 8, 7]], # instance 0
[[3, 4, 5], [0, 0, 0]], # instance 1
])
seq_length_batch = np.array([2, 1])
with tf.Session() as sess:
sess.run(tf.global_variables_initializer())
outputs_val, states_val = sess.run([outputs, states],
feed_dict={X: X_batch, seq_length: seq_length_batch})
print('outputs:')
print(outputs_val)
print('\nstates:')
print(states_val)
这打印如下:
outputs:
[[[-0.85381496 -0.19517037 0.36011398 -0.18617202 0.39162001]
[-0.99998015 -0.99461144 -0.82241321 0.93778896 0.90737367]]
[[-0.99849552 -0.88643843 0.20635395 0.157896 0.76042926]
[ 0. 0. 0. 0. 0. ]]] # because len=1
states:
[[-0.99998015 -0.99461144 -0.82241321 0.93778896 0.90737367]
[-0.99849552 -0.88643843 0.20635395 0.157896 0.76042926]]
请注意, states
保持与output
相同的向量,它们是每个批处理实例的最后非零输出。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.