To faciliate the initial use of SimBA, we provide several use scenarios. We have created these scenarios around a hypothetical experiment that take a user from initial use (completely new start) all the way through analyzing a complete experiment and then adding additional experimental datasets to an initial project.
All scenarios assume that the videos have been pre-processed and that DLC behavioral tracking CSV files have been created.
Three days of resident-intruder testing between aggressive CD-1 mice and subordinante C57 intruders. Each day of testing has 10 pairs of mice, for a total of 30 videos recorded across 3 days. Recordings are 3 minutes in duration, in color, at 30fps.
Also, so that we do not overfit the predictive classifiers to the experimental data, a different set of pilot videos have been recorded of resident-inturder pairings using identical video acquisition parameters. A total of 20 pilot videos were recorded.
In this current Scenario, you have already generated a predictive classifier for "Behavior that Will Get a Nature Paper (Behavior BtWGaNP)" (see Scenario 1), and you have used the classifier to analyze Day 1 of your Experimental data (see Scenario 2). You may have also updated your classifier to make it better in Scenario 3. You now wish to use the BtWGaNP classifier to analyse Days 2 and 3 of your Experimental data.
Note: This Scenario is very similar to Scenario 2, however, we will take a slightly different approach to analyzing additional data in SimBA (see Part 1 below).
We will need start with a project directory tree that does not contain any other CSV data than the data we want to analyze. If you are coming along from Scenario 1 or Scenario 2, you will have one or several project trees already. However, the project trees may contain the files used to create the BtWGaNP classifier (Scenario 1), or data from Day 1 of the experiments (Scenario 2). If you look in the different sub-directories of the project_folder/csv
folder in your previous projects, you will see the CSV files we used to generate the project and/or have analyzed previously. If we continue using one of these project as is, SimBA will see these CSV files and analyze these files in addition to your new as yet un-analyzed experimental data from Day 2 and 3 of the experiment.
As these files have been analyzed before, we shouldn't have to analyze them again. In Scenario 2, we created a new project to avoid mixing the files that were used to create the predictive classifier for behavior BtWGaNP with the new experimental files we were to analyze.
Another option is to "remove" these files from the immediate sub-directories of our project_folder/csv
folder. This way SimBA cannot see them, and won't analyze the already analyzed files again. In this current Scenario, we will hide the already analyzed files from the project created in Scenario 2, by *manually putting the files in a different directory. To hide the Day 1 files from SimBA, one option is to move the files to a sub-directory called Day 1, as in Step 1 in the below image:
Important: In this example we hide the files during Step 1 in a sub-directory of project_folder/csv/input
folder. You will need to repeat the process for the (i) project_folder/csv/outlier_corrected_movement
, (ii) project_folder/csv/outlier_corrected_movement_location
, (iii) project_folder/csv/features_extracted
, and (iv) project_folder/csv/machine_results
folders. This way you will keep the Day 1 analysis files stored safely and they won't interfere with the analysis of Day 2 and Day 3.
Note: In Scenario 1, the data analysis also generated additional CSV files indicating how many outliers were corrected, and further CSV files containing descriptive statistics of the classified behaviors. These files are stored in the
project_folder/csv/logs
folder and you may also want to cut/paste them to a new sub-directory to have better control over the outputted data. Also note that the sub-directory containing the Day 1 analysis files does not have to be in theproject_folder
, but can be anywhere except directly within theproject_folder/csv
sub-directories.
-
After cleaning your project folders, it is time to load your project in SimBA. Follow the instructions in Scenario 1 - Step 1: Load Project Config to load your project.
-
Once the project is loaded, follow the instructions in Scenario 1 - Step 2 (Optional step) : Import more DLC Tracking Data or videos to import further DLC tracking data, and further videos, into your project using the following menu:
Note: If you wish to visualize the data from imported videos, as decribed in Scenario 2 - Part 5: Visualizing machine predictions, you will need to create the frames for the newly added videos. Go ahead and click on the
Extract frames
button. If the frames are stored somewhere else, they do not have to be generated again and you can instead copy them in to the project by using theImport frame folders
menu.
Once the data is imported, you should see the new imported data for Day 2 in the project_folder/csv/input
directory, similar to after Step 2 in the below image:
Next, we will need to process the data for Day 2-3 of the experiment. This process includes (i) correcting outliers in the tracking, and (ii) extracting features. To process the newly added data imported during Part 2 of this current Scenario, follow the instructions for Step 3 to 5 in Part 2 of Scenario 1.
At this point we have the Day 2-3 data within the project, and the data has been corrected for outliers and the features have been extracted. We now want to predict behavior BtWGaNP in these videos - just like we did in Scenario 2. The process to do this is documented in Part 3 of tutorial for Scenario 2, and is repeated here below.
- In the Load Project menu, navigate to the Run Machine Model tab and you should see the following window.
- The
Model Selection
window .If you click onModel Selection
. The following window, containing the classifier names that were defined when you created the project, will pop up.
Note: You should not have to re-define the paths to the model files in this Scenario, and therefore you should not have to open the
Model Selection
window. However, if you do decide to however open theModel Selection
window , you'll see that the paths are empty. It does not matter. The paths have been saved in the background into your project_config.ini file located in yourproject_folder
the first time you defined the paths (i.e., when you analyzed the data for Day 1 during Scenario 2). If you open the project_config.ini you can see the previously defined paths to your predictive classifier(s) near the top of the text file.
- Fill in the
Discrimination threshold
and theMinimum behavior bout length
entry boxes. For a reminder of the functions of these entry boxes, click here.
Click on Run RF Model to run the machine model on the data for Day 2 of the experiment.
See Scenario 2 - Part 4: Analyze Machine Results for how to generate descriptive statistics for the behavioral classification for Day 2 of the experiment.
See Scenario 2 - Part 5 - Visualizing machine predictions for how to generate visualizations of the features and machine learning classification results for Day 2 of the experiment.
Now, when you likely have generated a large number of predictions, you may want to visualize them in videos that only display the classified events. This post-classification validation step generates a video for each .CSV in the project that contains the concatenated clips of all the events of the target behavior that the predictive classifier identifies.
-
Seconds
is the duration to add in seconds to the start of an event and to the end of the event. Let's say there was a event of 2 seconds of an attack, entering 1 in the Seconds entry box will add 1 second before the 2 second attack and 1 second after. -
Target
is the target behavior to implement into this step.
-
Enter 1 or 2 in the
Seconds
entry box. Note: the larger the seconds, the longer the duration of the video.* -
Select the target behavior from the
Target
dropdown box. -
Click
Validate
button and the videos will be generated in/project_folder/frames/output/classifier_validation
. The name of the video will be formated in the following manner: videoname + target behavior + number of bouts + .mp4
PLEASE HELP BY REPORTING BUGS VIA GITHUB, OR JOIN THE SIMBA GITTER FOR DISCUSSION