Brings CERN's ROOT data analysis framework into the MCP ecosystem through two tools: root_python for executing Python with PyROOT automatically in scope, and root_cpp for running C++ via ROOT's cling interpreter. Everything runs in-process with automatic error detection, console logging of executed code, and support for TCanvas graphics. The server handles histogram creation, statistical analysis, and physics computations without needing HTTP endpoints or external APIs. Reach for this when you want LLMs to generate and execute ROOT analysis code directly, whether you're fitting distributions, plotting particle physics data, or prototyping analyses interactively. Works with VS Code Copilot Chat or any MCP client over stdio transport.
Model Context Protocol server for executing Python and C++ code with PyROOT
Minimal MCP (Model Context Protocol) server that allows LLMs and other MCP clients to execute Python and C++ code directly using PyROOT, without HTTP endpoints or external APIs.
Below is the architecture diagram for the root_mcp_server project. The image contains a visual representation of the components and their interactions.

Description:
root_python, root_cpp) and dispatches them to the in-process executor.This architecture keeps ROOT running in-process for low-latency execution while providing a web-backed path for interactive visualization.
pip install -e .
The easiest way to use this MCP server is through VS Code with GitHub Copilot Chat.
Make sure you have the GitHub Copilot Chat extension installed in VS Code.
Add the MCP server configuration to your VS Code settings. Open your settings.json (Ctrl/Cmd + Shift + P → "Preferences: Open User Settings (JSON)") and add:
{
"github.copilot.chat.codeGeneration.instructions": [
{
"text": "Use ROOT MCP server for data analysis"
}
],
"mcp.servers": {
"root/mcp-server": {
"type": "stdio",
"command": "root_mcp_server",
"args": []
}
}
}
Important: Replace /path/to/ROOT/build/bin/thisroot.sh with the actual path to your ROOT installation's thisroot.sh script.
Once configured, you can use the MCP tools in GitHub Copilot Chat:
@workspace Use #root_python to execute Python code with PyROOT
@workspace Use #root_cpp to execute C++ code with ROOT
The server will automatically log executed code and results to the MCP console (visible in VS Code's Output panel).
Start the MCP server directly:
root_mcp_server
from mcp.client.stdio import stdio_client, StdioServerParameters
from mcp.client.session import ClientSession
server_params = StdioServerParameters(
command="bash",
args=["-lc", "source /path/to/thisroot.sh && python3 -m root_mcp_server.cli"],
env=None
)
async with stdio_client(server_params) as (read, write):
async with ClientSession(read, write) as session:
await session.initialize()
# Execute Python code
result = await session.call_tool("root_python", arguments={
"code": "import ROOT; print(ROOT.gROOT.GetVersion())"
})
print(result)
The server exposes two MCP tools:
root_pythonExecute Python code with ROOT automatically available in scope.
Arguments:
code (string): Python code to executeReturns:
{
"ok": boolean,
"stdout": string,
"stderr": string,
"error": string | null,
"error_type": string | null
}
Example:
code = """
import ROOT
h = ROOT.TH1F("h", "Gaussian", 100, -5, 5)
for i in range(10000):
h.Fill(ROOT.gRandom.Gaus(0, 1))
print(f"Mean: {h.GetMean():.3f}")
"""
root_cppExecute C++ code via ROOT's cling interpreter.
Arguments:
code (string): C++ code to executeReturns:
{
"ok": boolean,
"stdout": string,
"stderr": string,
"error": string | null,
"error_type": string | null
}
Example:
TH1F* h = new TH1F("h", "Gaussian;X;Y", 100, -5, 5);
for(int i=0; i<10000; i++) h->Fill(gRandom->Gaus(0,1));
TCanvas* c = new TCanvas("c", "Canvas", 900, 600);
h->Draw();
c->Update();
std::cout << "Mean: " << h->GetMean() << std::endl;
The server automatically detects C++ compilation errors by:
ROOT.gInterpreter.ProcessLine()error:, Error:, fatal error:)Errors are reported with ok=false and detailed error messages.
All code execution is logged to stderr (MCP console) with:
Example output:
============================================================
EXECUTING PYTHON CODE:
1 | import ROOT
2 | print(ROOT.gROOT.GetVersion())
============================================================
✓ EXECUTION SUCCESS
STDOUT:
6.39/01
The server initializes TApplication and supports ROOT graphics:
# Test basic functionality
python test_mcp_client.py
# Test persistent graphics
python test_persistent_window.py
# Test histogram creation
python test_histogram.py
root_mcp_server/
├── root_mcp_server/
│ ├── __init__.py
│ ├── cli.py # Entry point
│ ├── executor.py # Code execution
│ └── server.py # MCP server definition
├── test_mcp_client.py
├── test_persistent_window.py
├── test_histogram.py
└── README.md
See LICENSE file.
Contributions are welcome! Please feel free to submit a Pull Request.