fxhoudinimcp
Provides tools for interacting with SideFX Houdini, enabling AI agents to create and manipulate 3D scenes, simulations, renderings, and more through Houdini's Python API.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@fxhoudinimcpcreate a sphere and add a mountain"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Table of Contents
About
A comprehensive MCP (Model Context Protocol) server for SideFX Houdini. Connects AI assistants like Claude directly to Houdini's Python API, enabling natural language control over scene building, simulation setup, rendering, and more.
168 tools, 8 resources, and 6 workflow prompts out of the box.
Features
Category | Tools | Description |
Scene Management | 7 | Open, save, import/export, scene info |
Node Operations | 16 | Create, delete, copy, connect, layout, flags |
Parameters | 10 | Get/set values, expressions, keyframes, spare parameters |
Geometry (SOPs) | 12 | Points, prims, attributes, groups, sampling, nearest-point search |
LOPs/USD | 18 | Stage inspection, prims, layers, composition, variants, lighting |
DOPs | 8 | Simulation info, DOP objects, step/reset, memory usage |
PDG/TOPs | 10 | Cook, work items, schedulers, dependency graphs |
COPs (Copernicus) | 7 | Image nodes, layers, VDB data |
HDAs | 10 | Create, install, manage Digital Assets and their sections |
Animation | 9 | Keyframes, playbar control, frame range |
Rendering | 9 | Viewport capture, render nodes, settings, render launch |
VEX | 5 | Create/edit wrangles, validate VEX code |
Code Execution | 4 | Python, HScript, expressions, env variables |
Viewport/UI | 11 | Pane management, screenshots, status messages, error detection |
Scene Context | 8 | Network overview, cook chain, selection, scene summary, error analysis |
Workflows | 8 | One-call Pyro/RBD/FLIP/Vellum setup, SOP chains, render config |
Materials | 4 | List, inspect, create materials and shader networks |
CHOPs | 4 | Channel data, CHOP nodes, export channels to parameters |
Cache | 4 | List, inspect, clear, write file caches |
Takes | 4 | List, create, switch takes with parameter overrides |
Architecture
flowchart LR
subgraph Client[" ๐ค AI Client "]
direction TB
A1("Claude Desktop")
A2("Cursor / VS Code")
A3("Claude Code")
end
subgraph MCP[" โก FXHoudini MCP Server "]
direction TB
B1("๐ง 168 Tools")
B2("๐ฆ 8 Resources")
B3("๐ฌ 6 Prompts")
end
subgraph Houdini[" ๐ถ SideFX Houdini "]
direction TB
C1("๐ hwebserver")
C2("๐ก Dispatcher")
C3("๐๏ธ hou.* Handlers")
C1 --> C2 --> C3
end
Client -. "MCP Protocol ยท stdio" .-> MCP
MCP -. "HTTP / JSON ยท port 8100" .-> Houdini
classDef clientBox fill:#f0f4ff,stroke:#b8c9e8,stroke-width:1px,color:#2d3748,rx:12,ry:12
classDef mcpBox fill:#eef6f0,stroke:#a8d5b8,stroke-width:1px,color:#2d3748,rx:12,ry:12
classDef houdiniBox fill:#fff5f0,stroke:#e8c4a8,stroke-width:1px,color:#2d3748,rx:12,ry:12
classDef clientNode fill:#dbe4f8,stroke:#96b0dc,stroke-width:1px,color:#2d3748,rx:8,ry:8
classDef mcpNode fill:#d4edda,stroke:#82c896,stroke-width:1px,color:#2d3748,rx:8,ry:8
classDef houdiniNode fill:#fde4d0,stroke:#e0a87c,stroke-width:1px,color:#2d3748,rx:8,ry:8
class Client clientBox
class MCP mcpBox
class Houdini houdiniBox
class A1,A2,A3 clientNode
class B1,B2,B3 mcpNode
class C1,C2,C3 houdiniNodeUses Houdini's built-in hwebserver. No custom socket servers, no rpyc. Uses hdefereval.executeInMainThreadWithResult() to safely run hou.* calls on the main thread.
Installation
Requirements
Houdini 20.5+ (tested on 21.0)
Python 3.10+
MCP SDK (
mcppackage) 1.8+
1. Install the MCP Server
From PyPI:
pip install fxhoudinimcpFrom source:
pip install -e .Or with development dependencies:
pip install -e ".[dev]"2. Install the Houdini Plugin
Option A: Houdini package (recommended)
Copy
houdini/fxhoudinimcp.jsonto your Houdini packages directory:Windows:
%USERPROFILE%/Documents/houdiniXX.X/packages/Linux:
~/houdiniXX.X/packages/macOS:
~/Library/Preferences/houdini/XX.X/packages/
Edit the JSON file to set
FXHOUDINIMCPto point to thehoudinidirectory in this repo.
Option B: Manual copy
Copy the contents of houdini/ into your Houdini user preferences directory so that:
scripts/python/fxhoudinimcp_server/is on Houdini's Python pathpython3.Xlibs/uiready.pyauto-starts the server (copy the folder matching your Houdini's Python version)toolbar/fxhoudinimcp.shelfappears in your shelf
3. Configure Your MCP Client
Claude Desktop (claude_desktop_config.json):
{
"mcpServers": {
"fxhoudini": {
"command": "python",
"args": ["-m", "fxhoudinimcp"],
"env": {
"HOUDINI_HOST": "localhost",
"HOUDINI_PORT": "8100"
}
}
}
}Claude Code (global โ available in every project):
claude mcp add --scope user fxhoudini -- python -m fxhoudinimcpOr to scope it to a single project, add a .mcp.json in the project root:
{
"mcpServers": {
"fxhoudini": {
"command": "python",
"args": ["-m", "fxhoudinimcp"]
}
}
}If Claude Desktop reports the server asdisconnected, replace "python" with the
full absolute path to your Python executable. Claude Desktop does not always inherit
your system PATH. Find it with:
python -c "import sys; print(sys.executable)"Then use the result in your config, e.g. "command": "C:\\Program Files\\Python311\\python.exe".
After any config change, fully quit Claude Desktop (system tray โ Quit) and relaunch.
Usage
Launch Houdini normally. The plugin auto-starts once when the UI is ready (controlled by FXHOUDINIMCP_AUTOSTART env var). The startup script uses uiready.py, which stacks correctly with other Houdini packages. You can also toggle it manually via the MCP Server shelf tool.
Once connected, your AI assistant can:
"Create a procedural rock generator with mountain displacement"
"Set up a Pyro simulation with a sphere source"
"Build a USD scene with a camera, dome light, and ground plane"
"Create an HDA from the selected subnet"
"Debug why my scene has cooking errors"Environment Variables
Variable | Default | Description |
|
| Houdini host address |
|
| Houdini hwebserver port |
|
| Port for the Houdini plugin to listen on |
|
| Set to |
|
| MCP transport ( |
|
| Logging level |
Development
# Install dev dependencies
pip install -e ".[dev]"
# Run linter
ruff check python/
# Run tests
pytestHow It Works
Houdini Plugin (
houdini/): Runs inside Houdini's Python environment. Registers@hwebserver.apiFunctionendpoints that receive JSON commands. Useshdefereval.executeInMainThreadWithResult()to safely executehou.*calls on the main thread.MCP Server (
python/fxhoudinimcp/): A standalone Python process using FastMCP. Exposes 167 tools, 8 resources, and 6 prompts via the MCP protocol. Forwards tool calls to Houdini over HTTP.Bridge (
python/fxhoudinimcp/bridge.py): Async HTTP client that sends commands to Houdini's hwebserver and deserializes responses. Handles connection errors and timeouts.
Contact
Project Link: fxhoudinimcp
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/healkeiser/fxhoudinimcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server