Skip to main content

Meta-package: installs the MIDAS Python pipeline (FF/NF/PF HEDM, calibration, peakfit, integration, transforms, ODF, stress).

Project description

midas-suite

A meta-package that installs the MIDAS Python pipeline in a single command.

pip install midas-suite

This pulls in the currently published MIDAS sub-packages — the FF/NF HEDM analysis chain, calibration, peak fitting, radial integration, forward model, indexing, transforms, grain processing, and stress/strain analysis.

midas-suite itself contains no scientific code. It's a thin meta-package whose only job is to declare the sub-packages as dependencies so users don't have to install them one at a time.

What you get

pip install midas-suite installs 19 sub-packages (as of v0.3.1):

Top-level orchestrators (the entry points most users want):

Sub-package Role
midas-pipeline Unified FF + PF orchestrator (--scan-mode {ff,pf,auto}). End-to-end from raw data through grain reconstruction; single source for both scan modes.
midas-ff-pipeline Independent FF-HEDM workflow orchestrator (1-N detectors). Co-exists with midas-pipeline; same kernels under the hood.
midas-nf-pipeline Pure-Python NF-HEDM pipeline orchestrator (single + multi-resolution, multi-layer). Drop-in for nf_MIDAS.py / nf_MIDAS_Multiple_Resolutions.py.
midas-parsl-configs Bundled + user-extensible Parsl configs for running MIDAS pipelines on laptops, workstations, clusters.

FF-HEDM building blocks:

Sub-package Role
midas-peakfit Differentiable PyTorch peak fitting for FF-HEDM Zarr
midas-transforms FF-HEDM peak transforms (merge / radius / fit-setup / save-bin)
midas-index Pure-Python/PyTorch FF-HEDM indexer (drop-in for IndexerOMP)
midas-fit-grain Single/multi-grain refiner
midas-process-grains FF-HEDM grain-determination + strain pipeline

NF-HEDM building blocks:

Sub-package Role
midas-nf-preprocess NF-HEDM preprocessing (hex grid, tomo filter, spot prediction)
midas-nf-fitorientation NF-HEDM orientation/calibration fitter

Shared foundations:

Sub-package Role
midas-stress Crystallographic stress/strain analysis (Voigt-Mandel, Cij inversion, slip/Schmid/Taylor)
midas-params Parameter-file registry, validator, wizard for FF/NF/PF/RI
midas-hkls Pure-Python crystallography & HKL list generator (sginfo-equivalent)
midas-diffract End-to-end differentiable HEDM forward model (FF + NF + pf-HEDM)
midas-integrate Pure-Python radial integration (DetectorMapper + CSR + streaming server)
midas-integrate-v2 Differentiable, autograd-clean integration kernels (torch); companion to v1
midas-calibrate Native Python/Torch detector geometry calibration (LM-based)
midas-calibrate-v2 Torch-native Bayesian/Laplace calibration (LM + L-BFGS); companion to v1

You then import midas_stress, import midas_diffract, etc. directly — each sub-package retains its own API. midas-suite does not re-export them.

To check what was installed:

import midas_suite
print(midas_suite.installed())

Modality bundles

If you don't want everything, the optional extras let you pick a workflow:

pip install "midas-suite[ff]"        # FF-HEDM stack
pip install "midas-suite[pf]"        # PF-HEDM stack (scanning / point-focus)
pip install "midas-suite[nf]"        # NF-HEDM stack
pip install "midas-suite[calib]"     # v1 calibration + integration
pip install "midas-suite[calib-v2]"  # v2 (torch differentiable) calibration + integration
pip install "midas-suite[ff,plots]"
Extra What it pulls
ff midas-ff-pipeline (transitively pulls hkls, peakfit, transforms, index, fit-grain, process-grains, diffract, parsl-configs) + stress, params, calibrate, integrate
pf midas-pipeline[fast] (numba) + stress, params, calibrate, integrate (scan-mode pf pulls index + fit-grain + transforms + stress transitively)
nf midas-nf-pipeline (transitively pulls hkls, stress, nf-preprocess, nf-fitorientation) + params
calib hkls, integrate, peakfit, calibrate (v1 C-backed stack)
calib-v2 hkls, calibrate-v2, integrate-v2, peakfit (torch differentiable stack)
plots matplotlib (for sub-package plotting helpers)

What pip install midas-suite does NOT include

Be aware:

  • The MIDAS C executables (IndexerOMP, ProcessGrains, MakeDiffrSpots, …) still need to be built from source via cmake --build . from the MIDAS monorepo. The pure-Python pipeline (calibration → integration → indexing → grain processing) is now end-to-end in PyTorch and does not require them.
  • The PyQt FF viewer GUI needs PyQt5 or PySide6 installed separately. Not declared here because it's optional and platform-sensitive.
  • Optional crystallography backends for midas-hkls: install gemmi or pycifrw separately for CIF I/O via pip install midas-hkls[cif].
  • GPU acceleration is a runtime backend selected by PyTorch device string. CUDA/MPS just work if your torch install supports them; no separate *-gpu package needed.
  • In-tree-only packages (midas-grain-odf, midas-joint-ff-calibrate, midas-pf-odf, midas-pink, midas-propagate, midas-uq) are intentionally not published to PyPI — they live in the monorepo for ongoing research and only build / install from a local checkout.

Cross-platform

All MIDAS Python sub-packages are pure Python or PyTorch and ship as py3-none-any wheels. Tested install paths: Linux, macOS, Windows. See packages/RELEASE_READINESS.md for the detailed cross-platform readiness matrix.

Versioning

midas-suite versions are independent of the sub-package versions. The rule:

Change Bump
Floors tightened (no new sub-package added) patch (0.1.00.1.1)
New sub-package added to the dep list minor (0.1.00.2.0)
Backwards-incompatible reorganisation of bundles major (0.x.y1.0.0)

Floors are pinned with >=, never ==, so a sub-package patch release doesn't break midas-suite.

Releasing a new version

See RELEASING.md for the full release flow. TL;DR:

cd packages/midas_suite
./release.sh 0.3.2 --publish

License

BSD-3-Clause, same as the sub-packages.

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_suite-0.3.5.tar.gz (6.5 kB view details)

Uploaded Source

Built Distribution

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

midas_suite-0.3.5-py3-none-any.whl (5.4 kB view details)

Uploaded Python 3

File details

Details for the file midas_suite-0.3.5.tar.gz.

File metadata

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

File hashes

Hashes for midas_suite-0.3.5.tar.gz
Algorithm Hash digest
SHA256 7547472779457422cca27c9f0cc13681952fd207a2bbf009b53b05d750aeaeaa
MD5 0630ebac655d4563d7ed6e4dfaac722b
BLAKE2b-256 19b4f66f4b8884b1bfae50423fa6a5d5c9fb4ad8087eeaa60ecbe4f20709b14c

See more details on using hashes here.

Provenance

The following attestation bundles were made for midas_suite-0.3.5.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_suite-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: midas_suite-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 5.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for midas_suite-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 cd67ad5be2aaaf89c4f28f4238f62c8c7c7e2c3e497b4f981af56b34bfd320be
MD5 986cc34028d7627192bf399f57363e3c
BLAKE2b-256 79d1ff099ddc7dd70319c6cbe50fc831dc34ef035cde70c785f9d8d70e3add24

See more details on using hashes here.

Provenance

The following attestation bundles were made for midas_suite-0.3.5-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