Home

Awesome

<p align="center"> <a href="docs/img/matrax_logo.png"> <img src="docs/img/matrax_logo.png" alt="Matrax logo" width="50%"/> </a> </p> <h2 align="center"> <p>Matrix Games in JAX</p> </h2> <p align="center"> <a href="https://www.python.org/doc/versions/"> <img src="https://img.shields.io/badge/python-3.9-blue" alt="Python Versions"> </a> <a href="https://badge.fury.io/py/matrax"> <img src="https://badge.fury.io/py/matrax.svg" alt="PyPI version" height="18"> </a> <a href="https://github.com/instadeepai/matrax/actions/workflows/tests_linters.yml"> <img src="https://github.com/instadeepai/matrax/actions/workflows/tests_linters.yml/badge.svg" alt="Tests"> </a> <a href="https://github.com/psf/black"> <img src="https://img.shields.io/badge/code%20style-black-000000.svg" alt="Code Style"> </a> <a href="http://mypy-lang.org/"> <img src="http://www.mypy-lang.org/static/mypy_badge.svg" alt="MyPy"> </a> <a href="https://opensource.org/licenses/Apache-2.0"> <img src="https://img.shields.io/badge/License-Apache%202.0-orange.svg" alt="License"> </a> </p>

Enter the Matrax! 😎

<div align="center"> <h3>

Installation | Quickstart

</div>

Matrax is a lightweight suite of 2-player matrix game environments written in JAX. It is a direct re-implementation of the matrix games provided in this repository from the AARG. It follows the Jumanji RL environment suite API developed by InstaDeep.

<h2 name="environments" id="environments">2-Player Matrix Games 🧑‍🤝‍🧑 </h2>
CategoryShape (action space)Registered Version(s)Source
🔻 Penalty Game3 x 3Penalty-{k}-{state}-v0code
🧗‍♀️ Climbing Game3 x 3Climbing-{state}-v0code
🤝 No-Conflict Games2 x 2NoConflict-{id}-{state}-v0code
💣 Conflict Games2 x 2Conflict-{id}-{state}-v0code
<h2 name="install" id="install">Installation 🎬</h2>

You can install the latest release of Matrax from PyPI:

pip install matrax

Alternatively, you can install the latest development version directly from GitHub:

pip install git+https://github.com/instadeepai/matrax.git

Matrax has been tested on Python 3.9. Note that because the installation of JAX differs depending on your hardware accelerator, we advise users to explicitly install the correct JAX version (see the official installation guide).

<h2 name="quickstart" id="quickstart">Quickstart ⚡</h2>
import jax
import matrax

# Instantiate a matrix game environment using the registry
env = matrax.make("Penalty-25-stateless-v0")

# Reset your (jit-able) environment
key = jax.random.PRNGKey(0)
state, timestep = jax.jit(env.reset)(key)

# Interact with the (jit-able) environment
action = env.action_spec().generate_value()          # Action selection (dummy value here)
state, timestep = jax.jit(env.step)(state, action)   # Take a step and observe the next state and time step

Registry and Versioning 📖

Like Jumanji, Matrax keeps a strict versioning of its environments for reproducibility reasons. We maintain a registry of standard environments with their configuration. For each environment, a version suffix is appended, e.g. EnvironmentName-v1. When changes are made to environments that might impact learning results, the version number is incremented by one to prevent potential confusion.

Citing Matrax 📝

If you use any of the environment implementations in Matrax please consider citing this library.

@software{matrax2023github,
  author = {Arnu Pretorius},
  title = {Matrax: Matrix Games in JAX},
  url = {http://github.com/instadeepai/matrax},
  version = {v0.0.4-alpha},
  year = {2023},
}

See Also 🔎

Other works have embraced the approach of writing RL environments in JAX. In particular, we suggest users check out the following sister repositories: