Skip to main content

No project description provided

Project description

PeTu

Python Versions Stable Version Documentation Status tests codecov License

PeTu is a fully automated pipeline for segmenting pediatric brain tumors. It uses a 3D nnU-Net model trained on co-registered multi-parametric MRI scans, including T1c, T1n, T2w, and T2f sequences. Subsequently, the model provides segmented tumor regions, including:

  1. T2-hyperintense region (T2H) – typically encompassing solid tumor mass and associated edema.
  2. Enhancing tumor (ET) – regions with contrast uptake, indicative of active or aggressive tumor areas.
  3. Cystic component (CC) – fluid-filled regions often seen in certain pediatric tumor types.

Features

Data Requirements

PeTu is trained on pediatric brain MRI data from the Children's Hospital Zurich (Kispi), including cases with optic glioma affecting the optic nerve.

The model expects multi-parametric MRI scans (T1c, T1n, T2w, T2f) that are co-registered to T1c and then brought into SRI-24 brain atlas space.

[!IMPORTANT]
Since PeTu handles optic gliomas affecting the optic nerve, input data should be brain scans without defacing or skull-stripping to preserve critical anatomical structures. However, it may be worth experimenting with skull-stripped (BET) or defaced brain scans depending on your specific use case.

We recommend using the preprocessing package, part of the BrainLesion Suite, to design custom preprocessing pipelines tailored to your specific needs.

Installation

With a Python 3.10+ environment, you can install petu directly from PyPI:

pip install petu

Use Cases and Tutorials

A minimal example to create a segmentation could look like this:

from petu import Inferer

inferer = Inferer()

# Save NIfTI files
inferer.infer(
    t1c="path/to/t1c.nii.gz",
    fla="path/to/fla.nii.gz",
    t1="path/to/t1.nii.gz",
    t2="path/to/t2.nii.gz",
    ET_segmentation_file="example/ET.nii.gz",
    CC_segmentation_file="example/CC.nii.gz",
    T2H_segmentation_file="example/T2H.nii.gz",
)

# Or directly use pre-loaded NumPy data. (Both outputs work as well)
et, cc, t2h = inferer.infer(
    t1c=t1c_np,
    fla=fla_np,
    t1=t1_np,
    t2=t2_np,
)

[!NOTE]
If you're interested in the PeTu package, the Pediatric Segmentation may also be of interest.

Citation

Please support our development by citing the following manuscripts:

Enhancing efficiency in paediatric brain tumour segmentation using a pathologically diverse single-center clinical dataset

@misc{piffer2025enhancingefficiencypaediatricbrain,
      title={Enhancing efficiency in paediatric brain tumour segmentation using a pathologically diverse single-center clinical dataset}, 
      author={A. Piffer and J. A. Buchner and A. G. Gennari and P. Grehten and S. Sirin and E. Ross and I. Ezhov and M. Rosier and J. C. Peeken and M. Piraud and B. Menze and A. Guerreiro Stücklin and A. Jakab and F. Kofler},
      year={2025},
      eprint={2507.22152},
      archivePrefix={arXiv},
      primaryClass={cs.CV},
      url={https://arxiv.org/abs/2507.22152}, 
}

Contributing

We welcome all kinds of contributions from the community!

Reporting Bugs, Feature Requests and Questions

Please open a new issue here.

Code contributions

Nice to have you on board! Please have a look at our CONTRIBUTING.md file.

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

petu-0.0.7.tar.gz (12.8 kB view details)

Uploaded Source

Built Distribution

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

petu-0.0.7-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file petu-0.0.7.tar.gz.

File metadata

  • Download URL: petu-0.0.7.tar.gz
  • Upload date:
  • Size: 12.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for petu-0.0.7.tar.gz
Algorithm Hash digest
SHA256 0182f4206e331752f03e2bb4a4c8bd444048ff8e9786bc1aaba2d5154ec69dae
MD5 034e12107ea6f9e34c74c4a50419da88
BLAKE2b-256 93115044306bc58fe2348b01c45609852ac837c3bef8a280527806a3099866c4

See more details on using hashes here.

File details

Details for the file petu-0.0.7-py3-none-any.whl.

File metadata

  • Download URL: petu-0.0.7-py3-none-any.whl
  • Upload date:
  • Size: 13.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for petu-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 892849aee58d06c7f7c593e93b8704ad3d7cd8dbce460fee3aed0e08feff4703
MD5 1a90e00b65abcec83a91a00eae5f4b47
BLAKE2b-256 eab86bc2dd302fb7fe3e46bc279b5b81b8465b5fdc683c3f63569f12900f6799

See more details on using hashes here.

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