### 加载所需R包
# if (!requireNamespace("BiocManager", quietly = TRUE))
# install.packages("BiocManager")
# BiocManager::install("ggtree", version = "3.8")
library(ggplot2)
library(ggtree)
### 设置工作路径
setwd("/Users/liang/Desktop/")
# 清除当前环境中的变量
rm(list=ls())
# 使用read.newick函数读取nwk格式的树文件
# nodel.label="support"参数在读取nwk格式的树文件时可以存入bootstrap值
tree <- read.newick("RAxML_bipartitions.concatenation_out.nwk",node.label = "support")
ggtree(tree)
data:image/s3,"s3://crabby-images/7da85/7da85bb66542a5010a5341d8dd3c2ba7ad67a97a" alt=""
image.png
ggtree(tree, color="firebrick", size=1, linetype="dotted")
data:image/s3,"s3://crabby-images/601db/601dbe10618b71a028ce52a2d2cc0a56f5e24f96" alt=""
image.png
# 默认情况下,树以ladderize形式查看,可以设置参数ladderize = FALSE以禁用它
ggtree(tree, ladderize=FALSE)
data:image/s3,"s3://crabby-images/70a2d/70a2d832072debbc484eb73eae14e25d8b8a4bf0" alt=""
image.png
设置branch.length="none"只查看树的拓扑结构
ggtree(tree, branch.length="none")
data:image/s3,"s3://crabby-images/1240a/1240ae05b957b7b848124e1b82ac0a5c43c9476a" alt=""
image.png
# layout参数设置不同的展示布局,默认为“rectangular”
ggtree(tree, layout="rectangular") + ggtitle("rectangular (phylogram)")
ggtree(tree, layout="rectangular",branch.length = "none") + ggtitle("rectangular (cladogram)")
ggtree(tree, layout="slanted") + ggtitle("slanted (phylogram)")
ggtree(tree, layout="circular") + ggtitle("circular (phylogram)")
ggtree(tree, layout="circular",branch.length = "none") + ggtitle("circular (cladogram)")
ggtree(tree, layout="fan", open.angle=160) + ggtitle("fan (phylogram)")
ggtree(tree, layout="equal_angle") + ggtitle("equal angle (unrooted)")
ggtree(tree, layout="daylight") + ggtitle("daylight (unrooted)")
ggtree(tree, layout="daylight",branch.length = "none") + ggtitle("daylight (cladogram)")
data:image/s3,"s3://crabby-images/912fc/912fc7c404c248648a3de1615ad180983a4dfaed" alt=""
image.png
data:image/s3,"s3://crabby-images/e02c8/e02c878a9cdf4cb80600aebc4740392be96529f8" alt=""
image.png
data:image/s3,"s3://crabby-images/1c12b/1c12beb9aa3abf5579879a8667960bbb3b0012a5" alt=""
image.png
data:image/s3,"s3://crabby-images/e2ae7/e2ae7c315b50e209c33fe69c6cc59820e6824d4f" alt=""
image.png
data:image/s3,"s3://crabby-images/1aa7e/1aa7edcd7c620294b8549a2894e9a3bef140f170" alt=""
image.png
data:image/s3,"s3://crabby-images/33d89/33d893f0edf17429d3ef08ab52f8f2e352bb09e3" alt=""
image.png
data:image/s3,"s3://crabby-images/5c672/5c672b8d6e46aaab6ccd13e85c830c33979ab5e6" alt=""
image.png
data:image/s3,"s3://crabby-images/befea/befea9b31e9bf4acb90941ba904baba0c4c54699" alt=""
image.png
data:image/s3,"s3://crabby-images/24f1b/24f1bca380ad2081d00526b711ec6420204ce710" alt=""
image.png
显示树的尺度和时间标度
ggtree(tree) + geom_treescale()
ggtree(tree) + theme_tree2()
ggtree(tree) + geom_treescale(fontsize=8, linesize=1, offset=-0.5) + theme_tree2()
data:image/s3,"s3://crabby-images/34c5c/34c5c1b93b9888d57c7b2a3689ad09cec1b9b052" alt=""
image.png
data:image/s3,"s3://crabby-images/7609d/7609d03397bc3d02564905cf572e675d4e6ffb21" alt=""
image.png
data:image/s3,"s3://crabby-images/a3351/a33512eaa8be4a261197b5777f490afc2fdeed39" alt=""
image.png
# 显示树的节点和节点标签
# 使用geom_nodepoint,geom_tippoint或者geom_point添加内部节点
ggtree(tree) + geom_point(aes(shape=isTip, color=isTip), size=3)
data:image/s3,"s3://crabby-images/18084/180847d59423b0c8f1a2e628ff79304f69a08660" alt=""
image.png
ggtree(tree) + geom_nodepoint(color="#b5e521", alpha=1/4, size=10)
data:image/s3,"s3://crabby-images/61372/61372e602370e069e1dd248a4b9959a5dde9e630" alt=""
image.png
ggtree(tree) + geom_tippoint(color="#FDAC4F", shape=8, size=3)
data:image/s3,"s3://crabby-images/db58c/db58ce811aee69f0f991e63040e5a61d1e4cff1d" alt=""
image.png
ggtree(tree) + geom_nodepoint(color="#b5e521", alpha=1/4, size=10)+ geom_tippoint(color="#FDAC4F", shape=8, size=3)
data:image/s3,"s3://crabby-images/688bb/688bb4cc80da0e9bcde2ff8ce988e4a01a756b6d" alt=""
image.png
# 使用geom_nodelab和geom_tiplab显示节点标签
ggtree(tree) + geom_nodepoint(color="#b5e521", alpha=1/4, size=10) + geom_tiplab(size=3, color="purple") + xlim(0,0.5)
data:image/s3,"s3://crabby-images/3ae33/3ae330537bdf6ef9be2810daeb0318e6724c9ebd" alt=""
image.png
ggtree(tree) + geom_tiplab(size=3, color="purple") + xlim(0,0.5) + geom_nodelab(aes(subset=!isTip,label=node),hjust=-.3,color="red")
data:image/s3,"s3://crabby-images/0227a/0227ac2addf3cfdf228f908c26bb5772a723d1ff" alt=""
image.png
# 设置不同的主题
ggtree(tree, color="red") + theme_tree("steelblue")
data:image/s3,"s3://crabby-images/5e609/5e609592bf24325f7cf05e11f835a46bce44818c" alt=""
image.png
ggtree(tree, color="purple") + theme_tree("black")
data:image/s3,"s3://crabby-images/038db/038db092a168edab404ddf0a3315e7ca75ac2ba6" alt=""
image.png
# 显示树上所有节点的序号
ggtree(tree) + geom_text2(aes(label=node),hjust=-.3,color="red")
data:image/s3,"s3://crabby-images/132a4/132a450c5e1d87a42091ef43d659fc672b524812" alt=""
image.png
# 只显示内部节点的序号
ggtree(tree) + geom_text2(aes(subset=!isTip,label=node),hjust=-.3,color="red")
data:image/s3,"s3://crabby-images/1b7b3/1b7b31f5513aa3aaf485e3778cef921104f2577a" alt=""
image.png
# 给指定节点的clade添加标签
ggtree(tree) + geom_text(aes(label=node),hjust=-.3,color="red") + geom_cladelabel(node=19,label="A",barsize = 1,color="blue")
data:image/s3,"s3://crabby-images/ce017/ce017cd2106f7dfa2f95405af383d3357decd34c" alt=""
image.png
# 高亮指定节点所对应的区域
ggtree(tree) + geom_text(aes(label=node),hjust=-.3,color="red") + geom_hilight(node=16,fill = "blue",alpha = 0.6)
data:image/s3,"s3://crabby-images/d5c73/d5c738524a10a8edc2df747e151ba093dca875a9" alt=""
image.png
ggtree(tree) + geom_hilight(node=19,fill = "blue",alpha = 0.6) + geom_hilight(node=14,fill = "red",alpha = 0.6)
data:image/s3,"s3://crabby-images/36f9b/36f9bd6137dd334650cea959c47fe09f70261b5e" alt=""
image.png
# 在两个节点之间添加线段和标记
ggtree(tree) + geom_text(aes(label=node),hjust=-.3,color="red") + geom_strip(13,19,barsize = 2,color="red",label="A")
data:image/s3,"s3://crabby-images/82b39/82b3975d20bd3b8a09d0836bd670eeeb4ab398c7" alt=""
image.png
# 添加bootstrap值和节点标记
ggtree(tree,color="black",linetype=1,size=1.5,ladderize = T) + xlim(0,0.6) +
geom_tiplab(hjust = -0.05,size=5,fontface="italic") +
geom_text2(aes(subset=!isTip,label=support,color=support, hjust=-0.5),size=4) +
geom_point2(aes(subset=!isTip),fill="red",shape=21,size=4) +
scale_color_gradient(high='red', low='darkgreen') + theme(legend.position='right')
data:image/s3,"s3://crabby-images/1d7db/1d7dbed0516d12f87aed44064d2633253b63ea24" alt=""
image.png
sessionInfo()
## R version 3.5.1 (2018-07-02)
## Platform: x86_64-apple-darwin15.6.0 (64-bit)
## Running under: OS X El Capitan 10.11.3
##
## Matrix products: default
## BLAS: /Library/Frameworks/R.framework/Versions/3.5/Resources/lib/libRblas.0.dylib
## LAPACK: /Library/Frameworks/R.framework/Versions/3.5/Resources/lib/libRlapack.dylib
##
## locale:
## [1] zh_CN.UTF-8/zh_CN.UTF-8/zh_CN.UTF-8/C/zh_CN.UTF-8/zh_CN.UTF-8
##
## attached base packages:
## [1] stats graphics grDevices utils datasets methods base
##
## other attached packages:
## [1] bindrcpp_0.2.2 ggtree_1.12.7 ggplot2_3.0.0
##
## loaded via a namespace (and not attached):
## [1] Rcpp_0.12.18 pillar_1.3.0 compiler_3.5.1 plyr_1.8.4
## [5] bindr_0.1.1 tools_3.5.1 digest_0.6.16 jsonlite_1.5
## [9] tidytree_0.1.9 evaluate_0.11 tibble_1.4.2 gtable_0.2.0
## [13] nlme_3.1-137 lattice_0.20-35 pkgconfig_2.0.2 rlang_0.2.2
## [17] rstudioapi_0.7 rvcheck_0.1.0 parallel_3.5.1 yaml_2.2.0
## [21] treeio_1.4.3 withr_2.1.2 dplyr_0.7.6 stringr_1.3.1
## [25] knitr_1.20 rprojroot_1.3-2 grid_3.5.1 tidyselect_0.2.4
## [29] glue_1.3.0 R6_2.2.2 rmarkdown_1.10 tidyr_0.8.1
## [33] purrr_0.2.5 magrittr_1.5 backports_1.1.2 scales_1.0.0
## [37] htmltools_0.3.6 assertthat_0.2.0 colorspace_1.3-2 ape_5.1
## [41] labeling_0.3 stringi_1.2.4 lazyeval_0.2.1 munsell_0.5.0
## [45] crayon_1.3.4
网友评论