我有phylo
类的系统树,其中有24个提示和23个内部节点。我在这棵树和使用boot.phylo
的数据上进行了引导分析,它返回了一个包含23个引导值的向量。我从原始树创建了一个ggtree对象,现在尝试将引导程序值添加到节点。我做错了事,但我不知道该怎么办。
这是我所做的:
gg.tr <- ggtree(mp.tree)
gg.tr + geom_label2(aes(subset=!isTip, label=bphylo$BP))
bphylo$BP
是23个引导程序值的向量。运行此代码时,出现以下错误:
Error: Aesthetics must be either length 1 or the same as the data (47): subset, label, x, y
我不理解此错误,因为我只想将引导程序值放在可能的47个位置中的23个位置上。
当我调用以下函数时,我得到的值为23:
length(which(gg.tr$data$isTip==FALSE))
如果gg.tr$data$isTip==FALSE
的长度为23,并且我具有23个引导程序值,为什么会出现错误消息,告诉我我的标签长度错误?
答案 0 :(得分:1)
您可以用geom_text
注释树。没有看到您的数据,很难知道发生了什么,但这是一个具有可重现数据集的示例。
library(devtools)
devtools::install_github("GuangchuangYu/ggtree")
bs <- data.frame(nodename = c("t30", "t12", "t22", "t26", "t6", "t17", "t4","t7", "t9", "t1", "t8", "t25","t23",
"t28", "t10", "t20", "t3", "t11", "t19", "t29", "t2","t18", "t24",
"t27", "t15", "t13", "t14", "t16", "t5","t21"), bootstrap = c(runif(30, 85, 98)), stringsAsFactors = F)
bs$bootstrap <- round(bs$bootstrap, digits = 0)
rownames(bs) <- NULL
nodesupport = c(round(runif(59, 65, 80), digits = 0))
set.seed(0)
tree <- rtree(30)
p <- ggtree(tree)
p <- p %<+% bs + geom_tiplab()
p <- p + geom_text(aes(label = bootstrap), hjust = 1, vjust = -0.4, size = 3) + geom_nodelab(aes(label = nodesupport)) # specify your node label here, looks like BP
p