Skip to content

DataJoint Elements for Extracellular Electrophysiology - U24 effort

License

Notifications You must be signed in to change notification settings

kabilar/element-array-ephys

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PyPI version

DataJoint Element for Extracellular Electrophysiology

DataJoint Element for extracellular array electrophysiology that processes data acquired with a polytrode probe (e.g. Neuropixels, Neuralynx) using the SpikeGLX or OpenEphys acquisition software and MATLAB-based Kilosort or python-based Kilosort spike sorting software. DataJoint Elements collectively standardize and automate data collection and analysis for neuroscience experiments. Each Element is a modular pipeline for data storage and processing with corresponding database tables that can be combined with other Elements to assemble a fully functional pipeline.

Installation and usage instructions can be found at the Element documentation.

DataJoint Workflow for extracellular array electrophysiology combines multiple DataJoint Elements to process data acquired with a polytrode probe (e.g. Neuropixels, Neuralynx) using the SpikeGLX or OpenEphys acquisition software and processed with MATLAB-based Kilosort or python-based Kilosort spike sorting software. DataJoint Elements collectively standardize and automate data collection and analysis for neuroscience experiments. Each Element is a modular pipeline for data storage and processing with corresponding database tables that can be combined with other Elements to assemble a fully functional pipeline.

To get started, see below for an interactive tutorial on GitHub Codespaces. More information can be found at the Element documentation page.

Experiment Flowchart

flowchart

Data Pipeline for Acute Experiment

datajoint

  • We have designed four variations of the pipeline to handle different use cases. Displayed above is the default ephys_acute schema. Details on all of the ephys_* schemas can be found in the Data Pipeline documentation page.

Interactive Tutorial on GitHub Codespaces

The easiest way to learn about DataJoint Elements is to use the tutorial notebooks within the included interactive environment configured using DevContainer.

Launch Environment

  • Launch using GitHub Codespaces using the + option which will Create codespace on main in the codebase repository on your fork with default options. For more control, see the ... where you may create New with options....

  • Cloud-based Development Environment: (recommended)

    • Launch using GitHub Codespaces using the + option which will Create codespace on main in the codebase repository on your fork with default options. For more control, see the ... where you may create New with options....
    • Build time for a codespace is ~7m. This is done infrequently and cached for convenience.
    • Start time for a codespace is ~30s. This will pull the built codespace from cache when you need it.
    • Tip: Each month, GitHub renews a free-tier quota of compute and storage. Typically we run into the storage limits before anything else since Codespaces consume storage while stopped. It is best to delete Codespaces when not actively in use and recreate when needed. We'll soon be creating prebuilds to avoid larger build times. Once any portion of your quota is reached, you will need to wait for it to be reset at the end of your cycle or add billing info to your GitHub account to handle overages.
    • Tip: GitHub auto names the codespace but you can rename the codespace so that it is easier to identify later.
  • Local Development Environment:

    • Note: On Windows, running the tutorial notebook with the example data in a Dev Container is not currently possible due to a s3fs mounting issue. Please use the Cloud-based Development Environment option above.
    • Install Git
    • Install Docker
    • Install VSCode
    • Install the VSCode Dev Containers extension
    • git clone the codebase repository and open it in VSCode
    • Use the Dev Containers extension to Reopen in Container (More info in the Getting started included with the extension)
  • Start time for a codespace is ~30s. This will pull the built codespace from cache when you need it.

  • You will know your environment has finished loading once you either see a terminal open related to Running postStartCommand with a final message: Done or the README.md is opened in Preview.

  • Tip: Each month, GitHub renews a free-tier quota of compute and storage. Typically we run into the storage limits before anything else since Codespaces consume storage while stopped. It is best to delete Codespaces when not actively in use and recreate when needed. We'll soon be creating prebuilds to avoid larger build times. Once any portion of your quota is reached, you will need to wait for it to be reset at the end of your cycle or add billing info to your GitHub account to handle overages.

  • Tip: GitHub auto names the codespace but you can rename the codespace so that it is easier to identify later.

Instructions

  1. We recommend you start by navigating to the notebooks directory on the left panel and go through the demo_prepare.ipynb and demo_run.ipynb Jupyter notebooks. Execute the cells in the notebooks to begin your walk through of the tutorial.

  2. Once you are done, see the options available to you in the menu in the bottom-left corner. For example, in Codespace you will have an option to Stop Current Codespace but when running DevContainer on your own machine the equivalent option is Reopen folder locally. By default, GitHub will also automatically stop the Codespace after 30 minutes of inactivity.

  • If you are new to GitHub and run into any errors, please contact us via email at [email protected]. If you are experienced with GitHub, please create an issue on the upstream repository or issue a pull request with a thorough explanation of the error and proposed solution.

Experiment flowchart

flowchart

Data Pipeline Diagram

datajoint

Getting Started

Support

  • If you need help getting started or run into any errors, please contact our team by email at [email protected].

About

DataJoint Elements for Extracellular Electrophysiology - U24 effort

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 74.5%
  • Python 25.2%
  • Other 0.3%