tests/testthat/test-models.R

library(joineR)
context("Models fitting")


test_that("random-intercept and random-slope models", {
  # load data + fit model
  data(heart.valve)
  heart.surv <- UniqueVariables(heart.valve, 
                                var.col = c("fuyrs", "status"),
                                id.col = "num")
  heart.long <- heart.valve[, c("num", "time", "log.lvmi")]
  heart.cov <- UniqueVariables(heart.valve, 
                               c("age", "hs", "sex"), 
                               id.col = "num")
  heart.valve.jd <- jointdata(longitudinal = heart.long, 
                              baseline = heart.cov, 
                              survival = heart.surv, 
                              id.col = "num", 
                              time.col = "time")
  fit <- joint(data = heart.valve.jd, 
               long.formula = log.lvmi ~ 1 + time + hs, 
               surv.formula = Surv(fuyrs, status) ~ hs, 
               model = "intslope",
               tol = 1e-05)
  # tests
  expect_is(fit, "joint")
  expect_true(fit$convergence)
  expect_equal(unlist(fit$coefficients$fixed$longitudinal), 
               c(4.994109534, -0.006804991, 0.055544847),
               tol = 1e-03, check.attributes = FALSE)
  expect_equal(unlist(fit$coefficients$fixed$survival), 
               0.7929432,
               tol = 1e-03, check.attributes = FALSE)
  expect_equal(unlist(fit$coefficients$latent), 
               0.8287302,
               tol = 1e-03, check.attributes = FALSE)
  expect_output(str(fit$sigma.u), "random.effects")
  expect_equal(dim(fit$sigma.u), c(2, 2))
  expect_output(str(fit$data), "List of 6")
})


test_that("no survival model covariates", {
  # load data + fit model
  data(heart.valve)
  heart.surv <- UniqueVariables(heart.valve, 
                                var.col = c("fuyrs", "status"),
                                id.col = "num")
  heart.long <- heart.valve[, c("num", "time", "log.lvmi")]
  heart.cov <- UniqueVariables(heart.valve, 
                               c("age", "hs", "sex"), 
                               id.col = "num")
  heart.valve.jd <- jointdata(longitudinal = heart.long, 
                              baseline = heart.cov, 
                              survival = heart.surv, 
                              id.col = "num", 
                              time.col = "time")
  fit <- joint(data = heart.valve.jd, 
               long.formula = log.lvmi ~ 1 + time + hs, 
               surv.formula = Surv(fuyrs, status) ~ 1, 
               model = "intslope",
               tol = 1e-05)
  # tests
  expect_is(fit, "joint")
  expect_null(fit$coefficients$fixed$survival)
})


test_that("random-intercept only models", {
  # load data + fit model
  data(heart.valve)
  heart.surv <- UniqueVariables(heart.valve, 
                                var.col = c("fuyrs", "status"),
                                id.col = "num")
  heart.long <- heart.valve[, c("num", "time", "log.lvmi")]
  heart.cov <- UniqueVariables(heart.valve, 
                               c("age", "hs", "sex"), 
                               id.col = "num")
  heart.valve.jd <- jointdata(longitudinal = heart.long, 
                              baseline = heart.cov, 
                              survival = heart.surv, 
                              id.col = "num", 
                              time.col = "time")
  fit <- joint(data = heart.valve.jd, 
               long.formula = log.lvmi ~ 1 + time + hs, 
               surv.formula = Surv(fuyrs, status) ~ hs, 
               model = "int",
               tol = 1e-05)
  # tests
  expect_is(fit, "joint")
  expect_true(fit$convergence)
  expect_equal(unlist(fit$coefficients$fixed$longitudinal), 
               c(4.985127e+00, 8.352489e-05, 5.127367e-02),
               tol = 1e-03, check.attributes = FALSE)
  expect_equal(unlist(fit$coefficients$fixed$survival), 
               0.7921842,
               tol = 1e-03, check.attributes = FALSE)
  expect_equal(unlist(fit$coefficients$latent), 
               1.105096,
               tol = 1e-03, check.attributes = FALSE)
  expect_output(str(fit$sigma.u), "random.effects")
  expect_equal(dim(fit$sigma.u), c(1, 1))
  expect_output(str(fit$data), "List of 6")
})


test_that("quadratic models", {
  # load data + fit model
  data(heart.valve)
  heart.surv <- UniqueVariables(heart.valve, 
                                var.col = c("fuyrs", "status"),
                                id.col = "num")
  heart.long <- heart.valve[, c("num", "time", "log.lvmi")]
  heart.cov <- UniqueVariables(heart.valve, 
                               c("age", "hs", "sex"), 
                               id.col = "num")
  heart.valve.jd <- jointdata(longitudinal = heart.long, 
                              baseline = heart.cov, 
                              survival = heart.surv, 
                              id.col = "num", 
                              time.col = "time")
  fit <- joint(data = heart.valve.jd, 
               long.formula = log.lvmi ~ 1 + time + hs, 
               surv.formula = Surv(fuyrs, status) ~ hs, 
               model = "quad",
               tol = 1e-04)
  # tests
  expect_is(fit, "joint")
  expect_true(fit$convergence)
  expect_equal(unlist(fit$coefficients$fixed$longitudinal), 
               c(4.987599172, -0.001296657, 0.059073709),
               tol = 1e-03, check.attributes = FALSE)
  expect_equal(unlist(fit$coefficients$fixed$survival), 
               0.8020584,
               tol = 1e-03, check.attributes = FALSE)
  expect_equal(unlist(fit$coefficients$latent), 
               0.9672835,
               tol = 1e-03, check.attributes = FALSE)
  expect_output(str(fit$sigma.u), "random.effects")
  expect_equal(dim(fit$sigma.u), c(3, 3))
  expect_output(str(fit$data), "List of 6")
})


test_that("seperate association models", {
  # load data + fit model
  data(heart.valve)
  heart.surv <- UniqueVariables(heart.valve, 
                                var.col = c("fuyrs", "status"),
                                id.col = "num")
  heart.long <- heart.valve[, c("num", "time", "log.lvmi")]
  heart.cov <- UniqueVariables(heart.valve, 
                               c("age", "hs", "sex"), 
                               id.col = "num")
  heart.valve.jd <- jointdata(longitudinal = heart.long, 
                              baseline = heart.cov, 
                              survival = heart.surv, 
                              id.col = "num", 
                              time.col = "time")
  fit <- joint(data = heart.valve.jd, 
               long.formula = log.lvmi ~ 1 + time + hs, 
               surv.formula = Surv(fuyrs, status) ~ hs, 
               model = "intslope",
               sepassoc = TRUE,
               tol = 1e-04)
  # tests
  expect_is(fit, "joint")
  expect_true(fit$convergence)
  expect_equal(unlist(fit$coefficients$latent), 
               c(0.7689985, -2.0626615),
               tol = 1e-03, check.attributes = FALSE)
})


test_that("bootstrap SE", {
  # load data + fit model
  data(heart.valve)
  heart.surv <- UniqueVariables(heart.valve, 
                                var.col = c("fuyrs", "status"),
                                id.col = "num")
  heart.long <- heart.valve[, c("num", "time", "log.lvmi")]
  heart.cov <- UniqueVariables(heart.valve, 
                               c("age", "hs", "sex"), 
                               id.col = "num")
  heart.valve.jd <- jointdata(longitudinal = heart.long, 
                              baseline = heart.cov, 
                              survival = heart.surv, 
                              id.col = "num", 
                              time.col = "time")
  fit <- joint(data = heart.valve.jd, 
               long.formula = log.lvmi ~ 1 + time + hs, 
               surv.formula = Surv(fuyrs, status) ~ hs, 
               model = "intslope",
               tol = 1e-04)
  fit.boot <- jointSE(fitted = fit, n.boot = 3)
  # tests
  expect_output(str(fit.boot), "data.frame")
  expect_equal(dim(fit.boot), c(8, 6))
})


test_that("jointdata throws errors for incorrect data", {
  # data
  data(heart.valve)
  heart.surv <- UniqueVariables(heart.valve, 
                                var.col = c("fuyrs", "status"),
                                id.col = "num")
  heart.long <- heart.valve[, c("num", "time", "log.lvmi")]
  heart.cov <- UniqueVariables(heart.valve, 
                               c("age", "hs", "sex"), 
                               id.col = "num")
  # tests
  expect_error(jointdata(longitudinal = 1, 
                         baseline = heart.cov, 
                         survival = heart.surv, 
                         id.col = "num", 
                         time.col = "time"),
               "Longitudinal object must be a matrix or a data.frame")
  expect_error(jointdata(longitudinal = heart.long, 
                         baseline = 1, 
                         survival = heart.surv, 
                         id.col = "num", 
                         time.col = "time"),
               "Baseline object must be a matrix or a data.frame or a vector of names of baseline covariates")  
  expect_error(jointdata(longitudinal = heart.long, 
                         baseline = heart.cov, 
                         survival = 1, 
                         id.col = "num", 
                         time.col = "time"),
               "Survival object must be a matrix or a data.frame")  
  expect_error(jointdata(longitudinal = heart.long, 
                         baseline = heart.cov, 
                         survival = heart.surv, 
                         id.col = NA, 
                         time.col = "time"),
               "It is necessary to specify a subject identification column name")
  names(heart.cov)[1] <- "Num" # case change
  expect_error(jointdata(longitudinal = heart.long, 
                         baseline = heart.cov, 
                         survival = heart.surv, 
                         id.col = "num", 
                         time.col = "time"),
               "ID column does not exist in baseline object") 
  names(heart.cov)[1] <- "num"
  names(heart.long)[1] <- "Num"
  expect_error(jointdata(longitudinal = heart.long, 
                         baseline = heart.cov, 
                         survival = heart.surv, 
                         id.col = "num", 
                         time.col = "time"),
               "ID column does not exist in longitudinal object") 
  names(heart.long)[1] <- "num"
  names(heart.surv)[1] <- "Num"
  expect_error(jointdata(longitudinal = heart.long, 
                         baseline = heart.cov, 
                         survival = heart.surv, 
                         id.col = "num", 
                         time.col = "time"),
               "ID column does not exist in survival object")   
})

Try the joineR package in your browser

Any scripts or data that you put into this service are public.

joineR documentation built on Jan. 23, 2023, 5:39 p.m.