Неправильная форма ввода для lstm keras

Я наткнулся на учебник, в котором автор использует сеть LSTM для прогнозирования временных рядов, например:

trainX = numpy.reshape(trainX, (trainX.shape[0], 1, trainX.shape[1]))
testX = numpy.reshape(testX, (testX.shape[0], 1, testX.shape[1]))

model = Sequential()
model.add(LSTM(4, input_shape=(1, look_back)))
model.add(Dense(1))
model.compile(loss='mean_squared_error', optimizer='adam')
model.fit(trainX, trainY, epochs=100, batch_size=1, verbose=2)

Мы согласны с тем, что LSTM в этом действии похож на обычный NN (и бесполезен?), Поскольку LSTM получил только один шаг по времени без сохранения состояния = ИСТИНА. Я прав?

1 ответ

Решение

Вообще говоря, вы правы. Форма ввода должна быть (длина окна, особенности n).

Тем не менее, был достигнут некоторый успех в преобразовании входных данных в способ, который вы описали выше. Ниже приведен технический документ, в котором они смогли превзойти многие наиболее эффективные алгоритмы, и они использовали сверточные 1D слои для обработки шаблона временных рядов через отдельный вход.

Полностью сверточные сети LSTM для классификации временных рядов

Другие вопросы по тегам