RESOLVE R packageRESOLVE 1.11.2
Cancer is a genetic disease caused by somatic mutations in genes controlling key biological functions such as cellular growth and division. Such mutations may arise both through cell-intrinsic and exogenous processes, generating characteristic mutational patterns over the genome named mutational signatures. The study of mutational signatures have become a standard component of modern genomics studies, since it can reveal which (environmental and endogenous) mutagenic processes are active in a tumor, and may highlight markers for therapeutic response.
Mutational signatures computational analyses fall mostly within two categories: (i) de novo signatures extraction and (ii) signatures exposure estimation. In the first case, the presence of mutational processes is first assessed from the data, signatures are identified and extracted and finally assigned to samples. This task is typically performed by Non-Negative Matrix Factorization (NMF). While other approaches have been proposed, NMF-based methods are by far the most used. The estimation of signatures exposures is performed by holding a set of signatures fixed (see, e.g., COSMIC mutational signatures catalogue) and assigning them to samples by minimizing, e.g., mean squared error between observed and estimated mutational patterns for each sample.
However, available mutational signatures computational tools presents many pitfalls. First, the task of determining the number of signatures is very complex and depends on heuristics. Second, several signatures have no clear etiology, casting doubt on them being computational artifacts rather than due to mutagenic processes. Last, approaches for signatures assignment are greatly influenced by the set of signatures used for the analysis. To overcome these limitations, we developed RESOLVE (Robust EStimation Of mutationaL signatures Via rEgularization), a framework that allows the efficient extraction and assignment of mutational signatures.
The RESOLVE R package implements a new de novo signatures extraction algorithm, which employs a regularized Non-Negative Matrix Factorization procedure. The method incorporates a background signature during the inference step and adopts elastic net regression to reduce the impact of overfitting. The estimation of the optimal number of signatures is performed by bi-cross-validation. Furthermore, the package also provide a procedure for confidence estimation of signatures activities in samples.
Additionally, RESOLVE enables the precise stratification of cancer genomes based on mutational signatures, allowing for the identification of key signatures that drive specific cancer subtypes. Beyond de novo extraction, assignment, and confidence estimation, RESOLVE also supports patient clustering, survival analysis to identify risk groups linked to distinct mutational processes, and the investigation of associations between mutational signatures and driver gene mutations. These advanced capabilities offer deeper insights into tumorigenesis mechanisms, their prognostic relevance, and potential therapeutic targets.
As such, RESOLVE represents an addition to other Bioconductor packages, such as, e.g., SparseSignatures, MutationalPatterns, musicatk among others, that implements a novel approach for detecting mutational signatures.
In this vignette, we give an overview of the package by presenting some of its main functions.
The RESOLVE package can be installed from Bioconductor as follow.
if (!require("BiocManager", quietly = TRUE))
    install.packages("BiocManager")
BiocManager::install("RESOLVE")We now present some of the main features of the package. We notice that the package supports different types of mutational signatures such as: SBS (single base substitutions) and MNV (multi-nucleotide variant) (see Degasperi, Andrea, et al. “Substitution mutational signatures in whole-genome–sequenced cancers in the UK population.” Science 376.6591 (2022): abl9283), CX (chromosomal instability) (see Drews, Ruben M., et al. “A pan-cancer compendium of chromosomal instability.” Nature 606.7916 (2022): 976-983) and CN (copy number) signatures (see Steele, Christopher D., et al. “Signatures of copy number alterations in human cancer.” Nature 606.7916 (2022): 984-991). But, for the sake of this vignette, we present only results on the classical SBS signatures. We refer to the manual for details.
First, we show how to load example data and import them into a count matrix to perform the signatures analysis.
library("RESOLVE")
data(ssm560_reduced)These data are a reduced version of the 560 breast tumors provided by Nik-Zainal, Serena, et al. (2016) comprising only 3 patients. We notice that these data are provided purely as an example, and, as they are a reduced and partial version of the original dataset, they should not be used to draw any biological conclusion.
We now import such data into a count matrix to perform the signatures discovery. To do so, we also need to specify the reference genome as a BSgenome object to be considered. This can be done as follows, where in the example we used hs37d5 as reference genome as provided as data object within the package.
library("BSgenome.Hsapiens.1000genomes.hs37d5")
imported_data = getSBSCounts(data = ssm560_reduced, reference = BSgenome.Hsapiens.1000genomes.hs37d5)Now, we present an example of visualization feature provided by the package, showing the counts for the first patient, i.e., PD10010a, in the following plot.
patientsSBSPlot(trinucleotides_counts=imported_data,samples="PD10010a")## Warning: `aes_string()` was deprecated in ggplot2 3.0.0.
## ℹ Please use tidy evaluation idioms with `aes()`.
## ℹ See also `vignette("ggplot2-in-packages")` for more information.
## ℹ The deprecated feature was likely used in the RESOLVE package.
##   Please report the issue at <https://github.com/danro9685/RESOLVE/issues>.
## This warning is displayed once every 8 hours.
## Call `lifecycle::last_lifecycle_warnings()` to see where this warning was
## generated.
Figure 1: Visualization of the counts for patient PD10010a from the dataset published in Nik-Zainal, Serena, et al
After the data are loaded, we can perform signatures de novo extraction. To do so, we need to define a range for the number of signatures (variable K) to be considered. We now show how to perform the inference on the dataset from Nik-Zainal, Serena, et al. (2016), whose counts are provided within the package.
data(background)
data(patients)
set.seed(12345)
res_denovo = signaturesDecomposition(x = patients, 
                                     K = 1:15, 
                                     background_signature = background, 
                                     nmf_runs = 100, 
                                     num_processes = 50)We notice that this function can be also used to perform de novo estimation for other types of mutational signatures, such as SBS, MNV, CX and CN.
Now that we have performed the de novo inferece, we need to decide the optimal number of signatures to be extracted from our dataset. To do so, we provide a procedure based on cross-validation.
set.seed(12345)
res_cv = signaturesCV(x = patients, 
                      beta = res_denovo$beta, 
                      cross_validation_repetitions = 100, 
                      num_processes = 50)The computations for this task can be very time consuming, especially when many iterations of cross validations are performed (see manual) and a large set of configurations of the parameters are tested.
We refer to the manual for a detailed description of each parameter and to the RESOLVE manuscript for details on the method.
RESOLVE also allows researchers to perform downstream analyses once mutational signatures have been inferred. 1) It enables signatures-based clustering, using the k-medoids method to group patients with similar active mutational processes. Additionally, 2) it provides features to explore associations between signatures and somatic mutations, identifying links both from signatures to specific mutations and vice versa. Finally, 3) RESOLVE can examine the relationship between signature exposures and prognosis, providing insights into the clinical implications of different mutational processes. By integrating these analyses, RESOLVE enhances our understanding of the biological and clinical relevance of mutational signatures.
We next describe how to perform these three analyses with the RESOLVE R package.
Signatures-based clustering can be performed with the signaturesClustering functions, which takes as input exposures of signatures to patients. We suggest to provide normalized exposures.
data(sbs_assignments)
set.seed(12345)
norm_alpha = (sbs_assignments$alpha / rowSums(sbs_assignments$alpha))
sbs_clustering = signaturesClustering(alpha = norm_alpha, num_clusters = 1:3, num_processes = 1, verbose = FALSE)Associations of signatures exposures to somatic mutations in driver genes can be performed either with the associationAlterations function or the associationSignatures function via regularized regression. In the first case, mutations are the predictors of the regression and the signatures exposures the target varibles, which in the second case regularized logistic regression is performed with the mutations being the target varibles.
data(association_mutations)
set.seed(12345)
alterations = association_mutations$alterations
normalized_alpha = association_mutations$normalized_alpha
association_alterations = associationAlterations(alterations = alterations, signatures = normalized_alpha)data(association_mutations)
set.seed(12345)
alterations = association_mutations$alterations
normalized_alpha = association_mutations$normalized_alpha
association_signatures = associationSignatures(alterations = alterations, signatures = normalized_alpha)Finally, signatures exposures can be associated to prognosis via regularized Cox regression with the associationPrognosis function. The results of this analysis are a set of coefficients measuring the impact of each signatures to prognosis, with positive values representing positive association with risk (bad prognosis) and negative values representing negative association with risk (better prognosis).
data(association_survival)
set.seed(12345)
clinical_data = association_survival$clinical_data
normalized_alpha = association_survival$normalized_alpha
prognosis_associations = associationPrognosis(clinical_data = clinical_data, signatures = normalized_alpha)Also in this case, we refer to the manual for a detailed description of each parameter and to the RESOLVE manuscript for details on the method.
sessionInfo()## R version 4.5.1 Patched (2025-08-23 r88802)
## Platform: x86_64-pc-linux-gnu
## Running under: Ubuntu 24.04.3 LTS
## 
## Matrix products: default
## BLAS:   /home/biocbuild/bbs-3.22-bioc/R/lib/libRblas.so 
## LAPACK: /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3.12.0  LAPACK version 3.12.0
## 
## locale:
##  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
##  [3] LC_TIME=en_GB              LC_COLLATE=C              
##  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
##  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
##  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
## [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
## 
## time zone: America/New_York
## tzcode source: system (glibc)
## 
## attached base packages:
## [1] stats4    stats     graphics  grDevices utils     datasets  methods  
## [8] base     
## 
## other attached packages:
##  [1] BSgenome.Hsapiens.1000genomes.hs37d5_0.99.1
##  [2] BSgenome_1.77.2                            
##  [3] rtracklayer_1.69.1                         
##  [4] BiocIO_1.19.0                              
##  [5] Biostrings_2.77.2                          
##  [6] XVector_0.49.1                             
##  [7] GenomicRanges_1.61.5                       
##  [8] Seqinfo_0.99.2                             
##  [9] IRanges_2.43.5                             
## [10] S4Vectors_0.47.4                           
## [11] RESOLVE_1.11.2                             
## [12] bigmemory_4.6.4                            
## [13] Biobase_2.69.1                             
## [14] BiocGenerics_0.55.1                        
## [15] generics_0.1.4                             
## [16] BiocStyle_2.37.1                           
## 
## loaded via a namespace (and not attached):
##  [1] bitops_1.0-9                gridExtra_2.3              
##  [3] rlang_1.1.6                 magrittr_2.0.4             
##  [5] gridBase_0.4-7              matrixStats_1.5.0          
##  [7] compiler_4.5.1              vctrs_0.6.5                
##  [9] reshape2_1.4.4              ggalluvial_0.12.5          
## [11] stringr_1.5.2               pkgconfig_2.0.3            
## [13] shape_1.4.6.1               crayon_1.5.3               
## [15] fastmap_1.2.0               magick_2.9.0               
## [17] labeling_0.4.3              Rsamtools_2.25.3           
## [19] rmarkdown_2.30              pracma_2.4.4               
## [21] UCSC.utils_1.5.0            tinytex_0.57               
## [23] xfun_0.53                   glmnet_4.1-10              
## [25] cachem_1.1.0                GenomeInfoDb_1.45.12       
## [27] jsonlite_2.0.0              SnowballC_0.7.1            
## [29] DelayedArray_0.35.3         uuid_1.2-1                 
## [31] BiocParallel_1.43.4         parallel_4.5.1             
## [33] cluster_2.1.8.1             R6_2.6.1                   
## [35] bslib_0.9.0                 stringi_1.8.7              
## [37] RColorBrewer_1.1-3          jquerylib_0.1.4            
## [39] Rcpp_1.1.0                  bookdown_0.45              
## [41] SummarizedExperiment_1.39.2 iterators_1.0.14           
## [43] knitr_1.50                  Matrix_1.7-4               
## [45] splines_4.5.1               nnls_1.6                   
## [47] tidyselect_1.2.1            dichromat_2.0-0.1          
## [49] abind_1.4-8                 yaml_2.3.10                
## [51] doParallel_1.0.17           codetools_0.2-20           
## [53] curl_7.0.0                  lattice_0.22-7             
## [55] tibble_3.3.0                plyr_1.8.9                 
## [57] withr_3.0.2                 S7_0.2.0                   
## [59] evaluate_1.0.5              survival_3.8-3             
## [61] MutationalPatterns_3.19.1   pillar_1.11.1              
## [63] lsa_0.73.3                  BiocManager_1.30.26        
## [65] MatrixGenerics_1.21.0       rngtools_1.5.2             
## [67] foreach_1.5.2               RCurl_1.98-1.17            
## [69] ggplot2_4.0.0               scales_1.4.0               
## [71] NMF_0.28                    RhpcBLASctl_0.23-42        
## [73] glue_1.8.0                  tools_4.5.1                
## [75] data.table_1.17.8           GenomicAlignments_1.45.4   
## [77] registry_0.5-1              XML_3.99-0.19              
## [79] grid_4.5.1                  colorspace_2.1-2           
## [81] restfulr_0.0.16             cli_3.6.5                  
## [83] bigmemory.sri_0.1.8         S4Arrays_1.9.1             
## [85] dplyr_1.1.4                 gtable_0.3.6               
## [87] sass_0.4.10                 digest_0.6.37              
## [89] SparseArray_1.9.1           rjson_0.2.23               
## [91] farver_2.1.2                htmltools_0.5.8.1          
## [93] lifecycle_1.0.4             httr_1.4.7