Skip to content

AllenNeuralDynamics/aind-foraging-behavior-bonsai-automatic-training

Repository files navigation

Automatic training for the dynamic foraging task

Overview

Here is a diagram of the automatic training system we've been devloping for the dynamic foraging task (those blue arrows on top of our existing foraging behavior pipeline)

Screenshot 2023-12-04 at 11 11 32

This repo is the red circle in the diagram. It will be running on Code Ocean and do the following things (very similar to mTrack):

  1. Define the training curriculum (mTrack's "Regimen")
  2. Retrieve data for each mouse from the behavioral master table (df_behavior on S3 that stores session-wise metrics)
  3. Evaluate daily performance based on the curriculum and make decisions of the next training stage (stored in df_manager)
  4. Push the decisions back to S3 by uploading df_manager, from which our python GUI can access and automatically set the training parameters on the next day.

Key elements

  • Task schema defines schema for training parameters
  • Curriculum schema defines schema for the curriculum, especially the evaluate_transitions method
  • Auto train manager fetches data from df_behavior and updates df_manager (or "tables" on any other database)
  • Curriculum manager manages all available pre-generated curriculums (on any S3 bucket).

Usage

  1. Design the curriculum, i.e., all training stages and transition rules.
    • Here is an example curriculum for the dynamic foraging task.
    • Here is automatically generated json file
    • Here are automatically rendered diagrams for stage transitions rules and parameters (click the images to try the hover feature 😊)
rules parameters
  1. Create AutoTrainManager and connect it to the behavior database df_behavior.

  2. Feed all necessary metrics to Auto train manager and let it run.

    • Here is an open-loop simulation with our old mice
  3. To add other tasks, users should add their own task and curriculum schemas.

Demo

Notes

System upgrade checklist

  • Upgrade all training rigs
  • Upgrade CO capsule (terminate all running workers and start a new one)
  • Upgrade streamlit app

Compared with SLIMS/mTrack

See this thread