tests/testthat/test_tensor.R

context("fitting tensors")

set.seed(666)

m <- 10
n <- 10
p <- 30

LF1 <- rep(1, m) %o% rep(1, n) %o% rep(1, p)
LF2 <- 5 * (rnorm(m) %o% rnorm(n) %o% rnorm(p))
LF <- LF1 + LF2
M <- LF + 0.1 * rnorm(m * n * p)

f <- flash(M, greedy_Kmax = 2, verbose = 0)

test_that("tensor factor initialization is correct", {
  expect_equal(f$n_factors, 2)
  expect_equal(lowrank.expand(get.EF(f$flash_fit)), LF1 + LF2, tol = 0.25, scale = 1)
})

suppressWarnings({
  f.b <- flash_backfit(f, extrapolate = FALSE, maxiter = 1, verbose = 0)
})

test_that ("the backfit objective improves after one iteration", {
  expect_true(f.b$elbo > f$elbo)
})

f.b2 <- flash_backfit(f, extrapolate = FALSE, verbose = 0)

test_that ("the final backfit objective improves again", {
  expect_true(f.b2$elbo > f.b$elbo)
})

missing <- sample(1:length(M), floor(0.1 * length(M)))
M.missing <- M
M.missing[missing] <- NA

f <- flash(M.missing, greedy_Kmax = 2, verbose = 0)

test_that("tensor factor initialization is correct (with missing)", {
  expect_equal(f$n_factors, 2)
  expect_equal(lowrank.expand(get.EF(f$flash_fit)), LF1 + LF2, tol = 0.25, scale = 1)
})

suppressWarnings({
  f.b <- flash_backfit(f, maxiter = 1, verbose = 0)
})

test_that ("the backfit objective improves after one iteration (using Y, with missing)", {
  expect_true(f.b$elbo > f$elbo)
})

f.b2 <- flash_backfit(f, verbose = 0)

test_that ("the final backfit objective improves again (with missing)", {
  expect_true(f.b2$elbo > f.b$elbo)
})

Try the flashier package in your browser

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

flashier documentation built on Oct. 17, 2023, 5:07 p.m.