Tools for using idtracker.ai
Project description
id manual tools
id_manual_tools is a set of tools to use after a video has been tracked with idTracker.ai. They work on Python and are capable of visually correcting trajectories of animals, concatenate trajectory files and render awesome videos like the one above.
Table of Contents
- Install
- Steps to track a video with idTracker.ai
- Contact
Install
In the idTracker.ai environment: pip install id-manual-tools
Steps to track a video with idTracker.ai
1 Download the episodes from Google Drive
When downloading more than one file (or folder) of some GB each from Google Drive, Google tries to compress it but it can't, a bunch of files are then downloaded separately in the folder and you need to organize them.
These files should be saved at the external drive. Each one is around 4GB and you don't want to run out of space in the OS drive.
Once done, the files contain some extra numbers in their names (the video GX010128.MP4
is downloaded as GX010128-012.MP4
, for example). You can rename each file individually or use the bash command rename -v 's/-[0-9]{3}././' *.MP4
to rename all of them at once
2 Prepare the videos
You don't want to track every 5 minutes episode individually and join them afterwards. The episodes (from the same experiment) must be concatenated using ffmpeg
.
The larger the number of fishes in the experiment, the sorter the videos have to be so that idtracker.ai can track them. For up to 8 fishes, 30 minutes of 50fps videos (~90k frames) are ok for our computer. But try to track 30 minutes of 39 fish and your RAM will die (at least with our RAM with 64GB).
To concatenate all videos ended with 0154
in the current directory and write the output in the home directory you can run
ffmpeg -safe 0 -f concat -i <(find . -type f -name '*0154.MP4' -printf "file '$PWD/%p'\n" | sort) -c copy /home/jordi/0154.MP4
If you don't want to concatenate all of the videos and you want to specify the files you have to write an ordered file
like (for example)
file './GX010154.MP4'
file './GX020154.MP4'
file './GX030154.MP4'
and then run ffmpeg -safe 0 -f concat -i file -c copy /home/jordi/0102030154.MP4
I use this name encoding, the lasts 4 digits are the video name and the firsts pairs are the episodes. So
010203040187.MP4
are episodes 01 02 03 and 04 of video 01870187.MP4
are all episodes of the video 0187
3 Input parameters
idTracker.ai has 3 levels of parameters with increasing priority.
constants.py
file in the idtrackerai internal directory (you don't want to modify those parameters).local_settings.py
file in the current working directory.- Segmentation parameters from the idtrackerai GUI that wi will send to idtracker as
.json
file.
3.1 local_settings.py
Find complete info the official idtracker website.
Here, you want to define the next parameters:
NUMBER_OF_JOBS_FOR_SEGMENTATION = 20
- Currently, idtrackerai consume so much RAM in the segmentation process so you want to set the number of jobs somewhere around 20 (although our computer has 36 cores)
IDENTIFICATION_IMAGE_SIZE = 55
- If you want to match identities after the tracking process, you have to fix the image size. In out videos 55 is a good value
DATA_POLICY = 'idmatcher.ai'
- This will remove useless data in the session directory when the tracking ends (this will free you from GBs of trash data)
3.2 segmentation parameters
The segmentation parameters will be unique for every video. To get them you have to run the command idtrackerai
to enter the idtrackerai GUI. Here you will find extended info of that.
These are the steps to obtain a good segmentation .json file from the GUI:
- Open a video file by clicking Open.
- If a window appears asking if you want to track multiple videos at once, say NO. I don't recommend tracking various videos, at least by now.
- Define a ROI (Region of Interest) with a Polygon.
- Subtract background. This may take a while and the GUI will freeze until the background is computed
- Define the number of animals
- Click to the Blob information and pressing Alt+space put it Always on top.
- Modify the upper intensity threshold (the lower must be at 0) to obtain a minimum blob area of around 400 px and no noise blobs.
- Modify the lower area threshold to around 300 px (so that all fish appear as blobs but you limit some accidental small noise blob)
- Name you session with the same name as the video file
- Save the .json with the same name as the video file
- Close the GUI
Side notes:
- If you are working with 30 min videos, it's useful to use the GUI with one of the 5 min episodes so that the background computation takes less time. If you do that remember to rename the video path to the full 30 min video and modify the range (of frames to track) to something like $[0, 9999999999]$ in the .json.
- If you want to create the .json files for very similar videos (videos of the same day and characteristics). You can create the first one and copy-paste it changing the session name and the video path.
4 Running idTracker.ai from terminal
4.1 Commands to run idTracker.ai from terminal
The command to run idtrackerai in the terminal is
idtrackerai terminal_mode --load file.json --exec track_video
This will print output in the terminal and will be shut down when you exit the terminal.
If you want to run idtracker.ai not worrying about accidental shut downs, then
nohup idtrackerai terminal_mode --load file.json --exec track_video > file.log 2>&1 &
will print the output to a file and will keep running when you exit the terminal
A mini bash script for various videos to track could be
#!/bin/bash
declare -a files=("0102030405060146" "0708091011120146" "0147" "0148" "0149")
for file in "${files[@]}"
do
idtrackerai terminal_mode --load $file.json --exec track_video > $file.log 2>&1
done
And run it like nohup ./script.sh &
Keep track of the output file to check the status of the program
4.2 idTracker.ai logger
Even if you run idtracker actively on the terminal (so that the log is printed in screen) or on background (the log is written in a .log file), you have to check some important aspects.
-
The firsts lines of the log will indicate the parameters received by the software, check they are correct.
-
Look for the line
INFO --> check_segmentation
. After this line will appear the frames that contain more blobs than animal (if there is any). You don't want to have frames like that. For a 30 min 50 fps video you could accept < 20 error frames. But always think abut adjusting the segmentation parameters to avoid those frames. -
idTracker.ai has 3 tracking protocols depending of the needs of each video. If you video enters on protocol 3 (look for the line
INFO --------------------> Protocol 2 failed -> Start protocol 3
), kill the process. Protocol 3 is eternal, it is time itself. Try to readjust the segmentation parameters and pray to god this doesn't happen again. -
The last lines of a successful log will be
INFO Estimated accuracy: 0.????
andINFO Success
. A useful tracking should have an accuracy > 0.99.
5 id_manual_tools
When tracked, you may use the id_manual_tools
project
For now, id_manual_tools has 5 tools:
- 5.1
id_manual_tools_get_nans
- 5.2
id_manual_tools_set_corners
- 5.3
id_manual_tools_correct_traj
- 5.4
id_manual_tools_concatenate_traj
- 5.5
id_manual_tools_plot_traj
All of them are wrapped with Python's ArgParser and can be ran with -h
flag to print some basic information about input/output.
5.1 id_manual_tools_get_nans
The first tool checks for nans in the trajectory file. The raw trajectories from idTracker.ai use to have some NaNs (less than 1% of the total data). It reads the file and print a .csv list of NaNs
5.2 id_manual_tools_set_corners
This tool opens the video to set the setting_points
. A list of coordinates that we use to indicate the position of the tank corners.
5.3 id_manual_tools_correct_traj
That's the main tool here. The trajectory corrector will use id_manual_tools_get_nans
to look fort NaNs and will display a full matplotlib GUI to correct them using cubic interpolations. Additionally, the user will be asked to write the corners of the tank using id_manual_tools_set_corners
to crop the video and speed up the GUI.
This tool can also be used to correct suspicious high velocities (jumps) using a gaussian threshold.
id_manual_tools_correct_trajectories -s session_0146/ -video 0146.MP4 -fps 50 -n 10 -jumps_check_sigma 6
5.4 id_manual_tools_concatenate_traj
If your video has been tracked in chunks. You can concatenate them with this tool but first of all you have to match them. This can be done with idmatcher.
Since this repo is a bit out-of-date, in the computer there is a the idmatcher directory and, if you have session_A
session_B
session_C
, you can use it like
python idmatcher/main.py -sA session_A -sB session_B
python idmatcher/main.py -sA session_A -sB session_C
An additional folder will appear inside each session folder. Then you will be able to concatenate them.
5.5 id_manual_tools_plot_traj
This is used to make composed videos (the original video with the trajectories overlapped)
Contact
GitHub actions are recommended (issues, PR,...). Also, author's email is jordi.torrentsm@gmail.com
Project details
Release history Release notifications | RSS feed
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 id_manual_tools-1.0.0.tar.gz
.
File metadata
- Download URL: id_manual_tools-1.0.0.tar.gz
- Upload date:
- Size: 25.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 36e971d1f7d5013855cf47bbf9142e39d808dbb1481050c7107e3c5e87a54870 |
|
MD5 | 63fe00be78f079a0e84decb2a39259ab |
|
BLAKE2b-256 | b1804626cb3c10afc7b4e44af8550c77f6714664836b0f8ae183440126c1fd75 |
File details
Details for the file id_manual_tools-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: id_manual_tools-1.0.0-py3-none-any.whl
- Upload date:
- Size: 24.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 654bcc01681b8401018a2980bb0beee2f02cd9ee4223bb69e0e7d85093e6ce21 |
|
MD5 | a63a700b29f2228e273b64e9ded66a46 |
|
BLAKE2b-256 | 1df7d2422521102fc9994bfa55c5f4e1234c5bdc90c86a225249808796d60e24 |