Skip to content

Latest commit

 

History

History
222 lines (150 loc) · 8.35 KB

README.md

File metadata and controls

222 lines (150 loc) · 8.35 KB

U19 Python Pipeline

The U19-pipeline_python repository defines the DataJoint tables for the U19 projects. There is a companion MATLAB DataJoint pipeline where much of this repository has mirrored table definitions.

Installation

Recommended prerequisites

Click to expand details

Install an integrated development environment

  • DataJoint development and use can be done with a plain text editor in the terminal. However, an integrated development environment (IDE) can improve your experience. Several IDEs are available.

  • In this setup example, we will use Microsoft's Visual Studio Code. Installation instructions here.

  • Install the Jupyter extension for VS Code.

Install a virtual environment

  • A virtual environment allows you to install the packages required for a specific project within an isolated environment on your computer.

  • It is highly recommended to create a virtual environment to run the workflow.

  • Conda and virtualenv are virtual environment managers and you can use either option. Below are the commands for Conda.

  • If you are setting up the pipeline on your local machine follow the instructions below for Conda. If you are using spock.pni.princeton.edu or scotty.pni.princeton.edu, Conda is preinstalled and you can access it by running module load anacondapy/2021.11.

  • We will install Miniconda which is a minimal installer for conda.

  • Select the Miniconda installer link for your operating system and follow the instructions.

    • You may need to add the Miniconda directory to the PATH environment variable

      • First locate the Miniconda directory

      • Then modify and run the following command

        export PATH="<absolute-path-to-miniconda-directory>/bin:$PATH"
    • Create a new conda environment

      • Type the following command into a terminal window

        conda create -n <environment_name> python=<version>
      • Example command to create a conda environment

        conda create -n <environment_name> python=3.9
    • Activate the conda environment

      conda activate <environment_name>

    Install git

    • Linux and Mac operating systems come preinstalled with Git. If running in Windows get Git.

    Install graphviz

Configuration

Repository libraries installation and configuration

  • The following instructions will allow a user to access and fetch data from the database.
conda activate <environment_name>
cd U19-pipeline_python
pip install -e .
python initial_conf.py

(Username and password will be prompted at this moment: Princeton NETiD & NETiD password usually works)

  • The initial_conf.py script will store a global file with credentials to access DB and configuration variables/filepaths.
  • Now that the virtual modules are created to access the tables in the database, you can query and fetch from the database.

Tutorials

We have created some tutorial notebooks to help you start working with DataJoint.

  1. Querying data

    • jupyter notebook notebooks/tutorials/1-Explore U19 data pipeline with DataJoint.ipynb
  2. Building analysis pipelines

    • Recommended if you are going to create new databases or tables for analysis.
    • jupyter notebook notebooks/tutorials/2-Analyze data with U19 pipeline and save results.ipynb
    • jupyter notebook notebooks/tutorials/3-Build a simple data pipeline.ipynb

Accessing data files on your system

Major schemas in the pipeline

Click to expand details

lab

Lab Diagram

reference

Reference Diagram

subject

Subject Diagram

action

Action Diagram

acquisition

Acquisition Diagram

task

Task Diagram

behavior

Behavior data for Towers task.

Behavior Diagram

ephys_element

  • Ephys related tables were created with DataJoint Element Array Ephys, processing ephys data aquired with SpikeGLX and pre-processed by Kilosort2. For this pipeline, we are using the (acute) ephys module from element-array-ephys.

Ephys Diagram

imaging

  • Imaging pipeline processed with a customized algorithm for motion correction and CNMF for cell segmentation in matlab.

Imaging Diagram

scan_element and imaging_element

Scan element and imaging element Diagram

Datajoint features

Import datajoint as follows:

import datajoint as dj

Update a table entry

dj.Table._update(schema.Table & key, 'column_name', 'new_data')

Get list of all column names in a table (without having to issue a query or fetch)

table.heading.attributes.keys()

This also works on a query object:

schema = dj.create_virtual_module("some_schema","some_schema")
query_object = schema.Sample() & 'sample_name ="test"'
query_object.heading.attributes.keys()