我想将自定义初始状态传递给lstm输出,但是我只有一个隐藏状态,因此如何传递零初始状态。
from tensorflow.keras import layers
x = layers.Input((None,))
x = layers.Embedding(....)(x)
x = layers.Flatten()(x)
imp_vec = Dense()(x)
现在我要使用imp_vec作为隐藏的初始状态,并将其传递给解码器lstm
out, states = layers.LSTM(...., return_state=True)(inputs, initial_state=[imp_vec])
上面的代码返回值错误:
ValueError: An `initial_state` was passed that is not compatible with `cell.state_size`. Received `state_spec`=ListWrapper([InputSpec(shape=(None, 200), ndim=2)]); however `cell.state_size` is [10, 10]
我发现lstm需要两个状态作为初始状态(即hidden_state,cell_state),对吗?但是我只有一个隐藏状态向量才能将其传递给模型,所以如何只初始化hidden_state并使lstm自动初始化另一个为零的东西?
答案 0 :(得分:4)
LSTM具有两种状态,但是您只传递了一个输入。因此,有两种选择
LSTM
代替GRU
GRU只有一种状态,initial_state=imp_vec
可以正常工作。
创建imp_vec
和imp_vec_1
而不是单个imp_vec_2
,并将其传递为
layers.LSTM(..)(..., initial_state=[imp_vec_1, imp_vec_2])
请记住,LSTM
层依次h_state
和c_state
。
c_state
设为零如果您不想传递c_state
,只需传递一组零即可。
zero_out = layers.Lambda(lambda x: tf.zeros_like(x))(imp_vec)
layers.LSTM(..)(..., initial_state=[imp_vec, zero_out])