Skip to main content

A JAX-native MuJoCo environment suite for Envrax.

Project description

Logo

Python Version License

Mujorax is a lightweight open-source JAX-native MuJoCo environment suite for single-agent Reinforcement Learning (RL), built on top of Envrax. It wraps MuJoCo Playground environments with Envrax's JaxEnv so you can use them with envrax.make, envrax.make_vec, and the rest of Envrax's tooling.

It comes with 25 environments from the DM Control Suite. All environment logic follows a stateless functional design that builds on top of the MJX, JAX, and Chex packages to benefit from JAX accelerator efficiency.

Why Mujorax?

Envrax provides a JAX-native Gymnasium-style API standard for RL environments, but it doesn't ship with any environments of its own. One of the biggest spaces in RL is robotics, and the gold-standard physics engine for this is MuJoCo. This makes it the perfect fit for one of the first Envrax environment suites!

MuJoCo Playground is Google DeepMind's open-source library of MuJoCo environments, built on top of MJX (MuJoCo's JAX port that preserves the simulator's full physics fidelity). It already solves the hard parts: research-validated reward and termination logic for DM Control, locomotion, and manipulation environments. The only catch is that its environments expose a Brax-style MjxEnv API, which doesn't quite fit Envrax's API standard.

Rather than reinventing the wheel, Mujorax acts as a thin, type-safe wrapper around the MuJoCo Playground environments to maximise their benefits while maintaining Envrax's API standard, making it completely plug-and-play with Envrax's toolkit.

Requirements

  • Python 3.13+
  • JAX 0.9+ (CPU, CUDA, or TPU backend)

Installation

pip install mujorax

Or with uv:

uv add mujorax

Quick Start

import jax
import mujorax  # registers the suite at import
import envrax

env = envrax.make("mjx/cartpole_balance-v0")
obs, state = env.reset(jax.random.PRNGKey(0))

action = env.action_space.sample(jax.random.PRNGKey(1))
obs, state, reward, done, info = env.step(state, action)

Vectorised rollouts work the same way:

env = envrax.make_vec("mjx/cartpole_balance-v0", n_envs=128)
obs, state = env.reset(jax.random.PRNGKey(0))  # obs.shape == (128, 5)

You can also use make_multi to utilise several heterogeneous environments at once:

env = envrax.make_multi([
    "mjx/cartpole_balance-v0",
    "mjx/cheetah_run-v0",
])
obs_list, state_list = env.reset(jax.random.PRNGKey(0))  # one entry per env

Or, the make_multi_vec method for vectorised parallel copies of each environment:

env = envrax.make_multi_vec(
    ["mjx/cartpole_balance-v0", "mjx/cheetah_run-v0"],
    n_envs=64,
)
obs_list, state_list = env.reset(jax.random.PRNGKey(0))
# each entries obs.shape == (64, *single_obs.shape)

Mujorax auto-detects whether a CUDA backend is available; on CPU-only systems it transparently falls back to MJX's pure-JAX physics implementation.

You can override this choice through this MjxPlaygroundConfig(config_overrides={"impl": ...}) if needed.

Environments

All environments share canonical IDs in the form mjx/<name>-v0. Here's the full list of supported environments:

Canonical ID Description
mjx/acrobot_swingup-v0 Two-link underactuated pendulum; dense reward for swinging the tip to target
mjx/acrobot_swingup_sparse-v0 Same as acrobot_swingup with a sparse (binary) reward
mjx/ball_in_cup-v0 Planar ball-and-cup catching task; sparse reward when caught
mjx/cartpole_balance-v0 Cart starts near upright; dense reward for keeping the pole upright
mjx/cartpole_balance_sparse-v0 Same as cartpole_balance with a sparse reward
mjx/cartpole_swingup-v0 Cart starts hanging; dense reward for swinging up and balancing
mjx/cartpole_swingup_sparse-v0 Same as cartpole_swingup with a sparse reward
mjx/cheetah_run-v0 Planar bipedal cheetah; dense reward proportional to forward speed
mjx/finger_spin-v0 Two-DoF finger spinning a free body; dense reward for angular velocity
mjx/finger_turn_easy-v0 Two-DoF finger rotating a body to a target with large tolerance
mjx/finger_turn_hard-v0 Same as finger_turn_easy with a tighter tolerance
mjx/fish_swim-v0 3D free-swimming fish; dense reward for swimming to a randomised target
mjx/hopper_hop-v0 One-legged planar hopper; dense reward for forward speed
mjx/hopper_stand-v0 One-legged hopper; dense reward for standing upright
mjx/humanoid_run-v0 21-DoF humanoid; dense reward for matching a running speed
mjx/humanoid_stand-v0 21-DoF humanoid; dense reward for standing upright
mjx/humanoid_walk-v0 21-DoF humanoid; dense reward for matching a walking speed
mjx/pendulum_swingup-v0 Single-link pendulum; dense reward for swinging up and balancing
mjx/point_mass-v0 Planar point mass actuated in 2D; dense reward to a randomised target
mjx/reacher_easy-v0 Two-link planar arm reaching a large target
mjx/reacher_hard-v0 Same as reacher_easy with a smaller target
mjx/swimmer_swimmer6-v0 Six-link planar swimmer; dense reward for the head reaching a target
mjx/walker_run-v0 Planar bipedal walker; dense reward for running speed
mjx/walker_stand-v0 Planar bipedal walker; dense reward for standing upright
mjx/walker_walk-v0 Planar bipedal walker; dense reward for walking speed

Acknowledgements

Mujorax wouldn't be possible without these incredible projects:

  • MuJoCo Playground — the underlying environment implementations.
  • MuJoCo and MJX — the physics engine and JAX bindings.
  • Envrax — the registry and base environment API standard.

❤️ Thank you to all the developers involved - you guys are awesome! ❤️

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mujorax-0.1.3.tar.gz (14.6 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mujorax-0.1.3-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file mujorax-0.1.3.tar.gz.

File metadata

  • Download URL: mujorax-0.1.3.tar.gz
  • Upload date:
  • Size: 14.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mujorax-0.1.3.tar.gz
Algorithm Hash digest
SHA256 9542ed00cdbe0b0f27439cdcd1e12b95f0b5caa5919127fa0bbc7f3af41b101a
MD5 9d41c8b1540afa79bec5fe5579669fde
BLAKE2b-256 49d48bef4aa1655a00116d158b11670da499a33f7586040f8cee10568aaf0dce

See more details on using hashes here.

File details

Details for the file mujorax-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: mujorax-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 15.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mujorax-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 7c447d0a60c7060de984faab6aad72ea5587da8d4d9665c3ee931528b32e5bf8
MD5 fca47ffeb1359cc457281b96ed2eb9f3
BLAKE2b-256 1fa96b00e06ae0a2820635b1bff241dff8edc80d05c5df3de9f013e6e0584554

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page