The Keras deep learning library provides an implementation of the Long Short-Term Memory, or LSTM, recurrent neural network.
As part of this implementation, the Keras API provides access to both return sequences and return state. The use and difference between these data can be confusing when designing sophisticated recurrent neural network models, such as the encoder-decoder model.
In this tutorial, you will discover the difference and result of return sequences and return states for LSTM layers in the Keras deep learning library.
After completing this tutorial, you will know:
- That return sequences return the hidden state output for each input time step.
- That return state returns the hidden state output and cell state for the last input time step.
- That return sequences and return state can be used at the same time.
Kick-start your project with my new book Long Short-Term Memory Networks With Python, including step-by-step tutorials and the Python source code files for all examples.
Let’s get started.
Tutorial Overview
This tutorial is divided into 4 parts; they are:
- Long Short-Term Memory
- Return Sequences
- Return States
- Return States and Sequences
Long Short-Term Memory
The Long Short-Term Memory, or LSTM, is a recurrent neural network that is comprised of internal gates.
Unlike other recurrent neural networks, the network’s internal gates allow the model to be trained successfully using backpropagation through time, or BPTT, and avoid the vanishing gradients problem.
In the Keras deep learning library, LSTM layers can be created using the LSTM() class.
Creating a layer of LSTM memory units allows you to specify the number of memory units within the layer.
Each unit or cell within the layer has an internal cell state, often abbreviated as “c“, and outputs a hidden state, often abbreviated as “h“.
The Keras API allows you to access these data, which can be useful or even required when developing sophisticated recurrent neural network architectures, such as the encoder-decoder model.
For the rest of this tutorial, we will look at the API for access these data.
Return Sequences
Each LSTM cell will output one hidden state h for each input.
We can demonstrate this in Keras with a very small model with a single LSTM layer that itself contains a single LSTM cell.
In this example, we will have one input sample with 3 time steps and one feature observed at each time step:
The complete example is listed below.
Note: all examples in this post use the Keras functional API.
Running the example outputs a single hidden state for the input sequence with 3 time steps.
Your specific output value will differ given the random initialization of the LSTM weights and cell state.
It is possible to access the hidden state output for each input time step.
This can be done by setting the return_sequences attribute to True when defining the LSTM layer, as follows:
We can update the previous example with this change.
The full code listing is provided below.
Running the example returns a sequence of 3 values, one hidden state output for each input time step for the single LSTM cell in the layer.
You must set return_sequences=True when stacking LSTM layers so that the second LSTM layer has a three-dimensional sequence input. For more details, see the post:
You may also need to access the sequence of hidden state outputs when predicting a sequence of outputs with a Dense output layer wrapped in a TimeDistributed layer. See this post for more details:
Return States
The output of an LSTM cell or layer of cells is called the hidden state.
This is confusing, because each LSTM cell retains an internal state that is not output, called the cell state, or c.
Generally, we do not need to access the cell state unless we are developing sophisticated models where subsequent layers may need to have their cell state initialized with the final cell state of another layer, such as in an encoder-decoder model.
Keras provides the return_state argument to the LSTM layer that will provide access to the hidden state output (state_h) and the cell state (state_c). For example:
This may look confusing because both lstm1 and state_h refer to the same hidden state output. The reason for these two tensors being separate will become clear in the next section.
We can demonstrate access to the hidden and cell states of the cells in the LSTM layer with a worked example listed below.
Running the example returns 3 arrays:
- The LSTM hidden state output for the last time step.
- The LSTM hidden state output for the last time step (again).
- The LSTM cell state for the last time step.
The hidden state and the cell state could in turn be used to initialize the states of another LSTM layer with the same number of cells.
Return States and Sequences
We can access both the sequence of hidden state and the cell states at the same time.
This can be done by configuring the LSTM layer to both return sequences and return states.
The complete example is listed below.
Running the example, we can see now why the LSTM output tensor and hidden state output tensor are declared separably.
The layer returns the hidden state for each input time step, then separately, the hidden state output for the last time step and the cell state for the last input time step.
This can be confirmed by seeing that the last value in the returned sequences (first array) matches the value in the hidden state (second array).
Further Reading
This section provides more resources on the topic if you are looking to go deeper.
- Keras Functional API
- LSTM API in Keras
- Long Short-Term Memory, 1997.
- Understanding LSTM Networks, 2015.
- A ten-minute introduction to sequence-to-sequence learning in Keras
Summary
In this tutorial, you discovered the difference and result of return sequences and return states for LSTM layers in the Keras deep learning library.
Specifically, you learned:
- That return sequences return the hidden state output for each input time step.
- That return state returns the hidden state output and cell state for the last input time step.
- That return sequences and return state can be used at the same time.
Do you have any questions?
Ask your questions in the comments below and I will do my best to answer.
No comments:
Post a Comment