【发布时间】:2018-09-15 04:27:31
【问题描述】:
我知道这是一个有很多问题的主题,但我找不到任何解决问题的方法。
我正在使用掩码层在可变长度输入上训练 LSTM 网络,但它似乎没有任何效果。
输入形状 (100, 362, 24),其中 362 是最大序列长度,24 是特征数,100 是样本数(除以 75 训练 / 25 有效)。
输出形状 (100, 362, 1) 稍后转换为 (100, 362 - N, 1)。
这是我的网络的代码:
from keras import Sequential
from keras.layers import Embedding, Masking, LSTM, Lambda
import keras.backend as K
# O O O
# example for N:3 | | |
# O O O O O O
# | | | | | |
# O O O O O O
N = 5
y= y[:,N:,:]
x_train = x[:75]
x_test = x[75:]
y_train = y[:75]
y_test = y[75:]
model = Sequential()
model.add(Masking(mask_value=0., input_shape=(timesteps, features)))
model.add(LSTM(128, return_sequences=True))
model.add(LSTM(64, return_sequences=True))
model.add(LSTM(1, return_sequences=True))
model.add(Lambda(lambda x: x[:, N:, :]))
model.compile('adam', 'mae')
print(model.summary())
history = model.fit(x_train, y_train,
epochs=3,
batch_size=15,
validation_data=[x_test, y_test])
我的数据在最后被填充。示例:
>> x_test[10,350]
array([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,
0., 0., 0., 0., 0., 0., 0.], dtype=float32)
问题是遮罩层似乎没有效果。我可以看到它在训练期间打印的损失值等于我计算后没有掩码的损失值:
Layer (type) Output Shape Param #
=================================================================
masking_1 (Masking) (None, 362, 24) 0
_________________________________________________________________
lstm_1 (LSTM) (None, 362, 128) 78336
_________________________________________________________________
lstm_2 (LSTM) (None, 362, 64) 49408
_________________________________________________________________
lstm_3 (LSTM) (None, 362, 1) 264
_________________________________________________________________
lambda_1 (Lambda) (None, 357, 1) 0
=================================================================
Total params: 128,008
Trainable params: 128,008
Non-trainable params: 0
_________________________________________________________________
None
Train on 75 samples, validate on 25 samples
Epoch 1/3
75/75 [==============================] - 8s 113ms/step - loss: 0.1711 - val_loss: 0.1814
Epoch 2/3
75/75 [==============================] - 5s 64ms/step - loss: 0.1591 - val_loss: 0.1307
Epoch 3/3
75/75 [==============================] - 5s 63ms/step - loss: 0.1057 - val_loss: 0.1034
>> from sklearn.metrics import mean_absolute_error
>> out = model.predict(x_test, batch_size=1)
>> print('wo mask', mean_absolute_error(y_test.ravel(), out.ravel()))
>> print('w mask', mean_absolute_error(y_test[~(x_test[:,N:] == 0).all(axis=2)].ravel(), out[~(x_test[:,N:] == 0).all(axis=2)].ravel()))
wo mask 0.10343371
w mask 0.16236152
此外,如果我使用 nan 值作为掩码输出值,我可以看到 nan 在训练期间传播(损失等于 nan)。
要使遮罩层按预期工作,我缺少什么?
【问题讨论】:
-
遮罩在 keras 中有一些非常严重的问题。您的数据看起来 post 填充在这里。由于您的 LSTM 正朝着前进的方向前进,您可以尝试使用预填充进行上述操作吗?
-
这里不是根本原因,但 'w mask' 行是错误的。您正在选择带有
y_test[(x_test[:,N:] == 0).all(axis=2)]的屏蔽条目。 -
感谢您注意到 Yu-Yang 的错字,编辑并测试您的答案:)
-
这是否是 CMAPSSData?