PUMA (PET Universal Multi-tracer Aligner) aligns multi-tracer PET/CT studies using advanced diffeomorphic imaging.
Project description
PUMA 1.0 — Multiplexed PET, Ready for Practice
PUMA turns serial PET/CT acquisitions into a single, context-rich view. The pipeline multiplexes tracer studies, aligns anatomy, and produces consistent reporting assets so clinicians and researchers can read more in less time.
Why teams choose PUMA 🧠
- Multiplexed insight – Fuse several tracer volumes into colour-encoded composites without sacrificing quantitative context.
- Trusted accuracy – nnU-Net driven segmentations and diffeomorphic registration keep tumour boundaries and uptake values reliable.
- Workflow friendly – One CLI coordinates preprocessing, registration, blending, and export, keeping radiologists and physicists in sync.
- Platform agnostic – Linux, Windows, and macOS (including Apple Silicon) run the same wheel; PyTorch’s upstream MPS backend covers 3D convolutions with no custom build.
Quick start 🚀
- Install the package:
pip install pumaz - Arrange tracer folders as described in 🔗 Workflow essentials.
- Launch a run:
pumaz -d /path/to/patient -m -ir arms,legs,head
PUMA aligns each tracer, multiplexes RGB composites when requested, and writes results to a timestamped PUMAZ-v<version>-YYYY-MM-DD-HH-MM-SS folder beside your subject data. A run log (pumaz-v.<clock>.log) is saved in the working directory.
Installation 🛠️
- Using uv (recommended)
curl -Ls https://astral.sh/uv/install.sh | sh # install uv if needed uv venv .venv source .venv/bin/activate uv pip install pumaz
To add PUMA to an existinguvproject, runuv add pumaz. - Using pip
pip install pumaz
- From source (development work)
git clone https://github.com/LalithShiyam/PUMA.git cd PUMA uv pip install -e .
Use Python 3.10+ and create a virtual environment when possible.
Usage essentials 🧾
Retrieve the full command reference with:
pumaz --help
Common flags:
-d /path/to/patient– Root directory that contains one subfolder per tracer.-ir arms,legs– Skip specified body regions during registration (noneby default).-m– Produce multiplexed RGB composites alongside individual tracer outputs.-cm Tracer1:R,...– Assign explicit colour channels to each tracer (mutually exclusive with-cs).-cs– Interactively choose channel assignments when-mis enabled.-c2d– Convert aligned NIfTI volumes back to DICOM.
Workflow essentials 🧬
Organise every patient or study with one directory per tracer; each tracer must contain PET and CT data as DICOM folders or NIfTI files prefixed by modality:
Parent_Directory/
├── Tracer1/
│ ├── PT_series.nii.gz # or PET DICOM directory
│ └── CT_series.nii.gz # or CT DICOM directory
├── Tracer2/
│ ├── PT_series.nii.gz
│ └── CT_series.nii.gz
└── Tracer3/
├── PT_series.nii.gz
└── CT_series.nii.gz
Ensure PET/CT pairs are spatially corresponding within each tracer directory for best results.
Output artefacts 📁
Each run emits a timestamped workspace (PUMAZ-v<version>-<timestamp>) alongside your tracer folders:
| Path | Contents |
|---|---|
CT/ |
Resliced CT volumes staged for registration |
PT/ |
Resliced PET volumes indexed by tracer order |
aligned_CT/ |
Final aligned CT volumes |
aligned_MASK/ |
Aligned segmentation masks |
aligned_PT/ |
Aligned PET volumes; includes RGB-composite.nii.gz and grayscale-composite.nii.gz when multiplexing |
body_masks/ |
Body-region masks with ignored labels removed |
puma_masks/ |
24-label PUMA segmentations |
transforms/ |
Affine and warp fields for every tracer |
- Logs live alongside the run (
pumaz-v.<clock>.log); batch failures append topumaz-failures-YYYYMMDD-HHMMSS.log. - Passing
--convert-to-dicomcreates_dicomfolders insidealigned_PT/withProcessed-by-PUMAmetadata.
Platform support 💻
PUMA runs on CPU or GPU across major operating systems. PyTorch ≥2.1 ships native Metal (MPS) support, so Apple Silicon users can install the standard wheel—no custom forks or 3D-convolution patches required.
Benchmarks 📊
Performance benchmarks and reference datasets are in preparation. If you want early numbers or to contribute your own results, open an issue.
Support and roadmap 🤝
- File bugs or feature requests on the 🔗 issue tracker.
- Commercial support and integration services are available via 🔗 Zenta Solutions.
- The near-term roadmap includes automated QA scoring, longitudinal dashboards, and cloud-friendly batching.
Citation 📚
If you use PUMA in your research, please cite:
L.K. Shiyam Sundar, S. Gutschmayer, M. Pires, et al.
“Fully Automated Image-Based Multiplexing of Serial PET/CT Imaging for Facilitating Comprehensive Disease Phenotyping.”
Journal of Nuclear Medicine, September 2025. doi:10.2967/jnumed.125.269688
The QIMP “Z” signature ✨
Every QIMP library carries a trailing “z” to signal curiosity for what comes next. It nods to the unknown variable in science and to our commitment to keep stretching medical imaging beyond the expected. When you install pumaz, you join that exploration.
License ⚖️
The open-source edition ships under GPLv3. For commercial licensing or OEM partnerships, contact lalith.shiyam@zenta.solutions.
Contributors 🙌
Thanks to every contributor—large and small—for shaping PUMA.
W7ebere 📖 |
Manuel Pires 💻 📖 |
Sebastian Gutschmayer 💻 📖 |
This project follows the all-contributors specification. Contributions of any kind are welcome.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pumaz-1.8.11.tar.gz.
File metadata
- Download URL: pumaz-1.8.11.tar.gz
- Upload date:
- Size: 82.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8c89a91cd61f1e3aecd0985a4415fb1c2143a8f9912d07e183795ba7bc041cdf
|
|
| MD5 |
1dd1791086f4b080ab97851431f78a60
|
|
| BLAKE2b-256 |
e342c3c42d636117c59bdee756798d3c01779ea461aa333972e5d77a3e146e58
|
File details
Details for the file pumaz-1.8.11-py3-none-any.whl.
File metadata
- Download URL: pumaz-1.8.11-py3-none-any.whl
- Upload date:
- Size: 72.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
830feb17fce6f62497677e592e5882da368333e82c1bf98c96fb077d0346da71
|
|
| MD5 |
4c2615a4024afdd0ebdf1d1dcc9a707f
|
|
| BLAKE2b-256 |
bcb5ae361349f833b35a7637ad1bd383a9eb62517ff73f85b3373311a3788182
|