我使用Keras构建了一个LSTM体系结构。我的目标是映射长度29时间序列的浮标输入序列到长度29输出序列的浮点数。我正在尝试实施一种“多对多”的方法。我遵循this post实现了这样一个模型。
首先,我将每个数据点重组为一个形状为np.array‘(1,29,1)。我有多个数据点,并分别对模型进行训练。下面的代码是我如何构建模型的:
def build_model():
# define model
model = tf.keras.Sequential()
model.add(tf.keras.layers.LSTM(29, return_sequences=True, input_shape=(29, 1)))
model.add(tf.keras.layers.LeakyReLU(alpha=0.3))
model.compile(optimizer='sgd', loss='mse', metrics = ['mae'])
#cast data
for point in train_dict:
train_data = train_dict[point]
train_dataset = tf.data.Dataset.from_tensor_slices((
tf.cast(train_data[0], features_type),
tf.cast(train_data[1], target_type))
).repeat() #cast into X, Y
# fit model
model.fit(train_dataset, epochs=100,steps_per_epoch = 1,verbose=0)
print(model.summary())
return model 我很困惑,因为当我调用model.predict(test_point, steps = 1, verbose = 1)时,模型返回29个长度29序列!我不明白为什么会发生这种情况,根据我从链接帖子中得到的理解。当我尝试return_state=True而不是return_sequences=True时,我的代码会引发以下错误:ValueError: All layers in a Sequential model should have a single output tensor. For multi-output layers, use the functional API.
我该如何解决这个问题?
发布于 2019-07-25 00:19:43
你的模型几乎没有瑕疵。
我已经修复了针对上述问题的代码。看看这是否有帮助。
from tensorflow.keras.layers import Embedding, Input, Bidirectional, LSTM, Dense, Concatenate, LeakyReLU, TimeDistributed
from tensorflow.keras.initializers import Constant
from tensorflow.keras.models import Model
from tensorflow.keras.models import Sequential
def build_model():
# define model
model = Sequential()
model.add(LSTM(29, return_sequences=True, input_shape=(29, 1)))
model.add(TimeDistributed(Dense(1)))
model.compile(optimizer='sgd', loss='mse', metrics = ['mae'])
print(model.summary())
return model
model = build_model()https://stackoverflow.com/questions/57191517
复制相似问题