Thanks to visit codestin.com
Credit goes to github.com

Skip to content

ENHANCE-PET/PUMA

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Puma-logo

PUMA 1.0 β€” Multiplexed PET, Ready for Practice

PyPI version License: GPL v3 Monthly Downloads


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 πŸš€

  1. Install the package: pip install pumaz
  2. Arrange tracer folders as described in πŸ”— Workflow essentials.
  3. 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 existing uv project, run uv 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 (none by 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 -m is 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 to pumaz-failures-YYYYMMDD-HHMMSS.log.
  • Passing --convert-to-dicom creates _dicom folders inside aligned_PT/ with Processed-by-PUMA metadata.

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 [email protected].

License: GPL v3 Commercial License

Contributors πŸ™Œ

Thanks to every contributorβ€”large and smallβ€”for shaping PUMA.

W7ebere
W7ebere

πŸ“–
Manuel Pires
Manuel Pires

πŸ’» πŸ“–
Sebastian Gutschmayer
Sebastian Gutschmayer

πŸ’» πŸ“–

This project follows the all-contributors specification. Contributions of any kind are welcome.

About

Tool to multiplex different tracer PET data from the same patient.

Resources

License

Contributing

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •