Tools to sync ephys data with video data using IR LEDs, specifically using Open Ephys and Azure Kinect (mkv files) data. The sync signal comes from IR LEDs in view of the camera, whose trigger signals are also routed as TTL inputs to the ephys acquisition system. The LED on/off states are converted to bit codes, and the resulting sequences of bit codes in the video frames and ephys data are matched. The matches are used to build linear models (piecewise linear regression) that translate video time into ephys time and vice versa.
To get started, try the following in termanal (these instructions assume you're on a compute node on a cluster):
conda create -n sync_test python=3.7
conda activate sync_test
cd ~/code/
(or wherever you want the repo to livegit clone https://github.com/guitchounts/moseq2-ephys-sync.git
cd ./moseq2-ephys-sync/
python setup.py install
pip install git+ssh://[email protected]/dattalab/moseq2-extract.git@autosetting-params
(alternatively, try:pip install git+https://github.com/dattalab/moseq2-extract.git@autosetting-params
)conda install scikit-learn=0.24
(moseq2-extract pinsscikit
to an earlier version; need to update to0.24
module load ffmpeg
The script assumes your input folder structure looks like this:
/input_directory/
│
│
│
└───ephys_folder/ (this might be e.g. Record Node 10X/ or experiment1/ depending on the version of the Open Ephys GUI you're using)
│ │
│ └───recording1/
│ │
│ └───events/
│ │
│ └───Rhythm_FPGA-10X.0/
│ │
│ └───TTL_1/
│ channel_states.npy
│ channels.npy
│ full_words.npy
│ timestamps.npy
│
│
└───depth.mkv (can be named anything, with an .mkv extension)
To run an extraction:
python main.py -path /input_directory/
This will extract the IR LED data from the video and ephys files, find matches in the resulting bit codes, plot the results in /input_directory/sync/
and save two models that can be used for translating between the two timebases: video_model.p
which takes as inputs video times (in seconds) and translates them into ephys times; and ephys_model.p
which conversely takes in ephys times (in seconds) and translated them into video times.
To use the resulting models, try:
import joblib
ephys_model = joblib.load('input_directory/sync/ephys_timebase.p')
video_times = ephys_model.predict(ephys_times.reshape(-1,1))
(assuming times are1D
arrays)video_model = joblib.load('input_directory/sync/video_timebase.p')
ephys_times = video_model.predict(video_times.reshape(-1,1))