怎样用R语言ggplot2+ggtree+aplot画气泡图组合聚类树图
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,怎样用R语言ggplot2+ggtree+aplot画气泡图组合聚类树图,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。R语言ggpl
千家信息网最后更新 2025年02月01日怎样用R语言ggplot2+ggtree+aplot画气泡图组合聚类树图
怎样用R语言ggplot2+ggtree+aplot画气泡图组合聚类树图,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
R语言ggplot2画气泡图(dotplot)展示基因表达量,今天的内容介绍如何在气泡图和左侧和上方添加聚类树图,今天的内容主要参考 aplot包:让你画出更复杂的图
今天重复的内容是论文中的figure2f
按照论文提供的代码得到了画图用到的数据,部分数据如下
读入数据做气泡图,但是用他提供的画图代码没有能够画出图来。因为他用到了一个
dot_plot()
函数,没有找到这个函数是怎么来的。既然已经拿到了数据,就用ggplot2自己来画吧
data.final<-read.csv("NM/figure2f.csv",header=T,check.names=F)
head(data.final)
library(ggplot2)
ggplot(data.final,aes(x=features.plot,y=id))+
geom_point(aes(size=`Percent expressed`,
color=`Average expression`))+
theme_bw()+
theme(panel.grid = element_blank(),
axis.text.x=element_text(angle=90,hjust = 1,vjust=0.5))+
scale_color_gradient(low="lightgrey",high="blue")+
labs(x=NULL,y=NULL)+
guides(size=guide_legend(order=3))
以y轴为变量,做层次聚类,并使用ggtree展示层次聚类结果
聚类用到的是平均表达量那一列df<-data.final[,c(1,2,4)]
首先是长格式数据转换为宽格式df1<-reshape2::dcast(df,id~features.plot,value.var = "Average expression")
rownames(df1)<-df1$id
df1.1<-df1[,2:22]
层次聚类,ggtree展示结果df1.1.clust<-hclust(dist(df1.1))
df2.1.clust<-hclust(dist(df2.1))
library(ggtree)
p2<-ggtree(df1.1.clust)
p2+
geom_tiplab()+
xlim(NA,7)
使用aplot包拼图library(ggplot2)
p1<-ggplot(data.final,aes(x=features.plot,y=id))+
geom_point(aes(size=`Percent expressed`,
color=`Average expression`))+
theme_bw()+
theme(panel.grid = element_blank(),
axis.text.x=element_text(angle=90,hjust = 1,vjust=0.5))+
scale_color_gradient(low="lightgrey",high="blue")+
labs(x=NULL,y=NULL)+
guides(size=guide_legend(order=3))
library(aplot)
p1%>%
insert_left(p2,width = 0.2)
接下来就是在上方叠加聚类树,一样的操作df2<-reshape2::dcast(df,features.plot~id,value.var = "Average expression")
rownames(df2)<-df2$features.plot
df2.1<-df2[,2:15]
df2.1.clust<-hclust(dist(df2.1))
p3<-ggtree(df2.1.clust)+
#geom_tiplab(angle=90)+
#theme_tree2()+
layout_dendrogram()
p3
p1%>%
insert_left(p2,width = 0.2)%>%
insert_top(p3,height = 0.2)
这里多了一个知识点是ggtree作图默认开口树的方向是向右,如果需要把开口改成向下,需要加上layout_dendrogram()
函数
最终的结果如下
这里和论文中的图有些不一致,可能是聚类算法的原因;ggtree有一个默认的从上到下排序,比如左侧的树现在第一个是H6,第二个是H5,如果想把H5放到第一个也是可以实现的,可以参考之前的推文 R语言ggtree按照指定的节点旋转树。
关于怎样用R语言ggplot2+ggtree+aplot画气泡图组合聚类树图问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。
气泡
数据
语言
内容
函数
层次
结果
论文
问题
组合
代码
更多
格式
知识
参考
帮助
解答
复杂
易行
一致
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
1软件开发的工作流程
校园文明网络安全演讲稿
ios 获取服务器数据
闵行区推广软件开发价格对比
一般公司的软件开发成本占比
ps5需要设置代理服务器吗
洪山软件开发定制
书皮设计软件开发
软件开发计算机系统
优秀网络安全
服务器搭建书籍
ctf网络安全大赛2018
拓普龙工控服务器
数据库2008Sp2下载
公安机关网络安全知识考试
傻瓜式软件开发工具
软件开发大创申报书
手游火影忍者能转苹果服务器吗
软件开发面试笔试题
数据库建设工程师
怎么查看本地的数据库
服务器本地管理员添加用户
学校软件开发企业区别
优秀网络安全
重建华为图库数据库
网络安全初级适合书籍
我的世界基岩版手机如何创服务器
盐城nac网络安全准入控制公司
普通网民怎么保障网络安全
黄岩区本地软件开发价格行情