Skip to main content

Quantitative layer analysis for renal MRI

Project description

QLayers

Python CI codecov Documentation Status Binder PyPI version Downloads Anaconda-Server Badge Anaconda-Server Badge License: GPL v3 DOI status

Quantitative layer based analysis for renal magnetic resonance imaging.

Installation

The easiest way to install qlayersis via pip:

pip install qlayers

or if you're a conda user:

conda install qlayers -c conda-forge

Alternatively, you can install qlayersfrom source in pips editable mode:

git clone https://github.com/alexdaniel654/qlayers.git
cd qlayers
pip install -e .

Quick Start

Documentation for qlayers can be found here. This includes a full API reference, tutorials and examples of how to use qlayers to generate layers and apply them to quantitative maps. The tutorials can also be run through binder if you want to have a go with qlayers without installing anything. However, if you want to get started on your machine with the minimum lines of code, the snippet of code below should get you going.

import nibabel as nib
from qlayers import QLayers

mask_img = nib.load("kidney_mask.nii.gz")
t2star_img = nib.load("t2star_map.nii.gz")

qlayers = QLayers(mask_img, pelvis_dist=10)
qlayers.add_map(t2star_img, "t2star")

df = qlayers.get_df(format="wide")
df.groupby("layer").median().loc[:, "t2star"].plot(
    xlabel="Depth (mm)", ylabel="$T_2^*$ (ms)"
)

Theory

Background

The premise behind qlayers was first proposed by Pruijm et al and is based on the idea to segment the kidney into layers based on each voxels distance from the surface of the kidney. The average of a quantitative parameter can be calculated for each layer producing profiles of, for example, T2* with depth. The outer and inner layers are analogous to the cortex and medulla respectively while the gradient of the profile is representative of the cortico-medullary difference. qlayers extends this idea by allowing the user to define layers based on a 3D mask and apply the layer to any quantitative parameter.

Generating Layers

Layers are generated via the process outlined in the figure below.

a i. Shows the mask thats input to the QLayers class. This mask then has any holes smaller than fill_ml filled as these are most likely cysts and therefore not cortical surfaces, a ii. The mask is then converted from a voxel representation to a mesh surface representation, b i, this mesh is then smoothed because anatomical scans of the kidneys often have a low through-plane resolution, b ii. The distance from the centre of each voxel in the kidneys to the closest surface on the mesh is then calculated, b iii. As the tissue adjacent to the renal pelvis is not representative of the medulla, this is automatically excluded from the resulting depth maps. Fist the pelvis is automatically segmented, c i, and the distance from each voxel in the kidneys to the pelvis calculated as above, c ii. Voxels closer than a specified threshold pelvis_dist are then excluded from the depth maps, c iii. Finally, a layer image is generated by quantising the depth map to a desired layer thickness, typically 1 mm although shown with 5 mm layers here for illustrative purposes, d.

Applying Layers to Quantitative Data

If the space parameter of the QLayers object is set to layers, when a quantitative map is added to the QLayers object, it is resampled to the same resolution and orientation as the layers. If the space parameter is set to map then the layers are resampled to the resolution and orientation of the quantitative map. In both cases, Pandas DataFrames can be generated with the quantitative value, depth and layer each voxel is in. These DataFrames can then be used for further calculations such as generating profiles or linear regressions to explore the cortico-medullary difference. Some example voxels are shown in the table below.

Depth Layer T2* R2*
0 0 57 17.6
13.2 14 35.5 28.2
10.2 11 60.9 16.4
3.05 4 51.6 19.4
9.33 10 42.8 23.3
10.4 11 29.6 33.8
8.63 9 37.5 26.7
6.66 7 49.2 20.3
19.8 20 42.8 23.3
12.1 13 39.4 25.4

Citing 3DQLayers

If you have used 3DQLayers in your research, please cite the following conference abstract:

Daniel AJ, Francis ST. Volumetric Layer Based Analysis for Quantitative Renal MRI. In: Proc. Intl. Soc. Mag. Reson. Med. 33. Singapore; 2024:2748.

Alternatively, if you want to cite a specific version of this software, each release has an individual DOI on Zenodo, the DOI for the latest release can be found here.

Contributing

We welcome contributions to QLayers, a full contributing guide can be found here.

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

qlayers-1.0.0.tar.gz (32.5 kB view details)

Uploaded Source

Built Distribution

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

qlayers-1.0.0-py3-none-any.whl (32.4 kB view details)

Uploaded Python 3

File details

Details for the file qlayers-1.0.0.tar.gz.

File metadata

  • Download URL: qlayers-1.0.0.tar.gz
  • Upload date:
  • Size: 32.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for qlayers-1.0.0.tar.gz
Algorithm Hash digest
SHA256 4d2760c7f99261128384e4814d8b00bc5f9b6f2edd80f46116eccf25f9e792e9
MD5 fd24fbbccc19184e5a82838c23f8e387
BLAKE2b-256 33d021e62ef69348e7eb29fd36c306308e4d0a007433719a65db360abb21aa0e

See more details on using hashes here.

Provenance

The following attestation bundles were made for qlayers-1.0.0.tar.gz:

Publisher: new_release.yml on alexdaniel654/qlayers

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file qlayers-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: qlayers-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 32.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for qlayers-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 314974fed10244909e8652b6a56b2239c4f86a51dee548893620704c9eff4321
MD5 8e0b4e66b1879a50a2672928264c81a3
BLAKE2b-256 35299d02d765ad033a4491b2b6c118343cbf2670996234cb4fd30fc170382be8

See more details on using hashes here.

Provenance

The following attestation bundles were made for qlayers-1.0.0-py3-none-any.whl:

Publisher: new_release.yml on alexdaniel654/qlayers

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