############################################################################### # # # This is the cv-tracer software package, designed for tracking and # # analyzing dynamics of fish swimming in groups. It can be downloaded at # # # # https://github.com/patchmemory/cvtracer # # # # Software designed and developed by Adam Patch and Yaouen Fily at Florida # # Atlantic University. Began with github.com/vivekhsridhar/tracktor. # # # ############################################################################### In the cv-tracer package, one will find the modules TrAQ, Analysis, and GUI These three modules provide necessary tools for different stages of tracking birds-eye video of fish swimming in a tank, reviewing the results alongside video to check for errors, and analyzing the results across trials. Scripts for executing all tasks for tracking can be found in scripts/track subdirectory of each base module (e.g. TrAQ/scripts, Analysis/scripts). This document provides a basic overview of how to use this software and is broken into three sections: 1. Tracing and processing tracks 2. Analyzing results across trials 3. Reviewing kinematics alongside video This software is designed in python with free libraries so that it may be straightforwardly modified to incorporate more advanced methods of tracking and analysis. ############################# Tracing and processing tracks ############################# One can completely track and process a video trial, by executing the following commands and providing relevant input parameters. > python prepare.py [input_video] -opts > python trace.py [trial] -opts > python process.py [trial] -opts These each perform the following tasks: prepare.py: Loads video for the first time and takes down information about the run like the raw video file, the number of individuals, the type of fish, the total length of the run, and any other relevant input for characterizing the trial. The script then generates a Trial object to store all of this information. Once the trial object has been created, the script will prompt the user to utilize a GUI to locate the tank edges and store the result as a Tank object inside the trial object. A Group object (which contains Individual objects) within the Trial object will also be generated to store and analyze data at the time of tracing and processing. Finally, the script will generate a directory with a concise name reflecting that of the original video file, moving that file to this new directory as raw.mp4. The Trial object will also be stored in this directory with the name trial.pik trace.py: Loads Trial object and utilizes Tracer and VideoCV objects to track coordinates of fish throughout that trial. At each frame, Tracer will gather and sort the findings of VideoCV in order to best trace the location of fish throughout the run, ignoring fish misidentified outside of the Tank, as identified in prepare.py. The resulting coordinates are stored as Individuals in the Trial's Group. Trial object, now containing Tank, Group, and all relevant trial-specific information, is again saved in the trial-specific location, as found at the beginning of tracing. process.py: After the initial tracking has occurred, it is useful to now better calculate kinematic quantities like velocity and acceleration in both translational and rotational coordinates (latter w.r.t. director angle). Using these quantities, it is then useful to provide some initial statistical analysis without any cuts, for the sake of quickly summarizing the behavior of fish in each run. With further development, this stage would also be the place to fix errors in the initial tracks which may have issues with occlusions and jumping points. At this point in time, it only really makes sense to perhaps identify frames and points of interest for the sake of troubleshooting in the future. For our first paper, these issues are handled by simple ad-hoc cuts which will be made to obviously erraneous data during the next stage, Analysis, so that all Trials will be treated uniformly. ############################### Analyzing results across trials ############################### Once the tracking of a set of trials is complete, one can run the following command and relevant input parameters in order to analyze data given a set of cuts. > python analyze.py [trial_list] -opts While the analysis itself may be modified, this will perform a few basic tasks regardless of the specific analysis. analysis.py: First, all Trial objects will be loaded from their save locations and stored in an Archive object. This object has the ability to call functions on each trial (e.g. make a consistent set of cuts) and to combine statistical results across trials, storing results according to analysis-specific cuts applied. Once results have been computed and collected, they can be combined and stored in the Archive object's result dictionary. This allows easy access via the Archive object later. Utilizing the Analysis.Plot module, one can efficiently plot distributions and results for each trial and across trials. Trial-specific results will be stored in the Trial's home directory while the results across trials will be stored in results/. #################################### Reviewing kinematics alongside video #################################### While one can, in principle, follow all of the above steps, it is always useful to verify kinematic quantities being calculated correctly via some kind of visual sanity check. The easiest way to do this is to utilize the cvDataViewer, found in the GUI module. One can execute this GUI by simply > python GUI/cvDataViewer.py [trial_directory] -v cv.mp4 This will open a window containing a video of the tracked fish as well as a side panel displaying time-dependent results of three quantities: distance to the wall, speed, and angular speed. This tool facilitates checks on tracking throughout a run by allowing users to see directly if quantities are being properly calculated across frames of the video. A couple examples of how one might use this information... One may find that the tracer is having trouble locating fish at every frame, resulting in jumps from track-to-track. By viewing this in the cvDataViewer, one may step back to the tracking stage and try using a different set of contour-tracing parameters to better identify fish and then go back to verify after a second round of tracking has completed. Another may find that while the tracing has been done optimally, there are still undesirable errors where fish appear to be jumping across the tank or turning in an unphysical way. Despite the shortcomings of the tracking software, this provides a basis for eliminating erroneous frames by making cuts at the stage of Analysis, in order to consistently treat systematic errors across runs. ############ Dependencies ############ The following python libraries are required for full functionality of cv-tracer: - argparse - copy - matplotlib - numpy - opencv (cv2, which version?) - pickle - PyQt5 - pyqtgraph - scikit-learn - scipy