Skip to content

smanolloff/muzero-general

Repository files navigation

Code style: black

MuZero General

A commented and documented implementation of MuZero based on the Google DeepMind paper and the associated pseudocode. It is designed to be easily adaptable for every games or reinforcement learning environments (like gym). You only need to edit the game file with the parameters and the game class. Please refer to the documentation and the example.

MuZero is a model based reinforcement learning algorithm, successor of AlphaZero. It learns to master games without knowing the rules. It only knows actions and then learn to play and master the game. It is at least more efficient than similar algorithms like AlphaZero, SimPLe and World Models. See How it works

Features

  • Residual Network and Fully connected network in PyTorch
  • Multi-Threaded with Ray
  • CPU/GPU support
  • TensorBoard real-time monitoring
  • Model weights automatically saved at checkpoints
  • Single and multiplayer mode
  • Commented and documented
  • Easily adaptable for new games
  • Examples of board and Gym games (See list below)
  • Pretrained weights available
  • Improve TensorBoard logging (tree depth, ...)
  • Atari games
  • Appendix Reanalyse of the paper
  • Windows support (workaround by ihexx)

Demo

All performances are tracked and displayed in real time in tensorboard :

lunarlander training preview

Testing Lunar Lander :

lunarlander training preview

Games already implemented

  • Cartpole
  • Lunar Lander
  • Tic-tac-toe
  • Connect4
  • Gomoku

Code structure

code structure

Getting started

Installation

git clone https://github.com/werner-duvaud/muzero-general.git
cd muzero-general

pip install -r requirements.txt

Run

Run:

python muzero.py

To visualize the training results, run in a new terminal:

tensorboard --logdir ./results

Authors

  • Werner Duvaud
  • Aurèle Hainaut
  • Paul Lenoir

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%