Note
Click here to download the full example code
neuPrint#
This tutorial shows how to fetch neurons from a neuPrint server.
NeuPrint is a service for presenting and analyzing connectomics data. It is used to host, for example, the Janelia EM reconstructions from a Drosophila hemibrain at https://neuprint.janelia.org/.
neuprint-python is a Python library that lets you query data directly from a neuPrint server. You can install it from PyPI:
pip3 install neuprint-python
navis.interfaces.neuprint wraps neuprint-python and adds a few new functions to fetch and convert data into NAVis objects.
# Import navis
import navis
# Import neuprint wrapper by navis
import navis.interfaces.neuprint as neu
First set up the connection: You can either pass your API token directly or store as NEUPRINT_APPLICATION_CREDENTIALS environment variable. The latter is the recommended way and we will use it here:
client = neu.Client(
"https://neuprint.janelia.org/",
# token="MYLONGTOKEN" # use this to instead pass your token directly
dataset="hemibrain:v1.2.1",
)
You can use all of neuprint's functions:
mbons, roi_info = neu.fetch_neurons(
neu.SegmentCriteria(instance=".*MBON.*", regex=True)
)
mbons.head(3)
NAVis has added three functions to neu:
navis.interfaces.neuprint.fetch_roi: returns anavis.Volumefrom a ROInavis.interfaces.neuprint.fetch_skeletons: returns fully fledgednavis.TreeNeurons- nodes, synapses, soma and allnavis.interfaces.neuprint.fetch_mesh_neuron: returnsnavis.MeshNeurons- including synapses
Let's start by fetching the mesh for the right mushroom body ROI:
mb = neu.fetch_roi("MB(R)")
mb
Out:
<navis.Volume(name=MB(R), units=1 dimensionless, color=(0.85, 0.85, 0.85, 0.2), vertices.shape=(57913, 3), faces.shape=(115856, 3))>
Next, let's fetch the skeletons of all right MBONs:
mbon_skeletons = neu.fetch_skeletons(
neu.SegmentCriteria(instance=".*MBON.*_R", regex=True), with_synapses=True
)
mbon_skeletons.head()
Out:
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 5.11it/s]
100%|##########| 1/1 [00:00<00:00, 5.10it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 10.71it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 9.90it/s]
100%|##########| 1/1 [00:00<00:00, 9.89it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 6.52it/s]
100%|##########| 1/1 [00:00<00:00, 6.51it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 2.14it/s]
100%|##########| 1/1 [00:00<00:00, 2.14it/s]
100%|##########| 1/1 [00:00<00:00, 3.26it/s]
100%|##########| 1/1 [00:00<00:00, 3.26it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 10.11it/s]
100%|##########| 1/1 [00:00<00:00, 1.40it/s]
100%|##########| 1/1 [00:00<00:00, 1.40it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 1.04it/s]
100%|##########| 1/1 [00:00<00:00, 1.04it/s]
100%|##########| 1/1 [00:00<00:00, 1.40it/s]
100%|##########| 1/1 [00:00<00:00, 1.40it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 1.63it/s]
100%|##########| 1/1 [00:00<00:00, 1.63it/s]
100%|##########| 1/1 [00:00<00:00, 7.38it/s]
100%|##########| 1/1 [00:00<00:00, 7.38it/s]
100%|##########| 1/1 [00:00<00:00, 2.88it/s]
100%|##########| 1/1 [00:00<00:00, 2.88it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 20.96it/s]
100%|##########| 1/1 [00:00<00:00, 11.76it/s]
100%|##########| 1/1 [00:00<00:00, 10.20it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 7.85it/s]
100%|##########| 1/1 [00:00<00:00, 7.84it/s]
100%|##########| 1/1 [00:00<00:00, 1.32it/s]
100%|##########| 1/1 [00:00<00:00, 1.32it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 4.02it/s]
100%|##########| 1/1 [00:00<00:00, 4.02it/s]
100%|##########| 1/1 [00:00<00:00, 12.56it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 11.40it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 1.73it/s]
100%|##########| 1/1 [00:00<00:00, 1.73it/s]
100%|##########| 1/1 [00:00<00:00, 2.48it/s]
100%|##########| 1/1 [00:00<00:00, 2.48it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:01<00:00, 1.23s/it]
100%|##########| 1/1 [00:01<00:00, 1.23s/it]
100%|##########| 1/1 [00:00<00:00, 2.24it/s]
100%|##########| 1/1 [00:00<00:00, 2.24it/s]
100%|##########| 1/1 [00:00<00:00, 1.50it/s]
100%|##########| 1/1 [00:00<00:00, 1.50it/s]
100%|##########| 1/1 [00:00<00:00, 2.61it/s]
100%|##########| 1/1 [00:00<00:00, 2.61it/s]
100%|##########| 1/1 [00:00<00:00, 2.28it/s]
100%|##########| 1/1 [00:00<00:00, 2.28it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 2.65it/s]
100%|##########| 1/1 [00:00<00:00, 2.65it/s]
100%|##########| 1/1 [00:00<00:00, 2.19it/s]
100%|##########| 1/1 [00:00<00:00, 2.19it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 2.05it/s]
100%|##########| 1/1 [00:00<00:00, 2.05it/s]
100%|##########| 1/1 [00:00<00:00, 1.76it/s]
100%|##########| 1/1 [00:00<00:00, 1.75it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 5.96it/s]
100%|##########| 1/1 [00:00<00:00, 5.96it/s]
100%|##########| 1/1 [00:00<00:00, 4.19it/s]
100%|##########| 1/1 [00:00<00:00, 4.19it/s]
100%|##########| 1/1 [00:00<00:00, 1.24it/s]
100%|##########| 1/1 [00:00<00:00, 1.24it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 15.56it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 2.41it/s]
100%|##########| 1/1 [00:00<00:00, 2.41it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 3.40it/s]
100%|##########| 1/1 [00:00<00:00, 3.40it/s]
100%|##########| 1/1 [00:00<00:00, 2.23it/s]
100%|##########| 1/1 [00:00<00:00, 2.23it/s]
100%|##########| 1/1 [00:00<00:00, 2.13it/s]
100%|##########| 1/1 [00:00<00:00, 2.13it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 1.84it/s]
100%|##########| 1/1 [00:00<00:00, 1.84it/s]
100%|##########| 1/1 [00:00<00:00, 2.54it/s]
100%|##########| 1/1 [00:00<00:00, 2.54it/s]
0%| | 0/1 [00:00<?, ?it/s]
100%|##########| 1/1 [00:00<00:00, 3.60it/s]
100%|##########| 1/1 [00:00<00:00, 3.60it/s]
100%|##########| 1/1 [00:00<00:00, 2.18it/s]
100%|##########| 1/1 [00:00<00:00, 2.18it/s]
Co-visualize the MBONs and the MB volume:
navis.plot3d(
[mbon_skeletons[0], mb],
legend=False, # Hide the legend (more space for the plot)
)
Last (but not least), let's make a 2d plot for the tutorial's thumbnail:
import matplotlib.pyplot as plt
fig, ax = navis.plot2d(
[mbon_skeletons[0], mb],
c=(0, 0, 0, 1), # Make the neuron black
method="3d",
connectors=True,
linewidth=0.5, # Make neuron a bit thinner to emphasize the synapses
view=("x", "-z"),
)
plt.tight_layout()
All NAVis functions for analysis & visualization should work on these neurons. If not, please open an issue on Github.
Total running time of the script: ( 0 minutes 37.612 seconds)
Download Python source code: tutorial_remote_00_neuprint.py
Download Jupyter notebook: tutorial_remote_00_neuprint.ipynb
