Give AI agents full access to ITASCA PFC - documentation, simulation, and plot capture.
MCP server that gives AI agents full access to ITASCA PFC - browse documentation, run simulations, capture plots, all through natural conversation.
Built on the Model Context Protocol, pfc-mcp turns any MCP-compatible AI client (Claude Code, Codex CLI, Gemini CLI, OpenCode, toyoura-nagisa, etc.) into a PFC co-pilot that can look up commands, execute scripts, monitor long-running simulations, and capture visualizations.

pfc2d700_gui.exe or pfc3d700_gui.exe)uvx)Copy this to your AI agent and let it self-configure:
Fetch and follow this bootstrap guide end-to-end:
https://raw.githubusercontent.com/yusong652/pfc-mcp/main/docs/agentic/pfc-mcp-bootstrap.md1. Register the MCP server in your client config:
{
"mcpServers": {
"pfc-mcp": {
"command": "uvx",
"args": ["pfc-mcp"]
}
}
}2. Install dependency:
import pip
pip.main(["install", "--user", "-U", "pfc-mcp-bridge"])import pfc_mcp_bridge
pfc_mcp_bridge.start()
Verify - reconnect your MCP client and ask the agent to call pfc_list_tasks to verify the full MCP + bridge connection.
cycle() calls, and capture plots mid-simulation without pausing it| Component | PyPI | Python | Role |
|---|---|---|---|
| pfc-mcp | >= 3.10 | MCP server (documentation + execution client) | |
| pfc-mcp-bridge | >= 3.6 | WebSocket bridge inside PFC process (GUI or console) |
Documentation tools work standalone. Execution tools require a running bridge.
| Symptom | Fix |
|---|---|
uvx not found | Install uv or switch client MCP config to command: "uv" with args: ["tool", "run", "pfc-mcp"] |
| Bridge won't start | In PFC Python/IPython console, install/upgrade pfc-mcp-bridge with import pip; pip.main(["install", "--user", "-U", "pfc-mcp-bridge"]) |
| Tasks not processing / cannot connect | If execution tools return ok=false, error.code=bridge_unavailable, and error.details.reason=cannot connect to bridge service, start bridge in PFC (pfc_mcp_bridge.start()) and ensure PFC_MCP_BRIDGE_URL matches the active bridge URL |
pfc_capture_plot unsupported | Plot capture requires PFC GUI; console mode does not support it |
| Bridge on custom port | Set MCP server env PFC_MCP_BRIDGE_URL=ws://localhost:<bridge-port> (for example ws://localhost:9002) |
| Connection failed | Check bridge is running, target port is available, see .pfc-bridge/bridge.log |
uv sync --group dev # Install with dev dependencies
uv run pytest # Run tests
uv run pfc-mcp # Run server locallyMIT - see LICENSE.