tests/testthat/test-model-magma.R

test_that("Magma simulation", {
  nms <- intersect(Magma()@param.req, names(focusd1@param))
  params <- focusd1@param[nms]
  params$r_DW_TSL <- focusd1@param$r_DW_FN
  params$mu_control <- focusd1@param$k_photo_max

  # set up a Magma scenario with Lemna parameters for testing purposes
  Magma(growth="exp") %>%
    set_init(focusd1@init) %>%
    set_param(params) %>%
    set_exposure(focusd1@exposure@series) %>%
    set_times(0:20) -> sc

  focusd1 %>%
    set_param(c("k_photo_fixed"=1,"k_loss"=0)) %>%
    set_times(0:20) -> orig

  # equal results if all else is identical
  expect_equal(as.data.frame(solver(sc))$TSL, as.data.frame(solver(orig))$FrondNo)
  # check that TSL scales with r_DW_TSL
  r_DW_TSL <- focusd1@param$r_DW_FN * 10
  sc <- set_param(sc, c("r_DW_TSL"=r_DW_TSL))
  expect_equal(as.data.frame(solver(sc))$TSL, as.data.frame(solver(orig))$FrondNo/10)

  # Magma with logistic growth
  params$D_L <- focusd1@param$BM_L

  Magma(growth="log") %>%
    set_init(focusd1@init) %>%
    set_param(params) %>%
    set_exposure(focusd1@exposure@series) %>%
    set_times(0:20) %>%
    simulate(nout=7) %>%
    as.data.frame() -> out_log
  # we should have almost reached the density limit
  expect_equal(tail(out_log$BM, 1), params$D_L, tolerance=0.1)
  # dBM should decrease continuously because initial state is above 50% of BM_L
  expect_true(all(out_log$dBM > 0))
  expect_true(all(out_log$BM == sort(out_log$BM)))

  # error if r_DW_TSL is missing
  sc@param$r_DW_TSL <- NULL
  expect_error(solver(sc), regexp="missing.*r_DW_TSL")
})

Try the cvasi package in your browser

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

cvasi documentation built on Sept. 11, 2025, 5:11 p.m.