Skip to content

Exercises and examples for the latent dynamics workshop

License

Notifications You must be signed in to change notification settings

jocksanv/latent_dynamics_workshop

Repository files navigation

Neural Latent State and Dynamics Inference Workshop

Neural recordings are high-dimensional and complex. We aim to find spatiotemporal structure in data in order to "understand" it better, but what is the right kind of structure to look for? In this workshop, we will introduce the statistical problem of inferring latent state trajectories from high-dimensional neural time series and how it is related to dimensionality reduction methods such as principal component analysis (PCA). Subsequently, we will introduce the statistically more difficult, but theoretically more satisfying inference of the latent nonlinear dynamical system. There will be hands-on components to try some of the methods.

Schedule: 11 October 2022

  • 13:30-13:45 Conda/python/code installation
  • 13:45-14:30 Lecture 1: Latent state trajectories and dimensionality reduction
  • 14:30-14:45 Break 1
  • 14:45-16:00 Hands-on 1: dimensionality reduction
  • 16:00-17:00 Lecture 2: Latent neural dynamics theory and algorithms
  • 17:00-17:15 Break 2
  • 17:15-18:15 Hands-on 2: inferring latent dynamics
  • 18:15-18:30 Summary and discussions

Conda installation

For installation of conda follow the instructions here: https://docs.conda.io/projects/conda/en/latest/user-guide/install/index.html#

Git installation (for Windows)

Windows users would need to install and work in the Git BASH terminal. For installing git, see: https://git-scm.com/downloads


Code setup:

  1. Clone the repo using git clone --recursive

  2. If you missed the --recursive option, your nlb_tools folder will be empty. Use git submodule update --init --recursive to download the submodules

  3. Make a conda environment using the requirements.txt with

    • For Linux and MacOS use conda env create -f env.yml
    • For Windows use conda env create -f env_windows.yml and then pip install jax==0.3.13 https://whls.blob.core.windows.net/unstable/cuda111/jaxlib-0.3.7+cuda11.cudnn82-cp39-none-win_amd64.whl and `pip install git+https://github.com/yuanz271/vlgpax.git
  4. Activate the conda environment using conda activate lvmworkshop

Datasets

We will be focusing on two datasets – a toy dataset of spiking data with low dimensional dynamics governed by a Van der Pol Oscillator and electrophysiological recordings from the motor cortex (M1) and dorsal premotor cortex (PMd) of a monkey during a delayed reaching task.

Van der Pol Oscillator

  • To setup this dataset move to the code pack folder using cd code_pack/ then run python generate_vdp_data.py

Monkey reaching task

  • No action required. Included in the github.com repo.

Starting Jupyter Notebook or JupyterLab

Start Jupyter Notebook by typing jupyter notebook or JupyterLab by typing jupyter lab


Contributors

  • Matt Dowling
  • Tushar Arora
  • Ayesha Vermani
  • Abel Sagodi

About

Exercises and examples for the latent dynamics workshop

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 64.8%
  • Python 35.2%