跟着Nature Metabolism学作图:R语言ggplot2热图组合树图和双层分组标记

简介: 跟着Nature Metabolism学作图:R语言ggplot2热图组合树图和双层分组标记

论文

Single-cell profiling of vascular endothelial cells reveals progressive organ-specific vulnerabilities during obesity

https://www.nature.com/articles/s42255-022-00674-x#Sec58

s42255-022-00674-x.pdf

https://github.com/Osynchronika/sc_EC_obesity_atlas

大部分 作图的数据都有,可以试着用论文中提供的数据复现一下论文中的图

今天的推文我们试着复现一下论文中的Figure2中的热图,figure2中有3个热图,按照复杂程度排序是 figure2m figure2f 和figure2o

image.png

image.png

image.png

今天的推文我们先复现figure2o

论文中提供的数据如下

image.png

数据中有很多缺失值,看论文中的配色 我猜是把缺失值替换成0了,我不太确定这种处理方式是否可以

加载要用到的R包

library(readxl)
library(tidyverse)
library(stringr)
library(ggtree)
library(ggh4x)

读取数据

dat01<-read_excel("data/20230207/figure2o.xlsx",
                  sheet = "Sheet3",na="NA")
dat01

这里我把第一列的列名除了第一列修改成A01:A21,因为最上层的两层分组需要人为构造数据,列名修改成A01:A21在excel里好输入些

colnames(dat01)<-c("gene_name",paste0("A",str_pad(1:21,2,side = "left",pad = "0")))

首先是做最左侧的树图

因为有了树图后要根据树图的前后顺序调整热图的y轴的顺序

dat01  %>% 
  pivot_longer(!gene_name) %>% 
  mutate(value=replace_na(value,0)) %>% 
  pivot_wider() %>% 
  column_to_rownames("gene_name") %>% 
  dist() %>% 
  hclust() -> dat01.hclust

ggtree(dat01.hclust)+
  geom_tiplab()

y_levels<-c("Fabp5","Fabp4","Cd36","Fabp1","Dbi","Lpl")

ggtree(dat01.hclust) -> p2

p2

image.png

然后是热图的代码

dat01 %>% 
  mutate(gene_name=factor(gene_name,
                          levels = y_levels )) %>% 
  pivot_longer(!gene_name) %>% 
  mutate(value=replace_na(value,0)) %>% 
  ggplot(aes(x=name,y=gene_name))+
  geom_tile(aes(fill=value),color="black")+
  scale_fill_gradient2(low="blue",mid="white",high = "red",
                       midpoint = 0,
                       breaks=c(-0.5,-0.25,0,0.25,0.5),
                       labels=c("<-0.5","",0,"",">0.5"))+
  scale_y_discrete(position = "right")+
  scale_x_discrete(expand = expansion(mult = c(0,0)))+
  theme_bw()+
  theme(legend.position = "bottom",
        axis.text.x = element_blank(),
        axis.text.y = element_text(face="italic"),
        axis.ticks = element_blank(),
        axis.title = element_blank(),
        panel.border = element_blank(),
        panel.grid = element_blank())+
  guides(fill=guide_colorbar(title.position = "top",
                             title.hjust = 0.5,
                             barwidth = 10)) -> p1
p1

image.png

最后是分组标记的代码

我人为构造的数据如下
image.png

两层的分组标记:一层是热图,另外一层是分面的形式,分面的形式可以添加好多层

dat<-read_excel("data/20230207/figure2o.xlsx",
                sheet = "Sheet2")

dat %>% pull(group02) %>% unique()

dat %>% 
  mutate(group=factor(group02,levels = dat %>% pull(group02) %>% unique())) -> dat

strip.fill<-c("#ee716b","#c99e0d","#16b5ea","#5ab033","#37b28f","#a08ec3","#d96aa6")
ggplot(data=dat,aes(x=x,y=1))+
  geom_tile(aes(fill=group01),color="black")+
  geom_text(aes(label=group01),color="white")+
  facet_nested(.~group02,space = "free",scales = "free",
               strip=strip_nested(background_x = 
                                    elem_list_rect(fill=strip.fill,
                                                   by_layer_x=FALSE)))+
  scale_x_discrete(expand = expansion(mult = c(0,0)))+
  scale_y_discrete(expand = expansion(mult = c(0,0)))+
  scale_fill_manual(values = c("#dd0c1b","#48ad96","#4d6eb4"))+
  theme(panel.spacing = unit(0,"lines"),
        strip.background = element_rect(fill=c("white"),color="black"),
        axis.text = element_blank(),
        axis.title = element_blank(),
        axis.ticks = element_blank(),
        strip.text.x = element_text(margin = margin(0.5,0,0.5,0, "cm")),
        legend.position = "none",) -> p3

p3

image.png

这里遇到一个问题是

facet_nested(.~group02,space = "free",scales = "free",
               strip=strip_nested(background_x = 
                                    elem_list_rect(fill=strip.fill,
                                                   by_layer_x=FALSE)))

代码里scales=free不能和coord_equal()组合使用,暂时不知道如何解决这个问题

最后是组合图

library(patchwork)
(plot_spacer() + p3 + plot_layout(widths = c(1,8)))/(p2+p1+plot_layout(widths = c(1,8)))+
  plot_layout(heights = c(1,4))

最终结果如下

image.png

示例数据和代码可以给推文点赞,然后点击在看,最后留言获取

欢迎大家关注我的公众号

小明的数据分析笔记本

小明的数据分析笔记本 公众号 主要分享:1、R语言和python做数据分析和数据可视化的简单小例子;2、园艺植物相关转录组学、基因组学、群体遗传学文献阅读笔记;3、生物信息学入门学习资料及自己的学习笔记!

微信公众号好像又有改动,如果没有将这个公众号设为星标的话,会经常错过公众号的推文,个人建议将 小明的数据分析笔记本 公众号添加星标,添加方法是

点开公众号的页面,右上角有三个点
image.png

点击三个点,会跳出界面

image.png

直接点击 设为星标 就可以了

相关文章
|
4月前
|
数据可视化 数据挖掘 图形学
R语言基础可视化:使用ggplot2构建精美图形的探索
【8月更文挑战第29天】 `ggplot2`是R语言中一个非常强大的图形构建工具,它基于图形语法提供了一种灵活且直观的方式来创建各种统计图形。通过掌握`ggplot2`的基本用法和美化技巧,你可以轻松地将复杂的数据转化为直观易懂的图形,从而更好地理解和展示你的数据分析结果。希望本文能够为你探索`ggplot2`的世界提供一些帮助和启发。
|
4月前
|
数据可视化
R语言自定义图形:ggplot2中的主题与标签设置
【8月更文挑战第30天】`ggplot2`作为R语言中功能强大的绘图包,其自定义能力让数据可视化变得更加灵活和多样。通过合理使用`theme()`函数和`labs()`函数,以及`geom_text()`和`geom_label()`等几何对象,我们可以轻松创建出既美观又富有表达力的图形。希望本文的介绍能够帮助你更好地掌握`ggplot2`中的主题与标签设置技巧。
|
7月前
|
算法 数据可视化
R语言社区检测算法可视化网络图:ggplot2绘制igraph对象分析物种相对丰度
R语言社区检测算法可视化网络图:ggplot2绘制igraph对象分析物种相对丰度
|
3月前
|
数据采集 机器学习/深度学习 数据可视化
R语言从数据到决策:R语言在商业分析中的实践
【9月更文挑战第1天】R语言在商业分析中的应用广泛而深入,从数据收集、预处理、分析到预测模型构建和决策支持,R语言都提供了强大的工具和功能。通过学习和掌握R语言在商业分析中的实践应用,我们可以更好地利用数据驱动企业决策,提升企业的竞争力和盈利能力。未来,随着大数据和人工智能技术的不断发展,R语言在商业分析领域的应用将更加广泛和深入,为企业带来更多的机遇和挑战。
|
2月前
|
数据挖掘 C语言 C++
R语言是一种强大的统计分析工具,提供了丰富的函数和包用于时间序列分析。
【10月更文挑战第21天】时间序列分析是一种重要的数据分析方法,广泛应用于经济学、金融学、气象学、生态学等领域。R语言是一种强大的统计分析工具,提供了丰富的函数和包用于时间序列分析。本文将介绍使用R语言进行时间序列分析的基本概念、方法和实例,帮助读者掌握R语言在时间序列分析中的应用。
58 3
|
7月前
|
数据可视化 数据挖掘 API
【R语言实战】聚类分析及可视化
【R语言实战】聚类分析及可视化
|
7月前
|
机器学习/深度学习 数据可视化
R语言逻辑回归logistic模型ROC曲线可视化分析2例:麻醉剂用量影响、汽车购买行为2
R语言逻辑回归logistic模型ROC曲线可视化分析2例:麻醉剂用量影响、汽车购买行为
|
3月前
|
数据采集 数据可视化 数据挖掘
R语言在金融数据分析中的深度应用:探索数据背后的市场智慧
【9月更文挑战第1天】R语言在金融数据分析中展现出了强大的功能和广泛的应用前景。通过丰富的数据处理函数、强大的统计分析功能和优秀的可视化效果,R语言能够帮助金融机构深入挖掘数据价值,洞察市场动态。未来,随着金融数据的不断积累和技术的不断进步,R语言在金融数据分析中的应用将更加广泛和深入。
|
4月前
|
机器学习/深度学习 数据采集 数据可视化
R语言在数据科学中的应用实例:探索与预测分析
【8月更文挑战第31天】通过上述实例,我们展示了R语言在数据科学中的强大应用。从数据准备、探索、预处理到建模与预测,R语言提供了完整的解决方案和丰富的工具集。当然,数据科学远不止于此,随着技术的不断发展和业务需求的不断变化,我们需要不断学习和探索新的方法和工具,以更好地应对挑战,挖掘数据的潜在价值。 未来,随着大数据和人工智能技术的普及,R语言在数据科学领域的应用将更加广泛和深入。我们期待看到更多创新的应用实例,为各行各业的发展注入新的动力。
|
4月前
|
数据采集 存储 数据可视化
R语言时间序列分析:处理与建模时间序列数据的深度探索
【8月更文挑战第31天】R语言作为一款功能强大的数据分析工具,为处理时间序列数据提供了丰富的函数和包。从数据读取、预处理、建模到可视化,R语言都提供了灵活且强大的解决方案。然而,时间序列数据的处理和分析是一个复杂的过程,需要结合具体的应用场景和需求来选择合适的方法和模型。希望本文能为读者在R语言中进行时间序列分析提供一些有益的参考和启示。