--- title: "Case Studies" bibliography: bibliography.bib vignette: > %\VignetteIndexEntry{8. Case Studies} %\VignetteEngine{knitr::rmarkdown} --- ```{r setup, include=FALSE} knitr::opts_chunk$set(dpi = 300) knitr::opts_chunk$set(cache=FALSE) ``` ```{r message = FALSE, warning = FALSE, include = FALSE} library(TCGAbiolinks) library(SummarizedExperiment) library(dplyr) library(DT) ``` # Introduction This vignette shows a complete workflow of the TCGAbiolinks package. The code is divided in 4 case study: 1. Expression pipeline (BRCA) 2. Expression pipeline (GBM) 3. Integration of DNA methylation and RNA expression pipeline (COAD) 4. ELMER pipeline (KIRC) # Case study n. 1: Pan Cancer downstream analysis BRCA ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} library(SummarizedExperiment) library(TCGAbiolinks) query.exp <- GDCquery( project = "TCGA-BRCA", data.category = "Transcriptome Profiling", data.type = "Gene Expression Quantification", workflow.type = "STAR - Counts", sample.type = c("Primary Tumor","Solid Tissue Normal") ) GDCdownload( query = query.exp, files.per.chunk = 100 ) brca.exp <- GDCprepare( query = query.exp, save = TRUE, save.filename = "brcaExp.rda" ) # get subtype information infomation.subtype <- TCGAquery_subtype(tumor = "BRCA") # get clinical data information.clinical <- GDCquery_clinic(project = "TCGA-BRCA",type = "clinical") # Which samples are Primary Tumor samples.primary.tumour <- brca.exp$barcode[brca.exp$shortLetterCode == "TP"] # which samples are solid tissue normal samples.solid.tissue.normal <- brca.exp$barcode[brca.exp$shortLetterCode == "NT"] ``` Using `TCGAnalyze_DEA`, we identified 4,815 differentially expression genes (DEG) (log fold change >=1 and FDR < 1%) between 113 normal and 1106 BRCA samples. In order to understand the underlying biological process from DEGs we performed an enrichment analysis using `TCGAnalyze_EA_complete` function. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} dataPrep <- TCGAanalyze_Preprocessing( object = brca.exp, cor.cut = 0.6 ) dataNorm <- TCGAanalyze_Normalization( tabDF = dataPrep, geneInfo = geneInfoHT, method = "gcContent" ) dataFilt <- TCGAanalyze_Filtering( tabDF = dataNorm, method = "quantile", qnt.cut = 0.25 ) dataDEGs <- TCGAanalyze_DEA( mat1 = dataFilt[,samples.solid.tissue.normal], mat2 = dataFilt[,samples.primary.tumour], Cond1type = "Normal", Cond2type = "Tumor", fdr.cut = 0.01 , logFC.cut = 2, method = "glmLRT", pipeline = "edgeR" ) ``` TCGAbiolinks outputs bar chart with the number of genes for the main categories of three ontologies (GO:biological process, GO:cellular component, and GO:molecular function, respectively). ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} ansEA <- TCGAanalyze_EAcomplete( TFname = "DEA genes Normal Vs Tumor", RegulonList = dataDEGs$gene_name ) TCGAvisualize_EAbarplot( tf = rownames(ansEA$ResBP), GOBPTab = ansEA$ResBP, GOCCTab = ansEA$ResCC, GOMFTab = ansEA$ResMF, PathTab = ansEA$ResPat, nRGTab = dataDEGs$gene_name, nBar = 10 ) ``` The figure resulted from the code above is shown below. ```{r, fig.width=6, fig.height=4, echo = FALSE, fig.align="center",hide=TRUE, message=FALSE,warning=FALSE} library(png) library(grid) img <- readPNG("case1_EA.png") grid.raster(img) ``` The Kaplan-Meier analysis was used to compute survival univariate curves, and log-Ratio test was computed to assess the statistical significance by using TCGAanalyze_SurvivalKM function; starting with 3,390 DEGs genes we found 555 significantly genes with p.value <0.05. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} group1 <- TCGAquery_SampleTypes(colnames(dataFilt), typesample = c("NT")) group2 <- TCGAquery_SampleTypes(colnames(dataFilt), typesample = c("TP")) dataSurv <- TCGAanalyze_SurvivalKM( clinical_patient = dataClin, dataGE = dataFilt, Genelist = rownames(dataDEGs), Survresult = FALSE, ThreshTop = 0.67, ThreshDown = 0.33, p.cut = 0.05, group1 = group1, group2 = group2 ) ``` Cox-regression analysis was used to compute survival multivariate curves, and cox p-value was computed to assess the statistical significance by using TCGAnalyze_SurvivalCoxNET function. Survival multivariate analysis found 160 significantly genes according to the cox p-value FDR 5.00e-02. From DEGs that we found to correlate significantly with survival by both univariate and multivariate analyses we analyzed the following network. The interactome network graph was generated using STRING.,org.Hs.string version 10 (Human functional protein association network). The network graph was resized by dnet package considering only multivariate survival genes, with strong interaction (threshold = 700) we obtained a subgraphsub graph of 24 nodes and 31 edges. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} require(dnet) # to change org.Hs.string <- dRDataLoader(RData = "org.Hs.string") TabCoxNet <- TCGAvisualize_SurvivalCoxNET( dataClin, dataFilt, Genelist = rownames(dataSurv), scoreConfidence = 700, org.Hs.string = org.Hs.string, titlePlot = "Case Study n.1 dnet" ) ``` The figure resulted from the code above is shown below. ```{r, fig.width=6, fig.height=4, echo = FALSE, fig.align="center",hide=TRUE, message=FALSE,warning=FALSE} library(png) library(grid) img <- readPNG("case1_dnet.png") grid.raster(img) ``` # Case study n. 2: Pan Cancer downstream analysis LGG We focused on the analysis of LGG samples. In particular, we used TCGAbiolinks to download 293 samples with molecular subtypes. Link the complete [complete code](https://gist.github.com/tiagochst/277651ebed998fd3d1952d3fbc376ef2). . ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} library(TCGAbiolinks) library(SummarizedExperiment) query.exp <- GDCquery( project = "TCGA-LGG", data.category = "Transcriptome Profiling", data.type = "Gene Expression Quantification", workflow.type = "STAR - Counts", sample.type = c("Primary Tumor") ) GDCdownload(query.exp) lgg.exp <- GDCprepare( query = query.exp, save = FALSE ) ``` First, we searched for possible outliers using the `TCGAanalyze_Preprocessing` function, which performs an Array Array Intensity correlation AAIC. We used all samples in expression data which contain molecular subtypes, filtering out samples without molecular information, and using only IDHmut-codel (n=85), IDHmut-non-codel (n=141) and IDHwt (n=56), NA (11), to define a square symmetric matrix of pearson correlation among all samples (n=293). According to this matrix we found no samples with low correlation (cor.cut = 0.6) that can be identified as possible outliers, so we continued our analysis with 70 samples. Second, using the `TCGAanalyze_Normalization` function we normalized mRNA transcripts and miRNA, using EDASeq package. This function does use Within-lane normalization procedures to adjust for GC-content effect (or other gene-level effects) on read counts: loess robust local regression, global-scaling, and full-quantile normalization [@risso2011gc] and between-lane normalization procedures to adjust for distributional differences between lanes (e.g., sequencing depth): global-scaling and full-quantile normalization [@bullard2010evaluation]. Third, using the `TCGAanalyze_Filtering` function we applied 3 filters removing features / mRNAs with low signal across samples obtaining 4578, 4284, 1187 mRNAs respectively. Then we applied two Hierarchical cluster analysis on 1187 mRNAs after the three filters described above, the first cluster using as method ward.D2, and the second with ConsensusClusterPlus. After the two clustering analysis, with cut.tree = 4 we obtained n= 4 expression clusters (EC). ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} library(dplyr) dataPrep <- TCGAanalyze_Preprocessing( object = lgg.exp, cor.cut = 0.6 ) dataNorm <- TCGAanalyze_Normalization( tabDF = dataPrep, geneInfo = geneInfoHT, method = "gcContent" ) datFilt <- dataNorm %>% TCGAanalyze_Filtering(method = "varFilter") %>% TCGAanalyze_Filtering(method = "filter1") %>% TCGAanalyze_Filtering(method = "filter2",foldChange = 1) data_Hc2 <- TCGAanalyze_Clustering( tabDF = datFilt, method = "consensus", methodHC = "ward.D2" ) # Add cluster information to Summarized Experiment colData(lgg.exp)$groupsHC <- paste0("EC",data_Hc2[[4]]$consensusClass) ``` The next steps will be to visualize the data. First, we created the survival plot. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} TCGAanalyze_survival( data = colData(lgg.exp), clusterCol = "groupsHC", main = "TCGA kaplan meier survival plot from consensus cluster", legend = "RNA Group", height = 10, risk.table = T, conf.int = F, color = c("black","red","blue","green3"), filename = "survival_lgg_expression_subtypes.png" ) ``` The result is showed below: ```{r, fig.width=6, fig.height=4, echo = FALSE, fig.align="center",hide=TRUE, message=FALSE,warning=FALSE} library(png) library(grid) img <- readPNG("case2_surv.png") grid.raster(img) ``` We will also, create a heatmap of the expression. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} TCGAvisualize_Heatmap( data = t(datFilt), col.metadata = colData(lgg.exp)[, c("barcode", "groupsHC", "paper_Histology", "paper_IDH.codel.subtype") ], col.colors = list( groupsHC = c( "EC1"="black", "EC2"="red", "EC3"="blue", "EC4"="green3") ), sortCol = "groupsHC", type = "expression", # sets default color scale = "row", # use z-scores for better visualization. Center gene expression level around 0. title = "Heatmap from concensus cluster", filename = "case2_Heatmap.png", extremes = seq(-2,2,1), color.levels = colorRampPalette(c("green", "black", "red"))(n = 5), cluster_rows = TRUE, cluster_columns = FALSE, width = 1000, height = 500 ) ``` The result is shown below: ```{r, fig.width=6, fig.height=4, echo = FALSE, fig.align="center",hide=TRUE, message=FALSE,warning=FALSE} library(jpeg) library(grid) img <- readJPEG("case2_Heatmap.jpg") grid.raster(img) ``` Finally, we will take a look in the mutation genes. We will first download the MAF file with `GDCquery`,`GDCdownload` and `GDCprepare`. In this example we will investigate the gene "ATR". ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} library(maftools) library(dplyr) query <- GDCquery( project = "TCGA-LGG", data.category = "Simple Nucleotide Variation", access = "open", data.type = "Masked Somatic Mutation", workflow.type = "Aliquot Ensemble Somatic Variant Merging and Masking" ) GDCdownload(query) LGGmut <- GDCprepare(query) # Selecting gene LGGmut.atr <- LGGmut %>% dplyr::filter(Hugo_Symbol == "ATR") dataMut <- LGGmut.atr[!duplicated(LGGmut.atr$Tumor_Sample_Barcode),] dataMut$Tumor_Sample_Barcode <- substr(dataMut$Tumor_Sample_Barcode,1,12) # Adding the Expression Cluster classification found before dataMut <- merge(dataMut, cluster, by.y = "patient", by.x = "Tumor_Sample_Barcode") ``` # Case study n. 3: Integration of methylation and expression for ACC In recent years, it has been described the relationship between DNA methylation and gene expression and the study of this relationship is often difficult to accomplish. This case study will show the steps to investigate the relationship between the two types of data. First, we downloaded ACC DNA methylation data for HumanMethylation450k platforms, and ACC RNA expression data for Illumina HiSeq platform. TCGAbiolinks adds by default the subtypes classification already published by researchers. We will use this classification to do our examples. So, selected the groups CIMP-low and CIMP-high to do RNA expression and DNA methylation comparison. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} library(TCGAbiolinks) library(SummarizedExperiment) #----------------------------------- # STEP 1: Search, download, prepare | #----------------------------------- # 1.1 - DNA methylation # ---------------------------------- query.met <- GDCquery( project = "TCGA-ACC", data.category = "DNA Methylation", data.type = "Methylation Beta Value", platform = "Illumina Human Methylation 450" ) GDCdownload( query = query.met, files.per.chunk = 20, directory = "case3/GDCdata" ) acc.met <- GDCprepare( query = query.met, save = FALSE, directory = "case3/GDCdata" ) #----------------------------------- # 1.2 - RNA expression # ---------------------------------- query.exp <- GDCquery( project = "TCGA-ACC", data.category = "Transcriptome Profiling", data.type = "Gene Expression Quantification", workflow.type = "STAR - Counts" ) GDCdownload( query = query.exp, files.per.chunk = 20, directory = "case3/GDCdata" ) acc.exp <- GDCprepare( query = query.exp, save = FALSE, directory = "case3/GDCdata" ) ``` For DNA methylation, we perform a DMC (different methylated CpGs) analysis, which will give the difference of DNA methylation for the probes of the groups and their significance value. The output can be seen in a volcano plot. Note: Depending on the number of samples this function can be very slow due to the wilcoxon test, taking from hours to days. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} # na.omit acc.met <- acc.met[rowSums(is.na(assay(acc.met))) == 0,] # Volcano plot acc.met <- TCGAanalyze_DMC( data = acc.met, groupCol = "subtype_MethyLevel", group1 = "CIMP-high", group2="CIMP-low", p.cut = 10^-5, diffmean.cut = 0.25, legend = "State", plot.filename = "case3/CIMP-highvsCIMP-low_metvolcano.png" ) ``` The figure resulted from the code above is shown below: ```{r, fig.width=6, fig.height=4, echo = FALSE, fig.align="center",hide=TRUE, message=FALSE,warning=FALSE} library(png) library(grid) img <- readPNG("CIMP-highvsCIMP-low_metvolcano.png") grid.raster(img) ``` For the expression analysis, we do a DEA (differential expression analysis) which will give the fold change of gene expression and their significance value. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} #------------------------------------------------- # 2.3 - DEA - Expression analysis - volcano plot # ------------------------------------------------ acc.exp.aux <- subset( acc.exp, select = colData(acc.exp)$subtype_MethyLevel %in% c("CIMP-high","CIMP-low") ) idx <- colData(acc.exp.aux)$subtype_MethyLevel %in% c("CIMP-high") idx2 <- colData(acc.exp.aux)$subtype_MethyLevel %in% c("CIMP-low") dataPrep <- TCGAanalyze_Preprocessing( object = acc.exp.aux, cor.cut = 0.6 ) dataNorm <- TCGAanalyze_Normalization( tabDF = dataPrep, geneInfo = geneInfoHT, method = "gcContent" ) dataFilt <- TCGAanalyze_Filtering( tabDF = dataNorm, qnt.cut = 0.25, method = 'quantile' ) dataDEGs <- TCGAanalyze_DEA( mat1 = dataFilt[,idx], mat2 = dataFilt[,idx2], Cond1type = "CIMP-high", Cond2type = "CIMP-low", method = "glmLRT" ) TCGAVisualize_volcano( x = dataDEGs$logFC, y = dataDEGs$FDR, filename = "case3/Case3_volcanoexp.png", x.cut = 3, y.cut = 10^-5, names = rownames(dataDEGs), color = c("black","red","darkgreen"), names.size = 2, xlab = " Gene expression fold change (Log2)", legend = "State", title = "Volcano plot (CIMP-high vs CIMP-low)", width = 10 ) ``` The figure resulted from the code above is shown below: ```{r, fig.width=6, fig.height=4, echo = FALSE, fig.align="center",hide=TRUE, message=FALSE,warning=FALSE} library(png) library(grid) img <- readPNG("figure5exp.png") grid.raster(img) ``` Finally, using both previous analysis we do a starburst plot to select the genes that are Candidate Biologically Significant. Observation: over the time, the number of samples has increased and the clinical data updated. We used only the samples that had a classification in the examples. ```{r,eval=FALSE,echo=TRUE,message=FALSE,warning=FALSE} #------------------------------------------ # 2.4 - Starburst plot # ----------------------------------------- # If true the argument names of the genes in circle # (biologically significant genes, has a change in gene # expression and DNA methylation and respects all the thresholds) # will be shown # these genes are returned by the function see starburst object after the function is executed starburst <- TCGAvisualize_starburst( met = acc.met, exp = dataDEGs, genome = "hg19" group1 = "CIMP-high", group2 = "CIMP-low", filename = "case3/starburst.png", met.platform = "450K", met.p.cut = 10^-5, exp.p.cut = 10^-5, diffmean.cut = 0.25, logFC.cut = 3, names = FALSE, height = 10, width = 15, dpi = 300 ) ``` The figure resulted from the code above is shown below: ```{r, fig.width=6, fig.height=4, echo = FALSE, fig.align="center",hide=TRUE, message=FALSE,warning=FALSE} library(png) library(grid) img <- readPNG("figure5star.png") grid.raster(img) ``` # Case study n. 4: ELMER pipeline - KIRC An example of package to perform DNA methylation and RNA expression analysis is ELMER [@yao2015inferring,@elmer2,@yao2015demystifying]. ELMER, which is designed to combine DNA methylation and gene expression data from human tissues to infer multi-level cis-regulatory networks. ELMER uses DNA methylation to identify distal probes, and correlates them with the expression of nearby genes to identify one or more transcriptional targets. Transcription factor (TF) binding site analysis of those anti-correlated distal probes is coupled with expression analysis of all TFs to infer upstream regulators. This package can be easily applied to TCGA public available cancer data sets and custom DNA methylation and gene expression data sets. ELMER analyses have the following steps: 1. Organize data as a *MultiAssayExperiment* object 2. Identify distal probes with significantly different DNA methylation level when comparing two sample groups. 3. Identify putative target genes for differentially methylated distal probes, using methylation vs. expression correlation 4. Identify enriched motifs for each probe belonging to a significant probe-gene pair 5. Identify master regulatory Transcription Factors (TF) whose expression associate with DNA methylation changes at multiple regulatory regions. We will present this the study KIRC by TCGAbiolinks and ELMER integration.