Skip to main content

MCP server for OpenUSD — let AI assistants read and manipulate 3D scenes

Project description

openusd-mcp

An MCP server that lets AI assistants read, inspect, and manipulate OpenUSD scenes.

Live Demo — interactive 3D viewer with variant switching

pip install openusd-mcp

What it does

Connect this MCP server to Claude, ChatGPT, Cursor, or any MCP-compatible client. Your AI assistant can then work directly with .usda, .usdc, and .usdz files — inspecting scene graphs, querying properties, exporting meshes, and switching variants.

Tools

Tool Description
usd_inspect Read the scene graph — list all prims, types, hierarchy
usd_get_prim Get detailed properties, attributes, and metadata for a specific prim
usd_get_materials List all materials and their shader parameters
usd_get_transforms Get world-space transforms for prims
usd_list_variants List all variant sets and their options
usd_set_variant Switch a variant selection
usd_export_mesh Export a mesh prim as STL or OBJ
usd_scene_stats Get scene statistics — prim count, mesh count, material count, bounding box

Quick start

With Claude Desktop

Add to your claude_desktop_config.json:

{
  "mcpServers": {
    "openusd": {
      "command": "openusd-mcp",
      "args": []
    }
  }
}

Then try it with the included example scenes:

"Inspect the scene graph of examples/desk_setup.usda and describe what's on the desk."

"What color options does the product in examples/product_configurator.usda have? Switch it to gold."

With any MCP client

openusd-mcp --stdio

The server communicates over stdin/stdout using the MCP protocol.

Examples

The repo includes two example scenes that exercise all 8 tools.

Desk setup — scene inspection

A desk with a table, monitor, keyboard, and mug. 5 PBR materials (wood, metal, screen, ceramic, dark plastic), 10 meshes, real-world dimensions.

You: What's in examples/desk_setup.usda?

Claude: A desk scene with 25 prims, 10 meshes, 5 materials:

  /Desk (Xform)
    /Desk/Table/Top (Mesh) — Wood, 120×60×3 cm
    /Desk/Table/Leg1..4 (Mesh) — Metal
    /Desk/Monitor/Screen (Mesh) — dark glossy
    /Desk/Monitor/Stand (Mesh) — Metal
    /Desk/Monitor/Base (Mesh) — Metal
    /Desk/Keyboard (Mesh) — DarkPlastic
    /Desk/Mug/Body (Mesh) — Ceramic

  Bounds: 1200 × 835 × 1250 mm

You: Export the tabletop as STL

Claude: Exported /Desk/Table/Top to tabletop.stl (12 triangles, 684 bytes)

Product configurator — variant switching

A device with 3 variant sets: size (small, medium, large), color (midnight, silver, gold, red), and finish (matte, satin, glossy).

You: What configuration options does examples/product_configurator.usda have?

Claude: The product at /Product has 3 variant sets:

  size:   small | medium* | large
  color:  midnight* | silver | gold | red
  finish: matte | satin* | glossy

  (* = currently selected)

You: Switch to gold, large, glossy

Claude: Done. Updated /Product:
  size:   large (1.4× scale)
  color:  gold — diffuseColor: (0.83, 0.69, 0.22), metallic: 0.9
  finish: glossy — roughness: 0.1

Requirements

  • Python 3.9+
  • usd-core (Pixar's USD Python bindings)
pip install usd-core

How it works

The server uses Pixar's official pxr Python bindings (the same libraries used by NVIDIA Omniverse, Apple's Reality Composer, and every major VFX pipeline) to read and manipulate USD stages. It exposes these capabilities as MCP tools that any AI assistant can call.

OpenUSD is the industry standard for describing 3D scenes, backed by Pixar, Apple, NVIDIA, Adobe, and Autodesk. As of December 2025, the Alliance for OpenUSD has ratified Core Specification 1.0.

Author

Mirko KieferDaslab

License

MIT

Links

  • OpenUSD — Universal Scene Description
  • AOUSD — Alliance for OpenUSD
  • MCP — Model Context Protocol
  • Daslab — Where AI meets the physical world

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

openusd_mcp-0.1.0.tar.gz (17.8 kB view details)

Uploaded Source

Built Distribution

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

openusd_mcp-0.1.0-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

Details for the file openusd_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: openusd_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 17.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for openusd_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 bfbf69d470dd2edc1e09a4021c795392cfd5c41e575e92ccd26f70119a788ffc
MD5 a7ca3da4226e765f4b66847884008fec
BLAKE2b-256 97ceebe7ace3a69f66333c4c276f5f04f55630672ce86d33c6c9fc19f43880db

See more details on using hashes here.

File details

Details for the file openusd_mcp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: openusd_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 8.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for openusd_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c99593a4a0049b580bfc24d7bd30ea4508ecb2a2c903ab3268c5a8ac04799c74
MD5 56493110d8e6b3e3a56a4a66bb485dbe
BLAKE2b-256 24c6f313c957a41314bfa59d0640fd0d2a30762a917fed65b7ea5b1a5e8de0d8

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