CompSign: An R package for differential abundance of compositional mutational signatures
Lena Morrill Gavarró 2024
Pandoc is required to build R Markdown vignettes - please install it before installing the package as follows:
install.packages('devtools') ## if needed
library(devtools)
devtools::install_github("lm687/CompSign", build_vignettes = TRUE)
We recommend browing the vignettes for a more in-depth explanation of models and the functioning of the package, several examples of input data, how to run several models, and how to interpret the results. You can find the vignette here:
browseVignettes("CompSign")
or directly online without need of installing the package.
This is a minimal example for running the model and extracting the estimated coefficients.
The input dataset is the argument object
, which is a list with the following structure:
x
: covariate matrix (p x n
)z
: matrix of random effects indicating which patient-specific subsample belongs to which patient (n x N
)Y
(n x d
)
The function wrapper_run_TMB()
is used to run all variations of the model.
A minimal example is:
diagDM_no_small_sigs <- wrapper_run_TMB(object = simplified_object,
model = "diagRE_DM", use_nlminb=T, smart_init_vals=F)
in which simplified_object
is a list containing simplified_object$x
, simplified_object$z
, simplified_object$Y
. The object
input for wrapper_run_TMB
is always a list containing a matrix of covariates x
, a matrix of observations Y
and a matrix matching observations patients and the labels corresponding to the random effects. All three matrices should have the same number of rows - the number of observations. In this case, simplified_object
corresponds to the nucleotides abundances in clonal and subclonal mutations in the Lung-AdenoCA cohort. simplified_object$x
, contains two columns (a column of 1 for the intercept and a column of 0 and 1 indicating whether the observation corresponds to clonal (0) or subclonal (1) mutations. simplified_object$z
contains a matrix where each observation is paired with its corresponding patient, simplified_object$Y
is a matrix of counts for the nucleotide abundances for each patient and (clonal/subclonal) group.
Here we are using the model diagRE_DM
, which is a mixed-effect Dirichlet-multinomial model with non-correlated random effects and two dispersion parameters (one per group). See below for the list of alternative models available.
You can load simplified_object
, as well as several other example datasets, using the data
funtion:
data(package='CompSign')
data(simplified_object)
Depending on the model, the output of wrapper_run_TMB
contains the estimated values of different coefficients. The parameters of interest are beta_0
, beta_1
and lambda
. Both beta
are values in log-ratio space in with respect to the last category included in the input object
for wrapper_run_TMB
(i.e. the last colun of object$Y
). beta_0
indicates the coefficient for the baseline - in the two-group example of simplified_object
, this baseline reflects the abundance in the first (clonal) group. beta_1
indicates the cofficient for the second column - here representing the difference between clonal and subclonal mutations. If beta_1
is a vector of 0, this indicates that none of the log-ratios of abundances have changed between the two groups, and hence that there is no differential abundance.
To test for differential abundance, a generalised Wald test can be used with the function wald_TMB_wrapper
, which gives a p-value as output:
wald_TMB_wrapper(diagDM_no_small_sigs)
The estimated beta
coefficients can be visualised as follows:
library(ggplot2)
plot_betas(diagDM_no_small_sigs, return_ggplot = T)
The interest of the user is generally on which categories increase or decrease in absolute terms. This is not possible in compositional data, but, assuming that the abundance of most categories does not change, we can visualise which categories deviate highly from the median coefficient. This visualisation can be generated with plot_betas_minimal_perturbation
. The red line is the line of “zero perturbation” and for each estimate its 95% confidence interval is shown in blue. We can consider a signature to be differentially abundant if the line of “zero perturbation” is not included in the confidence interval of its coefficient for differential abundance. Note that we draw conclusions for the signatures included in the numerator of the log-ratios, but we are unable to get equivalent results for the baseline signature (although it is used to compute the line of “zero perturbation”).
plot_betas_minimal_perturbation(diagDM_no_small_sigs)
In the example above, nucleotide abundances are used as input. Alternatively, mutational signatures (as counts) and be used instead. If signatures have not yet been extracted, this can be done with the wrapper function extract_sigs_TMB_obj
and using as input a mutation matrix (commonly, a matrix with trinucleotide mutations; see more details in the Vignette).
CompSign
has been applied to study the differences in mutational signatures between clonal and subclonal mutations in the PCAWG dataset. The github repository reproducing these results can be found here.
There are several variations on the model, each with a particular combination of the following:
- Base model: Dirichlet-multinomial in most cases, but two simpler models -- multinomial models
diagRE_M
andfullRE_M
are implemented for comparison. - Random effects: correlated or not (e.g. uncorrelated in
diagRE_DM
, correlated infullRE_DM
). - Number of dispersion parameters: generally one per group (e.g. in
diagRE_DM
), but possibly fewer or more if specified in the name (e.g. one single dipersion parameter indiagRE_DM_singlelambda
, one dispersion parameter per patient indiagRE_DM_patientlambda
).
The names of the model correspond to {random effects}_{base model}_{particularities of the dispersion parameter, if any}
.
The first column is the <model>
argument in the function wrapper_run_TMB()
.
Name of model (for user) | Description and usage |
---|---|
FE_DM_singlelambda |
Dirichlet-multinomial with no RE and a single lambda which can be used in a two-group comparison (if we consider the dipersion to be the same in both groups), a multi-group comparison, or any regression setting. |
FE_DM |
Dirichlet-multinomial with no random effects and two lambda , used for the comparison between two groups in which we want to account for group-specific dispersion. Model slightly more complex than FE_DM_singlelambda |
diagRE_M |
Multinomial with non-correlated multivariate effects. Simpler model than diagRE_DM , as no dispersion is included |
diagRE_DM_singlelambda |
Dirichlet-multinomial with non-correlated multivariate RE and one: equivalent of diagRE_DM but with a shared . It can be used in a two-group comparison (if we consider the dipersion to be the same in both groups), a multi-group comparison, or any regression setting. |
singleRE_DM |
Dirichlet-multinomial with a single RE intercept and two lambda : simple model in which random effects are not multivariate, but where group-specific dispersion is needed, in a two-group comparison. |
diagRE_DM |
Dirichlet-multinomial with independent RE and two lambda : used most commonly throughout the paper. The data are matched to warrant multivariate RE, but correlations between categories are not explicitly modelled. Faster than fullRE_DM with often comparable results for beta_1 . |
fullRE_DM_singlelambda |
Dirichlet-multinomial with correlated RE and two lambdab: equivalent of diagR_DM_singlelambda that can be used if categories have strong correlations. |
fullRE_M |
Multinomial with correlated RE: assuming no overdispersion, it can be used in any regression setting |
fullRE_DM |
Dirichlet-multinomial with correlated RE and two lambda : model with multivariate RE with correlations modelled explicitly. As a (K-1)*(K-1) covariance matrix is estimated, this model is not recommended where the ratio of signatures to samples is high. |
diagRE_DM_patientlambda |
Dirichlet-multinomial with non-correlated RE and one lambda$ per patient: model more complex than diag_RE_DM that can be used when there are several observations per patient and we wish to include a patient-specific dispersion parameter |
fullRE_DM_patientlambda |
Dirichlet-multinomial with correlated RE and one per patient: equivalent of diagRE_DM_patientlambda , but modelling correlations between categories |