tests/testthat/test-mvn_family.R

test_that("mvn_family", {
  
  library(mgcViz)
  # Simulate some data
  V <- matrix(c(2,1,1,2),2,2)
  f0 <- function(x) 2 * sin(pi * x)
  f1 <- function(x) exp(2 * x)
  f2 <- function(x) 0.2 * x^11 * (10 * (1 - x))^6 + 10 * 
    (10 * x)^3 * (1 - x)^10
  n <- 3000
  x0 <- runif(n);x1 <- runif(n);
  x2 <- runif(n);x3 <- runif(n)
  y <- matrix(0,n,2)
  for (i in 1:n) {
    mu <- c(f0(x0[i])+f1(x1[i]),f2(x2[i]))
    y[i,] <- rmvn(1,mu,V)
  }
  dat <- data.frame(y0=y[,1],y1=y[,2],x0=x0,x1=x1,x2=x2,x3=x3)
  
  # Fit model
  b <- gamV(list(y0~s(x0)+s(x1),y1~s(x2)+s(x3)),family=mvn(d=2),data=dat)
  b <- getViz(b, nsim = 10)
  
  # Check in 0, 1 and 2 dimensions
  expect_error(print(check0D(b) + l_hist() + l_rug()), NA)

  expect_error(print(check1D(b, x0) + l_gridCheck1D()), NA)
  expect_error(print(check1D(b, x0, trans = function(.x) .x[ , 2]) + l_gridCheck1D()), NA)
  
  expect_error(print(check2D(b, x1 = "x0", x2 = "x1") + 
               l_gridCheck2D(gridFun = sd) + l_rug() + l_points()), NA)

})
mfasiolo/mgcViz documentation built on April 19, 2024, 8:16 a.m.