怎么使用R语言ggtree展示进化树
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,今天就跟大家聊聊有关怎么使用R语言ggtree展示进化树,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。今天要模仿的图片来自于论文 Core g
千家信息网最后更新 2025年01月22日怎么使用R语言ggtree展示进化树
今天就跟大家聊聊有关怎么使用R语言ggtree展示进化树,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
今天要模仿的图片来自于论文 Core gut microbial communities are maintained by beneficial interactions and strain variability in fish。期刊是 Nature microbiology
今天重复的图片是Figure1中的聚类树图
论文中写道Hierarchical clustering dendrogram with jackknife support (numbers on the branches; only values above 50 are shown in the tree).
所以论文中实际的数据做的是聚类分析,而并不是进化树。他这里做聚类分析也能够获得每个节点对应的支持率。这个如何实现我暂时还不知道。为了模仿这个图,下面的输入数据我直接使用进化树文件了,因为构建进化树的时候能够很方便的获得节点的支持率信息。
首先准备构建进化树需要用到的fasta格式序列文件这里用到的数据集来自 网址 https://www.kuleuven.be/aidslab/phylogenybook/Data_sets.html
首先是做多序列比对,这里我使用mafft这本 The Phylogenetic Handbook second edition 不知道大家有没有电子版可以分享呀!
mafft --auto ggtree_practice.fasta > ggtree_practice_aligned.fasta
构建进化树,我是用iqtreeiqtree -s ggtree_practice_aligned.fasta -bb 1000
得到树文件ggtree_practice_aligned.fasta.treefile
接下来是在R语言里的操作
首先是准备一个分组的数据文件数据总共三列
第一列是 构建进化树用到的fasta文件的序列名,这里注意列明用label,不要用其他 第二列是分组信息,用来填充不同的颜色 第三列也是分组信息,用来映射形状
第二列和第三列的列名就是图例上想显示什么就用什么
加载需要用到的包library(ggtree)
library(treeio)
library(tidytree)
treeio
用来读入进化树tidytree
用来将分组信息整合给进化树ggtree
用来可视化展示进化树
tree<-read.newick("ggtree_practice_aligned.fasta.treefile",
node.label = "support")
d<-read.csv("ggtree_group_info.csv",header=T)
d
将树文件和分组信息整合到一起trs<-full_join(tree,d,by='label')
去掉支持率小于50的信息tree@data$support<-ifelse(tree@data$support<50,NA,tree@data$support)
最后一步就是画图了ggtree(trs,layout = "circular",branch.length = "none")+
#geom_tiplab(offset = 0.01)+
geom_tippoint(aes(shape=Diet,color=Gut.compartment),
size=5)+
scale_shape_manual(values = c(16,17,18,15))+
geom_text2(aes(label=support,angle=angle),hjust=-0.2)+
scale_color_manual(values = c("#800080","#ff8000","#008080"),
name="Gut_compartment")+
guides(color=guide_legend(order = 1))
进化
信息
数据
文件
分组
支持
语言
内容
支持率
论文
图片
就是
序列
节点
准备
分析
整合
不同
接下来
图例
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
decimal数据库
软件开发风潮是什么原因
网络安全调查量表
怎样成为网络安全
七日杀服务器管理mod
软件开发试验总结报告
手机连接网页服务器错误
服务器加速区和安全区
济南易途网络技术有限公司
rsc是否是常见文摘数据库
服务器在东南亚能做防火墙吗
数据库窗体实训结论
在国企做软件开发
fifa3超级数据库
福州网络技术学院
网络安全的运维管理
软件开发编码考核指标
专业配送系统软件开发
金蝶专业版数据库怎么写
oracle数据库的密码文件
定制化国产服务器企业
网络安全技术有哪些工具
互联网数据库怎么建立
我市举行网络安全宣传周
mqtt服务器启动不了什么原因
征信系统用的什么数据库
湖南医付保互联网科技
网络安全上网手抄报图片
闻道网络安全
服务器频繁自动重启开不了机