Skip to main content

MCP server providing pre-flight validation and post-processing tools for OpenMC inputs

Project description

openmc-validator-mcp

Tests Coverage Python License 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

openmc_validator-0.4.0.tar.gz (37.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openmc_validator-0.4.0-py3-none-any.whl (45.6 kB view details)

Uploaded Python 3

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

Hashes for openmc_validator-0.4.0.tar.gz
Algorithm Hash digest
SHA256 fbc47f4fbe19d4a4e622655a4b1366d642da8412b88cedf6a898b4c167c003d1
MD5 b4fd0cea8772748a4fbecce9465776ee
BLAKE2b-256 5f973db7f0fcc510dba9be29aab60fd6545585b560c553d7c700dc722fc7155b

See more details on using hashes here.

File details

Details for the file openmc_validator-0.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for openmc_validator-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 07eacb17b81cabc6e553815db62c3fac95232984444172db514a166b77ca7f92
MD5 84aa8e8dffec77f443c0944888ced9ef
BLAKE2b-256 74539d268d0da55d2f53bc4d5c7616273f53f5136e2bdc154145180edbde858d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page