tests/testthat/test-augmentlhs.R

# Copyright 2019 Robert Carnell

context("test-augmentlhs")

test_that("augment works", {
  expect_error(augmentLHS(randomLHS(10, 4), NA))
  expect_error(augmentLHS(randomLHS(10, 4), NaN))
  expect_error(augmentLHS(randomLHS(10, 4), Inf))

  set.seed(1976)
  temp <- randomLHS(10, 4)
  temp[1,1] <- NA
  expect_error(augmentLHS(temp, 5))

  set.seed(1976)
  temp <- randomLHS(10, 4)
  temp[1,1] <- 2
  expect_error(augmentLHS(temp, 5))

  set.seed(1976)
  expect_true(checkLatinHypercube(augmentLHS(randomLHS(4, 2), 4)))

  set.seed(1977)
  expect_true(checkLatinHypercube(augmentLHS(randomLHS(3, 3), 3)))

  set.seed(1977)
  expect_true(checkLatinHypercube(augmentLHS(randomLHS(4, 1), 2)))

  # this test addresses a bug where an error ocurred on adding 1 row in
  #   augmentLHS
  temp <- randomLHS(7, 2)
  temp <- augmentLHS(temp, 1)
  expect_equal(nrow(temp), 8)

  expect_true(checkLatinHypercube(augmentLHS(randomLHS(7, 2), 7)))
  expect_true(checkLatinHypercube(augmentLHS(randomLHS(10, 5), 10)))

  # test exceptions
  expect_error(augmentLHS(c(1,2), 5))
  expect_error(augmentLHS(randomLHS(10,3), c(5,9)))
  expect_error(augmentLHS(randomLHS(10,3), -1))
  expect_error(augmentLHS(randomLHS(10,3), 2.2))

  A <- augmentLHS(randomLHS(1,4), 1)
  expect_true(checkLatinHypercube(A))

})

Try the lhs package in your browser

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

lhs documentation built on Dec. 28, 2022, 2:59 a.m.