Author: Alan O’Callaghan (alan.b.ocallaghan@gmail.com)

Introduction

Due to the size of the objects, this file is seperated to three files. You can view this series in the following links:

This is file 2 in the series.

# Let's load the packages
library(heatmaply)
#> Loading required package: plotly
#> Loading required package: ggplot2
#> 
#> Attaching package: 'plotly'
#> The following object is masked from 'package:ggplot2':
#> 
#>     last_plot
#> The following object is masked from 'package:stats':
#> 
#>     filter
#> The following object is masked from 'package:graphics':
#> 
#>     layout
#> Loading required package: viridis
#> Loading required package: viridisLite
#> 
#> ---------------------
#> Welcome to heatmaply version 0.11.1
#> Type ?heatmaply for the main documentation.
#> The github page is: https://github.com/talgalili/heatmaply/
#> 
#> Suggestions and bug-reports can be submitted at: https://github.com/talgalili/heatmaply/issues
#> Or contact: <tal.galili@gmail.com>
#> 
#>  To suppress this message use:  suppressPackageStartupMessages(library(heatmaply))
#> ---------------------
library(heatmaplyExamples)

Visualization of raw data (median-centered data, PAM50 genes only)

Breast cancer has been studied extensively using gene expression profiling methods (see Breast cancer gene expression). This has lead to the identification of a number of gene sets which stratify patients into molecular subgroups. One such gene set is commonly known as the PAM50 gene set. In this example, we will visualize gene expression patterns using heatmaply.

Centering data before performing clustering tends to result in more meaningful cluster assignment. This is particularly true when the measure of interest is the similarity in patterns across features, rather than the total distance between values. Furthermore, it is typically the difference between samples which is of interest, rather than the difference between measures. Non-centered data may show that all samples measure high for one variable, and low for another, while centered data shows relative differences. Alternatively, one could use a distance measure which is invariant to total distance, such as correlation. Heatmaps of non-centered are shown in another vignette within this package. It can be seen that the concordance between the centered and non-centered heatmaps is mediocre, and the clustering of triple negative samples is not as definite.

In the heatmaps shown below, it is clear that samples appear to cluster loosely based on PAM50 subtype more than the previous examples. Concordance with the assigned labels shown in the row annotation is not complete, however this may be expected, given that a different clustering method was used here (hierarchical clustering, rather than k-medioids).

pam50_genes <- intersect(pam50_genes, rownames(raw_expression))
raw_pam50_expression <- raw_expression[pam50_genes, ]
voomed_pam50_expression <- voomed_expression[pam50_genes, ]

center_raw_mat <- raw_pam50_expression - 
    apply(raw_pam50_expression, 1, median)

raw_max <- max(abs(center_raw_mat), na.rm=TRUE)
raw_limits <- c(-raw_max, raw_max)
heatmaply(t(center_raw_mat), 
    row_side_colors = tcga_brca_clinical,
    showticklabels = c(FALSE, FALSE),
    fontsize_col = 7.5,
    col = cool_warm(100),
    main = 'Centred log2 read counts, PAM50 genes',
    limits = raw_limits,
    plot_method = 'plotly')

Note that heatmaply_cor is just like heatmaply but with defaults that are better suited for correlation matrix (limits from -1 to 1, and a cold-warm color scheme).

heatmaply_cor(cor(center_raw_mat), 
    row_side_colors = tcga_brca_clinical,
    showticklabels = c(FALSE, FALSE),
    main = 'Sample-sample correlation based on centred, log2 PAM50 read counts',
    plot_method = 'plotly')

Discussion

It may be useful when examining expression heatmaps to identify particularly high or low measures for a single gene in a group of patients, or a gene which shows unusually high or low variance. The mouse-over text available in the heatmaply package allows visual assessment of measures of interest and quick identification of samples or genes with unusual gene expression patterns. Similarly, visualizing correlation heatmaps with heatmaply allows the user to rapidly identify samples with unusually high or low pairwise correlation.

sessionInfo

sessionInfo()
#> R version 3.4.2 (2017-09-28)
#> Platform: x86_64-pc-linux-gnu (64-bit)
#> Running under: Ubuntu 16.04.3 LTS
#> 
#> Matrix products: default
#> BLAS: /usr/lib/openblas-base/libblas.so.3
#> LAPACK: /usr/lib/libopenblasp-r0.2.18.so
#> 
#> locale:
#>  [1] LC_CTYPE=en_GB.UTF-8       LC_NUMERIC=C              
#>  [3] LC_TIME=en_GB.UTF-8        LC_COLLATE=en_GB.UTF-8    
#>  [5] LC_MONETARY=en_GB.UTF-8    LC_MESSAGES=en_GB.UTF-8   
#>  [7] LC_PAPER=en_GB.UTF-8       LC_NAME=C                 
#>  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
#> [11] LC_MEASUREMENT=en_GB.UTF-8 LC_IDENTIFICATION=C       
#> 
#> attached base packages:
#> [1] stats     graphics  grDevices utils     datasets  methods   base     
#> 
#> other attached packages:
#> [1] heatmaplyExamples_0.2.0 heatmaply_0.11.1        viridis_0.4.0          
#> [4] viridisLite_0.2.0       plotly_4.7.1            ggplot2_2.2.1.9000     
#> [7] knitr_1.16             
#> 
#> loaded via a namespace (and not attached):
#>  [1] httr_1.3.1         tidyr_0.6.3        jsonlite_1.5      
#>  [4] foreach_1.4.3      gtools_3.5.0       shiny_1.0.5       
#>  [7] assertthat_0.2.0   stats4_3.4.2       yaml_2.1.14       
#> [10] robustbase_0.92-7  backports_1.1.0    lattice_0.20-35   
#> [13] glue_1.1.1         digest_0.6.12      RColorBrewer_1.1-2
#> [16] colorspace_1.3-2   htmltools_0.3.6    httpuv_1.3.5      
#> [19] plyr_1.8.4         pkgconfig_2.0.1    xtable_1.8-2      
#> [22] purrr_0.2.3        mvtnorm_1.0-6      scales_0.5.0.9000 
#> [25] gdata_2.18.0       whisker_0.3-2      tibble_1.3.4      
#> [28] nnet_7.3-12        lazyeval_0.2.0     mime_0.5          
#> [31] magrittr_1.5       mclust_5.3         evaluate_0.10.1   
#> [34] MASS_7.3-47        gplots_3.0.1       class_7.3-14      
#> [37] tools_3.4.2        registry_0.3       data.table_1.10.4 
#> [40] trimcluster_0.1-2  stringr_1.2.0      kernlab_0.9-25    
#> [43] munsell_0.4.3      cluster_2.0.6      fpc_2.1-10        
#> [46] bindrcpp_0.2       compiler_3.4.2     caTools_1.17.1    
#> [49] rlang_0.1.2.9000   grid_3.4.2         iterators_1.0.8   
#> [52] htmlwidgets_0.9    crosstalk_1.0.0    bitops_1.0-6      
#> [55] rmarkdown_1.6      gtable_0.2.0       codetools_0.2-15  
#> [58] flexmix_2.3-14     TSP_1.1-5          R6_2.2.2          
#> [61] seriation_1.2-2    gridExtra_2.2.1    prabclus_2.2-6    
#> [64] dplyr_0.7.2        bindr_0.1          rprojroot_1.2     
#> [67] KernSmooth_2.23-15 dendextend_1.5.2   modeltools_0.2-21 
#> [70] stringi_1.1.5      Rcpp_0.12.12       gclus_1.3.1       
#> [73] DEoptimR_1.0-8     diptest_0.75-7