The MetaGxOvarian package is a compendium of Ovarian Cancer datasets. The package is publicly available and can be installed from Bioconductor into R version 3.6.0 or higher.
To install the MetaGxOvarian package from Bioconductor:
if (!requireNamespace("BiocManager", quietly = TRUE))
install.packages("BiocManager")
BiocManager::install("MetaGxOvarian")
First we load the MetaGxOvarian package into the workspace.
To load the packages into R, please use the following commands:
library(MetaGxOvarian)
esets <- MetaGxOvarian::loadOvarianEsets()[[1]]
This will load 26 expression datasets. Users can modify the parameters of the function to restrict datasets that do not meet certain criteria for loading. Some example parameters are shown below:
keepCommonOnly
: Retain only genes that are common across all platforms loaded (default = FALSE)minSampleSize
: Retain studies with a minimum sample size (default = 0)minNumberGenes
: Retain studies with a minimum number of genes (default = 0)minNUmberEvents
: Retain studies with a minimum number of survival events (default = 0)removeDuplicates
: Remove duplicate samples (default = TRUE)numSamples <- vapply(seq_along(esets), FUN=function(i, esets) {
length(sampleNames(esets[[i]]))
}, numeric(1), esets=esets)
SampleNumberSummaryAll <- data.frame(NumberOfSamples = numSamples,
row.names = names(esets))
total <- sum(SampleNumberSummaryAll[,"NumberOfSamples"])
SampleNumberSummaryAll <- rbind(SampleNumberSummaryAll, total)
rownames(SampleNumberSummaryAll)[nrow(SampleNumberSummaryAll)] <- "Total"
xtable(SampleNumberSummaryAll, digits = 2)
## % latex table generated in R 4.2.1 by xtable 1.8-4 package
## % Thu Nov 3 11:17:16 2022
## \begin{table}[ht]
## \centering
## \begin{tabular}{rr}
## \hline
## & NumberOfSamples \\
## \hline
## E.MTAB.386 & 129.00 \\
## GSE2109 & 202.00 \\
## GSE6008 & 101.00 \\
## GSE6822 & 62.00 \\
## GSE8842 & 83.00 \\
## GSE9891 & 276.00 \\
## GSE12418 & 54.00 \\
## GSE12470 & 49.00 \\
## GSE13876 & 157.00 \\
## GSE14764 & 79.00 \\
## GSE17260 & 110.00 \\
## GSE18520 & 59.00 \\
## GSE20565 & 135.00 \\
## GSE26193 & 14.00 \\
## GSE26712 & 191.00 \\
## GSE30009 & 103.00 \\
## GSE30161 & 58.00 \\
## GSE32062 & 257.00 \\
## GSE32063 & 40.00 \\
## GSE44104 & 47.00 \\
## GSE49997 & 204.00 \\
## GSE51088 & 172.00 \\
## PMID15897565 & 63.00 \\
## PMID17290060 & 117.00 \\
## PMID19318476 & 42.00 \\
## TCGAOVARIAN & 536.00 \\
## Total & 3340.00 \\
## \hline
## \end{tabular}
## \end{table}
We can also obtain a summary of the phenotype data (pData) for each expression dataset. Here, we assess the proportion of samples in every datasets that contain a specific pData variable.
pDataID <- c("sample_type", "histological_type", "primarysite", "summarygrade",
"summarystage", "tumorstage", "grade",
"age_at_initial_pathologic_diagnosis", "pltx", "tax",
"neo", "days_to_tumor_recurrence", "recurrence_status",
"days_to_death", "vital_status")
pDataPercentSummaryTable <- NULL
pDataSummaryNumbersTable <- NULL
pDataSummaryNumbersList = lapply(esets, function(x)
vapply(pDataID, function(y) sum(!is.na(pData(x)[,y])), numeric(1)))
pDataPercentSummaryList = lapply(esets, function(x)
vapply(pDataID, function(y)
sum(!is.na(pData(x)[,y]))/nrow(pData(x)), numeric(1))*100)
pDataSummaryNumbersTable = sapply(pDataSummaryNumbersList, function(x) x)
pDataPercentSummaryTable = sapply(pDataPercentSummaryList, function(x) x)
rownames(pDataSummaryNumbersTable) <- pDataID
rownames(pDataPercentSummaryTable) <- pDataID
colnames(pDataSummaryNumbersTable) <- names(esets)
colnames(pDataPercentSummaryTable) <- names(esets)
pDataSummaryNumbersTable <- rbind(pDataSummaryNumbersTable, total)
rownames(pDataSummaryNumbersTable)[nrow(pDataSummaryNumbersTable)] <- "Total"
# Generate a heatmap representation of the pData
pDataPercentSummaryTable<-t(pDataPercentSummaryTable)
pDataPercentSummaryTable<-cbind(Name=(rownames(pDataPercentSummaryTable))
,pDataPercentSummaryTable)
nba<-pDataPercentSummaryTable
gradient_colors = c("#ffffff","#ffffd9","#edf8b1","#c7e9b4","#7fcdbb",
"#41b6c4","#1d91c0","#225ea8","#253494","#081d58")
library(lattice)
nbamat<-as.matrix(nba)
rownames(nbamat)<-nbamat[,1]
nbamat<-nbamat[,-1]
Interval<-as.numeric(c(10,20,30,40,50,60,70,80,90,100))
levelplot(nbamat,col.regions=gradient_colors,
main="Available Clinical Annotation",
scales=list(x=list(rot=90, cex=0.5),
y= list(cex=0.5),key=list(cex=0.2)),
at=seq(from=0,to=100,length=10),
cex=0.2, ylab="", xlab="", lattice.options=list(),
colorkey=list(at=as.numeric(factor(c(seq(from=0, to=100, by=10)))),
labels=as.character(c( "0","10%","20%","30%", "40%","50%",
"60%", "70%", "80%","90%", "100%"),
cex=0.2,font=1,col="brown",height=1,
width=1.4), col=(gradient_colors)))
## 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] lattice_0.20-45 MetaGxOvarian_1.18.0
## [3] SummarizedExperiment_1.28.0 GenomicRanges_1.50.0
## [5] GenomeInfoDb_1.34.0 IRanges_2.32.0
## [7] S4Vectors_0.36.0 MatrixGenerics_1.10.0
## [9] matrixStats_0.62.0 ExperimentHub_2.6.0
## [11] AnnotationHub_3.6.0 BiocFileCache_2.6.0
## [13] dbplyr_2.2.1 Biobase_2.58.0
## [15] BiocGenerics_0.44.0 xtable_1.8-4
##
## loaded via a namespace (and not attached):
## [1] Rcpp_1.0.9 png_0.1-7
## [3] Biostrings_2.66.0 assertthat_0.2.1
## [5] digest_0.6.30 utf8_1.2.2
## [7] mime_0.12 R6_2.5.1
## [9] RSQLite_2.2.18 evaluate_0.17
## [11] highr_0.9 httr_1.4.4
## [13] pillar_1.8.1 zlibbioc_1.44.0
## [15] rlang_1.0.6 curl_4.3.3
## [17] blob_1.2.3 Matrix_1.5-1
## [19] stringr_1.4.1 RCurl_1.98-1.9
## [21] bit_4.0.4 DelayedArray_0.24.0
## [23] shiny_1.7.3 compiler_4.2.1
## [25] httpuv_1.6.6 xfun_0.34
## [27] pkgconfig_2.0.3 htmltools_0.5.3
## [29] tidyselect_1.2.0 KEGGREST_1.38.0
## [31] tibble_3.1.8 GenomeInfoDbData_1.2.9
## [33] interactiveDisplayBase_1.36.0 fansi_1.0.3
## [35] withr_2.5.0 crayon_1.5.2
## [37] dplyr_1.0.10 later_1.3.0
## [39] bitops_1.0-7 rappdirs_0.3.3
## [41] grid_4.2.1 lifecycle_1.0.3
## [43] DBI_1.1.3 magrittr_2.0.3
## [45] impute_1.72.0 cli_3.4.1
## [47] stringi_1.7.8 cachem_1.0.6
## [49] XVector_0.38.0 promises_1.2.0.1
## [51] ellipsis_0.3.2 filelock_1.0.2
## [53] generics_0.1.3 vctrs_0.5.0
## [55] tools_4.2.1 bit64_4.0.5
## [57] glue_1.6.2 purrr_0.3.5
## [59] BiocVersion_3.16.0 fastmap_1.1.0
## [61] yaml_2.3.6 AnnotationDbi_1.60.0
## [63] BiocManager_1.30.19 memoise_2.0.1
## [65] knitr_1.40