千家信息网

R语言ggplot2绘制热图展示GO富集分析结果的是怎样的

发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,本篇文章为大家展示了R语言ggplot2绘制热图展示GO富集分析结果的是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。image.png这个图的实现办法
千家信息网最后更新 2025年01月23日R语言ggplot2绘制热图展示GO富集分析结果的是怎样的

本篇文章为大家展示了R语言ggplot2绘制热图展示GO富集分析结果的是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

image.png

这个图的实现办法有很多,今天的推文介绍一下使用R语言的ggplot2实现上图的代码。

首先是构造示例数据

构造两份数据
  • 一份是最左侧的分组颜色条
  • 一份是右侧展示数值的热图

构造数据用到的代码

x<-seq(0,1,by=0.001)
set.seed(1234)
x1<-sample(x,240)
mymatrix<-matrix(x1,ncol=6)
head(mymatrix)
colnames(mymatrix)<-paste0("gene",1:6)
rownames(mymatrix)<-paste0("GO:000",1:40," ",
sample(LETTERS[1:26],40,replace = T))
write.csv(mymatrix,file = "GO_qvalue.csv",quote=F,row.names = T)
dfclass<-data.frame(x="class",
y=rownames(mymatrix),
group=c(rep("Biological Process",25),
rep("Cellular Component",5),
rep("Molecular Function",10)))
write.csv(dfclass,file = "class.csv",quote=F,row.names = F)

大家可以自己运行代码得到示例数据,或者直接在文末留言

数据部分截图如下

image.png
image.png
首先是画右侧的如图

最基本的热图代码

df1<-read.csv("GO_qvalue.csv",header = T,row.names = 1)
df1$GO_term<-rownames(df1)
df1.1<-reshape2::melt(df1,var.id="GO_term")
head(df1.1)
df1.1$GO_term<-factor(df1.1$GO_term,
levels = row.names(df1))
library(ggplot2)
ggplot(df1.1,aes(x=variable,y=GO_term))+
geom_tile(aes(fill=value))
image.png
接下来是美化
ggplot(df1.1,aes(x=variable,y=GO_term))+
geom_tile(aes(fill=value),color="grey")+
scale_x_discrete(expand = c(0,0))+
scale_y_discrete(expand = c(0,0),
position = "right")+
theme(panel.background = element_blank(),
axis.ticks = element_blank(),
axis.title = element_blank(),
axis.text.x = element_text(angle = 90,hjust=1,vjust = 0.5))+
scale_fill_gradient(low="red",high="green")

image.png

说实话这个红绿配色的热图我真欣赏不来,我们换一个配色吧还是

ggplot(df1.1,aes(x=variable,y=GO_term))+
geom_tile(aes(fill=value),color="grey")+
scale_x_discrete(expand = c(0,0))+
scale_y_discrete(expand = c(0,0),
position = "right")+
theme(panel.background = element_blank(),
axis.ticks = element_blank(),
axis.title = element_blank(),
axis.text.x = element_text(angle = 90,hjust=1,vjust = 0.5))+
scale_fill_viridis_c()
image.png

这个颜色看起来还挺舒服的

接下来是左侧的分组颜色条

df2<-read.csv("class.csv",header = T)
head(df2)
df2$y<-factor(df2$y,
levels = rownames(df1))
ggplot(df2,aes(x=x,y=y))+
geom_tile(aes(fill=group),color="grey")+
theme(panel.background = element_blank(),
axis.title = element_blank(),
axis.text.y = element_blank(),
axis.ticks = element_blank(),
axis.text.x = element_text(angle=90,hjust=1,vjust=0.5))+
scale_x_discrete(expand = c(0,0))+
scale_y_discrete(expand = c(0,0))+
scale_fill_manual(name="class",
values = c("#619cff","#00ba38","#f8766d"))
image.png
最后就是拼图了
library(ggplot2)
p1<-ggplot(df1.1,aes(x=variable,y=GO_term))+
geom_tile(aes(fill=value),color="grey")+
scale_x_discrete(expand = c(0,0))+
scale_y_discrete(expand = c(0,0),
position = "right")+
theme(panel.background = element_blank(),
axis.ticks = element_blank(),
axis.title = element_blank(),
axis.text.x = element_text(angle = 90,hjust=1,vjust = 0.5))+
scale_fill_viridis_c(name="Q-value")



p2<-ggplot(df2,aes(x=x,y=y))+
geom_tile(aes(fill=group),color="grey")+
theme(panel.background = element_blank(),
axis.title = element_blank(),
axis.text.y = element_blank(),
axis.ticks = element_blank(),
axis.text.x = element_text(angle=90,hjust=1,vjust=0.5))+
#scale_x_discrete(expand = c(0,0))+
scale_y_discrete(expand = c(0,0))+
scale_fill_manual(name="class",
values = c("#619cff","#00ba38","#f8766d"))

library(aplot)
p1%>%
insert_left(p2,0.1)

最终的结果如下

image.png

上述内容就是R语言ggplot2绘制热图展示GO富集分析结果的是怎样的,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。

热图 数据 代码 结果 语言 颜色 分析 富集 接下来 内容 右侧 就是 技能 知识 示例 分组 简明 舒服 简明扼要 说实话 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 服务器可以同时带几个电脑吗 net软件开发机构 服务器大文件如何存储 通辽市元都网络技术有限公司 淘宝网络安全负责人是谁 大华平台用什么数据库 电子政务软件开发人月单价 沉迷网络安全的手抄报 数据库开发工程师待遇6 我的世界基岩版台湾服务器 服务器加显卡需要配置吗 化州手机软件开发 分析实际工程应用网络技术 怎样备份数据库2000 数据库有哪些语言 大型服务器显卡有要求吗 交易软件开发多少钱 ibm刀塔服务器维修 学校网络安全解决办法 腾达路由器远端服务器没反应 四川网络技术开发销售价格 湖南企薪社互联网科技有限公司 幼儿园网络安全责任制落实情况 计算机网络技术可以纹身吗 雅安网络技术服务 网络安全发展规划正式发布 金枝玉叶下载软件开发 游戏公司租用服务器价格 台服服务器 联盟 魔兽世界 史上最好玩的娱乐服务器
0