Skip to main content

Tau-Sim — an LLM-assisted IDE for MuJoCo robotic simulation

Project description

tau-sim

LLM-assisted MuJoCo simulation IDE — runs in your browser, locally on your laptop, or as a hosted demo. Edit MJCF / Python on the left, watch episodes render live in the center, and ask any model (OpenRouter / OpenAI / Gemini) to propose changes that appear as reviewable diffs.

Built by Tau Intelligence.

Try it

One command, anywhere with Python ≥ 3.10

uvx tau-sim     # or: pipx run tau-sim

That installs everything (FastAPI, MuJoCo, OSMesa-friendly bindings) in an isolated environment and opens http://127.0.0.1:7860 in your browser. Project files are stored under ~/.tau/projects/.

If you've already got uv, you can also do:

uv tool install tau-sim
tau --help

From source

cd backend
python -m venv .venv && source .venv/bin/activate
pip install -e .
cp .env.example .env       # (optional) configure default LLM provider
tau

Frontend dev server

cd frontend
npm install
npm run dev      # http://localhost:5173 (proxies /api and /ws to :8000)

When developing the frontend separately, run the backend via uvicorn app.main:app --reload --port 8000 so the Vite proxy targets the right port.

Architecture

┌──────────────────────────┐         ┌──────────────────────────────┐
│ React + Vite + Monaco    │  HTTP   │ FastAPI                      │
│  - Editor (MJCF / Py)    │ ──────▶ │  /api/projects   (CRUD)      │
│  - Viewer (frames)       │         │  /api/chat       (LLM diff)  │
│  - Chat + Diff review    │ ◀────── │  /ws/sim/{id}    (frames)    │
│  - BYOK settings         │   WS    └──────────────┬───────────────┘
└──────────────────────────┘                        │
                                          ┌─────────▼────────┐
                                          │ subprocess sand- │
                                          │ box (cloud only) │
                                          └─────────┬────────┘
                                                    │
                                            ┌───────▼────────┐
                                            │ MuJoCo runner  │
                                            │ (offscreen GL) │
                                            └────────────────┘

Deploy as a single container

The repo ships a multi-stage Dockerfile that builds the React app, installs MuJoCo + OSMesa, and serves the SPA + API + WS from one FastAPI process on $PORT (default 7860).

docker build -t tau-sim .
docker run --rm -p 7860:7860 tau-sim
# open http://localhost:7860

The container defaults to multi-tenant mode: each visitor gets a cookie session, projects are stored under /tmp/projects_data/<session>/, and user env code runs inside a subprocess sandbox with CPU + wall-clock limits. For local single-user runs (your laptop), the tau CLI sets TAU_SINGLE_USER=1 automatically and disables the sandbox for speed.

Hugging Face Spaces (free)

  1. Create a new Space → SDK Docker.
  2. Push this repo. Rename SPACE_README.md to README.md at the Space root (or merge its YAML header into the existing README before pushing).
  3. The Space builds the Docker image and exposes the app on its *.hf.space URL.

No API keys are baked into the image — users add their own via the in-app Settings panel (stored only in their browser).

Configuration (env vars)

Variable Default Effect
PROJECTS_DIR ~/.tau/projects (CLI) / /tmp/projects_data (Docker) Where project files live.
MUJOCO_GL egl (CLI) / osmesa (Docker) MuJoCo offscreen renderer.
TAU_SINGLE_USER 0 (Docker) / 1 (CLI) Disable cookie-based isolation.
TAU_SANDBOX 0 (CLI) / 1 (Docker) Run user env in subprocess with rlimits.
TAU_CPU_LIMIT 60 CPU seconds per episode (sandbox only).
TAU_WALL_LIMIT 120 Wall-clock seconds per episode (sandbox only).
TAU_MEM_LIMIT_MB unset Optional RLIMIT_AS cap. Don't set unless you've tested with numpy/MuJoCo.
OPENROUTER_API_KEY / OPENAI_API_KEY / GEMINI_API_KEY unset Optional server-side defaults; per-user BYOK overrides take precedence.
GITHUB_TOKEN unset Lifts menagerie-importer rate limit from 60/hr to 5000/hr.

Security note

env.py is executed by the backend whenever you press Run. The default Docker deployment runs it in a subprocess with rlimits — that protects CPU / disk / wall-clock but not arbitrary syscalls or network. For real public exposure also run the container with --memory, --pids-limit, and a no-egress network policy.

LLM-proposed diffs are never auto-applied; the user must click Apply.

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

tau_sim-0.1.2.tar.gz (90.1 kB view details)

Uploaded Source

Built Distribution

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

tau_sim-0.1.2-py3-none-any.whl (92.8 kB view details)

Uploaded Python 3

File details

Details for the file tau_sim-0.1.2.tar.gz.

File metadata

  • Download URL: tau_sim-0.1.2.tar.gz
  • Upload date:
  • Size: 90.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for tau_sim-0.1.2.tar.gz
Algorithm Hash digest
SHA256 8de9cc23b218a10a51e05bd8a97a40389e85e6ac34d2d694d4fbfc7f54c0fc50
MD5 bb706e2d547de5ccd6776eda63d97029
BLAKE2b-256 a40e5cb8c4481c1c337b53ae220c5217d704cf96d55e9be9671419bdb48ec2ed

See more details on using hashes here.

File details

Details for the file tau_sim-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: tau_sim-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 92.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for tau_sim-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e5e652dae004de50ce1db699431e1999bb8bcbd355e13e439d97637a2589bbfe
MD5 f052f8c36a5c65bf24aa1b38bf2b1d03
BLAKE2b-256 07c480ea2ffc32edc23a93223017641fdfb489a4515970eb53361243430cc8c0

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