SimBA has an in-built behavior annotation interface that allow users to append experimenter-made labels to the features extracted from pose-estimation data. Accurate human labelling of images can be the most time-consuming part of creating reliable supervised machine learning models. However, often experimenters have previously hand-labelled videos using manual software annotation tools and these labels can be appended to the pose-estimation datasets in SimBA. Some users may also prefer to use other dedicated behavior annotation tools rather than using the annotation tool built into SimBA.
SimBA currently supports the import of annotations created in:
If you have annotation created in any other software tool and would like to append them to your data in SimBA, please reach out to us on Gitter or GitHub and we can work together to make the option available in the SimBA GUI.
In brief, before we can import the third-party annotations, we need to (i) create a SimBA project, (ii) import our pose-estimation data into this project, (iii) correct any outliers (or indicate to skip outlier correction), and (iv) extract features for our data set, thus:
-
Once you have created a project, click on
File
-->Load project
to load your project. For more information on creating a project, click HERE. -
Make sure you have extracted the features from your tracking data and there are files, one file representing each video in your project, located inside the
project_folder/csv/features_extracted
directory of your project. For more information on extracting features, click HERE.
1. After loading your project, click on the [LABEL BEHAVIOR]
tab, and the Append third-party annotations
button inside the LABELLING TOOLS
sub-frame and you should see the following pop-up:
2. In the first drop-down menu named 'THIRD-PARTY APPLICATION`, select the application which your annotations were created in:
3. Next, where it says DATA DIRECTORY
, click Browse Folder
and select the directory where your third-party annotations are stored.
4. Next, we need to tell SimBA how to deal with inconsistancies in the annotation data and conflicts with the pose-estimation data (if they exist). While developing these tools in SimBA, we have been shared a lot of annotation files from a lot of users. We have noticed that the annotation files sometimes have oddities; e.g., behaviors that are annotated to end before they start or that start more times then they end etc etc.. We need to deal with these inconsistancies and conflicts when appeding the labels, and these settings gives the users some powers in how we do this.
Each of the WARNINGS AND ERRORS
dropdowns have two options: WARNING
, and ERROR
:
If WARNING
is selected, then SimBA will warn you with printed text that an inconsistancy has been found, where it was found, and try to remedy the issue. If ERROR
is selected, then SimBA will shut down the appending process and print a text saying an inconsistancy has been found and where it was found, so that the user can look into and fix the issue. Below we will go through the potential inconsistancies and conflicts that SimBA will look for:
(i) INVALID ANNOTATION DATA FILE FORMAT
: SimBA expects the annotation files to look a certain way depending on the third-party application. SimBA needs to make assumptions on - for example - where to find the time-stamps, the behaviors, and the video names etc. within your files, and when these assumptions are wrong, SimBA will show and INVALID ANNOTATION DATA FILE FORMAT error or warning. If this dropdown is set to WARNING, then SimBA will skip to read in the invalid file. If this dropdown is set to ERROR, then SimBA will halt the reading of your annotation files and show you en error. See below links for the file formats expected by SimBA from the differet annotation tools.
(ii) ADDITIONAL THIRD PARTY BEHAVIOR DETECTED
: At times, the annotation files contain annotations for behaviors that you have not defined in your SimBA project.
Example 1: You have defined two classifiers/behaviors in your SimBA project called: Attack
and Sniffing
. In your annotation files, SimBA finds annotations for Attack
, Sniffing
, and Grooming
. As Grooming
is not defined in your SimBA project we are not sure what to do with those annotations.
Example 2: You have defined two classifiers/behaviors in your SimBA project called: Attack
and Sniffing
. In your annotation files, SimBA finds annotations for attack
, sniffing
. As attack
and sniffing
is not defined in your SimBA project we are not sure what to do with those annotations.
If this dropdown is set to WARNING, then SimBA will show you a warning and discard the behaviors not defined in your SimBA project. If this dropdown is set to ERROR, then SimBA will stop appending the annotations and show you an error about the additional classifiers/annotations found and where SImBA found them.
(ii) ANNOTATION OVERLAP CONFLICT
: Many third-party annotation softwares give you a BEHAVIOR
and EVENT
columns (e.g., Noldus tools). For example, a specific log in a file can be a behavior of Grooming
and the event is START
, and the next row log the behavior is Grooming
and the event is STOP
. But what happens when a behavior is recorded as STOP
before any record of an associated START
? This would happen if you have sequantial logs of Grooming
as START
->STOP
->STOP
->START
or STOP
->START
->START
->STOP
etc. Make sure your START and STOP events are intertwined.
If this dropdown is set to WARNING, then SimBA will show you a warning and try to find the innaccurate start->stop annotations and discard them. If this dropdown is set to ERROR, then SimBA will stop appending the annotations and show you an error about which behavior and video the overlap was found.
(iii) ZERO THIRD-PARTY VIDEO BEHAVIOR ANNOTATIONS FOUND
: At times, a specific video contains zero third-party annotations for a specific behavior.
If this dropdown is set to WARNING, then SimBA will show you a warning and set all frames in your data to annotated as behavior absent. If this dropdown is set to ERROR, then SimBA will stop appending the annotations and show you an error about which behavior and video contains zero annotations as behavior present.
(iv) ANNOTATION AND POSE FRAME COUNT FONFLICT
: It happens that the video annotated in your annotation tool and the pose-estimation data imported to SimBA has different number of frames. For example, the annotation data for a specific video may contains annotations for 2k frames, but the imported pose-estimation data for the same video is 1.5k frames long. More, if the annotation file indicates that your behavior is present between frame 1750 and frame 1800, then SimBA does not know what to do with those annotations as the pose-estimation data only has 1500 entries.
If this dropdown is set to WARNING, then SimBA will show you a warning and discard any annotations made after the last frame in the pose-estimation data. If this dropdown is set to ERROR, then SimBA will stop appending your labels when this conflict occurs, and give you information about where the conflict was found (which video, which behavior, which frames, and how many frames).
(v) ANNOTATION EVENT COUNT CONFLICT
: Many third-party annotation softwares give you a BEHAVIOR
and EVENT
columns (e.g., Noldus tools). For example, a specific log in a file can be a behavior of Grooming
and the event is START
, and the next row log the behavior is Grooming
and the event is STOP
. But what happens when a behavior is recorded as have started N times and stopped N-1 or N+1 times? This would happen if you have sequantial logs of Grooming
as START
->STOP
->START
->STOP
->'START' or START
->STOP
->STOP
etc. Then we have an extra event with no counterevent which SimBA doesn't know how to deal with.
If this dropdown is set to WARNING, then SimBA will show you a warning and try to find the innaccurate start/stop annotations and discard them. If this dropdown is set to ERROR, then SimBA will stop appending the annotations and show you an error about which behavior and video the count conflict was found in.
(vi) ANNOTATION DATA FILE NOT FOUND
: Say we have two video data files representing our pose-estimation in our SimBA project - Video_1
and Video_2
- that we want to append third-party annotations to. We import our third-party annotations for two videos Video_1
and Video_3
. When SimBA gets to Video_2
and looks for the third-party annotations, it doesn't find any.
If this dropdown is set to WARNING, then SimBA will show you a warning and skip appending annotations to the video that lack annotation data. If this dropdown is set to ERROR, then SimBA will stop appending the annotations and show you an error about which video is lacking annotation data.
5. We may want to create a log file recording all of the WARNINGS displayed during the append process. If you want a log, tick the CREATE IMPORT LOG
checkbox. The log will be saved in the project_folder/logs
directory of your SimBA project and named something like BORIS_append_20230328095919.log
.
-
Please make sure that the FPS of the imported video registered in the video_info.csv file and the video annotated in the third-party tool are identical - otherwise SimBA may get the frame numbers jumbled up.
-
The imported annotations into SimBA has to have START and STOP demarcations. This means that behaviors coded BORIS or NOLDUS tools as
POINT
events will be discarded by SimBA during importation. We discard these as we cannot build classifiers around events that are only present for a single frame, as is the case withPOINT
events. -
To pair the video names as recorded in SimBA with the video names as recorded in the annotation tools, SimBA will look at different places depending on the annotation tool:
- BORIS: The file-name (excluding the file-path) in the
Media file path
column. - DEEPETHOGRAM: The annotation file filename.
- NOLDUS ETHOVISION: The file-name (excluding the file-path) in the
Video file:
entry. - NOLDUS OBSERVER: The entry in the
Observation
column. - BENTO: The annotation file filename.
- SOLOMON CODER: The annotation file filename.
If you look at the SimBA expected BORIS example files HERE or HERE, you'll see that the Subjects
column is empty. Sometimes, however, you're Subject
column might be populated with animal names, and these names determine which animal is performing the behavior specified in the Behavior
column. If this is the case, we need to re-organize the BORIS annotation files before feeding them into SimBA, so that SimBA doesn't need to look in the Subjects
columns. A way to solve it would be to restructure the BORIS files, to include the animal names in the behavior names. So for example, “My_Behavior” in the Behavior
columns would become “Animal_1_My_Behavior” or “Animal_2_My_Behavior” depending on which animal performs “My_Behavior”. You would have two classifiers defined in your SimBA project: “Animal_1_My_Behavior” and “Animal_2_My_Behavior”. To do this, see the BORIS source cleaner. This code is not accessable through the GUI, but detailed instructions are included at the top of the file. If you have any questions, issues, or need help, please let us know on Gitter or open an issue here on Github and we'll solve it together!