A collection of notebooks to provide examples of using data from microns-explorer.org. The repository is designed to work with mybinder.org
In July 2021, we released the data from Phase 3 of the project that includes functional and anatomical data from large scale EM reconstructions covering approximately a mm^3 . We have created some introductory notebooks to help users begin to analyze the anatomical data. There is a companion set of repositories for how to access the functional data located here ()
-
CAVESetup This notebook walks users through how to setup their environment to connect to the Connectome Annotation Versioning Engine services that are needed to access the data. When using mybinder you will need to follow this notebook each time you launch the docker image. When setting up your own machine it will only need to be followed once. All other notebooks assume you have setup an account and credentials before continuing.
-
SynapseAndAnnotationQuery This notebook shows how to query the inputs and outputs of a neuron, and then goes on to show you how to query any of the data annotation tables, including automated detection of where the neurons are, what neurons have been proofread, and so on.
-
MeshAccess Demonstrates how to download meshes of neurons from the flat and dynamic segmentation using cloud-volume and MeshParty, explaining their differences. Note the visualization components of this require
An earlier releases of the Phase 1 data from layer 2/3 used alternative data formats, and so we have alternative notebooks for accessing this data.
We've created some introductory notebooks to demonstrate some potential uses of the data. See:
- MostSynapsesInAndOut
This notebook introduces you to reading synapses and the soma valence table. It creates neuroglancer links that let you explore the inputs and outputs of individual neurons. - DashSynapseExplorer
This notebook shows you how to create dynamic scatterplots that recreate some of the results about layer 2/3 to layer 2/3 connections that were reported in Dorkenwald et al. 2019. - ImageAndSegmentationDownload
This notebook shows you how to create figures with overlaid EM and segmentation figures.
The introductory notebooks below are not intended to be run on mybinder for reasons specified below. To run them you should set up a local python environment (see these instructions).
- MeshExample This demonstrates basic 3D visualization of meshes and skeletons using vtk, as well as calculating shortest paths along a mesh. This example uses more memory than allocated to most binder instances, and may be killed during processing while using those resources.
- Render3DScaleBar This demonstrates two techinques to create 3D scale bars on 3D visualization plots. It requires access to an X windows system to view these plots.
These notebooks walk through some newer analyses studying the Phase 1 data from layer 2/3.
These include:
- Motif analysis of a proofread synaptic connectivity graph between pyramidal cells.
- Functional analysis of a subset of the same pyramidal cells based on two-photon calcium imaging. The analysis relates local connectivity to function.
- Mitochondria analysis comparing mitochondria across neuronal compartments (axon, dendrite, soma), as well as a relation between mitochondrial density and synapse density.
- Resource statistics that summarize neurite branch length and the expected completeness of the dendritic arbors in the volume.
See each directory and our biorxiv manuscript for more details.
A local environment for running the intermediate code generation scripts can be installed using the Anaconda environment installed within the binder and the postBuild
script. We highly recommend using mamba to at least resolve the initial set of dependencies.
conda install mamba -n base -c conda-forge
mamba env create -f environment.yml
conda activate micronsbinder
This installs the required python packages for running the contained code.
If you'd like to use these notebooks as part of your general jupyter environment. You'll likely need to install this environment into your ipython kernels.
conda activate micronsbinder
python -m ipykernel install --user --name=micronsbinder
You can then select this python environment when opening the relevant notebooks.
If you'd like to download the data or jupyter plugins for a specific analysis, you can use the Makefile
targets to download the data for a specific notebook directory. For example, the command for the motif analysis is:
make vignette_analysis/motifs
You can also install all data using make all
and remove all data using make clean
. See the Makefile
for more options.
The notebooks contained here make heavy use of standard python tools, but also tools built as part of the collaboration between the Connectomics group at Allen Institute, the Seung Lab at Princeton, and the Tolias lab at Baylor, along with neuroglancer (developed by Jeremy Maitin-Shepard from the Connectomics group at Google).
- neuroglancer
This is the main neuroglancer repository developed by Jeremy Maitin-Shepard. - neuroglancer Seung-lab
This is the Seung lab's fork of neuroglancer that has some alternative features added by many different Seung lab members. - NeuroglancerAnnotationUI (nglui)
This is a package principally developed by Casey Schneider-Mizell from the Allen Institute. The package helps to create a pipeline that connects pandas dataframes to neuroglancer links that visualize the contained data. - CloudVolume
This is a python library developed principally by Will Silversmith from the Seung Lab for reading and writing volumetric data (e.g. EM images, segmentation), meshes, and skeletons to a variety of storage locations (e.g. cloud buckets, chunked files). - MeshParty
This is a package developed by Sven Dorkenwald (Princeton), Forrest Collman (Allen), and Casey Schneider-Mizell (Allen) to make downloading meshes (via CloudVolume), performing analysis (with tools like trimesh, and scipy) and visualization (via vtk) of neuronal meshes easier. There are also some tools for helping make dynamic movies of these data. - DashDataFrame
This is a package developed by Leila Elabaddy, Melissa Hendershott, and Forrest Collman at the Allen Institute. It simplifies constructing dynamic visualization from pandas dataframes using Dash, including making dynamic links out to external services. In this case, we use this to make dynamic scatterplots that allow you to select variables to plot, select and filter data points, and construct neuroglancer views of the specific locations in the dataset of those data points.
We are releasing this repository as-is, and plan to update it without a fixed schedule. It is intended to be a teaching tool to start interacting with the data. Community involvement is encouraged through both issues and pull requests.