/TwinDQN

Twin DQN - Two tasks, one net

Primary LanguageJupyter Notebook

Twin DQN - Two tasks, one net

This implemention contains the work for the DL4CV project WS17/18 at TUM.

Our goal was to train an agent, that is capable to play two games at once, with the same inputs. You can imagine this as playing two games with one controller and trying to be as good as possible. If you want to move an agent, the other agent moves simultaneously in the same direction.

twogames

The content of the subdirectory is:

  • FailedArchitcture: An architecture, that did not work
  • Notebooks: Jupyter Notebooks to evaluate the training and generate plots
  • Poster: The final poster for the presentation
  • ProjectProposal: our project ProjectProposal
  • Results: Data of the training, the evaluation and the evaluation of random agents
  • TrainedModels: models, that can be used to train the model further or to play

Requirements

  • Python 3.5+

All requiremnts installed:

$ pip3 install -r requirements.txt

Usage

There is an extensive help provided inside the agents.

To train or play a single game use:

$ python single_agent.py [--help]

To train or play two games at once use:

$ python double_agent.py [--help]

Results

Result of training the games Breakout & SpaceInvaders for 15000 games

Both agents move at every step into the same direction. Because SpaceInvaders is less sensitive to controller inputs, you have to watch carefully to notice the synchronous motions

demo

Training history

hist

References