Skip to content

Signatures of hierarchical temporal processing in the mouse visual system

Notifications You must be signed in to change notification settings

Priesemann-Group/mouse_visual_timescales

Repository files navigation

Code repository: Signatures of hierarchical temporal processing in the mouse visual system

This repository contains the analysis pipeline and plotting routines for our paper @PLOS Computational Biology.

@article{rudelt2024signatures,
  title={Signatures of hierarchical temporal processing in the mouse visual system},
  author={Rudelt, Lucas and Gonz{\'a}lez Marx, Daniel and Spitzner, F Paul and Cramer, Benjamin and Zierenberg, Johannes and Priesemann, Viola},
  journal={PLOS Computational Biology},
  volume={20},
  number={8},
  pages={e1012355},
  year={2024},
  publisher={Public Library of Science San Francisco, CA USA}
}

Refactoring Note

We are currently cleaning this repository.

This requires converting all scripts to a new data backend, using our prepared spiking data in a minimal format (to avoid AllenSDK dependencies to just reproduce the paper).

The current state is as follows:

  • branching_network/ BN simulation results are independent, self-contained and up to date.
  • experiment_analysis/ contains updated scripts.
  • experiment_legacy/ contains the old scripts, which are not compatible with the new data format, and instead the AllenSDK.
  • we provide the new data format and the intermediate analysis results in the old format (for legacy plot scripts), in the data repository on gin.g-node.org.

Data

We analyse data of mouse visual cortex from the Allen Brain Atlas. The data is accessed using the Allen SDK. For convenience, we provide a copy of the preprocessed data that is compatible with our analysis pipeline on gin.g-node.org. Loading these files requires only minimal dependencies and should be easy to setup using our environment.yaml. All use of these data must comply with the orignal sources' Terms of Use.

Instructions on how to download the original data can be found in the docs. In the folder experiment_analysis/download/ we provide scripts that download and preprocess the spike data and related metrics. For these scripts to work you will have to change the path in data_directory = os.path.abspath("/path/to/repo/experiment_analysis/dat/") to your local path.

  • download_csv_files.py downloads csv files containing information regarding the experimental sessions, probes, channels and sorted unit, as well as other analysis metrics such as stimulus selectivity. This will create a file brain_observatory_unit_metrics_filtered.csv, which is required for further analysis regarding stimulus selectivity.
  • download_session_data.py downloads the full session data containing spike data for each experimental session of both the functional_connectivity and brain_observatory_1_1 experiments
  • if this does not work well, you can also execute download_session_data_via_http.py to download the data directly using http (see docs for more info)
  • write_spike_times_hdf5.py to create h5 files from the raw data that contain the spiketimes for each session and are required for further analysis. Alternatively, these files can be downloaded from gin.g-node.org under the folder experiment_analysis/dat/spikes/.

Analysis

Experiments

Because the analysis takes some compute, we provide the results in the data repository. This data does not include the metric csvs, which are also needed. Use download_csv_files.py.

All analysis run on our preprocessed spiking data. Requirements can be installed by creating a new conda environment

conda env create -f environment.yaml --name mouse_visual_timescales
conda activate mouse_visual_timescales

There are two notebooks (with only minor differences) to analyse stimulated and spontaneous activity.

In short, they:

  • set data directories (adjust this as needed!)
  • load spikes and metadata
  • setup the hde and mr estimators
  • run the analysis using dask.
  • if you want to explore this on your laptop, the full_analysis() function is of interest, and you can use local compute by altering the last big cell:
with ExitStack() as stack:
    dask_cluster = stack.enter_context(
        LocalCluster(local_directory=f"{tempfile.gettempdir()}/dask/")
    )
    dask_cluster.scale(cores=num_cores)
    dask_client = stack.enter_context(Client(dask_cluster))

    final_df = main(dask_client, meta_df)

Branching Network

We again provide the simulation results in the data repository

The full analysis is contained in bn_analysis.ipynb. It is also designed to loop on a dask cluster.

  • The full analysis for one neuron takes one hour on one core.
  • The notebook scans the directory specified, extracts the coordinates to pass what filenames each dask worker has to analyse.
  • the hdestimator_wrapper is planned to become part of hdesitmator itself. For now, it temporarily stores all the output to disk and then reads it back to provide a dict, and cleans up.

Plotting

Here we summarize which plot comes from which notebook so you can trace back the ingredients that went in.

Main paper

Supplementary material

About

Signatures of hierarchical temporal processing in the mouse visual system

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published