tests/testthat/test-unit-mtc.model.consistency.R

context("mtc.model.consistency")

test_that("func.param.matrix was implemented correctly", {
  model <- list(
    'type'='consistency',
    'tree'=igraph::make_graph(c('A','B','A','C','B','D')))

  expect_equal(matrix(0, nrow=3, dimnames=list(NULL, 'd.A.A')),
               mtc.model.call('func.param.matrix', model, t1='A', t2='A'))
  expect_equal(matrix(c(1,0,0), nrow=3, dimnames=list(NULL, 'd.A.B')),
               mtc.model.call('func.param.matrix', model, t1='A', t2='B'))
  expect_equal(matrix(c(1,0,0,0,1,0), nrow=3, dimnames=list(NULL, c('d.A.B', 'd.A.C'))),
               mtc.model.call('func.param.matrix', model, t1='A', t2=c('B', 'C')))
  expect_equal(matrix(c(-1,0,0), nrow=3, dimnames=list(NULL, c('d.B.A'))),
               mtc.model.call('func.param.matrix', model, t1='B', t2='A'))
  expect_equal(matrix(c(1,0,1), nrow=3, dimnames=list(NULL, c('d.A.D'))),
               mtc.model.call('func.param.matrix', model, t1='A', t2='D'))
})

test_that("mtc.model reports disconnected networks", {
  network <- parkinson
  network$data.ab <- network$data.ab[1:11,]
  expect_error(mtc.model(network), "Network is disconnected")
})

test_that("mtc.model sets re.prior.sd", {
  expect_equal(mtc.model(parkinson)$re.prior.sd, 15 * 2.3)
  expect_equal(mtc.model(parkinson, om.scale=3)$re.prior.sd, 15 * 3)
  expect_equal(mtc.model(parkinson, re.prior.sd=3)$re.prior.sd, 3)
})

Try the gemtc package in your browser

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

gemtc documentation built on July 9, 2023, 5:33 p.m.