我正试图用以下方法制作一个seq2seq模型 tfa.seq2seq.BaseDecoder
在TensorFlow 2.1中。我有
tf.keras.layers.GRU(64)(inputs, [states])
其中输入的形状是 (batch_size, 1, embedding_dimension)
并来自于
inputs = tf.keras.layers.Embedding(1000, 64, mask_zero=True)(tf.fill([batch_size, 1], value=1))
和 states
是该批编码器的隐藏状态。
我正在实现 tfa.seq2seq.BaseDecoder
's initialize
, step
和一些属性,错误发生在 step
其中包含了我在这里复制的一行。
然而,它却给了我以下的错误信息(有些函数名称是为了方便解释问题而更改的,在代码中略有不同)。
Traceback (most recent call last):
File "/home/.local/lib/python3.7/site-packages/tensorflow_core/python/keras/engine/training.py", line 2659, in _set_inputs
outputs = self(inputs, **kwargs)
File "/home/.local/lib/python3.7/site-packages/tensorflow_core/python/keras/engine/base_layer.py", line 773, in __call__
outputs = call_fn(cast_inputs, *args, **kwargs)
File "/home/.local/lib/python3.7/site-packages/tensorflow_core/python/autograph/impl/api.py", line 237, in wrapper
raise e.ag_error_metadata.to_exception(e)
TypeError: in converted code:
/home/lemmatizer_noattn.py:155 call *
output_layer, _, output_lens, _ = self.DecoderTraining((source_states, target_charseqs), True)
/home/.local/lib/python3.7/site-packages/tensorflow_core/python/keras/engine/base_layer.py:785 __call__
str(e) + '\n"""')
TypeError: You are attempting to use Python control flow in a layer that was not declared to be dynamic. Pass `dynamic=True` to the class constructor.
Encountered error:
"""
in converted code:
/home/.local/lib/python3.7/site-packages/tensorflow_addons/seq2seq/decoder.py:162 call *
return dynamic_decode(
/home/.local/lib/python3.7/site-packages/tensorflow_addons/seq2seq/decoder.py:405 body *
(next_outputs, decoder_state, next_inputs, decoder_finished) = decoder.step(
/home/.local/lib/python3.7/site-packages/tensorflow_core/python/ops/control_flow_ops.py:2478 while_loop_v2
return_same_structure=True)
/home/lemmatizer_noattn.py:79 step *
outputs, [states] = self.lemmatizer.target_rnn_cell(inputs, [states])
/home/.local/lib/python3.7/site-packages/tensorflow_core/python/framework/ops.py:539 __iter__
self._disallow_iteration()
/home/.local/lib/python3.7/site-packages/tensorflow_core/python/framework/ops.py:535 _disallow_iteration
self._disallow_in_graph_mode("iterating over `tf.Tensor`")
/home/.local/lib/python3.7/site-packages/tensorflow_core/python/framework/ops.py:515 _disallow_in_graph_mode
" this function with @tf.function.".format(task))
OperatorNotAllowedInGraphError: iterating over `tf.Tensor` is not allowed in Graph execution. Use Eager execution or decorate this function with @tf.function.
"""
我没能从文档中找出错误的来源,也没有在网上找到任何建议。有什么办法可以解决这个问题吗?
这一行看起来像是一个元组和一个列表的扩展,而autograph并没有扩展(导致这个混乱的错误)。
/home/lemmatizer_noattn.py:79 step *
outputs, [states] = self.lemmatizer.target_rnn_cell(inputs, [states])
什么是 self.lemmatizer.target_rnn_cell
返回?试试在展开之前打印出数值,类似这样。
retval = self.lemmatizer.target_rnn_cell(inputs, [states])
print(retval)
inputs = retval[0]
states = retval[1][0]