前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ComplexHeatmap|绘制单个热图-I

ComplexHeatmap|绘制单个热图-I

作者头像
生信补给站
发布2021-06-24 21:33:39
1.4K0
发布2021-06-24 21:33:39
举报
文章被收录于专栏:生信补给站

ComplexHeatmap可以绘制很复杂的热图,能满足日常以及文章所需,本次先简单的介绍单个热图绘制的内容。

单个热图由热图主体和热图组件组成。其中主体可分为行和列;组件可以是标题、树状图、矩阵名称和热图注释,在主图的四周均可,且顺序可调整。

一 载入数据,R包

1.1 载入ComplexHeatmap包
代码语言:javascript
复制
代码语言:javascript
复制
#if (!requireNamespace("BiocManager", quietly = TRUE))
#    install.packages("BiocManager")
#BiocManager::install("ComplexHeatmap")
library(ComplexHeatmap)
代码语言:javascript
复制
1.2 载入数据

为更贴近生信使用场景,直接使用内置的基因表达数据

代码语言:javascript
复制
代码语言:javascript
复制
expr = readRDS(paste0(system.file(package = "ComplexHeatmap"), "/extdata/gene_expression.rds"))
#查看数据
str(expr)
expr[1:4,c(1:4,25:27)]
代码语言:javascript
复制

拿到一个新数据后,除了检查[1:4,1:4]外,也许还需要看看最后几列,另外还需要观察列名称的规律。

去除最后几列,或者只选取列名字包含cell的(TCGA数据处理中也会经常遇到)

代码语言:javascript
复制
代码语言:javascript
复制
mat = as.matrix(expr[, grep("cell", colnames(expr))])
代码语言:javascript
复制
1.3 绘制最简单的热图
代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat)
代码语言:javascript
复制

可以看到有很多需要“美化”的地方,别急,一点点来。

二 热图修饰

2.1 颜色
1)连续型变量

可以使用circle::colorRamp2()函数来生成Heatmap()中的颜色映射函数,输入参数为分割位置以及分割点上的颜色。下例中,大于12的值都映射为红色,小于12的值映射为绿色;

代码语言:javascript
复制
代码语言:javascript
复制
library(circlize)
#c中的范围要根据实际情况设置
col_fun = colorRamp2(c(8, 12, 16), c("green", "white", "red"))
Heatmap(mat, name = "mat", col = col_fun)
代码语言:javascript
复制
2)分类型变量

更改分类变量的颜色,需要把所有分类的数字均进行赋值。

代码语言:javascript
复制
代码语言:javascript
复制
discrete_mat = matrix(sample(1:4, 100, replace = TRUE), 10, 10)
colors = structure(1:4, names = c("1", "2", "3", "4")) # black, red, green, blue
Heatmap(discrete_mat, name = "mat", col = colors,
    column_title = "a discrete numeric matrix")
代码语言:javascript
复制

更多颜色修改请参考官方文档,文末的参考资料的链接。

2.2 标题

1)设置行,列和图例的标题

代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat, 
        name = "legend title", #图例title
        column_title = "I am a column title", #列title 
        row_title = "I am a row title",
        column_title_side = "bottom") #行title
代码语言:javascript
复制

2)设置标题的位置,颜色,字体,大小

代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat, name = "mat", 
        row_title = "row title",
        row_title_rot = 0, #旋转方向
        column_title = "I am a big column title", 
        column_title_side = "bottom", #标题位置
        column_title_gp = gpar(fontsize = 20, fontface = "bold",col = "red")) #颜色,字体,大小
代码语言:javascript
复制

3)设置标题的背景

column_title_gp中的填充参数来设置标题的背景颜色

代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat, name = "mat", 
        column_title = "I am a column title", 
        column_title_gp = gpar(fill = "red", col = "white", border = "blue"),
        )
代码语言:javascript
复制
2.3 聚类

聚类是热图可视化的关键组成部分,在ComplexHeatmap包中可以非常灵活的进行设置。

A:一般设置

cluster_rows/columns :是否进行聚类 show_column/row_dend :是否显示聚类树 column/row_dend_side :聚类图绘制的位置 column_dend_height/row_dend_widht :聚类树的高度 和 宽度

代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat, name = "mat",
        cluster_columns = T,  
        cluster_rows = F, ## turn off row clustering
        show_column_dend = T, ## hide column dendrogram
        show_row_dend = F,
        column_dend_side = "top",  #dendrogram location
        column_dend_height = unit(4, "cm"))
代码语言:javascript
复制

注意:聚类树的高度 和 宽度有区别。

B:距离方法

可选计算距离的方式包括pearson, spearman以及kendall , 或者计算距离的自定义函数。

代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat, name = "mat", clustering_distance_rows = "pearson",
    column_title = "pre-defined distance method (1 - pearson)")
代码语言:javascript
复制

2)自定义

代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat, name = "mat", clustering_distance_rows = function(x, y) 1 - cor(x, y),
    column_title = "a function that calculates pairwise distance")
C:聚类方法

支持hclust()中的聚类方法。

代码语言:javascript
复制
代码语言:javascript
复制
Heatmap(mat, name = "mat", clustering_method_rows = "single")
代码语言:javascript
复制
D:聚类树的渲染

根据聚类结果将聚类树的枝设置不同的颜色

代码语言:javascript
复制
代码语言:javascript
复制
library(dendextend)
row_dend = as.dendrogram(hclust(dist(mat)))
row_dend = color_branches(row_dend, k = 4) # `color_branches()` returns a dendrogram object
Heatmap(mat, name = "mat", 
        cluster_rows = row_dend,
        row_dend_width  = unit(4, "cm"))
代码语言:javascript
复制
2.4 设置行列顺序

通过row_order/column_order函数自定义其排序,为方便展示选择前30个基因。

代码语言:javascript
复制
代码语言:javascript
复制
mat <- mat[1:30,]
Heatmap(mat, name = "mat", 
          row_order = order(as.numeric(gsub("gene", "", rownames(mat)))), #将gene1替换为1,在排序
          column_order = sort(colnames(mat)),
          column_title = "reorder matrix")

注:此处将gene1,gene10 先替换掉gene(不去的话是按照ASCII码),然后按照数值排序。

参考资料:

https://zhuanlan.zhihu.com/p/363769759

https://jokergoo.github.io/ComplexHeatmap-reference/book/a-single-heatmap.html

PS:有个交流的讨论组,想沟通交流的,后台回复”入群“。

◆ ◆ ◆ ◆ ◆

精心整理(含图PLUS版)|R语言生信分析,可视化(R统计,ggplot2绘图,生信图形可视化汇总)

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-06-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 生信补给站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.1 载入ComplexHeatmap包
  • 1.2 载入数据
  • 1.3 绘制最简单的热图
  • 2.1 颜色
    • 1)连续型变量
      • 2)分类型变量
      • 2.2 标题
      • 2.3 聚类
        • A:一般设置
          • B:距离方法
            • C:聚类方法
              • D:聚类树的渲染
              • 2.4 设置行列顺序
              相关产品与服务
              腾讯云 BI
              腾讯云 BI(Business Intelligence,BI)提供从数据源接入、数据建模到数据可视化分析全流程的BI能力,帮助经营者快速获取决策数据依据。系统采用敏捷自助式设计,使用者仅需通过简单拖拽即可完成原本复杂的报表开发过程,并支持报表的分享、推送等企业协作场景。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档