tests/testthat/test-EMAlgorithm.R

context("Check EMAlgorithm")

suppressWarnings(RNGversion("3.5.0"))
set.seed(1)
n <- 1000

test_that("EMAlgorithm returns properly formatted output", {
  for (d in 3:4) {
    for (m in 3) {
      dat <- SimulateGMMData(n = n, d = d, m = m)  # Simulate some data

      for (trace_theta in c(TRUE, FALSE)) {
        suppressWarnings({
          res <-  GMCM:::EMAlgorithm(dat$z,
                                     m = m,
                                     max.ite = 100,
                                     trace.theta = trace_theta)
        })
        expect_that(length(res), equals(ifelse(trace_theta, 4L, 3L)))
        expect_true(is.theta(res$theta))  # theta
        expect_true(is.numeric(res$loglik.tr))
        expect_that(length(res$loglik.tr), is_less_than(101))
        expect_true(is.matrix(res$kappa))
        expect_that(max(res$kappa), is_less_than(1 + 1e-10))
        expect_that(min(res$kappa), is_more_than(0 - 1e-10))
        expect_that(dim(res$kappa), equals(c(n, res$theta$m)))
        expect_that(length(res$theta$mu), equals(m))
        expect_that(length(res$theta$sigma), equals(m))
        expect_true(all(sapply(res$theta.tr, is.theta)))

      }
    }
  }
})

# Test failures

m <- 2
d <- 3
dat <- SimulateGMMData(n = n, d = d, m = m)  # Simulate some data
start.theta <- rtheta(d = d, m = m, method = "EqualSpherical")
km <- kmeans(dat$z, centers = m)
start.theta$mu[] <- lapply(1:m, function(j) km$centers[j, ])
start.theta$pie[] <- km$size/sum(km$size)
start.theta$sigma[] <- lapply(1:m, function(j) cov(dat$z[km$cluster == m, ]))

test_that("EMAlgorithm warns if max iterations is hit", {
  expect_warning(
    GMCM:::EMAlgorithm(dat$z, theta = start.theta, max.ite = 2)
  )
})

test_that("EMAlgorithm is verbose if asked", {
  expect_output(
    GMCM:::EMAlgorithm(dat$z, theta = start.theta, verbose = TRUE)
  )
})

Try the GMCM package in your browser

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

GMCM documentation built on Nov. 6, 2019, 1:08 a.m.