dicompare is an open-source, vendor-independent tool for automated validation and comparison of MRI acquisition protocols using DICOM metadata. It enables researchers to determine whether imaging protocols implemented at different sites are truly equivalent, similar, or meaningfully different — a task that is currently manual, error-prone, and often infeasible in large, multi-site studies.
dicompare is a collaboration between the Neurodesk and Brainlife groups.
This repository contains the core Python package, which provides a command-line interface (CLI) and Python API for building, validating, and matching protocol schemas.
For the visual web and desktop application, see dicompare-web or use the live app at dicompare.neurodesk.org or brainlife.io/dicompare.
dicompare performs structured comparisons of DICOM files to evaluate whether imaging protocols match a target reference or schema. It works directly with DICOM metadata and does not depend on scanner manufacturer formats or proprietary exam card systems.
dicompare supports validation against:
- Reference sessions — JSON schema files generated from a reference MRI scanning session
- Domain guidelines — Flexible guidelines for specific domains (e.g. QSM, ASL, MS/CMSC)
- Landmark studies — A bundled schema library with protocols from HCP, ABCD, UK Biobank, and more
pip install dicompareAlternatively, use the web app or desktop app for a visual interface with no installation required.
The package provides a unified dicompare command with three subcommands:
dicompare build: Generate a JSON schema from a reference DICOM sessiondicompare check: Validate DICOM sessions against a JSON schemadicompare match: Find best-matching schemas for input DICOM data from a library
dicompare build /path/to/dicom/session schema.jsonThis creates a JSON schema describing the session based on default reference fields present in the data.
dicompare check /path/to/dicom/session schema.jsonThe tool will output an acquisition mapping summary with confidence scores, followed by a compliance report indicating deviations from the schema. Use --auto-yes or -y to skip interactive mapping prompts:
dicompare check /path/to/dicom/session schema.json --auto-yesSave the compliance report to a JSON file by specifying a report path:
dicompare check /path/to/dicom/session schema.json compliance_report.jsonSearch across a schema library to identify which protocols best match your DICOM data:
# Search the bundled schema library
dicompare match /path/to/dicom/session --library
# Search custom schema files or directories
dicompare match /path/to/dicom/session --schemas /path/to/schemas/
# Combine bundled library and custom schemas
dicompare match /path/to/dicom/session --library --schemas /path/to/custom_schema.jsonThis compares each input acquisition against every acquisition in the loaded schemas, ranking matches by compliance score. Options:
--library: Include the bundled schema library (HCP, ABCD, UK Biobank, and more)--schemas PATH [PATH ...]: Path(s) to schema files or directories containing schemas--top N: Number of top matches to show per acquisition (default: 5)--report PATH: Save the match report to a JSON file
The dicompare package provides a comprehensive Python API for programmatic schema generation, validation, and DICOM processing.
Load a DICOM session:
from dicompare import load_dicom_session
session_df = load_dicom_session(
session_dir="/path/to/dicom/session",
show_progress=True
)Load individual DICOM files:
from dicompare import load_dicom
dicom_data = load_dicom(
dicom_paths=["/path/to/file1.dcm", "/path/to/file2.dcm"],
show_progress=True
)Load Siemens .pro files:
from dicompare import load_pro_session
pro_session = load_pro_session(
session_dir="/path/to/pro/files",
show_progress=True
)from dicompare import load_dicom_session, build_schema, make_json_serializable
from dicompare.config import DEFAULT_SETTINGS_FIELDS
import json
# Load the reference session
session_df = load_dicom_session(
session_dir="/path/to/dicom/session",
show_progress=True
)
# Build the schema
json_schema = build_schema(session_df)
# Save the schema
serializable_schema = make_json_serializable(json_schema)
with open("schema.json", "w") as f:
json.dump(serializable_schema, f, indent=4)from dicompare import (
load_schema,
load_dicom_session,
check_acquisition_compliance,
map_to_json_reference,
assign_acquisition_and_run_numbers
)
# Load the JSON schema
reference_fields, json_schema, validation_rules = load_schema(json_schema_path="schema.json")
# Load the input session
in_session = load_dicom_session(
session_dir="/path/to/dicom/session",
show_progress=True
)
# Assign acquisition and run numbers
in_session = assign_acquisition_and_run_numbers(in_session)
# Map acquisitions to schema
session_map = map_to_json_reference(in_session, json_schema)
# Check compliance for each acquisition
compliance_summary = []
for ref_acq_name, schema_acq in json_schema["acquisitions"].items():
if ref_acq_name not in session_map:
continue
input_acq_name = session_map[ref_acq_name]
acq_validation_rules = validation_rules.get(ref_acq_name) if validation_rules else None
results = check_acquisition_compliance(
in_session,
schema_acq,
acquisition_name=input_acq_name,
validation_rules=acq_validation_rules
)
compliance_summary.extend(results)
# Display results
for entry in compliance_summary:
print(entry)Assign acquisition and run numbers:
from dicompare import assign_acquisition_and_run_numbers
session_df = assign_acquisition_and_run_numbers(session_df)Get DICOM tag information:
from dicompare import get_tag_info, get_all_tags_in_dataset
# Get info about a specific tag
tag_info = get_tag_info("EchoTime")
print(tag_info) # {'tag': '(0018,0081)', 'name': 'Echo Time', 'type': 'float'}
# Get all tags in a dataset
all_tags = get_all_tags_in_dataset(dicom_metadata)- dicompare Web & Desktop App — Visual interface for building, viewing, and validating protocol schemas
- Live App (Neurodesk)
- Live App (Brainlife)
- Report Issues
