Skip to main content

End-to-end pure-Python FF-HEDM workflow orchestrator (1-N detectors)

Project description

midas-ff-pipeline

End-to-end pure-Python FF-HEDM workflow. Drives all the midas-* sibling packages so a single command — or a single notebook — takes raw detector zarr inputs through to Grains.csv with no C binaries on the path.

Status: 0.1.0 (initial public). Single-detector path is fully exercised; 1-N multi-detector pinwheel layout is supported via the existing midas_diffract.HEDMForwardModel(multi_mode="panel") backend.

What it does

For each FF-HEDM layer:

Stage Sibling package
HKL list generation midas-hkls
Peak finding (per detector) midas-peakfit (peakfit_torch)
Overlap merge midas-peakfit (midas-merge-peaks)
Calc radius midas-peakfit (midas-calc-radius)
Detector transforms midas-transforms (midas-fit-setup)
Cross-detector merge midas-ff-pipeline (this package)
Binning midas-transforms (midas-bin-data)
Indexing midas-index
Grain refinement midas-fit-grain
Grain consolidation + strain midas-process-grains

The cross-detector merge is the only piece this package implements itself. It concatenates per-detector spot lists and emits a side-car Spots_det.bin mapping each obs spot to its source detector (det_id), keeping the main Spots.bin byte-compatible with the C IndexerOMP so any cross-pipeline parity test still works.

Quick start

CLI

midas-ff-pipeline run \
    --params /path/to/Parameters.txt \
    --result /path/to/run_dir \
    --layers 1-1 \
    --device cuda --dtype float64

Library API

from midas_ff_pipeline import Pipeline, PipelineConfig

pipe = Pipeline(
    config=PipelineConfig(
        result_dir="/path/to/run_dir",
        params_file="/path/to/Parameters.txt",
        n_cpus=16,
        device="cuda",
        dtype="float64",
    ),
)
pipe.run()
print(pipe.layer_result.n_grains)

Notebook

See notebooks/01_smoke_walkthrough.ipynb for the simplest end-to-end demo (synthetic 50-grain Au, single detector). 02_stage_diagnostics.ipynb adds per-stage plots between cells. 03_multi_detector_demo.ipynb runs the four-detector pinwheel layout against a synthetic ground truth.

Multi-detector

from midas_ff_pipeline import Pipeline, PipelineConfig, DetectorConfig

detectors = DetectorConfig.load_many("detectors.json")
pipe = Pipeline(
    config=PipelineConfig(
        result_dir="/path/to/multi_det_run",
        params_file="/path/to/Parameters_4det.txt",
        n_cpus=16, device="cuda", dtype="float64",
    ),
    detectors=detectors,
)
pipe.run()

detectors.json:

[
  {"det_id": 1, "zarr_path": "det1.MIDAS.zip", "lsd": 1000000.0,
   "y_bc": 1024.0, "z_bc": 1024.0, "tx": 0.0, "ty": 0.0, "tz": 0.0,
   "p_distortion": [0,0,0,0,0,0,0,0,0,0,0]},
  {"det_id": 2, "zarr_path": "det2.MIDAS.zip", "lsd": 1005000.0, ...},
  {"det_id": 3, "zarr_path": "det3.MIDAS.zip", "lsd": 1010000.0, ...},
  {"det_id": 4, "zarr_path": "det4.MIDAS.zip", "lsd": 1015000.0, ...}
]

If detectors.json is absent the pipeline falls back to DetParams 1/DetParams 2/... rows in Parameters.txt (same convention as FitMultipleGrains.c).

Resume

Each layer's directory holds a midas_state.h5 provenance ledger. --resume auto skips stages whose recorded input/output hashes match the current files. --resume from:indexing deletes the indexing-stage outputs and resumes from there. midas-ff-pipeline status prints the per-stage state for a given run dir.

Relationship to ff_MIDAS.py

FF_HEDM/workflows/ff_MIDAS.py is the historical workflow that shells out to a mix of C binaries and torch tools. midas-ff-pipeline is its pure-Python successor: same stages, no C binaries, multi-detector aware out of the box. ff_MIDAS.py is left untouched for users still on the mixed path.

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

midas_ff_pipeline-0.1.0.tar.gz (72.3 kB view details)

Uploaded Source

Built Distribution

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

midas_ff_pipeline-0.1.0-py3-none-any.whl (79.9 kB view details)

Uploaded Python 3

File details

Details for the file midas_ff_pipeline-0.1.0.tar.gz.

File metadata

  • Download URL: midas_ff_pipeline-0.1.0.tar.gz
  • Upload date:
  • Size: 72.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for midas_ff_pipeline-0.1.0.tar.gz
Algorithm Hash digest
SHA256 8e7fd78102879ef123e21bc34866a5baaaee914273bf9c25e4a980f91bb02290
MD5 c1e7932f57956083ac048a949c6b8cf7
BLAKE2b-256 0d1bcd09ec6972f7bb2ac43d9cef17990e2840ca12bf24f0984445eea7273618

See more details on using hashes here.

Provenance

The following attestation bundles were made for midas_ff_pipeline-0.1.0.tar.gz:

Publisher: python-packages.yml on marinerhemant/MIDAS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file midas_ff_pipeline-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for midas_ff_pipeline-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 91cbec2bcbfb24ad1d9f3fb9d8f6964cf05bfaa80cd754b08f4eef5c0838b129
MD5 1005df1edc70483e80eb3b0f2ba54fb5
BLAKE2b-256 ec51acd3eb045e202ef32dfbfe2fcbeff5bb533f71433bd92d4d0d7f263de6c0

See more details on using hashes here.

Provenance

The following attestation bundles were made for midas_ff_pipeline-0.1.0-py3-none-any.whl:

Publisher: python-packages.yml on marinerhemant/MIDAS

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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