nasty <- structure(list(edge = structure( c(9, 12, 10, 13, 11, 10, 11, 13, 10, 13, 12, 9, 5, 10, 1, 2, 3, 13, 9, 4, 11, 7, 8, 6), .Dim = c(12, 2)), Nnode = 5L, tip.label = letters[1:8]), class = "phylo") # Danger: Do not plot! test_that("NodeNumbers() works", { expect_equal(NodeNumbers(BalancedTree(5)), 6:9) expect_equal(NodeNumbers(StarTree(5)), 6L) expect_equal(NodeNumbers(BalancedTree(5), TRUE), 1:9) expect_equal(NodeNumbers(StarTree(5), TRUE), 1:6) }) test_that("Root node can be found", { rooted <- BalancedTree(8) postorder <- Postorder(rooted) unrooted <- UnrootTree(rooted) expect_true(TreeIsRooted(rooted)) expect_false(TreeIsRooted(unrooted)) expect_equal(RootNode(rooted$edge), 9L) expect_equal(RootNode(rooted), 9L) expect_equal(RootNode(as.phylo(1337L, 8L)), 9L) expect_equal(RootNode(c(unrooted, Preorder(postorder), postorder)), rep(9L, 3L)) expect_equal(RootNode(list(Cladewise(postorder), ApePostorder(rooted), Pruningwise(postorder))), rep(9L, 3L)) expect_warning(RootNode(matrix(1:4, 2)), "Root not unique") }) test_that("NodeOrder() works", { expect_equal(ignore_attr = TRUE, c(2L, rep(3L, 6)), as.integer(NodeOrder(BalancedTree(8), internalOnly = TRUE))) expect_equal(ignore_attr = TRUE, c(rep(1L, 8), 2L, rep(3L, 6)), as.integer(NodeOrder(BalancedTree(8), internalOnly = FALSE))) expect_equal(ignore_attr = TRUE, rep(2L, 7), as.integer(NodeOrder(BalancedTree(8), FALSE))) tree <- CollapseNode(BalancedTree(8), 12:15) expect_equal(5:3, as.integer(NodeOrder(tree$edge, internalOnly = TRUE))) expect_equal(list(NodeOrder(tree), NodeOrder(tree)), NodeOrder(c(tree, tree))) expect_equal(NodeOrder(c(tree, tree)), NodeOrder(list(tree, tree))) expect_equal(c(3, 2, 2), NDescendants(UnrootTree(PectinateTree(5)))) }) test_that("Rooting and partition counting", { set.seed(0) expect_false(TreeIsRooted(ape::read.tree(text="(a, b, c);"))) expect_true(TreeIsRooted(ape::read.tree(text="(a, (b, c));"))) tree8 <- RandomTree(8L, TRUE) expect_true(TreeIsRooted(tree8)) expect_false(TreeIsRooted(UnrootTree(tree8))) expect_equal(NPartitions(8), 5L) expect_equal(NPartitions(tree8), 5L) expect_equal(NPartitions(UnrootTree(tree8)), 5L) expect_equal(NPartitions(ape::read.tree(text="(A, ((B, C)));")), 0L) expect_equal(NPartitions(list(tree8, UnrootTree(tree8))), c(5L, 5L)) expect_equal(NPartitions(c(8, 8)), c(5L, 5L)) expect_equal(NSplits("((a, b), (c, (d, e)));"), 2L) expect_equal(NSplits("a"), 0L) emptyTree <- structure( list(edge = structure(numeric(0), dim = c(0L, 2L)), tip.label = character(0), Nnode = 0), class = "phylo") expect_equal(NSplits(emptyTree), 0L) expect_null(NSplits(NULL)) expect_equal(NSplits(letters[1:2]), 0L) expect_equal(NSplits(letters[1:6]), 3L) expect_error(NPartitions(raw(1)), "no applicable method") }) test_that("NTip() works", { Test <- function(n) { tr <- BalancedTree(n) pec <- PectinateTree(n) expect_identical(NTip(tr), n) expect_identical(NTip(tr$edge), n) expect_identical(NTip(Postorder(tr$edge)), n) expect_identical(NTip(list(tr)), n) expect_identical(rep(n, 2L), NTip(list(tr, tr))) expect_identical(rep(n, 3L), NTip(structure(list(tr, tr, pec), class = "multiPhylo"))) expect_null(NTip(matrix("", n, 2))) } Test(1L) Test(8L) Test(64L) Test(2000L) expect_identical(48L, NTip(Lobo.phy)) }) test_that("NSplits() works", { expect_equal(NSplits(5L), NSplits(LETTERS[1:5])) expect_equal(NSplits(as.ClusterTable(BalancedTree(6))), NSplits(BalancedTree(6))) }) test_that("Edge distances are calculated correctly", { tree <- ape::read.tree(text = "(((a, b), (c, d)), (e, (f, (g, (h, i)))));") ed <- EdgeDistances(tree) expect_equal(ed, t(ed)) # Symmetry expect_equal(c(4, 5, 6, 6, 5, 6, 6, 4, 4, 3, 3, 2, 2, 1, 1, 0), ed[, 16]) expect_equal(c(1, 2, 3, 3, 2, 3, 3, 1, 1, 0, 1, 1, 2, 2, 3, 3), ed[, 10]) expect_equal(c(1, 0, 1, 1, 1, 2, 2, 1, 2, 2, 3, 3, 4, 4, 5, 5), ed[, 2]) tree <- ape::read.tree(text="(a, (b, (c, (d, (((e, f), g), (h, (i, j)))))));") ed <- EdgeDistances(tree) expect_equal(ed, t(ed)) # Symmetry expect_equal(c(6, 6, 6, 5, 5, 4, 4, 3, 2, 1, 0, 1, 2, 3, 4, 4, 5, 5), ed[11, ]) }) test_that("Node depths calculated correctly", { #par(mar=rep(0.4, 4)) expect_equal(c(rep(0, 20), 19:1), NodeDepth(PectinateTree(20))) expect_equal(c(rep(0, 20), rep(1, 19)), NodeDepth(PectinateTree(20), shortest = TRUE)) expect_equal(c(rep(0, 20), 1:9, 9:1), NodeDepth(UnrootTree(PectinateTree(20)))) expect_equal(c(rep(0, 20), rep(1, 18)), NodeDepth(UnrootTree(PectinateTree(20)), shortest = TRUE)) tree <- BalancedTree(20) expect_equal(c(5,4,3,2,1,1,3,2,1,1,4,3,2,1,1,3,2,1,1), NodeDepth(tree, includeTips = FALSE)) expect_equal(c(4,3,2,1,1,1,2,1,1,1,3,2,1,1,1,2,1,1,1), NodeDepth(tree, shortest = TRUE, includeTips = FALSE)) expect_equal(list(c(4,3,2,1,1,1,2,1,1,1,3,2,1,1,1,2,1,1,1)), NodeDepth(list(tree), shortest = TRUE, includeTips = FALSE)) tree <- UnrootTree(tree) expect_equal(c(4,3,2,1,1,3,2,1,1,4,3,2,1,1,3,2,1,1), NodeDepth(tree, includeTips = FALSE)) expect_equal(c(3,2,1,1,1,2,1,1,1,3,2,1,1,1,2,1,1,1), NodeDepth(tree, shortest = TRUE, includeTips = FALSE)) tree <- UnrootTree(RootTree(BalancedTree(20), "t10")) #plot(tree); nodelabels(adj = 2, bg = "yellow") #nodelabels(NodeDepth(tree, F, FALSE)) #nodelabels(NodeDepth(tree, T, FALSE)) expect_equal(c(1,3,4,3,2,1,1,4,3,2,1,1,3,2,1,1,2,1), NodeDepth(tree, includeTips = FALSE)) expect_equal(c(1,2,3,2,1,1,1,3,2,1,1,1,2,1,1,1,1,1), NodeDepth(tree, shortest = TRUE, includeTips = FALSE)) tree <- CollapseNode(BalancedTree(20), c(22:26, 33:35)) expect_equal(c(4,3,2,1,1,4,1,3,2,1,1), NodeDepth(tree, FALSE, FALSE)) expect_equal(c(1,2,1,1,1,2,1,2,1,1,1), NodeDepth(tree, TRUE, FALSE)) tree <- CollapseNode(BalancedTree(20), c(22, 33:35)) expect_equal(c(4,3,2,1,1,3,2,1,1,4,1,3,2,1,1), NodeDepth(tree, FALSE, FALSE)) expect_equal(c(3,2,1,1,1,2,1,1,1,2,1,2,1,1,1), NodeDepth(tree, TRUE, FALSE)) expect_equal(1L, NodeDepth(StarTree(8), FALSE, FALSE)) expect_equal(1L, NodeDepth(StarTree(8), TRUE, FALSE)) }) test_that("SplitsInBinaryTree() works", { expect_identical(5L, SplitsInBinaryTree(8)) expect_identical(5L, SplitsInBinaryTree(as.phylo(0, 8))) expect_identical(rep(5L, 4), SplitsInBinaryTree(as.phylo(0:3, 8))) expect_null(SplitsInBinaryTree(NULL)) })