A complete MJCF lifecycle and trial orchestration suite for MuJoCo, powered by Pydantic v2.
Project description
A complete MJCF lifecycle and trial orchestration suite for MuJoCo, powered by Pydantic v2.
MuJoCo Mojo bridges the gap between static XML modeling and large-scale simulation research. It provides a strongly-typed bridge for building models and a robust execution engine for running them at scale.
- Model: Build MJCFs via validated Python objects allowing for programatic generation.
- Scale: Execute multi-threaded Monte Carlo trials with built-in resume logic.
- Monitor: Track progress via a zero-dependency web dashboard and persistent logs.
- Assess: Quickly view interactive results of a trial in context of others.
- Reproduce: Automatic environment snapshotting (
requirements.txt) for every job.
Installation
Install using uv (recommended):
uv add mujoco-mojo
or with pip:
pip install mujoco-mojo
Features
MJCF Tools
- Strongly-Typed Elements: MJCF components backed by Pydantic v2 for immediate validation.
- Semantic Validation: Early detection of structural errors and attribute mismatches before the engine starts.
- MuJoCo Alignment: Designed to mirror MuJoCo’s XML schema closely (no magic abstractions)
- Object Enumerations: Embedded MuJoCo object mappings to simplify retrieving
mjOBJIDs. - Asset Sharing: Specialized handling of dependency by remapping assets to become shared allows for space efficient execution of complex models
Job Utilities
Campaign Orchestration
- Multi-Threaded Execution: Single or multi-threaded trial execution
- Environment Snapshotting: Automatically record installed Python packages to
requirements.txtfor job recreation (works withuvorpip) - Resume Logic: Resume a previously started job without rerunning previous cases
- Robust Logging: Built in Rich logging for terminal and a rotating file handler for persistent logs and status files for insight on trial progress
- Global Overrides: Force specific values onto distributions via CLI or JSON overrides to test "golden" cases.
Monte Carlo
- Reproducible Sampling: Random draw tools for Monte Carlo or rerun with global variable override
- End of run summary with metric to help perform a state of health check
- Support for running jobs with SLURM for distributed compute
[!TIP]
mujoco-mojo run monte-carlo \ --generator monte_carlo_test.Experiment.generate \ --runtime monte_carlo_test.runtime \ --workdir ./mc_test/ \ --no-resume \ --gen-arg 123 \ --gen-kwarg 'test=1234' \ --n-trial 10 \ --n-proc 1
Optimization
- Bayesian Search: Intelligent design space navigation powered by Optuna integration.
- Design Variables: Continuous (
DesignFloat) and discrete (DesignCategorical) parameters evolved by the solver. - Adaptive Refinement: "Zoom" into promising neighborhoods by aggressively shrinking search bounds on resume.
- Stochastic Robustness: Multi-evaluation trials that average scores over different seeds to filter out noisy physics outliers.
[!TIP]
mujoco-mojo run optimiztion \ -g sim.generate \ -r sim.runtime \ --objective sim.objective \ --n-trial 400 \ --n-proc 10 \ --seed 42 \ --storage \ --direction minimize
Dojo Dashboard
A zero-dependency, offline-first web suite for monitoring and analyzing your simulation jobs in real-time.
Monitor: Real-Time Oversight
- Live Progress Tracking: Dynamic progress bars and color-coded status cards provide a high-level view of your Monte Carlo runs.
- Success/Failure Analytics: Automatic categorization of trials with built-in data integrity checks to identify "empty" vs. "failed" runs.
- Sensory Feedback: Optional audio cues and visual celebrations let you know exactly when a multi-hour job hits 100%.
- Deep-Linked Navigation: Jump straight from the monitor to any individual trial in the viewer with one click.
Mosaic: Advanced Telemetry Analysis
- High-Fidelity Plotting: Hardware-accelerated visualization using Plotly.js for seamless zooming and panning through millions of data points.
- Dynamic Versus Mode: Overlay current telemetry against previous trials using an intuitive range-selection slider for instant regression testing.
- Regex-Powered Filtering: Navigate high-dimensional datasets using a "folder-style" signal selector with suffix and regex support.
- State Persistence & Sharing: Every view is captured in a shareable, compressed URL by pasting a link to share your exact configuration.
- Pro-Grade Tooling: Built-in JSON configuration editor, drag-and-drop config restoration, and multi-format exports (SVG, PNG, CSV).
- Keyboard-First Design: Full hotkey support for warping between trials and managing views without leaving the home row.
Reloaded
A rapid prototyping loop that allows you to modify physics logic and model architecture on the fly without ever closing the visualizer.
- Module Hot-Reloading: Recursively reloads local Python modules and MJCF logic, allowing code changes to propagate instantly to the active simulation.
- Unified Visualizer Bridge: Synchronized visualization of custom force and torque vectors across native OpenGL, Viser web interfaces, and video recordings.
- Interactive Prototyping: A developer-centric command loop to toggle playback speeds, repeat last commands, or trigger "generation-only" mode for rapid MJCF debugging.
- Asset Persistence: Automatically dumps current MJCF snapshots and model configurations to a workspace directory for post-hoc analysis or version tracking.
[!TIP]
mujoco-mojo reloaded \ --generator monte_carlo_test.Experiment.generate \ --runtime monte_carlo_test.runtime \
[!NOTE] MuJoCo Mojo is an independently developed open-source toolbox. It is not affiliated with, sponsored by, or endorsed by Google DeepMind or the official MuJoCo development team. MuJoCo® is a registered trademark of Google LLC. All MJCF schemas and MuJoCo-related terminology used within this project are for compatibility and documentation purposes only.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mujoco_mojo-2.2.0.tar.gz.
File metadata
- Download URL: mujoco_mojo-2.2.0.tar.gz
- Upload date:
- Size: 2.0 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f08414c371f2142cb8722720e50d8d83567d38aa9665ba464ee4e90198417085
|
|
| MD5 |
ce9d6049d75a55f615ac65a291caa3cf
|
|
| BLAKE2b-256 |
cff3e43addfe81d047160ea4cb8ad843225f84fd582ec5536506118b6617d2fa
|
File details
Details for the file mujoco_mojo-2.2.0-py3-none-any.whl.
File metadata
- Download URL: mujoco_mojo-2.2.0-py3-none-any.whl
- Upload date:
- Size: 2.1 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.13 {"installer":{"name":"uv","version":"0.11.13","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f87ddc20c59a3301622658e010f9114365a9da2211e23de51836902599146ccb
|
|
| MD5 |
db26a9a421055440b9a19d8cf2e75e45
|
|
| BLAKE2b-256 |
c7800a5faf1286dff2a8a8e702708c9c939501e19bd4e7f933fd5a4dcd09c2e4
|