Neural Episodic Control
Actions space: Discrete
References: Neural Episodic Control
Choosing an action
- Use the current state as an input to the online network and extract the state embedding, which is the intermediate output from the middleware.
- For each possible action , run the DND head using the state embedding and the selected action as inputs. The DND is queried and returns the nearest neighbor keys and values. The keys and values are used to calculate and return the action value from the network.
- Pass all the values to the exploration policy and choose an action accordingly.
- Store the state embeddings and actions taken during the current episode in a small buffer , in order to accumulate transitions until it is possible to calculate the total discounted returns over the entire episode.
Finalizing an episode
For each step in the episode, the state embeddings and the taken actions are stored in the buffer . When the episode is finished, the replay buffer calculates the -step total return of each transition in the buffer, bootstrapped using the maximum value of the -th transition. Those values are inserted along with the total return into the DND, and the buffer is reset.
Training the network
Train the network only when the DND has enough entries for querying.
To train the network, the current states are used as the inputs and the -step returns are used as the targets. The -step return used takes into account consecutive steps, and bootstraps the last value from the network if necessary: