I am trying to reconcile my understand of LSTMs and pointed out here in this post by Christopher Olah implemented in Keras. I am following the blog written by Jason Brownlee
First of all, you choose great tutorials(1,2) to start.
What Time-step means: Time-steps==3
in X.shape (Describing data shape) means there are three pink boxes. Since in Keras each step requires an input, therefore the number of the green boxes should usually equal to the number of red boxes. Unless you hack the structure.
many to many vs. many to one: In keras, there is a return_sequences
parameter when your initializing LSTM
or GRU
or SimpleRNN
. When return_sequences
is False
(by default), then it is many to one as shown in the picture. Its return shape is (batch_size, hidden_unit_length)
, which represent the last state. When return_sequences
is True
, then it is many to many. Its return shape is (batch_size, time_step, hidden_unit_length)
Does the features argument become relevant: Feature argument means "How big is your red box" or what is the input dimension each step. If you want to predict from, say, 8 kinds of market information, then you can generate your data with feature==8
.
Stateful: You can look up the source code. When initializing the state, if stateful==True
, then the state from last training will be used as the initial state, otherwise it will generate a new state. I haven't turn on stateful
yet. However, I disagree with that the batch_size
can only be 1 when stateful==True
.
Currently, you generate your data with collected data. Image your stock information is coming as stream, rather than waiting for a day to collect all sequential, you would like to generate input data online while training/predicting with network. If you have 400 stocks sharing a same network, then you can set batch_size==400
.