The purpose of this vignette is to help you become productive as quickly as possible with the multiSight package.
R version: R version 4.2.1 (2022-06-23)
Bioconductor version:
3.16
Package version:
1.6.0
You can install the released version of multiSight from Bioconductor with:
#To install this package ensure you have BiocManager installed
if (!requireNamespace("BiocManager", quietly = TRUE))
install.packages("BiocManager")
#The following initializes usage of Bioc devel
BiocManager::install("multiSight")
multiSight is an R package providing a graphical interface to analyze and explore your omic datasets (e.g. RNAseq, RPPA) by both single-omics and multi-omics approaches.
Single-omics means Differential Expression Analysis (DEA) is led by DESeq2 towards Over Representation Analysis (ORA). Features with DEA p-values under the 0.05 threshold, or user’s value set in the Biological Insight tab, are selected. These features are saved to carry out ORA on several databases (see Biological insights tab section).
Multi-omics is defined by substituting the DEA part by sPLS-DA method. This is a multi-block selection features method taking several omic blocks into account to select features (see sPLS-DA section). Biological processes (BPs) from a database (e.g. Reactome) are then enriched with these selected features by ORA to reveal putative altered biological processes.
Enrichment results obtained by ORAs are tables with BP IDs, descriptions and p-values. An enrichment table is provided for each omic data block and for each database. multiSight proposes easing enrichment results interpretation from several omic datasets. For each BP shared between enrichment results from a given database, the relative p-values are merged. Stouffer’s pooling method is used to calculate probabilities fusion (see Multi-omics table section). For instance, if “signaling by ERBB2” is highlighted by ORAs of RNAseq and RPPA features with p-values of 0.06 and 0.10, Stouffer’s method calculates a probability of 0.0224 for this pathway. Thereby, multi-omics information is harnessed to make decision of significance.
Stouffer’s p-values for BP beget a multi-omics table where BP IDs, description and Stouffer’s p-values are provided. This multi-omics enrichment table is used to draw an enrichment map.
Enrichment map is a network based on BPs information. BPs are nodes while the bonds are built between BPs sharing some features (see Multi-omics enrichment map section).
In addition, classification models are fitted to select few subsets of features, using biosigner or sPLS-DA methods. biosigner provides one model by omic block and one list of features named biosignature. Nevertheless, sPLS-DA biosignatures are based on more features than biosigner.
Biosignatures can be used:
Moreover, numerical relationships between features selected by sPLS-DA or biosigner can feed network inferences (for instance by correlation or mutual information, see Assumption tab section).
multiSight package provides a graphical interface and relative functions to use in a script.
multiSight allows to get better biological insights for each omic dataset based on four analytic modules:
All figures and tables can be retrieved in an automatic report.
All types of omic data respecting input format are supported to build classification models, biosignatures and network inference.
This package supports all numerical matrices.
You can take a look on data format supported in Home tab details.
This is the first tab of multiSight.
In this tab, you can load your biological data and find all results in a generated report (.html or .doc formats).
You should provide two types of data: numerical matrices and classes vector as csv tables for the same samples.
Omic data 1 | ||||
---|---|---|---|---|
SIGIRR | SIGIRR | MANSC1 | ||
AOFJ | 0 | 150 | 1004 | … |
A13E | 34 | 0 | 0 | |
… |
Omic data 2 | ||||
---|---|---|---|---|
ENSG00000139618 | ENSG00000226023 | ENSG00000198695 | ||
AOFJ | 25 | 42 | 423 | … |
A13E | 0 | 154 | 4900 | |
… |
Omic classes | |
---|---|
Y | |
AOFJ | condA |
A13E | condB |
… |
multiSight downloads organism database automatically according to your choice in Home tab. 19 organism databases are available (see Home tab). Please note that multiSight can be used without enrichment analysis, and thus, without a organism database matching with your data.
Report of results can be generated in Home tab below datasets input part inside the Analysis Results block (.html or .doc formats).
This tab background is launched when you start analysis in Home tab. Results are displayed after biosigner and sPLS-DA models fitting.
This tab presents classification models to predict sample classes based upon only a small subset of features selected by multiSight models.
Two types of models have been implemented so far to answer different questions: from biosigner & mixOmics (sPLS-DA) R packages.
biosigner is an R package available in Bioconductor project.
In a single-omics approach, biosigner computes SVM and Random Forest models and selects features for all omic datasets one by one.
Thereby, a biosignature is defined for each omic as the union of SVM and RF variable lists.
If there are 3 omic datasets, biosigner gives 6 models and 3 feature lists (about 5-10 features by data type).
require(multiSight)
## omic2 is a multi-omics dataset of 2 simulated omics included in package
data("omic2", package = "multiSight")
#set.seed(123)
splitData <- splitDatatoTrainTest(omic2, freq = 0.8)
data.train <- splitData$data.train
data.test <- splitData$data.test
## Build model and one biosignature by omic dataset.
biosignerRes <- runSVMRFmodels_Biosigner(data.train)
## Results
biosignerModels <- biosignerRes$model #list of SVM/RF models for each omic.
biosignerFeats <- biosignerRes$biosignature #selected features for each omic.
## Assess model classification performances
biosignerPerf <- assessPerformance_Biosigner(modelList = biosignerModels,
dataTest = data.test)
print(biosignerPerf) #confusion matrices and performance metrics
## $svm
## $svm$rnaRead
## Confusion Matrix and Statistics
##
##
## A B
## A 4 0
## B 0 2
##
## Accuracy : 1
## 95% CI : (0.5407, 1)
## No Information Rate : 0.6667
## P-Value [Acc > NIR] : 0.08779
##
## Kappa : 1
##
## Mcnemar's Test P-Value : NA
##
## Sensitivity : 1.0000
## Specificity : 1.0000
## Pos Pred Value : 1.0000
## Neg Pred Value : 1.0000
## Prevalence : 0.6667
## Detection Rate : 0.6667
## Detection Prevalence : 0.6667
## Balanced Accuracy : 1.0000
##
## 'Positive' Class : A
##
##
## $svm$dnaRead
## Confusion Matrix and Statistics
##
##
## A B
## A 4 0
## B 0 2
##
## Accuracy : 1
## 95% CI : (0.5407, 1)
## No Information Rate : 0.6667
## P-Value [Acc > NIR] : 0.08779
##
## Kappa : 1
##
## Mcnemar's Test P-Value : NA
##
## Sensitivity : 1.0000
## Specificity : 1.0000
## Pos Pred Value : 1.0000
## Neg Pred Value : 1.0000
## Prevalence : 0.6667
## Detection Rate : 0.6667
## Detection Prevalence : 0.6667
## Balanced Accuracy : 1.0000
##
## 'Positive' Class : A
##
##
##
## $rf
## $rf$rnaRead
## Confusion Matrix and Statistics
##
##
## A B
## A 4 0
## B 0 2
##
## Accuracy : 1
## 95% CI : (0.5407, 1)
## No Information Rate : 0.6667
## P-Value [Acc > NIR] : 0.08779
##
## Kappa : 1
##
## Mcnemar's Test P-Value : NA
##
## Sensitivity : 1.0000
## Specificity : 1.0000
## Pos Pred Value : 1.0000
## Neg Pred Value : 1.0000
## Prevalence : 0.6667
## Detection Rate : 0.6667
## Detection Prevalence : 0.6667
## Balanced Accuracy : 1.0000
##
## 'Positive' Class : A
##
##
## $rf$dnaRead
## Confusion Matrix and Statistics
##
##
## A B
## A 3 0
## B 1 2
##
## Accuracy : 0.8333
## 95% CI : (0.3588, 0.9958)
## No Information Rate : 0.6667
## P-Value [Acc > NIR] : 0.3512
##
## Kappa : 0.6667
##
## Mcnemar's Test P-Value : 1.0000
##
## Sensitivity : 0.7500
## Specificity : 1.0000
## Pos Pred Value : 1.0000
## Neg Pred Value : 0.6667
## Prevalence : 0.6667
## Detection Rate : 0.5000
## Detection Prevalence : 0.5000
## Balanced Accuracy : 0.8750
##
## 'Positive' Class : A
##
By a multi-omics approach, sPLS-DA (DIABLO) method selects relevant features to explain biological outcome of interest. This is implemented into the mixOmics R package available in Bioconductor project.
sPLS-DA method builds a new space for each omic dataset by linear combinations of initial features giving several components. In fact, around 20-40 features, for each omic, are selected according to contributions to components. Then, these features can be used to enrich some biological processes from a biological database (e.g. KEGG, Reactome) by ORA.
Classification performances are displayed in classification tab for each model and selected features by omic data type (e.g. if you have provided 3 omic types, you could observe 3 feature lists).
require(multiSight)
## omic2 is a multi-omics dataset of 2 simulated omics included in package
data("omic2", package = "multiSight")
data("diabloRes", package = "multiSight")
splitData <- splitDatatoTrainTest(omic2, freq = 0.9)
data.train <- splitData$data.train
data.test <- splitData$data.test
## Build model and one biosignature by omic dataset.
# diabloRes <- runSPLSDA(data.train)
# diabloRes #internal object of package to save time
## Results
diabloModels <- diabloRes$model #sPLS-DA model using all omics.
diabloFeats <- diabloRes$biosignature #selected features for each omic.
## Asses model classification performances
#diabloPerf <- assessPerformance_Diablo(splsdaModel = diabloModels,
# dataTest = data.test)
#print(diabloPerf) #confusion matrices and performance metrics
This tab is ready to use when Classification tab features selection is over.
Biological Insights tab is dedicated to give biological sense to your data.
You can carry out enrichment by ORA with features selected according to DESeq2 feature probabilities under the 0.05 threshold. Or, you can compute biological enrichment with features selected by sPLS-DA.
Several databases are implemented in multiSight package to provide a large panel of enrichment analysis:
There are Pathways and Gene Ontology databases helped by clusterProfiler and reactomePA R Bioconductor packages:
See table below to check available biological information for pathways from these databases, according to organism annotations.
multiSight supports 19 organism databases (required only for enrichment analysis):
orgDb | kegg | reactome | wikipathways |
---|---|---|---|
org.Hs.eg.db | hsa | human | Homo sapiens |
org.Mm.eg.db | mmu | mouse | Mus musculus |
org.Rn.eg.db | rno | rat | Rattus norvegicus |
org.Sc.sgd.db | sce | yeast | Saccharomyces cerevisiae |
org.Dm.eg.db | dme | fly | Drosophila melanogaster |
org.Dr.eg.db | dre | zebrafish | Danio rerio |
org.Ce.eg.db | cel | celegans | Caenorhabditis elegans |
org.At.tair.db | ath | x | Arabidopsis thaliana |
org.Bt.eg.db | bta | x | Bos taurus |
org.Gg.eg.db | gga | x | Gallus gallus |
org.Cf.eg.db | cfa | x | Canis familiaris |
org.Ss.eg.db | ssc | x | Sus scrofa |
org.EcK12.eg.db | eck | x | Escherichia coli |
org.Pt.eg.db | ptr | x | Pan troglodytes |
org.Ag.eg.db | aga | x | Anopheles gambiae |
org.Pf.plasmo.db | pfa | x | Plasmodium falciparum |
org.EcSakai.eg.db | ecs | x | Escherichia coli |
org.Mmu.eg.db | mcc | x | x |
org.Xl.eg.db | xla | x | x |
Note for enrichment: only convertible feature names to genes could be enriched according to information in organism’s database (e.g. Gene SYMBOL to entrez ids).
To know what feature name types are supported, copy these two lines of codes with your organism database of interest. For instance, org.Mm.eg.db for Human provides 24 input names you can use as feature names in your datasets.
if (requireNamespace("org.Mm.eg.db", quietly = TRUE))
{
library(org.Mm.eg.db)
columns(org.Mm.eg.db)
}
## [1] "ACCNUM" "ALIAS" "ENSEMBL" "ENSEMBLPROT" "ENSEMBLTRANS"
## [6] "ENTREZID" "ENZYME" "EVIDENCE" "EVIDENCEALL" "GENENAME"
## [11] "GENETYPE" "GO" "GOALL" "IPI" "MGI"
## [16] "ONTOLOGY" "ONTOLOGYALL" "PATH" "PFAM" "PMID"
## [21] "PROSITE" "REFSEQ" "SYMBOL" "UNIPROT"
Please note that feature IDs can differ between omic blocks (e.g. one dataset with gene SYMBOL, another one with ENSEMBL IDs). You can provide this information to convert them for enrichment in the application.
Therefore, in this Biological insights tab you can compute Differential Expression Analysis (DEA) by DESeq2 for several omic datasets Moreover, with features selected according to p-value threshold set by the user you can enrich pathway or Gene Ontology databases.
require(multiSight)
## omic2 is a multi-omics dataset of 2 simulated omics included in package
data("omic2", package = "multiSight")
data("deseqRes", package = "multiSight")
# deseqRes <- runMultiDeseqAnalysis(omicDataList = omic2,
# padjUser = 0.05)
## One Differential Expression Analysis table for each omic dataset
# View(deseqRes$DEtable)
## One feature selected list for each omic according to padjust user threshold
multiOmic_biosignature <- deseqRes$selectedFeatures
# View(multiOmic_biosignature)
## Multi-omics enrichment
### convert features
dbList <- list(rnaRead = "ENSEMBL",
dnaRead = "ENSEMBL")
convFeat <- convertToEntrezid(multiOmic_biosignature, dbList, "org.Mm.eg.db")
### ORA enrichment analysis
if (requireNamespace("org.Mm.eg.db", quietly = TRUE))
{
# database <- c("kegg", "wikiPathways", "reactome", "MF", "CC", "BP")
database <- c("reactome")
data("enrichResList", package = "multiSight")
# enrichResList <- runMultiEnrichment(omicSignature = convFeat,
# databasesChosen = database,
# organismDb = "org.Mm.eg.db",
# pvAdjust = "BH", #default value
# minGSSize = 5, #default value
# maxGSSize = 800, #default value
# pvStouffer = 0.1) #default value
reacRes <- enrichResList$pathways$reactome
names(reacRes$result) # classical enrichment tables, multi-omics and EMap
}
## NULL
This tab gives a graphical interface where all multi-omics features selected by sPLS-DA method are used to enrich chosen databases. You could retrieve functional enrichment results in Home tab’s report or save tables in this tab.
require(multiSight)
## omic2 is a multi-omics dataset of 2 simulated omics included in package
data("omic2", package = "multiSight")
data("diabloRes", package = "multiSight")
# splitData <- splitDatatoTrainTest(omic2, 0.8)
# data.train <- splitData$data.train
# data.test <- splitData$data.test
#
# diabloRes <- runSPLSDA(data.train)
# diabloRes #internal object of package to save time
diabloModels <- diabloRes$model #sPLS-DA model using all omics.
diabloFeats <- diabloRes$biosignature #selected features for each omic.
## Multi-omics enrichment
### convert features
names(diabloFeats) #/!\use same names for dbList and omic datasets.
## [1] "rnaRead" "dnaRead"
dbList <- list(rnaRead = "ENSEMBL", #feature names origin
dnaRead = "ENSEMBL")
if (requireNamespace("org.Mm.eg.db", quietly = TRUE))
{
convFeat <- convertToEntrezid(diabloFeats,
dbList,
"org.Mm.eg.db")
### ORA enrichment analysis for omic feature lists
# database <- c("kegg", "wikiPathways", "reactome", "MF", "CC", "BP")
database <- c("reactome")
multiOmicRes <- runMultiEnrichment(omicSignature = convFeat,
databasesChosen = database,
organismDb = "org.Mm.eg.db",
pvAdjust = "BH", #default value
minGSSize = 5, #default value
maxGSSize = 800, #default value
pvStouffer = 0.1) #default value
## Results
reacRes <- multiOmicRes$pathways$reactome
names(reacRes$result) # classical enrichment tables, multi-omics and EMap
}
## [1] "enrichTable_omic1" "enrichTable_omic2" "multi"
## [4] "enrichMap"
Two types of result visualization are given:
A multi-omics table is built by annotation database (e.g. Reactome) with all enrichment results obtained for omic datasets using Stouffer’s method. Stouffer’s p-value method consists in p-values pooling for same pathways or ontology. In fact, a Stouffer’s value is computed for every biological annotations shared by at least 2 enrichment analysis results (NOTE: each omic data used for enrichment has one usual enrichment table by selected database).
Thereby, you can summarize information for several datasets and enrichment results with a multi-omics table, for instance:
ID | Description | p-value:Omic1 | p-value:Omic2 | Stouffer | StoufferWeighted | geneID | GeneRatio | Count |
---|---|---|---|---|---|---|---|---|
R-MMU-2173791 | TGF-beta receptor signaling in EMT (epithelial to mesenchymal transition) | 0.043 | 0.047 | 0.008 | 0.008 | 102098/11848/16456/18762/21803/… | 2/60 | 2 |
R-MMU-194315 | Signaling by Rho GTPases | 0.096 | 0.029 | 0.011 | 0.011 | 100043813/101497/102098/102920/… | 1/60 | 1 |
R-MMU-73887 | Death Receptor Signalling | 0.056 | 0.06 | 0.013 | 0.013 | 101497/102098/106025/109934/11491/ | 2/60 | 2 |
R-MMU-8953854 | Metabolism of RNA | 0.533 | 0.002 | 0.024 | 0.021 | 100043813/100044627/100502825/… | 1/60 | 1 |
Each value is similar to an enrichRes object obtained by clusterProfiler.
In fact, Stouffer’s results are transformed as *enrichRes** objects and could be used for usual enrichRes analysis and visualization functions.
Note in our cytoscape-like case that geneID column refers to all genes in pathways or ontology named in database annotations. In usual enrichRes, this column presents genes enriched contributing in pathways.
A graphical network is built according to this table as an Enrichment Map.
Enrichment map is a graph drawn to observe pathway or ontology relationships according to overlapping elements in each parts.
Each pathway is a node and a bond is built between them if there have common genes (see Jaccard similarity coefficient - JC’s similarity method).
Here, enrichment map functions from enrichPlot package are adapted to draw similar map to cytoscape add-on EnrichmentMap: all genes in each pathway are used to compute similarity between pathway building network bonds.
Each multi-omics enrichment map (one by enrichment database) could be retrieve in a report automatically generated and in the Home tab to be saved.
Assumption tab aims to help biological hypothesis making by network inference from feature relationship values (e.g correlation, partial correlation) and by a PubMed module.
You can find both functions:
require(multiSight)
data("omic2", package = "multiSight")
data("diabloRes", package = "multiSight")
## omic2 is a multi-omics dataset of 2 simulated omics included in package
splitData <- splitDatatoTrainTest(omic2, 0.8)
data.train <- splitData$data.train
data.test <- splitData$data.test
## Build sPLS-DA models
# diabloRes <- runSPLSDA(data.train)
diabloFeats <- diabloRes$biosignature #selected features for each omic.
## Build biosigner models
biosignerRes <- runSVMRFmodels_Biosigner(data.train)
biosignerFeats <- biosignerRes$biosignature #selected features for each omic.
## Network inference
### DIABLO features
concatMat_diablo <- getDataSelectedFeatures(omic2, diabloFeats)
corrRes_diablo <- correlationNetworkInference(concatMat_diablo, 0.85)
pcorRes_diablo <- partialCorrelationNI(concatMat_diablo, 0.4)
miRes_diablo <- mutualInformationNI(concatMat_diablo, 0.2)
### biosigner features
concatMat_biosigner <- getDataSelectedFeatures(omic2, biosignerFeats)
corrRes_bios <- correlationNetworkInference(concatMat_biosigner, 0.85)
pcorRes_bios <- partialCorrelationNI(concatMat_biosigner, 0.4)
miRes_bios <- mutualInformationNI(concatMat_biosigner, 0.2)
corrRes_diablo$graph
Here is the output of sessionInfo()
on the system on which this
document was compiled running pandoc 2.5:
## R version 4.2.1 (2022-06-23)
## Platform: x86_64-pc-linux-gnu (64-bit)
## Running under: Ubuntu 20.04.5 LTS
##
## Matrix products: default
## BLAS: /home/biocbuild/bbs-3.16-bioc/R/lib/libRblas.so
## LAPACK: /home/biocbuild/bbs-3.16-bioc/R/lib/libRlapack.so
##
## 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
##
## attached base packages:
## [1] stats4 stats graphics grDevices utils datasets methods
## [8] base
##
## other attached packages:
## [1] org.Mm.eg.db_3.16.0 AnnotationDbi_1.60.0 IRanges_2.32.0
## [4] S4Vectors_0.36.0 Biobase_2.58.0 BiocGenerics_0.44.0
## [7] multiSight_1.6.0 BiocStyle_2.26.0
##
## loaded via a namespace (and not attached):
## [1] rappdirs_0.3.3 ModelMetrics_1.2.2.2
## [3] tidyr_1.2.1 ggplot2_3.3.6
## [5] bit64_4.0.5 knitr_1.40
## [7] multcomp_1.4-20 DelayedArray_0.24.0
## [9] data.table_1.14.4 rpart_4.1.19
## [11] KEGGREST_1.38.0 hardhat_1.2.0
## [13] RCurl_1.98-1.9 generics_0.1.3
## [15] metap_1.8 TH.data_1.1-1
## [17] cowplot_1.1.1 usethis_2.1.6
## [19] RSQLite_2.2.18 mixOmics_6.22.0
## [21] shadowtext_0.1.2 proxy_0.4-27
## [23] future_1.28.0 bit_4.0.4
## [25] enrichplot_1.18.0 anyLib_1.0.5
## [27] mutoss_0.1-12 xml2_1.3.3
## [29] lubridate_1.8.0 httpuv_1.6.6
## [31] SummarizedExperiment_1.28.0 assertthat_0.2.1
## [33] viridis_0.6.2 gower_1.0.0
## [35] xfun_0.34 jquerylib_0.1.4
## [37] evaluate_0.17 promises_1.2.0.1
## [39] fansi_1.0.3 igraph_1.3.5
## [41] DBI_1.1.3 geneplotter_1.76.0
## [43] htmlwidgets_1.5.4 rWikiPathways_1.18.0
## [45] rARPACK_0.11-0 purrr_0.3.5
## [47] ellipsis_0.3.2 RSpectra_0.16-1
## [49] ggnewscale_0.4.8 dplyr_1.0.10
## [51] bookdown_0.29 calibrate_1.7.7
## [53] annotate_1.76.0 MatrixGenerics_1.10.0
## [55] vctrs_0.5.0 caret_6.0-93
## [57] cachem_1.0.6 withr_2.5.0
## [59] ggforce_0.4.1 HDO.db_0.99.1
## [61] treeio_1.22.0 MultiAssayExperiment_1.24.0
## [63] ropls_1.30.0 mnormt_2.1.1
## [65] DOSE_3.24.0 ape_5.6-2
## [67] lazyeval_0.2.2 crayon_1.5.2
## [69] ellipse_0.4.3 genefilter_1.80.0
## [71] labeling_0.4.2 recipes_1.0.2
## [73] pkgconfig_2.0.3 qqconf_1.3.0
## [75] tweenr_2.0.2 GenomeInfoDb_1.34.0
## [77] nlme_3.1-160 pkgload_1.3.1
## [79] nnet_7.3-18 rlang_1.0.6
## [81] globals_0.16.1 biosigner_1.26.0
## [83] lifecycle_1.0.3 sandwich_3.0-2
## [85] qqman_0.1.8 downloader_0.4
## [87] mathjaxr_1.6-0 randomForest_4.7-1.1
## [89] rprojroot_2.0.3 polyclip_1.10-4
## [91] matrixStats_0.62.0 graph_1.76.0
## [93] Matrix_1.5-1 aplot_0.1.8
## [95] zoo_1.8-11 rjson_0.2.21
## [97] png_0.1-7 viridisLite_0.4.1
## [99] bitops_1.0-7 shinydashboard_0.7.2
## [101] gson_0.0.9 pROC_1.18.0
## [103] Biostrings_2.66.0 blob_1.2.3
## [105] stringr_1.4.1 qvalue_2.30.0
## [107] parallelly_1.32.1 gridGraphics_0.5-1
## [109] reactome.db_1.82.0 scales_1.2.1
## [111] memoise_2.0.1 graphite_1.44.0
## [113] magrittr_2.0.3 plyr_1.8.7
## [115] zlibbioc_1.44.0 compiler_4.2.1
## [117] scatterpie_0.1.8 RColorBrewer_1.1-3
## [119] plotrix_3.8-2 DESeq2_1.38.0
## [121] cli_3.4.1 XVector_0.38.0
## [123] listenv_0.8.0 patchwork_1.1.2
## [125] MASS_7.3-58.1 tidyselect_1.2.0
## [127] stringi_1.7.8 yaml_2.3.6
## [129] GOSemSim_2.24.0 locfit_1.5-9.6
## [131] ggrepel_0.9.1 grid_4.2.1
## [133] sass_0.4.2 fastmatch_1.1-3
## [135] tools_4.2.1 future.apply_1.9.1
## [137] parallel_4.2.1 rstudioapi_0.14
## [139] foreach_1.5.2 gridExtra_2.3
## [141] prodlim_2019.11.13 farver_2.1.1
## [143] ggraph_2.1.0 digest_0.6.30
## [145] BiocManager_1.30.19 shiny_1.7.3
## [147] lava_1.7.0 networkD3_0.4
## [149] ppcor_1.1 Rcpp_1.0.9
## [151] GenomicRanges_1.50.0 later_1.3.0
## [153] infotheo_1.2.0.1 httr_1.4.4
## [155] Rdpack_2.4 colorspace_2.0-3
## [157] XML_3.99-0.12 fs_1.5.2
## [159] splines_4.2.1 yulab.utils_0.0.5
## [161] tidytree_0.4.1 sn_2.1.0
## [163] graphlayouts_0.8.3 multtest_2.54.0
## [165] ggplotify_0.1.0 MultiDataSet_1.26.0
## [167] xtable_1.8-4 jsonlite_1.8.3
## [169] ggtree_3.6.0 tidygraph_1.2.2
## [171] corpcor_1.6.10 timeDate_4021.106
## [173] ggfun_0.0.7 ipred_0.9-13
## [175] R6_2.5.1 TFisher_0.2.0
## [177] pillar_1.8.1 htmltools_0.5.3
## [179] mime_0.12 glue_1.6.2
## [181] fastmap_1.1.0 clusterProfiler_4.6.0
## [183] DT_0.26 BiocParallel_1.32.0
## [185] easyPubMed_2.13 class_7.3-20
## [187] codetools_0.2-18 fgsea_1.24.0
## [189] mvtnorm_1.1-3 utf8_1.2.2
## [191] lattice_0.20-45 bslib_0.4.0
## [193] tibble_3.1.8 numDeriv_2016.8-1.1
## [195] attempt_0.3.1 ReactomePA_1.42.0
## [197] config_0.3.1 GO.db_3.16.0
## [199] golem_0.3.5 survival_3.4-0
## [201] limma_3.54.0 roxygen2_7.2.1
## [203] rmarkdown_2.17 desc_1.4.2
## [205] munsell_0.5.0 e1071_1.7-12
## [207] GenomeInfoDbData_1.2.9 iterators_1.0.14
## [209] reshape2_1.4.4 gtable_0.3.1
## [211] rbibutils_2.2.9