Skip to main content

MCP server for the Blender Optics Simulator — build, inspect, align, and render a real optical bench in Blender over MCP.

Project description

Blender Optics — dedicated MCP server

A standalone MCP server that lets an MCP client (e.g. Claude Desktop / Claude Code) drive a running Blender Optics Simulator scene: build canonical setups, read the full optical state (ports, world normals, beam path, detector readings), align, swap parts, position elements relative to one another, scan, and render.

It talks to the add-on through a tiny localhost socket bridge built into the add-on (optical_alignment_sim/bridge.py), so it works against the live Blender you already have open — no headless re-launch, no file round-trips.

MCP client  ──stdio──▶  optics_mcp_server.py  ──TCP 127.0.0.1:9765──▶  Blender add-on bridge ──▶ optics_api

1. Start the bridge in Blender

In the running Blender: View3D ▸ Sidebar (N) ▸ Optics ▸ Simulation ▸ Start MCP Bridge. The status line shows MCP bridge: 127.0.0.1:9765 (live). (Or tick Auto-start bridge in the add-on preferences to start it on load. Change the port there if 9765 is taken.)

Only the add-on's whitelisted optics_api functions are reachable, and the socket binds to 127.0.0.1 only.

2. Run the MCP server

The server is a packaged console app — blender-optics-mcp. Pick whichever you like:

# zero-install, one line (recommended) — runs the packaged entry point
uvx blender-optics-mcp                      # once published to PyPI
uvx --from ./mcp blender-optics-mcp         # straight from this repo, no publish needed

# or install it
pipx install blender-optics-mcp             # (PyPI)  /  pipx install ./mcp   (from source)
pip install ./mcp && blender-optics-mcp     # into the current environment

# or just run the single file (needs `pip install "mcp[cli]"`)
OPTICS_BRIDGE_PORT=9765 python3 optics_mcp_server.py

Environment:

  • OPTICS_BRIDGE_PORT — bridge port (default 9765, must match the add-on preference).
  • OPTICS_BRIDGE_HOST — default 127.0.0.1.

3. Wire it into an MCP client

With the packaged entry point the client config is a single command — no absolute script path:

{
  "mcpServers": {
    "blender-optics": {
      "command": "uvx",
      "args": ["blender-optics-mcp"],
      "env": { "OPTICS_BRIDGE_PORT": "9765" }
    }
  }
}

("command": "blender-optics-mcp" works too once it's installed on your PATH; or, from a checkout, "command": "uvx", "args": ["--from", "/absolute/path/to/mcp", "blender-optics-mcp"].)

Distribution (MCP Registry / PyPI)

This folder is a self-contained Python distribution:

  • pyproject.toml — builds blender-optics-mcp (a single-module wheel; depends only on mcp[cli]). python -m build → publish to PyPI with twine.
  • server.json — the MCP Registry manifest (namespace io.github.emircbngl/..., PyPI package, stdio transport). Publish/validate it with the official mcp-publisher CLI (it authenticates via GitHub and checks the schema — confirm the $schema version it expects at submission time, as the registry schema evolves).

Tools

The server mirrors the add-on's full optics_api surface — the bridge auto-derives its allow-list from optics_api's public functions, so every tool below maps 1:1 to a core API call.

Tool What it does
get_state Full optical state: elements, ports (world pos + normal), mounts/DOFs, beam path, detector report
build_example Build mach_zehnder / michelson / hong_ou_mandel / bell / adaptive_optics / newton_rings
trace_beam Re-trace the beam path
tag_element Mark an object as an optical element (set type) + auto-detect ports
set_mount Apply a kinematic-mount preset to an element
set_param Set an optical parameter (reflectivity, wavelength, pol_angle, …)
align_element / align_all Auto-align one element / every element's knobs toward its target
check_mechanics Report the worst opto-mechanical limit (post pull-out, cage-rod travel)
add_component Spawn a catalog component (or its generic fallback)
swap_part Replace an element's mesh from a file, keeping its optical slot
place_relative Place an element relative to another (along an axis or its beam), optionally linked
scan Sweep OPD / waveplate angle / wavelength → plot PNG + CSV
ao_measure / get_wavefront Read a wavefront sensor's residual Zernike modes + RMS
ao_command Set a deformable mirror's Zernike command (waves)
ao_close_loop Close the adaptive-optics loop (sensor → deformable mirror) until the wavefront flattens
bake_beams / clear_beams Bake the beam path into emission meshes / remove them
render Configure or render the scene (EEVEE preview / Cycles final)
export_svg Write a top-view SVG schematic of the layout + beam path (publication figures)
beam_profile Spot radius w(z) along the beam path: waist, element positions, plot PNG + CSV

Notes

  • The bridge dispatches every call onto Blender's main thread (bpy is not thread-safe), so tools are serialized and safe.
  • An interactively-authenticated Blender session is required for live edits; the server itself is stateless and reconnects per call.

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

blender_optics_mcp-0.24.2.tar.gz (26.5 kB view details)

Uploaded Source

Built Distribution

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

blender_optics_mcp-0.24.2-py3-none-any.whl (23.6 kB view details)

Uploaded Python 3

File details

Details for the file blender_optics_mcp-0.24.2.tar.gz.

File metadata

  • Download URL: blender_optics_mcp-0.24.2.tar.gz
  • Upload date:
  • Size: 26.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for blender_optics_mcp-0.24.2.tar.gz
Algorithm Hash digest
SHA256 269b184568cd0b8a0bbba4f6f579b955e7c5065361fb27070f7aa3059636a9e9
MD5 16b5fbd4fd3e7ff93357714975716253
BLAKE2b-256 1a62d31f0e48e76d5aeac9e6ed05fbd5d01b0c64b6a8643c9e4bc984fff02b68

See more details on using hashes here.

File details

Details for the file blender_optics_mcp-0.24.2-py3-none-any.whl.

File metadata

File hashes

Hashes for blender_optics_mcp-0.24.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4c4cc0d623c590e54496568aa267b1cd5f0e7e87d09faacf5056183627a8d3f1
MD5 8ccac30647d417f131571f38d7fdb870
BLAKE2b-256 e3727e5c9b65ae6de413d36026f96e87d9b4c57ff08b3d8ebfd303d5851f7967

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