MCP server providing pre-flight validation and post-processing tools for OpenMC inputs
Project description
openmc-validator-mcp
An MCP (Model Context Protocol) server that provides pre-flight validation and post-processing tools for OpenMC Monte Carlo transport simulations. Catch common authoring mistakes before the job hits the HPC queue — eliminate the costly "submit → queue → fail → fix → resubmit" loop.
Features
The server exposes 14 tools across four categories:
Validators (5) — Catch mistakes at authoring time
| Tool | What it checks |
|---|---|
validate_materials |
Nuclide name typos, negative density, ao/wo fraction mixing, L2 round-trip |
validate_geometry |
Unclosed surface references, unknown universes/cells, DAGMC path validity |
validate_settings |
Batch/population sanity, source definition completeness, D-T energy check |
validate_tallies |
Energy bin ordering, mesh axis validity, score whitelist |
validate_model |
End-to-end model validation; optional openmc --geometry-debug subprocess |
Cross-Checks (3) — Spot interface mismatches
| Tool | What it checks |
|---|---|
check_cross_section_library |
Nuclide + temperature availability in cross_sections.xml |
check_energy_filter_coverage |
Energy filter upper edge vs. source max energy (e.g. 14.1 MeV) |
check_tally_filter_consistency |
Tally cell filters vs. geometry cells, mesh extent boundaries |
Converters (2) — Bridge OpenMC to downstream codes
| Tool | What it does |
|---|---|
convert_spectrum_openmc_to_fispact |
OpenMC energy tally → FISPACT-II ARBI spectrum file |
extract_tally_summary |
statepoint.h5 → structured JSON (mean / std / rel_err) |
Template & Material Catalog (4) — Browse pre-built OpenMC templates
| Tool | What it does |
|---|---|
list_templates |
List all available OpenMC model templates by category |
get_template |
Retrieve a specific template with all files (geometry, materials, settings) |
list_materials |
List all pre-defined material definitions across templates |
get_material |
Look up a specific material by name, get nuclide composition |
Requires OPENMC_TEMPLATES_DIR environment variable pointing to an
openmc-templates repository.
Error Code System
40+ structured error codes across 7 domains (MAT-*, SET-*, TAL-*, GEO-*,
XS-*, EFC-*, TFC-*, MOD-*, ENV-*), each with severity, trigger
description, and suggested fix. See docs/error-codes.md.
Installation
Requires Python ≥ 3.10.
# Basic install (L1 validation only, no OpenMC API required)
pip install openmc-validator
# Editable install for development
pip install -e ".[dev]"
For L2 validation (material round-trip through OpenMC API, geometry-debug):
# OpenMC is only available via conda-forge
conda create -n openmc-env -c conda-forge python=3.11 openmc
conda activate openmc-env
pip install -e ".[dev]"
Without OpenMC, L2-dependent checks degrade gracefully with ENV-W001 warnings.
Quick Start
As an MCP Server
Add to your VS Code mcp.json:
{
"servers": {
"openmc-validator": {
"command": "openmc-validator",
"args": []
}
}
}
See examples/mcp-config.json for a complete
example with OPENMC_CROSS_SECTIONS env.
Programmatic Use
from openmc_validator.validators.materials import validate_materials
from openmc_validator.schemas import MaterialSpec, NuclideSpec
spec = MaterialSpec(
name="Water",
density=1.0,
density_units="g/cm3",
nuclides=[
NuclideSpec(name="H1", fraction=2.0, fraction_type="ao"),
NuclideSpec(name="O16", fraction=1.0, fraction_type="ao"),
],
)
report = validate_materials([spec])
print(report.passed, report.issues)
Documentation
| Document | Description |
|---|---|
docs/tool-reference.md |
Full API reference for all 14 tools |
docs/error-codes.md |
Index of all validation error/warning codes |
docs/changelog.md |
Version history |
examples/agent-integration.md |
Using the server with AI coding agents |
Project Layout
src/openmc_validator/
schemas/ # pydantic input/output models
validators/ # 5 validator modules
crosschecks/ # 3 cross-check modules
converters/ # 2 converter modules
utils/ # subprocess helpers, logging
server.py # FastMCP entry point
tests/
unit/ # pure-python unit tests (no openmc binary required)
integration/ # end-to-end MCP protocol tests
fixtures/
valid/ # positive examples
invalid/ # negative examples (expected to fail validation)
Contributing
Contributions are welcome! Please see CONTRIBUTING.md for
development setup, test instructions, and pull request guidelines.
This project follows the Contributor Covenant Code of
Conduct. Security vulnerabilities should be reported as described in
SECURITY.md.
License
MIT — see LICENSE for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file openmc_validator-0.4.0.tar.gz.
File metadata
- Download URL: openmc_validator-0.4.0.tar.gz
- Upload date:
- Size: 37.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fbc47f4fbe19d4a4e622655a4b1366d642da8412b88cedf6a898b4c167c003d1
|
|
| MD5 |
b4fd0cea8772748a4fbecce9465776ee
|
|
| BLAKE2b-256 |
5f973db7f0fcc510dba9be29aab60fd6545585b560c553d7c700dc722fc7155b
|
File details
Details for the file openmc_validator-0.4.0-py3-none-any.whl.
File metadata
- Download URL: openmc_validator-0.4.0-py3-none-any.whl
- Upload date:
- Size: 45.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
07eacb17b81cabc6e553815db62c3fac95232984444172db514a166b77ca7f92
|
|
| MD5 |
84aa8e8dffec77f443c0944888ced9ef
|
|
| BLAKE2b-256 |
74539d268d0da55d2f53bc4d5c7616273f53f5136e2bdc154145180edbde858d
|