The ambitions of collaborative single cell biology will only be achieved through the coordinated efforts of many groups, to help clarify cell types and dynamics in an array of functional and environmental contexts. The use of formal ontology in this pursuit is well-motivated and research progress has already been substantial.
Bakken et al. (2017) discuss “strategies for standardized cell type representations based on the data outputs from [high-content flow cytometry and single cell RNA sequencing], including ‘context annotations’ in the form of standardized experiment metadata about the specimen source analyzed and marker genes that serve as the most useful features in machine learning-based cell type classification models.” Aevermann et al. (2018) describe how the FAIR principles can be implemented using statistical identification of necessary and sufficient conditions for determining cell class membership. They propose that Cell Ontology can be transformed to a broadly usable knowledgebase through the incorporation of accurate marker gene signatures for cell classes.
In this vignette, we review key concepts and tasks required to make progress in the adoption and application of ontological discipline in Bioconductor-oriented data analysis.
As of 1.99.0, facilities are present to import any valid OWL ontology. We use basilisk to incorporate functionality from owlready2 and bioregisty. One way of identifying a large number of ontologies available for ingestion is to query bioregistry.
bioregistry_ols_resources() br =
## + /home/biocbuild/.cache/R/basilisk/1.19.1/0/bin/conda create --yes --prefix /home/biocbuild/.cache/R/basilisk/1.19.1/ontoProc/2.1.7/bsklenv 'python=3.12.8' --quiet -c conda-forge --override-channels
## + /home/biocbuild/.cache/R/basilisk/1.19.1/0/bin/conda install --yes --prefix /home/biocbuild/.cache/R/basilisk/1.19.1/ontoProc/2.1.7/bsklenv 'python=3.12.8' -c conda-forge --override-channels
## + /home/biocbuild/.cache/R/basilisk/1.19.1/0/bin/conda install --yes --prefix /home/biocbuild/.cache/R/basilisk/1.19.1/ontoProc/2.1.7/bsklenv -c conda-forge 'python=3.12.8' 'h5py=3.13.0' --override-channels
library(DT)
datatable(br[,c(2,3)])
We can use the URLs given in this table to explore ontologies of interest. For example, the AEO (anatomical entity ontology) extends CARO (the common anatomy reference ontology). What sorts of terms are regarded as extensions?
owl2cache(url="http://purl.obolibrary.org/obo/aeo.owl") # localize OWL
aeo = setup_entities2(aeo)
aeoinr =set.seed(1234)
suppressWarnings({ # zero-length angle
onto_plot2(aeoinr, sample(grep("AEO", names(aeoinr$name), value=TRUE),12))
})
So CARO is already using some of the extensions.
Use a search facility in owlready2 to check the UBERON ontology (check the table above for references) for terms involving the substring ‘vein’:
owl2cache(url="http://purl.obolibrary.org/obo/uberon.owl")
ub = search_labels(ub, "*vein*")
allv =length(allv)
## [1] 363
head(unlist(allv))
## AEO_0000209
## "vein"
## CL_0002543
## "vein endothelial cell"
## CL_0002588
## "smooth muscle cell of the umbilical vein"
## CL_0002618
## "endothelial cell of umbilical vein"
## CL_0009094
## "endothelial cell of hepatic portal vein"
## CL_1001052
## "kidney cortex vein cell"
It is interesting to note that owlready2 includes the ability to provide relevance measurement for search results using the BM25 index. We need to add some code to capitalize on this in ontoProc.
Definitions, semantics. For concreteness, we provide some definitions and examples. We use ontology
to denote the systematic organization of terminology used in a conceptual domain. The Cell Ontology
is a graphical data structure with carefully annotated terms as nodes and conventionally defined semantic relationships among terms serving as edges. As an example, lung ciliated cell
has URI . This URI includes a fixed-length identifier CL_1000271
with unambiguous interpretation wherever it is encountered. There is a chain of relationships from lung ciliated cell
up through ciliated cell
, then native cell
, then cell
, each possessing its own URI and related interpretive metadata. The relationship connecting the more precise to the less precise term in this chain is denoted SubclassOf
. Ciliated cell
is equivalent to a native cell
that has plasma membrane part
cilium
. Semantic characteristics of terms and relationships are used to infer relationships among terms that may not have relations directly specified in available ontologies.
Barriers to broad adoption. Given the wealth of material available in biological ontologies, it is somewhat surprising that formal annotation is so seldom used in practice. Barriers to more common use of ontology in data annotation include: (i) Non-existence of exact matching between intended term and terms available in ontologies of interest. (ii) The practical problem of decoding ontology identifiers. A GO tag or CL tag is excellent for programming, but it is clumsy to co-locate with the tag the associated natural language term or phrase. (iii) Likelihood of disagreement of suitability of terms for conditions observed at the boundaries of knowledge. To help cope with the first of these problems, Bioconductor’s ontologyProc
package includes a function liberalMap
which will search an ontology for terms lexically close to some target term or phrase. The second problem can be addressed with more elaborate data structures for variable annotation and programming in R, and the third problem will diminish in importance as the value of ontology adoption becomes manifest in more applications.
Class vs. instance. It is important to distinguish the practice of designing and maintaining ontologies from the use of ontological class terms to annotate instances of the concepts. The combination of an ontology and a set of annotated instances is called a knowledge base. To illustrate some of the salient distinctions here, consider the cell line called A549, which is established from a human lung adenocarcinoma sample. There is no mention of A549 in the Cell Ontology. However, A549 is present in the EBI Experimental Factor Ontology as a subclass of the “Homo sapiens cell line” class. Presumably this is because A549 is a class of cells that are widely used experimentally, and this cell line constitutes a concept deserving of mapping in the universe of experimental factors. In the universe of concepts related to cell structure and function per se, A549 is an individual that can be characterized through possession of or lack of properties enumerated in Cell Ontology, but it is not deserving of inclusion in that ontology.
The 10X Genomics corporation has distributed a dataset on results of sequencing 10000 PBMC from a healthy donor . Subsets of the data are used in tutorials for the Seurat analytical suite (Butler et al. (2018)).
One result of the tutorial analysis of the 3000 cell subset is a table of cell types and expression-based markers of cell identity. The first three columns of the table below are from concluding material in the Seurat tutorial; the remaining columns are created by “manual” matching between the Seurat terms and terms found in Cell Ontology.
kable(stab <- seur3kTab())
grp | markers | seurTutType | formal | tag |
---|---|---|---|---|
0 | IL7R | CD4 T cells | CD4-positive helper T cell | CL:0000492 |
1 | CD14, LYZ | CD14+ Monocytes | CD14-positive monocyte | CL:0001054 |
2 | MS4A1 | B cells | B cell | CL:0000236 |
3 | CD8A | CD8 T cells | CD8-positive, alpha-beta T cell | CL:0000625 |
4 | FCGR3A, MS4A7 | FCGR3A+ Monocytes | monocyte | CL:0000576 |
5 | GNLY, NKG7 | NK cells | natural killer cell | CL:0000623 |
6 | FCER1A, CST3 | Dendritic Cells | dendritic cell | CL:0000451 |
7 | PPBP | Megakaryocytes | megakaryocyte | CL:0000556 |
Given the informally selected tags in the table above, we can sketch the Cell Ontology graph connecting the associated cell types. The ontoProc package adds functionality to ontologyPlot with make_graphNEL_from_ontology_plot
. This allows use of all Rgraphviz and igraph visualization facilities for graphs derived from ontology structures.
Here we display the PBMC cell sets reported in the Seurat tutorial, annotated using the cached 2023 version of Cell Ontology.
library(ontoProc)
getOnto("cellOnto", "2023")
cl =onto_plot2(cl, stab$tag)
It is of interest to compare to a current version of Cell Ontology. This version is imported from OWL using owl2ready, and the tags have underscore instead of colon. Here we use quickOnto which will look in the cache for a version of the OWL file that has been ingested and transformed to ontologyIndex format and tagged with suffix “OIRDS”; if no OIRDS file is found but the owl file is found it will ingest and transform and cache the RDS format of the ontologyIndex representation.
quickOnto("cl.owl")
cl =onto_plot2(cl, gsub(":", "_", stab$tag))
Aaron Lun has produced a mapping from informal terms used in the Human Primary Cell Atlas to Cell Ontology tags. We provisionally include a copy of this mapping in ontoProc:
read.csv(system.file("extdata/hpca.csv", package="ontoProc"), strings=FALSE)
hpca_map =head(hpca_map)
## uncontrolled controlled
## 1 DC:monocyte-derived:immature CL:0000840
## 2 DC:monocyte-derived:Galectin-1 CL:0000451
## 3 DC:monocyte-derived:LPS CL:0000451
## 4 DC:monocyte-derived CL:0000451
## 5 Smooth_muscle_cells:bronchial:vit_D CL:0002598
## 6 Smooth_muscle_cells:bronchial CL:0002598
We will rename columns of this map for convenience of our bind_formal_tags
method.
names(hpca_map) = c("informal", "formal") # obligatory for now
ontoProc::getOnto("cellOnto", "2023") cell_onto =
## loading from cache
subset_descendants( hpca_sce, cell_onto, "^monocyte$" )
hpca_mono =table(hpca_mono$label.fine)
##
## Monocyte Monocyte:CD14+
## 27 3
## Monocyte:CD16+ Monocyte:CD16-
## 6 7
## Monocyte:CXCL4 Monocyte:F._tularensis_novicida
## 2 6
## Monocyte:MCSF Monocyte:S._typhimurium_flagellin
## 2 1
## Monocyte:anti-FcgRIIB Monocyte:leukotriene_D4
## 2 4
table(hpca_mono$label.ont) # not much diversity
##
## CL:0000576 CL:0001054
## 57 3
subset_descendants( hpca_sce, cell_onto, "^T cell$" )
hpca_tcell =table(hpca_tcell$label.fine)
##
## T_cell:CD4+ T_cell:CD4+_Naive
## 12 6
## T_cell:CD4+_central_memory T_cell:CD4+_effector_memory
## 5 4
## T_cell:CD8+ T_cell:CD8+_Central_memory
## 16 3
## T_cell:CD8+_effector_memory T_cell:CD8+_effector_memory_RA
## 4 4
## T_cell:CD8+_naive T_cell:Treg:Naive
## 4 2
## T_cell:effector T_cell:gamma-delta
## 4 2
table(hpca_tcell$label.ont) #
##
## CL:0000624 CL:0000625 CL:0000798 CL:0000895 CL:0000900 CL:0000904 CL:0000905
## 12 16 2 6 4 5 4
## CL:0000907 CL:0000911 CL:0000913 CL:0001062 CL:0002677
## 3 4 4 4 2
unique(hpca_tcell$label.ont)
uu =onto_plot2(cell_onto, uu)
Using the ontoDiff function, you can visually identify which related terms exist in the newest provided version of an ontology but not in the old version.
getOnto("diseaseOnto") dO =
## loading from cache
getOnto(ontoname = "diseaseOnto", year_added = "2021") dO2 =
## loading from cache
c("DOID:0040064","DOID:0040076","DOID:0081127","DOID:0081126","DOID:0081131","DOID:0060034")
cl3k =ontoDiff(dO,dO2,cl3k)
The Experimental Factor Ontology is available and integrates information among diverse ontologies. Here we check on terms likely related to asthma.
getOnto("efoOnto") ef =
## loading from cache
grep("sthma", ef$name, value=TRUE)
alla <- grep("obso", alla, invert=TRUE, value=TRUE)
aa <-onto_plot2(ef, names(aa))
However, the Human Disease Ontology seems more developed in terms of defining asthma subtypes. We have not integrated that ontology into ontoProc yet, but it can be retrieved conveniently as follows:
2022_09 = get_OBO(
hdo_"https://github.com/DiseaseOntology/HumanDiseaseOntology/raw/main/src/ontology/HumanDO.obo",
extract_tags = "everything"
)
With this resource, we can see finer-grained handling of asthma subtyping:
Aevermann, Brian D., Mark Novotny, Trygve Bakken, Jeremy A. Miller, Alexander D. Diehl, David Osumi-Sutherland, Roger S. Lasken, Ed S. Lein, and Richard H. Scheuermann. 2018. “Cell type discovery using single-cell transcriptomics: Implications for ontological representation.” Human Molecular Genetics 27 (R1): R40–R47. https://doi.org/10.1093/hmg/ddy100.
Bakken, Trygve, Lindsay Cowell, Brian D. Aevermann, Mark Novotny, Rebecca Hodge, Jeremy A. Miller, Alexandra Lee, et al. 2017. “Cell type discovery and representation in the era of high-content single cell phenotyping.” BMC Bioinformatics 18 (Suppl 17). https://doi.org/10.1186/s12859-017-1977-1.
Butler, Andrew, Paul Hoffman, Peter Smibert, Efthymia Papalexi, and Rahul Satija. 2018. “Integrating Single-Cell Transcriptomic Data Across Different Conditions, Technologies, and Species.” Nature Biotechnology. https://doi.org/10.1038/nbt.4096.
Westbury, Sarah K., Ernest Turro, Daniel Greene, Claire Lentaigne, Anne M. Kelly, Tadbir K. Bariana, Ilenia Simeoni, et al. 2015. “Human Phenotype Ontology Annotation and Cluster Analysis to Unravel Genetic Defects in 707 Cases with Unexplained Bleeding and Platelet Disorders.” Genome Medicine 7 (1): 36. https://doi.org/10.1186/s13073-015-0151-5.