tests/testthat/test_pglmm_utils.R

#context("test utils functions for phylogenetic GLMMs")

test_that("ignore these tests when on CRAN since they are time consuming", {
  testthat::skip_on_cran()
  testthat::skip_on_travis()
  library(dplyr)
  comm = phyr::comm_a
  comm$site = row.names(comm)
  dat = tidyr::gather(comm, key = "sp", value = "freq", -site) %>% 
    left_join(phyr::envi, by = "site") %>% 
    left_join(phyr::traits, by = "sp")
  dat$pa = as.numeric(dat$freq > 0)
  dat$freq2 = 20 - dat$freq
  dat = arrange(dat, site, sp)
  # dat = sample_frac(dat, size = 0.8)
  dat = mutate(dat, Species = sp, Location = site) # can be names other than sp or site
  
  x1 = phyr::communityPGLMM(
    pa ~ 1 + shade + (1 | Species__) + (1 | site) + (1 | Species__@site), 
    dat, cov_ranef = list(Species = phylotree), REML = FALSE, family = "binomial",
    cpp = TRUE, optimizer = "Nelder-Mead")
  x2 = phyr::communityPGLMM(
    freq ~ 1 + shade + (1 | Species__) + (1 | site) + (1 | Species__@site), 
    dat, cov_ranef = list(Species = phylotree), REML = FALSE,
    cpp = TRUE, optimizer = "Nelder-Mead")
  x3 = phyr::communityPGLMM(
    freq ~ 1 + shade + (1 | Species__) + (1 | site) + (1 | Species__@site), 
    dat, cov_ranef = list(Species = phylotree), bayes = TRUE)
  x4 = phyr::communityPGLMM(
    pa ~ 1 + shade + (1 | Species__) + (1 | site) + (1 | Species__@site), 
    dat, cov_ranef = list(Species = phylotree), family = "binomial", bayes = TRUE)
  
  # test significance of random term
  pglmm_profile_LRT(x1, 1)
  pglmm_profile_LRT(x2, 1)
  expect_error(pglmm_profile_LRT(x3, 1))
  
  # test design matrix
  expect_equal(
    pglmm_matrix_structure(
      freq ~ 1 + shade + (1 | Species__) + (1 | site) + (1 | Species__@site), 
      data = dat, cov_ranef = list(Species = phyr::phylotree), ss = 1),
    pglmm_matrix_structure(
      pa ~ 1 + shade + (1 | Species__) + (1 | site) + (1 | Species__@site), 
      data = dat, cov_ranef = list(Species = phyr::phylotree),
      family = "binomial", ss = 1)
  )
  
  # test predicted values
  expect_equal(
    phyr::pglmm_predicted_values(x2, gaussian.pred = 'tip_rm')$Y_hat, 
    pez::communityPGLMM.predicted.values(x2, show.plot = FALSE)[, 1], ignore_attr = TRUE
  )
  
  # test simulation
  sims_x1 <- simulate(x1, 250)
  sims_x2 <- simulate(x2, 250)
  sims_x3 <- simulate(x3, 250)
  sims_x4 <- simulate(x4, 250)
  
  expect_identical(dim(sims_x1), c(225L, 250L))
  expect_identical(dim(sims_x2), c(225L, 250L))
  expect_identical(dim(sims_x3), c(225L, 250L))
  expect_identical(dim(sims_x4), c(225L, 250L))
  
  expect_type(sims_x1, "integer")
  expect_type(sims_x2, "double")
  expect_type(sims_x3, "double")
  expect_type(sims_x4, "integer")
  
  # not equal because of different methods used
  phyr::pglmm_predicted_values(x1)$Y_hat
  pez::communityPGLMM.predicted.values(x1, show.plot = FALSE) 
  phyr::pglmm_predicted_values(x3)[,1]
  
  residuals(x1)
  residuals(x2)
  residuals(x3)
  residuals(x4)
  
  fitted(x1)
  fitted(x2)
  fitted(x3)
  fitted(x4)
  
  fixef(x1)
  fixef(x2)
  fixef(x3)
  fixef(x4)
  
  ranef(x1)
  ranef(x2)
  ranef(x3)
  ranef(x4)
  
  x1_fam <- family(x1)
  x2_fam <- family(x2)
  x3_fam <- family(x3)
  x4_fam <- family(x4)
  
  expect_identical(x1_fam$family, "binomial")
  expect_identical(x2_fam$family, "gaussian")
  expect_identical(x3_fam$family, "gaussian")
  expect_identical(x4_fam$family, "binomial")
  
  preds <- predict(x4)
  expect_identical(class(preds)[1], "matrix")
  expect_equal(dim(preds), c(225, 1))
  
  sims <- simulate(x4, nsim = 5)
  expect_identical(class(sims)[1], "matrix")
  expect_equal(dim(sims), c(225, 5))
})
daijiang/phyr documentation built on Feb. 25, 2024, 3:01 a.m.