crantr is an R package designed to support the analysis of connectome data sets for clonal raider ants (Ooceraea biroi, formerly Cerapachys biroi). The package primarily focuses on proofread auto-segmentation data from the CRANT (Clonal Raider Ant) project. This project has a community based in the CRANT slack.
Clonal raider ants (Ooceraea biroi) are a fascinating species of ant known for their unique reproductive biology and social structure:
- They reproduce through parthenogenesis, meaning all individuals are female clones.
- They lack a queen caste, with all individuals capable of laying eggs.
- They alternate between reproductive and brood care phases in synchronized cycles.
- They exhibit collective hunting behavior, raiding other ant colonies for their larvae.
These characteristics make clonal raider ants an excellent model system for studying the neural basis of social behavior and the evolution of eusociality in insects.
At present, the connectome data for one brain is available: CRANTb, which represents the brain of a worker clonal raider ant.
The crantr package serves as a wrapper over the fafbseg package, the wrapper adds:
- Setup of necessary default paths / data redirects.
- Integration with CAVE tables for storing various annotation information.
- Relevant helper functions called from the bancr package.
- CLANT project specific data wrangling and browsing code.
You can install the development version of crantr
from GitHub:
remotes::install_github('natverse/crantr')
remotes::install_github('natverse/fafbseg@asb-dev')
To use the crantr package, you need authorisation to access CRANT resources.
Follow these steps to set up your access CAVE token, if you have been given authorisation:
# Set up token - will open your browser to generate a new token
crant_set_token()
# If you already have a token:
# crant_set_token("<my token>")
To ensure everything is set up correctly, run:
# Diagnose issues
dr_crant()
# Confirm functionality (should return FALSE)
crant_islatest("576460752684030043")
Some functions rely on underlying Python code. To install the full set of recommended libraries, including fafbseg-py
, run:
fafbseg::simple_python("full")
If you encounter errors related to cloud-volume, update it with:
fafbseg::simple_python('none', pkgs='cloud-volume~=8.32.1')
Use with_crant()
to wrap additional fafbseg::flywire_*
functions for use with CRANT data. Alternatively, use choose_crant()
to set all flywire_*
functions from fafbseg
to target CRANT.
Example:
library(crantr)
choose_crant()
# Your analysis code here
To update the package and all dependencies:
remotes::install_github('natverse/crantr')
To update a specific Python library dependency:
fafbseg::simple_python(pkgs='fafbseg')
Lindsey Lopes in the Kronauer group is interested in the olfactory system of the ant, and so some of the earliest reconstruction was done in the ant antennal lobe.
Let us look at some antennal lobe projection neurons.
If you are a collaborator on the project and have access to our seatable, you can do this:
# load library
library(crantr)
# get meta data, will one dya be available via CAVE tables
ac <- crant_table_query()
# have a look at it!
View(ac)
# filter to get our IDs
pn.meta <- ac %>%
dplyr::filter(cell_class=="olfactory_projection_neuron")
# get our ids
pn.ids <- unique(pn.meta$root_id)
If not, here are some neuron IDs to get started:
# load library
library(crantr)
# specify IDs to examine, could also be gotten from a CAVE table
pn.ids <- c("576460752684030043", "576460752688452399", "576460752688452655",
"576460752666304186", "576460752683636730", "576460752724736013")
# update these IDs to their most current versions, they change after each proofreading edit
pn.ids <- crant_latestid(pn.ids)
Now we can read mesh data for these reconstructions and plot them together with a surface model of the CRANTb
brain, using rgl
!
# fetch
pn.meshes <- crant_read_neuron_meshes(pn.ids)
# plot brain
crant_view()
plot3d(crantb.surf, col = "lightgrey", alpha = 0.1)
# plot neurons
plot3d(pn.meshes)
We can also make this plot in 2D, in the popular ggplot2
framework.
# ggplot
crant_ggneuron(pn.meshes , volume = crantb.surf)
Sometimes it is also useful for work with skeletons, for example for NBLASTing neurons. We can swiftly fetch the L2 skeletons of a neuron, built from its super-voxel locations using the python library pcg_skel, as so:
# fetch
pn.skels <- crant_read_l2skel(pn.ids)
# plot brain
nopen3d()
crant_view()
plot3d(crantb.surf, col = "lightgrey", alpha = 0.1)
# plot neurons
plot3d(pn.skels, lwd = 1)
plot3d(pn.meshes, alpha = 0.1)
When using CRANT data, please acknowledge it in accordance with the CRANT community guidelines and in agreement with the CRANT consortium.
If you use this package, please cite:
- The upcoming CRANT paper (TBD)
- The natverse paper: Bates et al. 2020
- This R package:
citation(package = "crantr")
Bates A (2024). crantr: R Client Access to the Brain And Nerve Cord (CRANT) Dataset. R package version 0.1.0, https://github.com/flyconnectome/crantr.
- CRANT data set: Collected at Harvard Medical School in the laboratory of Wei-Chung Allen Lee, by Wangchu Xiang and Lindsey Lopes.
- Segmentation and synapse prediction: Built by Zetta.ai.
- Neuron reconstruction: Hosted and supported by the laboratory of Wei-Chung Allen Lee and the Kronauer Laboratory at the Rockerfeller Institute.
- R package: Initialized using the fancr package developed by Greg Jefferis at the MRC Laboratory of Molecular Biology, Cambridge, UK.
- Development: Alexander S. Bates worked on this R package while in the laboratory of Rachel Wilson at Harvard Medical School.
Bates, Alexander Shakeel, James D. Manton, Sridhar R. Jagannathan, Marta Costa, Philipp Schlegel, Torsten Rohlfing, and Gregory SXE Jefferis. 2020. The Natverse, a Versatile Toolbox for Combining and Analysing Neuroanatomical Data. eLife 9 (April). https://doi.org/10.7554/eLife.53350.