UDMT: Unsupervised Multi-animal Tracking for Quantitative Ethology
Project description
UDMT: Unsupervised Multi-animal Tracking for Quantitative Ethology
Project page | Paper
Contents
Overview
Animal behavior is closely related to their internal state and external environment. Quantifying animal behavior is a fundamental step in ecology, neuroscience, psychology, and various other fields. However, there exist enduring challenges impeding multi-animal tracking advancing towards higher accuracy, larger scale, and more complex scenarios, especially the similar appearance and frequent interactions of animals of the same species.
Growing demands in quantitative ethology have motivated concerted efforts to develop high-accuracy and generalized tracking methods. Here, we present UDMT, the first unsupervised multi-animal tracking method that achieves state-of-the-art performance without requiring any human annotations. The only thing users need to do is to click the animals in the first frame to specify the individuals they want to track.
We demonstrate the state-of-the-art performance of UDMT on five different kinds of model animals, including mice, rats, Drosophila, C. elegans, and Betta splendens. Combined with a head-mounted miniaturized microscope, we recorded the calcium transients synchronized with mouse locomotion to decipher the correlations between animal locomotion and neural activity.
For more details, please see the companion paper where the method first appeared: "Unsupervised multi-animal tracking for quantitative ethology".
Installation
1. For Linux (recommended)
Our environment
- Ubuntu 20.04 (or newer)
- Python 3.8
- Pytorch 1.7.1
- NVIDIA GPU (GeForce RTX 3090) + CUDA (11.7)
Environment configuration
-
Create a virtual environment and install PyTorch. In the 3rd step, please select the correct Pytorch version that matches your CUDA version from https://pytorch.org/get-started/previous-versions/.
$ conda create -n udmt python=3.8 $ conda activate udmt $ conda install pytorch==1.7.1 torchvision==0.8.2 torchaudio==0.7.2 cudatoolkit=11.0 -c pytorch $ sudo apt-get install ninja-build $ sudo apt-get install libturbojpeg -
We made a installable pip release of UDMT [pypi]. You can install it by entering the following command:
$ pip install udmt-pip
Download the source code
$ git clone https://github.com/cabooster/UDMT
$ cd UDMT/
2. For Windows
Our environment
- Windows 10
- Python 3.8
- Pytorch 1.7.1
- NVIDIA GPU (GeForce RTX 3090) + CUDA (11.0)
Environment configuration
-
Create a virtual environment and install PyTorch. In the 3rd step, please select the correct Pytorch version that matches your CUDA version from https://pytorch.org/get-started/previous-versions/.
$ conda create -n udmt python=3.8 $ conda activate udmt $ pip install torch==1.7.1+cu110 torchvision==0.8.2+cu110 torchaudio==0.7.2 -f https://download.pytorch.org/whl/torch_stable.html -
We made a installable pip release of UDMT [pypi]. You can install it by entering the following command:
$ pip install udmt-pip -
Install Precise ROI pooling: If your environment is the same as ours, directly copy
<UDMT_install_path>\UDMT\env_file\prroi_pool.pydto<Anaconda_install_path>\anaconda3\envs\udmt\Lib\site-packages. Otherwise, buildprroi_pool.pydfile with Visual Studio with the tutorial. -
Install libjpeg-turbo: You can download installer from the official libjpeg-turbo Sourceforge repository, install it and copy
<libjpeg-turbo_install_path>\libjpeg-turbo64\bin\turbojpeg.dllto the directory from the system PATHC:\Windows\System32.
GUI Tutorial
We have released the Python source code and a user-friendly GUI of UDMT to make it an easily accessible tool for quantitative ethology and neuroethology. Tutorials on installing and using the GUI has been moved to this page.
Results
1. Tracking the movement of 10 mice simultaneously with UDMT.
2. Neuroethology analysis of multiple mice combined with a head-mounted microscope.
3. Analyzing the aggressive behavior of betta fish with UDMT.
More demo videos are presented on our website.
Citation
If you use this code, please cite the companion paper where the original method appeared:
- Xinyang Li, Yixin Li, Yiliang Zhou, et al. Real-time denoising enables high-sensitivity fluorescence time-lapse imaging beyond the shot-noise limit. Nat. Biotechnol. (2022). https://doi.org/10.1038/s41587-022-01450-8
@article {li2022realtime,
title = {Real-time denoising enables high-sensitivity fluorescence time-lapse imaging beyond the shot-noise limit},
author = {Li, Xinyang and Li, Yixin and Zhou, Yiliang and Wu, Jiamin and Zhao, Zhifeng and Fan, Jiaqi and Deng, Fei and Wu, Zhaofa and Xiao, Guihua and He, Jing and Zhang, Yuanlong and Zhang, Guoxun and Hu, Xiaowan and Chen, Xingye and Zhang, Yi and Qiao, Hui and Xie, Hao and Li, Yulong and Wang, Haoqian and Fang, Lu and Dai, Qionghai},
journal={Nature Biotechnology},
year={2022},
publisher={Nature Publishing Group}
}
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
File details
Details for the file udmt_pip-1.0.0.tar.gz.
File metadata
- Download URL: udmt_pip-1.0.0.tar.gz
- Upload date:
- Size: 4.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.8.3 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.6.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d4607f404e32d87204e7772ead23d9b7695186daaf8cf187141da920b7e53747
|
|
| MD5 |
7f923819c8dd732d8867ba2ef24e8f10
|
|
| BLAKE2b-256 |
079ef4b33adfa2fbe9b99bd4efdf10a73157535cf543678be795c1122a1c8cc2
|