An open Model Context Protocol server for Vose Software's ModelRisk.
Use it with Claude Desktop, Claude Code, Cursor, Zed, or any MCP-compliant client to read, build, fit, and run Monte Carlo risk models in Excel from a conversation.
ModelRisk MCP is an open MCP server on the standard Anthropic Model Context Protocol. No proprietary layer, no lock-in. The 1417-entry function catalogue, the Vose methodology principles, and the audit rule set are all included in the package — and editable.
Stable: 0.3.0 — programmatic simulation via the run_simulation tool wired end-to-end (XLL command surface, no fragile COM dispatch); .vmrs results read via the official ModelRisk SDK; activation ships bundled so no environment configuration is required. 40 tools across reading, building, simulation, scenario-sweep, restore, charting, audit, and workflow surfaces.
Monte Carlo risk modelling is the right way to reason about an uncertain future — and almost nobody does it.
The mathematics has been settled for decades: when your inputs are uncertain, you don't reason with a single "best guess" number, you reason with the distribution of outcomes. A point estimate ("Q3 revenue will be $4.2M") hides exactly the thing a decision-maker needs to know — how wrong could it be, how bad is the downside, which assumption is driving the risk. ModelRisk has given Excel users a rigorous, validated engine for this for years.
The barrier was never the maths. It was the friction:
- The discipline carries a real skill curve — 1,400+ functions, the right distribution family for each input, the methodology traps (fit without parameter uncertainty, correlations ignored, risk events modelled as
p × impact) that quietly produce confident-but-wrong answers. - Setting a model up by hand is slow and fiddly — wrapping inputs, naming outputs, wiring copulas and time-series, formatting the report.
- So under deadline pressure, most teams fall back to a single-point spreadsheet and a gut-feel range. The rigorous tool sits unused.
This server removes that friction. Large language models can now drive domain tools through the open Model Context Protocol. ModelRisk MCP puts the whole ModelRisk surface — build, fit, simulate, audit, interpret — behind a conversation. You describe the problem in plain language; Claude proposes the right distributions, wires the structure, runs the simulation, reads the tail, and writes the report. The expertise moves into the loop; the friction drops to a sentence.
It is built on five deliberate principles:
- Open, not locked-in. A server on the standard Anthropic MCP — works with Claude Desktop, Claude Code, Claude for Excel, Cursor, Zed, and any compliant client. MIT-licensed. The function catalogue, methodology, and audit rules ship in the package and are editable. No proprietary connector, no vendor cage.
- Methodology-grounded, not just mechanically capable. The server is opinionated about correct practice. Fits default to
uncertainty=TRUE; risk events use the bimodalVoseRiskEvent; the 13-rule audit encodes the mistakes Vose practitioners have seen across decades of consulting. It won't just do what you ask — it'll steer you toward what's right. - Local-only, no telemetry. Everything runs on your machine against your Excel and your ModelRisk install. No data leaves your computer; the activation key is bundled and offline.
- Excel stays the model. No re-platforming, no shadow tooling. The workbook is the model — versionable in Git, openable by anyone with Excel + ModelRisk, reproducible by re-running one tool call.
- Safe by design. Every write previews first (
dry_run=True), lands in Excel's undo stack, and is logged. The server can modify your workbook — and does so under nine layered safeguards (see Safety by design).
The goal is simple: make defensible, quantitative risk analysis something you reach for by default — because it's now no harder than asking.
This server turns Claude (or any MCP client) into a methodology-aware co-pilot for ModelRisk. It can:
- Build new Monte Carlo models from a description — insert distributions, fit families to data, build aggregates, copulas, time-series, risk events.
- Run simulations from the conversation.
run_simulationtriggers the same XLL command the ribbon "Simulate" button uses, blocks until the run finishes, saves a.vmrsnext to the workbook, and auto-pins it as the results source. - Read model structure and per-iteration results — inputs, outputs, percentiles, correlation matrices, tornado rankings — directly from
.vmrsfiles via ModelRisk's official SDK (MRService.dll). No COM dispatch fragility. - Audit a workbook against Vose's methodology rules and propose fixes.
- Interpret results into structured executive summaries with contingency analysis.
Every formula written to Excel is validated against the ModelRisk function catalogue first — there's no path to a hallucinated function name reaching your workbook.
See the user manual for a walkthrough of the eight things you can do, a realistic end-to-end example, and what the server explicitly does and doesn't do. New to Monte Carlo or to the ModelRisk MCP toolchain? Start with the 15-minute quick-start tutorial, then pick a walk-through scenario matching your problem (budgets, data fitting, loss aggregation, correlated inputs, stress tests, model audits); unfamiliar with a term, see the glossary.
| Capability | ModelRisk MCP | Closed alternatives |
|---|---|---|
| Read model structure (inputs, outputs, distributions) | ✓ | ✓ |
| Read simulation results, percentiles, sensitivity | ✓ | ✓ |
| Insert distributions into cells | ✓ | — |
| Fit distributions from data | ✓ | — |
| Build aggregate (frequency × severity) models | ✓ | — |
| Build copulas / correlated inputs | ✓ | — |
| Build time-series stochastic processes | ✓ | — |
| Run simulations from the conversation | ✓ | — |
| Audit model for common methodology mistakes | ✓ | — |
| Works with Claude Desktop / Code / Cursor / Zed / any MCP client | ✓ | — |
| Open source, MIT licensed | ✓ | — |
| Local-only, no telemetry | ✓ | varies |
| Default-safe (dry-run preview before every write) | ✓ | n/a |
- Windows 10 or 11, 64-bit
- Excel 2019 or newer with the ModelRisk add-in installed and loaded
- One of:
- Python 3.11+ (recommended via
uv) - Or the standalone
modelrisk-mcp.exefrom the latest release — no Python knowledge required
- Python 3.11+ (recommended via
Activation: None required. MRService.dll (the SDK that reads .vmrs files) is activated automatically by a bundled offline key. Set MRSERVICE_ACTIVATION_KEY only if you want to override the default with your own.
pip install modelrisk-mcpgit clone https://github.com/vosesoftware/modelrisk-mcp
cd modelrisk-mcp
uv sync
uv run python -m modelrisk_mcp # speaks MCP over stdioDownload modelrisk-mcp.exe from Releases, drop it anywhere on disk, and point Claude Desktop at it. See docs/claude-desktop.md.
Three options, simplest first.
pip install modelrisk-mcp
modelrisk-mcp installmodelrisk-mcp install detects every installed MCP client (Claude Desktop, Claude Code), backs up its existing config, and adds the modelrisk server entry — preserving any other servers you already have configured. Output looks like:
+ Claude Desktop added C:\Users\you\AppData\Roaming\Claude\claude_desktop_config.json
Registered 'modelrisk' -> {'command': 'C:\\...\\Scripts\\modelrisk-mcp.exe'}
backup: ...claude_desktop_config.json.bak.20260521-153000
Restart Claude Desktop / Claude Code to pick up the new server.
To undo: modelrisk-mcp uninstall. To register a second instance with a different name (e.g. dev and prod side-by-side): modelrisk-mcp install --name=modelrisk-dev.
If you have uv installed, you can skip the pip install step entirely. Just add to %APPDATA%\Claude\claude_desktop_config.json directly:
{
"mcpServers": {
"modelrisk": {
"command": "uvx",
"args": ["modelrisk-mcp"]
}
}
}uvx downloads modelrisk-mcp into an ephemeral cache on first run and updates automatically when new versions hit PyPI.
Open %APPDATA%\Claude\claude_desktop_config.json and add the entry by hand:
{
"mcpServers": {
"modelrisk": {
"command": "C:/path/to/modelrisk-mcp.exe"
}
}
}Use the absolute path to the .exe you downloaded from the latest release, or "command": "python", "args": ["-m", "modelrisk_mcp"] if you pip installed.
After any of the three, restart Claude Desktop so it spawns the MCP server subprocess. The ModelRisk tools appear under the connections icon. Full guide: docs/claude-desktop.md. Claude Code setup: docs/claude-code.md.
Claude for Excel runs inside an Office.js sandbox and can't spawn subprocesses, so it talks to MCP servers over HTTP. Start the server in HTTP mode:
$env:MODELRISK_MCP_TOKEN = [Guid]::NewGuid().ToString("N") * 2
modelrisk-mcp --transport=streamable-http --port=8000 --token=$env:MODELRISK_MCP_TOKENThen in Claude for Excel: Settings → Connectors → Add MCP server, URL http://127.0.0.1:8000/mcp, paste the token. Full guide: docs/claude-for-excel.md.
Why this is interesting: Claude for Excel's sandbox can't reach Excel's COM surface or the ModelRisk ribbon on its own. ModelRisk MCP runs outside the sandbox and bridges that gap — Claude for Excel can do things via this server it structurally can't do otherwise (run simulations, dispatch ModelRisk COM, write distributions through the safety pipeline).
Open a workbook in Excel that has at least one Vose function — even a single =VoseNormal(0,1). Then in Claude:
Summarise the active workbook's risk model — inputs, outputs, distributions.
Or jump straight into building:
/build-risk-model
This walks through 9 steps, from identifying outputs through running the simulation and interpreting results. See the slash-command catalogue for the other workflows.
The server can both read and modify your workbook — that's the central differentiator. We make that safe with nine layered mechanisms (spec §11):
dry_run=Trueis the default on every building tool. Claude must explicitly passdry_run=Falseto commit. Previewing comes free; a forgotten flag becomes a preview, never an overwrite.- Every write lands in Excel's native undo stack.
Ctrl+Zworks exactly as you'd expect. - Bulk-write guard. Tools writing >50 cells in one call require explicit
confirm_bulk=True. Time-series and copula tools — which write contiguous ranges by design — are exempt. - No automatic saves. The server never calls
Workbook.Save(). You controlCtrl+S. - No overwriting non-Vose formulas. A formula-tokenised detector (not a substring check) refuses to overwrite a cell whose existing formula uses non-Vose functions. The one tool explicitly allowed to do this is
replace_constant_with_distribution, by design. - Audit log of every write in
%LOCALAPPDATA%\VoseSoftware\modelrisk-mcp\writes.log— timestamp, cell, before/after formulas, before value. JSONL, append-only. - Read-only mode. Launch with
--read-onlyto disable every building/simulation tool. - Single-writer mutex. Two MCP server instances can't drive the same Excel concurrently — the second instance raises
ConcurrentWriterErroron any building tool call. - Restore from audit log. The
restore_celltool reads writes.log and rewrites the pre-write formula — even after Excel's undo stack has been cleared.
- 40 tools — 12 reading, 13 building, 5 simulation (incl.
run_simulation,run_scenarios,get_samples,restore_cell,restore_deterministic_state), 7 workflow / reporting (incl.audit_model,diagnose_workbook,create_tornado_chart,build_drivers_report,build_executive_report,generate_executive_summary,save_workbook_as), 3 VMRS (read_vmrs,set_active_vmrs,list_vmrs_variables) - 5 resources —
modelrisk://functions,modelrisk://distributions,modelrisk://methodology,modelrisk://workbook/current,modelrisk://audit-rules - 5 slash-command prompts —
/build-risk-model,/audit-model,/interpret-results,/add-uncertainty,/import-legacy-model - 1417-entry function catalogue extracted directly from the ModelRisk IDL + XLL header
- 17 audit rules — 13 Monte-Carlo-methodology (VOSE-001 … VOSE-013) + 4 spreadsheet-integrity (SS-001 … SS-004) — with editable severity in
data/audit_rules.yaml; add your own withdocs/authoring-audit-rules.md - Methodology-grounded distribution selection guide in
data/distributions.yaml
The server is opinionated about Monte Carlo methodology — fetch modelrisk://methodology from any MCP client to read the 8 core principles. Highlights:
- Every uncertain input is a distribution. Treating a noisy input as deterministic understates total uncertainty by exactly the amount it could swing.
- Distribution fits use
uncertainty=TRUE. Carry parameter uncertainty through the simulation; don't pretend the best-fit parameters are exact. - Risk events use
VoseRiskEvent, notprobability * impact. The bimodal nature matters. - Correlated inputs use copulas. Independent inputs that are actually correlated produce artificially tight outputs.
Three internal layers plus two external integration paths:
┌──────────────────────────────────┐
│ MCP client │
│ (Claude Desktop, Code, etc.) │
└────────────────┬─────────────────┘
│ JSON-RPC / stdio (or HTTP)
▼
┌──────────────────────────────────┐
│ FastMCP layer (tools, resources,│
│ prompts) │
├──────────────────────────────────┤
│ ModelRiskBridge (domain) │
│ + SimulationController │
│ + ResultsReader │
├──────────────────────────────────┤
│ ExcelBridge MrServiceBridge│
│ (xlwings) (ctypes) │
└──────┬───────────────────┬───────┘
│ Application.Run │ MRLIB_*
│ + cell I/O │ (read .vmrs)
▼ ▼
┌──────────────┐ ┌──────────────────┐
│ Excel + │ │ MRService.dll │
│ ModelRisk XLL│ │ (SDK) │
└──────────────┘ └──────────────────┘
Two integration paths, each chosen for what it does best:
- Builds + simulation trigger → Excel COM via xlwings, plus
Application.Run("VoseStartSimulCustom12", …)for the simulation kickoff. Mirrors what the ModelRisk ATL does internally; bypasses the fragile ATL CoClass Dispatch surface that doesn't expose IDispatch. - Results read → MRService.dll directly via ctypes. Vose's official SDK opens
.vmrsfiles, returns sample arrays, computes statistics. No COM round-trips per output; per-iteration sample arrays available for arbitrary downstream analysis.
More: docs/architecture.md, docs/com-surface.md.
- Launch order: Excel first, MCP server second. Excel must already be running interactively (started from the Start menu, taskbar, or by double-clicking an
.xlsx) before the MCP server tries to driverun_simulation. When Excel is launched programmatically by an automation client, ModelRisk's XLL skips part of itsxlAutoOpeninitialisation — the XLL functions still register as worksheet UDFs, but the XLL commands (VoseStartSimulCustom12etc.) never get added to Excel'sApplication.Runtable. The simulation pipeline depends on those commands. Ifrun_simulationfails with "macro may not be available", restart Excel by hand and try again. - OneDrive-hosted workbooks: xlwings can fail to resolve the workbook's full path without
ONEDRIVE_COMMERCIAL_WINset. The bridge degrades gracefully — name-based operations still work, andrun_simulationdefaults the.vmrssave location to the user's Desktop when the workbook folder can't be resolved. - Active simulation results:
get_simulation_resultsreads from the.vmrsfile produced by the most recentrun_simulationcall, or the most recent sibling.vmrsnext to the workbook. Useset_active_vmrs(path)orread_vmrs(path)to point at a specific file.
MIT. See LICENSE.
| Doc | What it's for |
|---|---|
| Quick-start tutorial | 15 minutes, zero to your first simulation |
| Walk-through scenarios | Six problem-shaped recipes — budgets, data fitting, loss aggregation, correlated inputs, stress tests, audits |
| User manual | The eight things you can do, in depth; what the server does and doesn't do |
| Methodology | The principles behind every model, each tied to the audit rule that enforces it |
| Knowledge base | Risk-analysis guidance distilled from the ModelRisk Help — served to the LLM at build time (modelrisk://knowledge) |
| Distribution selection | Which distribution for which uncertain quantity |
| Modeling patterns | Techniques — frequency-severity, correlation, common random numbers, time-series choice |
| Glossary | Monte Carlo + MCP vocabulary for non-statisticians |
| Installation | Full install + activation detail |
| Claude Desktop setup · Claude Code setup · Claude for Excel setup | Per-client wiring |
| Chart style guide | The native-Excel-chart styling ruleset the reports follow |
| Authoring audit rules | Extend the 13-rule audit set with your own |
| Architecture | Internal layers + the two integration paths |
- Vose Software: https://www.vosesoftware.com
- ModelRisk product page: https://www.vosesoftware.com/products/modelrisk/
- Source: https://github.com/vosesoftware/modelrisk-mcp
- Releases: https://github.com/vosesoftware/modelrisk-mcp/releases
- Issues: https://github.com/vosesoftware/modelrisk-mcp/issues
- Changelog: CHANGELOG.md
- MCP spec: https://modelcontextprotocol.io