Build unbiased anatomical templates from individual images
Project description
brainglobe-template-builder
Build unbiased anatomical templates from individual images
Overview
brainglobe-template-builder
provides a streamlined process to create unbiased anatomical reference images, or templates, from multiple high-resolution brain images. While primarily designed for brain imaging, its versatility extends to any organ with available 3D digital images, especially those produced by 3D volumetric microscopy like serial two-photon tomography (STPT) and light-sheet microscopy (LSM).
brainglobe-template-builder
aims to:
- Offer an intuitive Python interface to the optimised ANTs template construction pipeline.
- Support 3D volumetric microscopy images, such as STPT and LSM.
- Generate templates compatible with the BrainGlobe ecosystem, especially the BrainGlobe Atlas API.
Warning
- Early development phase. Stay tuned
- Interface may undergo changes.
Installation
Warning
- ANTs, which we depend on, is a large package. The installation may take a while.
- ANTs is only available for Linux and macOS. If you are on Windows, you can use WSL
We recommend installing brainglobe-template-builder
within a conda or mamba environment. Instructions assume conda
usage, but mamba
/micromamba
are interchangeable.
Use the provided environment.yaml
file to create a new environment.
git clone https://github.com/brainglobe/brainglobe-template-builder
cd brainglobe-template-builder
conda env create -f environment.yaml -n template-builder
conda activate template-builder
We have called the environment template-builder
, but you can choose any name you like.
To install the latest development version of brainglobe-template-builder
,
pip install -e .[dev]
For zsh users (default shell on macOS):
pip install -e '.[dev]'
Background
On templates and atlases
In brain imaging, a template serves as a standard reference for brain anatomy, often used interchangeably with the term reference image. By aligning multiple brain images to a common template, researchers can standardize their data, facilitating easier data-sharing, cross-study comparisons, and meta-analyses.
An atlas elevates this concept by annotating a template with regions of interest, often called labels or parcellations. With an atlas, researchers can pinpoint specific brain regions and extract quantitative data from them.
The entire process, from registration to data extraction, hinges on the quality of the template image. A high-quality template can significantly improve registration accuracy and the precision of atlas label annotations.
The aim of brainglobe-template-builder
is to assist researchers in constructing such high-quality templates.
Single-subject vs population templates
Templates can be derived in two primary ways. A single-subject template is based on the brain of one individual. While this approach is simpler and may be suitable for some applications, it risks being unrepresentative, as the chosen individual might have unique anatomical features. On the other hand, population templates are constructed by aligning and averaging brain images from multiple subjects. This method captures the anatomical variability present in a population and reduces biases inherent in relying on a single subject. Population templates have become the standard in human MRI studies and are increasingly being adopted for animal brain studies.
Template construction with ANTs
brainglobe-template-builder
leverages the power of ANTs (Advanced Normalisation Tools), a widely used software suite for image registration and segmentation.
ANTs includes a template construction piepline - implemented in the antsMultivariateTemplateConstruction2.sh script - that iteratively aligns and averages multiple images to produce an unbiased population template (see this issue for details).
An optimsed implementation of the above pipeline, developed by the CoBra lab, lies at the core of the brainglobe-template-builder
's functionality.
License
⚖️ BSD 3-Clause
Package blueprint
This package layout and configuration (including pre-commit hooks and GitHub actions) have been copied from the python-cookiecutter template.
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
Built Distribution
File details
Details for the file brainglobe-template-builder-0.0.10.tar.gz
.
File metadata
- Download URL: brainglobe-template-builder-0.0.10.tar.gz
- Upload date:
- Size: 7.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f0c5972ce00fac8e9d8c72a999ba73b344504a107654476bef4f02ce44bbe5ed |
|
MD5 | 899f662b97980d5643a97d3db36aae2d |
|
BLAKE2b-256 | c177ebcfa4ccf2b85a0fe34e8374ba8b9de9deaa67a7e06aad97e1cb714ca4d5 |
File details
Details for the file brainglobe_template_builder-0.0.10-py3-none-any.whl
.
File metadata
- Download URL: brainglobe_template_builder-0.0.10-py3-none-any.whl
- Upload date:
- Size: 5.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6bbaf23b75fef027854e30bbfdfe17169b4acb3cf571947ebd3f4fc940604d0d |
|
MD5 | 740a7fbae7c8daa7df0e99c72efcea7b |
|
BLAKE2b-256 | 061a5b0e4ae479f86cb9a12dbd097ddca48cb0e6e79a7a69af5611d89e11b32e |