Metadata-Version: 2.4
Name: brainglobe-template-builder
Version: 0.0.14
Summary: Build unbiased anatomical templates from individual images
Author-email: Niko Sirmpilatze <niko.sirbiladze@gmail.com>
License: BSD-3-Clause
Project-URL: Homepage, https://github.com/brainglobe/brainglobe-template-builder
Project-URL: Bug Tracker, https://github.com/brainglobe/brainglobe-template-builder/issues
Project-URL: Documentation, https://brainglobe.github.io/brainglobe-template-builder
Project-URL: Source Code, https://github.com/brainglobe/brainglobe-template-builder
Project-URL: User Support, https://github.com/brainglobe/brainglobe-template-builder/issues
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Operating System :: OS Independent
Classifier: License :: OSI Approved :: BSD License
Requires-Python: >=3.10.0
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: napari[all]==0.4.19
Requires-Dist: brainglobe-utils>=0.6.2
Requires-Dist: brainglobe-atlasapi>=2.0.7
Requires-Dist: napari-itk-io
Requires-Dist: loguru
Requires-Dist: antspyx
Requires-Dist: qt-niu
Provides-Extra: dev
Requires-Dist: pytest; extra == "dev"
Requires-Dist: pytest-cov; extra == "dev"
Requires-Dist: coverage; extra == "dev"
Requires-Dist: tox; extra == "dev"
Requires-Dist: black; extra == "dev"
Requires-Dist: mypy; extra == "dev"
Requires-Dist: pre-commit; extra == "dev"
Requires-Dist: ruff; extra == "dev"
Requires-Dist: setuptools_scm; extra == "dev"
Dynamic: license-file

[![DOI](https://zenodo.org/badge/700299148.svg)](https://doi.org/10.5281/zenodo.14608573)
[![License](https://img.shields.io/badge/License-BSD_3--Clause-orange.svg)](https://opensource.org/license/bsd-3-clause/)
![CI](https://img.shields.io/github/actions/workflow/status/brainglobe/brainglobe-template-builder/test_and_deploy.yml?label=CI)
[![codecov](https://codecov.io/gh/brainglobe/brainglobe-template-builder/branch/main/graph/badge.svg?token=P8CCH3TI8K)](https://codecov.io/gh/brainglobe/brainglobe-template-builder)
[![Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/charliermarsh/ruff/main/assets/badge/v0.json)](https://github.com/charliermarsh/ruff)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/python/black)
[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://github.com/pre-commit/pre-commit)

# brainglobe-template-builder
Build unbiased anatomical templates from individual images

- [Overview](#overview)
- [Installation](#installation)
  - [Pre-requisites](#pre-requisites)
  - [Create a `conda` environment](#create-a-conda-environment)
  - [Install `brainglobe-template-builder` with `pip`](#install-brainglobe-template-builder-with-pip)
- [Background](#background)
  - [On templates and atlases](#on-templates-and-atlases)
  - [Single-subject vs population templates](#single-subject-vs-population-templates)
  - [Template construction with ANTs](#template-construction-with-ants)
- [License](#license)
- [Package blueprint](#package-blueprint)

## 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](#template-construction-with-ants).
- Support 3D volumetric microscopy images, such as STPT and LSM.
- Generate templates compatible with the [BrainGlobe ecosystem](https://brainglobe.info/), especially the [BrainGlobe Atlas API](https://brainglobe.info/documentation/brainglobe-atlasapi/index.html).

> **Warning**
> - Early development phase. Stay tuned
> - Interface may undergo changes.

## Installation

### Pre-requisites

- A Unix-like operating system (Linux or MacOS)
- A `bash` shell (if you are using MacOS, where `zsh` is the default, you may need to install `bash` via Homebrew).
- A working installation of [Advanced Normalisation Tools (ANTs)](http://stnava.github.io/ANTs/). We recommend following [these instructions](https://github.com/ANTsX/ANTs/wiki/Compiling-ANTs-on-Linux-and-Mac-OS) to compile ANTs from source and to follow all recommended post-installation steps.
- The scripts from the [optimised ANTs template construction pipeline](https://github.com/CoBrALab/optimized_antsMultivariateTemplateConstruction/tree/master), which should be available in your `PATH`. According to the instructions in that repository's README, you should do the following:

  ```sh
  git clone --recursive https://github.com/CoBrALab/optimized_antsMultivariateTemplateConstruction.git
  cd optimized_antsMultivariateTemplateConstruction
  echo "export PATH=$(pwd):\$PATH" >> $HOME/.bashrc
  echo "export PATH=$(pwd)/minc-toolkit-extras:\$PATH" >> $HOME/.bashrc
  source $HOME/.bashrc  # or restart your terminal
  ```

  If you are on MacOS, you may need to replace `$HOME/.bashrc` with `$HOME/.bash_profile`.



### Create a `conda` environment
We recommend installing `brainglobe-template-builder` within a [conda](https://docs.conda.io/en/latest/) or [mamba](https://mamba.readthedocs.io/en/latest/index.html) environment. Instructions assume `conda` usage, but `mamba`/`micromamba` are interchangeable.


```sh
conda env create -n template-builder -f environment.yaml
conda activate template-builder
```

We have called the environment "template-builder", but you can choose any name you like.

This environment contains all dependencies for running the optimised ANTs template construction pipeline, but if you want to use the pre- and
post-processing funcitonalities of `brainglobe-template-builder`, you will need to also pip install the package in editable mode (see below).

### Install `brainglobe-template-builder` with `pip`


To install the latest development version of `brainglobe-template-builder`, first clone the repository:

```sh
git clone https://github.com/brainglobe/brainglobe-template-builder
cd brainglobe-template-builder
```

Then, install the package in editable mode with the following command:

```sh
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)](http://stnava.github.io/ANTs/), a widely used software suite for image registration and segmentation.

ANTs includes a template construction piepline - implemented in the [antsMultivariateTemplateConstruction2.sh](https://github.com/ANTsX/ANTs/blob/master/Scripts/antsMultivariateTemplateConstruction2.sh) script - that iteratively aligns and averages multiple images to produce an unbiased population template (see [this issue](https://github.com/ANTsX/ANTs/issues/520) for details).

An [optimsed implementation of the above pipeline](https://github.com/CoBrALab/optimized_antsMultivariateTemplateConstruction/tree/master), developed by the [CoBra lab](https://www.cobralab.ca/), lies at the core of the `brainglobe-template-builder`'s functionality.

## Seeking help or contributing
We are always happy to help users of our tools, and welcome any contributions. If you would like to get in contact with us for any reason, please see the [contact page of our website](https://brainglobe.info/contact.html).

## Citation

If you find the BrainGlobe Template Builder useful, please cite it in your work:

>Niko Sirmpilatze, Alessandro Felder, Igor Tatarnikov, viktorpm, & Adam Tyson. (2025). brainglobe/brainglobe-template-builder, Zenodo. https://doi.org/10.5281/zenodo.14608573

## License
⚖️ [BSD 3-Clause](https://opensource.org/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](https://github.com/neuroinformatics-unit/python-cookiecutter) template.
