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.5.tar.gz (117.9 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.5-py3-none-any.whl (127.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: tau_sim-0.1.5.tar.gz
  • Upload date:
  • Size: 117.9 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.5.tar.gz
Algorithm Hash digest
SHA256 532088e517145b3412288b3478c0e002ba384bc38529d2af2ddae95500d98b4d
MD5 dac66a8bd4b967bf9fc46fed6e605fae
BLAKE2b-256 e2c4de261d5b9434c4586e7cf3d5389ac384a376ed837e63bf60cb023f4bd5a9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: tau_sim-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 127.9 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.5-py3-none-any.whl
Algorithm Hash digest
SHA256 281bb122221c9ac666b5b62872196bd7e92495da2dccb9a5f94f7a104723cb93
MD5 e9d7f833b950774e9007ba0955d0a318
BLAKE2b-256 893c52d74bdfa4d6aee68168000293cb51824ce5c3595cfc7ffa65cc79c1af64

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