mach#

Note

🚧 This documentation is under construction.

mach 5 beamformer#

PyPI Python License Actions status

An ultrafast CUDA-accelerated ultrasound beamformer for Python users. Developed at Forest Neurotech.

Benchmark Results

Benchmark: Beamforming PyMUST’s rotating-disk Doppler dataset at 0.86 trillion points per second (5x the speed of sound).

⚠️ Alpha Release

This library is currently under active development and is released as an alpha version. The primary goal of this release is to collect community feedback.

Highlights#

  • ⚑ Ultra-fast beamforming: ~10x faster than prior state-of-the-art

  • πŸš€ GPU-accelerated: Leverages CUDA for maximum performance on NVIDIA GPUs

  • 🎯 Optimized for research: Designed for functional ultrasound imaging (fUSI) and other ultrafast, high-channel-count, or volumetric-ensemble imaging

  • 🐍 Python bindings: Zero-copy integration with CuPy, and JAX arrays via nanobind. NumPy support included.

  • πŸ”¬ Validated: Matches vbeam and PyMUST outputs

Installation#

Build from source#

make compile

Build prerequisites:

  • Linux

  • make

  • uv >= 0.6.10

  • gcc >= 8

  • nvcc >= 11.0

Examples#

Try our examples:

If you don’t have a CUDA-enabled GPU, you can download the notebook from the docs and open in Google Colab (select a GPU instance).

Contributing#

We welcome contributions! Please see CONTRIBUTING.md for guidelines.

Roadmap#

Alpha release (v0.0.Z)#

  • βœ… Single-wave transmissions (plane wave, focused, diverging)

  • βœ… Linear interpolation beamforming

  • βœ… Allow NumPy/CuPy/JAX/PyTorch inputs through Array API

  • βœ… Comprehensive error handling

  • βœ… PyPI packaging and distribution

Experimental features#

  • Coherent compounding

Tentative Future Plans#

  • Additional interpolation methods (spline, sinc)

  • Additional apodization windows

See the project page for our up-to-date roadmap. We welcome feature requests!

Acknowledgments#

mach builds upon the excellent work of the ultrasound imaging community:

  • vbeam - For educational examples and validation benchmarks

  • PyMUST / PICMUS - For standardized evaluation datasets

  • Community contributors - Gev and Qi for CUDA optimization guidance

Citation#

If you use mach in your research, please cite:

@software{mach,
  title={mach: Ultra-fast GPU-accelerated ultrasound beamforming},
  author={Guan, Charles and Rockhill, Alex and Pinton, Gianmarco},
  organization={Forest Neurotech},
  year={2025},
  url={https://github.com/Forest-Neurotech/mach}
}

Examples:

Performance: