Skip to main content

Biological particle tracking with Python

Project description

ByoTrack

Lint and Test Documentation Status

pipeline

ByoTrack is a Python library that enables tracking of biological object in videos (2D or 3D).

Many bioimage informatics tools already implement their own tracking tools (Icy [1], ImageJ [6], ...) but most of them are implemented in Java which makes it difficult for non-Java developers to experiment with the code. It is also difficult to integrate deep learning algorithms (mainly developed in Python) into these software.

We provide a unified python API for tracking that can be easily extended with new (and old) algorithms. We also provide implementations of well-known algorithms following our API. ByoTrack is based on numpy, pytorch and numba allowing fast computations with the access to the full python ecosystem.

Overview:

  • Video
    • Able to read most classical format (supported by opencv) + tiff
    • Supports 2D and 3D.
  • Particle Tracking
    • MultiStepTracker (Detect / Link / Refine)
  • Particle Detections
    • Wavelet Detector [2] (Similar as the one in Icy [1] but coded in pytorch)
    • Stardist [3] (Inference only. Training should be done with the official implementation)
  • Particle Linking
    • Nearest neighbors using optical flow, kalman filters or both (KOFT) [9] (with optional adaptive gating [12])
    • EMHT [4] (Wraps the implementation in Icy [1], requires Icy to be installed)
    • u-track / TrackMate [7] (Wraps the TrackMate [6, 8] implementation in ImageJ/Fiji, requires Fiji to be installed)
  • Tracks Refining
    • Cleaning
    • EMC2 [5]: Track stitching (gap closing)
    • Interpolate missing positions
  • Optical Flow
    • Support for Open-CV and Scikit-Image algorithms. Can be used for particle linking, track stitching and interpolations.
  • Datasets
    • Supports for loading annotations/video from datasets.
    • Cell Tracking Challenge (CTC) [10]
    • SINETRA [11]
  • Metrics:
    • Support for some segmentation/detection/tracking metrics. Currently, only CTC metrics are provided. More to come...

Install

$ pip install byotrack

Some implementations require additional dependencies that are not installed with the library, to use them you need to install their dependencies on your own. Here is the complete list:

For visualization, with byotrack.visualize module you need to install matplotlib.

Getting started

import byotrack

# Load some specific implementations
from byotrack.implementation.detector.wavelet import WaveletDetector
from byotrack.implementation.linker.icy_emht import IcyEMHTLinker
from byotrack.implementation.refiner.cleaner import Cleaner
from byotrack.implementation.refiner.stitching import EMC2Stitcher

# Read a video from a path, normalize and aggregate channels
video = byotrack.Video(video_path)
transform_config = VideoTransformConfig(aggregate=True, normalize=True, q_min=0.01, q_max=0.999)
video.set_transform(transform_config)

# Create a multi step tracker
## First the detector
## Smaller scale <=> search for smaller spots
## The noise threshold is linear with k. If you increase it, you will retrieve less spots.
detector = WaveletDetector(scale=1, k=3.0, min_area=5)

## Second the linker
## Hyperparameters are automatically chosen by Icy
linker = IcyEMHTLinker(icy_path)

## Finally refiners
## If needed you can add Cleaning and Stitching operations
refiners = []
if True:
    refiners.append(Cleaner(5, 3.5))  # Split tracks on position jumps and drop small ones
    refiners.append(EMC2Stitcher())  # Merge tracks if they track the same particle

tracker = byotrack.MultiStepTracker(detector, linker, refiners)

# Run the tracker
tracks = tracker.run(video)

# Save tracks
byotrack.Track.save(tracks, output_path)

Please refer to the official documentation.

Cell Tracking Challenge

Our submission to the Cell Linking Benchmark of the Cell Tracking Challenge can be found in the examples/ctc folder.

Contribute

In coming...

Cite us

@article{hanson2024automatic,
  title={Automatic monitoring of neural activity with single-cell resolution in behaving Hydra},
  author={Hanson, Alison and Reme, Raphael and Telerman, Noah and Yamamoto, Wataru and Olivo-Marin, Jean-Christophe and Lagache, Thibault and Yuste, Rafael},
  journal={Scientific Reports},
  volume={14},
  number={1},
  pages={5083},
  year={2024},
  publisher={Nature Publishing Group UK London}
}

References

  • [1] F. De Chaumont, S. Dallongeville, N. Chenouard, et al., "Icy: an open bioimage informatics platform for extended reproducible research", Nature methods, vol. 9, no. 7, pp. 690–696, 2012.
  • [2] J.-C. Olivo-Marin, "Extraction of spots in biological images using multiscale products", Pattern Recognition, vol. 35, no. 9, pp. 1989–1996, 2002.
  • [3] U. Schmidt, M. Weigert, C. Broaddus, and G. Myers, "Cell detection with star-convex polygons", in Medical Image Computing and Computer Assisted Intervention–MICCAI 2018: 21st International Conference, Granada, Spain, September 16-20, 2018, Proceedings, Part II 11. Springer, 2018, pp. 265–273.
  • [4] N. Chenouard, I. Bloch, and J.-C. Olivo-Marin, "Multiple hypothesis tracking for cluttered biological image sequences", IEEE transactions on pattern analysis and machine intelligence, vol. 35, no. 11, pp. 2736–3750, 2013.
  • [5] T. Lagache, A. Hanson, J. Perez-Ortega, et al., "Tracking calcium dynamics from individual neurons in behaving animals", PLoS computational biology, vol. 17, pp. e1009432, 10 2021.
  • [6] J. Schindelin, I. Arganda-Carreras, E. Frise, et al., "Fiji: an open-source platform for biological-image analysis", Nature Methods, 9(7), 676–682, 2012.
  • [7] K. Jaqaman, D. Loerke, M. Mettlen, et al., "Robust single-particle tracking in live-cell time-lapse sequences.", Nature Methods, 5(8), 695–702, 2008.
  • [8] J.-Y. Tinevez, N. Perry, J. Schindelin, et al., "TrackMate: An open and extensible platform for single-particle tracking.", Methods, 115, 80–90, 2017.
  • [9] R. Reme, A. Newson, E. Angelini, J.-C. Olivo-Marin and T. Lagache, "Particle tracking in biological images with optical-flow enhanced kalman filtering", in International Symposium on Biomedical Imaging (ISBI2024).
  • [10] M. Maška, V. Ulman, D. Svoboda, P. Matula, et al., "A benchmark for comparison of cell tracking algorithms", in Bioinformatics, 2014.
  • [11] R. Reme, A. Newson, E. Angelini, J.-C. Olivo-Marin and T. Lagache, "SINETRA: a Versatile Framework for Evaluating Single Neuron Tracking in Behaving Animals", arXiv preprint arXiv:2411.09462, 2024.
  • [12] A. Genovesio, Z. Belhassine, and J.-C. Olivo-Marin, "Adaptive gating in Gaussian Bayesian multi-target tracking", in 2004 International Conference on Image Processing (ICIP'04).

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

byotrack-1.4.1.tar.gz (111.8 kB view details)

Uploaded Source

Built Distribution

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

byotrack-1.4.1-py3-none-any.whl (140.3 kB view details)

Uploaded Python 3

File details

Details for the file byotrack-1.4.1.tar.gz.

File metadata

  • Download URL: byotrack-1.4.1.tar.gz
  • Upload date:
  • Size: 111.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.24

File hashes

Hashes for byotrack-1.4.1.tar.gz
Algorithm Hash digest
SHA256 9aa1d82d372ec3772357f83ded8a01710e00112f572b2527512703f04e169f05
MD5 645a83df6b6fac1fa28b3c4bba5951e8
BLAKE2b-256 84030e1f9733d37c934b8874dafb580526a98aafcdd1c0357f5d564c2dad8c77

See more details on using hashes here.

File details

Details for the file byotrack-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: byotrack-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 140.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.24

File hashes

Hashes for byotrack-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 189b5ecbe59c1898d56ff3554fdf29c05a5bd1085a1f8e74c3a9d389f67bc2d6
MD5 7d1656b2e23745c28d4c95fe3be7d18b
BLAKE2b-256 8076eaa721ffe45846fcd62831172a1ab19775c48ee75ddd72dd6cd7af10ba73

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