SimReg has a function sim_reg for performing Bayesian Similarity Regression [1]. It returns an estimated probability of an association between ontological term sets and a binary variable, and conditional on the association: a characteristic ontological profile, such that ontological similarity to the profile increases the probability of the binary variable taking the value TRUE. The procedure has been used in the context of linking an ontologically encoded phenotype (as HPO terms) to a binary genotype (indicating the presence or absence of a rare variant within given genes) [1], so in this guide, we'll adopt the same theme.
The function accepts arguments including logical response variable y, ontologically encoded predictor variable x, and additional arguments for tuning the compromise between execution speed and precision for the procedure.
It returns an object of class sim_reg_output, which contains the pertinent information about the results of the inference. Of particular interest is the estimated probability of association, i.e. the probability that model selection indicator gamma = 1. The function prob_association can be used on the output to obtain such and estimate. Also, the posterior distribution of the characteristic ontological profile phi may be of interest, for which the function get_term_marginals can be used.
To set up an environment where we can run a simple example, we need an ontology_index object. The ontologyIndex package contains such an object - the Human Phenotype Ontology, hpo - so we load the package and the data, and proceed to create an HPO profile template and an enclosing set of terms, terms, from which we'll generate random term sets upon which to apply the function. In our setting, we'll interpret this HPO profile template as the typical phenotype of a hypothetical disease. We set template to the set HP:0005537, HP:0000729 and HP:0001873, corresponding to phenotype abnormalities 'Decreased mean platelet volume', 'Autistic behavior' and 'Thrombocytopenia' respectively.
library(ontologyIndex)
library(SimReg)
data(hpo)
set.seed(1)
template <- c("HP:0005537", "HP:0000729", "HP:0001873")
terms <- get_ancestors(hpo, c(template, sample(hpo$id, size=50)))First, we'll do an example where there is no association between x and y, and then one where there is an association.
In the example with no association, we'll fix y, with 10 TRUEs and generate the x randomly, with each set of ontological terms determined by sampling 5 random terms from terms.
y <- c(rep(TRUE, 10), rep(FALSE, 90))
x <- replicate(simplify=FALSE, n=100, expr=minimal_set(hpo, sample(terms, size=5)))Thus, our input data looks like:
y##   [1]  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE  TRUE FALSE FALSE
##  [13] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
##  [25] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
##  [37] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
##  [49] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
##  [61] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
##  [73] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
##  [85] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
##  [97] FALSE FALSE FALSE FALSEhead(x)## [[1]]
## [1] "HP:0040224" "HP:0011458" "HP:0011328" "HP:0008386" "HP:0009025"
## 
## [[2]]
## [1] "HP:0000235" "HP:0001315" "HP:0009783" "HP:0011792" "HP:0003115"
## 
## [[3]]
## [1] "HP:0002493" "HP:0001928" "HP:0008490" "HP:0001392" "HP:0000935"
## 
## [[4]]
## [1] "HP:0001476" "HP:0030133" "HP:0007477" "HP:0100261"
## 
## [[5]]
## [1] "HP:0000614" "HP:0000525" "HP:0000270" "HP:0012140" "HP:0011799"
## 
## [[6]]
## [1] "HP:0000235" "HP:0001018" "HP:0000935" "HP:0003468" "HP:0040068"Now we can call the sim_reg function to estimate the probability of an association (note: by default, the probability of an association has a prior of 0.05 and this can be set by passing a gamma_prior_prob argument), and print the mean posterior value of gamma, corresponding to our estimated probability of association.
no_assoc <- sim_reg(ontology=hpo, x=x, y=y)
prob_association(no_assoc)## [1] 0.0001543326We note that there is a low probability of association. Now, we sample x conditional on y, so that if y[i] == TRUE, then x has 2 out of the 3 terms in template added to its profile.
x_assoc <- lapply(y, function(y_i) minimal_set(hpo, c(
    sample(terms, size=5), if (y_i) sample(template, size=2))))If we look again at the first few values in x for which y[i] == TRUE, we notice that they contain terms from the template.
head(x_assoc)## [[1]]
## [1] "HP:0012638" "HP:0030669" "HP:0100261" "HP:0100491" "HP:0011314"
## [6] "HP:0005537" "HP:0001873"
## 
## [[2]]
## [1] "HP:0030680" "HP:0100240" "HP:0009126" "HP:0000236" "HP:0000729"
## [6] "HP:0001873"
## 
## [[3]]
## [1] "HP:0011554" "HP:0030178" "HP:0003115" "HP:0030332" "HP:0003474"
## [6] "HP:0001873" "HP:0005537"
## 
## [[4]]
## [1] "HP:0011004" "HP:0009126" "HP:0003119" "HP:0040069" "HP:0000729"
## [6] "HP:0005537"
## 
## [[5]]
## [1] "HP:0011792" "HP:0030332" "HP:0011182" "HP:0000598" "HP:0100240"
## [6] "HP:0001873" "HP:0005537"
## 
## [[6]]
## [1] "HP:0006915" "HP:0001634" "HP:0000759" "HP:0002493" "HP:0005537"
## [6] "HP:0001873"Now we run the procedure again with the new x and y and print the mean posterior value of gamma.
assoc <- sim_reg(ontology=hpo, x=x_assoc, y=y)
prob_association(assoc)## [1] 0.9999955We note that we infer a higher probability of association. We can also visualise the estimated characteristic ontological profile, using the function plot_term_marginals, and note that the inferred characteristic phenotype corresponds well to template.
plot_term_marginals(hpo, get_term_marginals(assoc), max_terms=8, fontsize=30)