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}
}
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.
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 filebrain_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 thefunctional_connectivity
andbrain_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 folderexperiment_analysis/dat/spikes/
.
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)
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.
Here we summarize which plot comes from which notebook so you can trace back the ingredients that went in.
- Figure 1
- Figure 2
- Figure 3
- Figure 4
-
Figure S1
- [`experiment_legacy/plotting/allen_fc_number_of_units.py]
-
Figure S7 (Illustrates the autocorrelation fits)
-
Figure S11 (Similar to Fig 2 but for the natural movie three condition of the Brain Observatory 1.1 data set)
-
Figure S12 (Similar to Fig 2 but for spontaneous activity in the Functional Connectivity data set)
-
Figures S13-S16 (Posterior distributions for hierarchical parameters for both models)
-
Figures S17 and S18 (Posterior distributions for non-hierarchical parameters for both models)
-
Figures S19-S21 (Posterior predictive checks for both hierarchical models for all three stimulus conditions)
-
Figure S22 (Area-wise comparison of timescales and predictability between stimulus conditions)
-
Figure S23 and S25 (Areawise plot of timescales and predictability vs stimulus selectivity measures)
-
Figure S24 (Plot of timescales and predictability vs image selectivity)