tests/testthat/test-dependencies.R

context("Test dependencies")

withr::with_output_sink("test-dependencies.Rout", {

test_that("param depend error checking", {
  expect_error_readParameters <- function(text, error)
    expect_error(readParameters(text=text), error)

  expect_error_readParameters('
p1 "" r (0, 1)
p2 "" r (p3, 1)
', "parameter 'p2' is not valid: 'p3' cannot be found")
  
  expect_error_readParameters('
p1 "" c (0, 1)
p2 "" r (1, p1)
', "parameter 'p2' depends on non-numerical parameters")
  
  expect_error_readParameters('
p1 "" r (0, 1)
p2 "" r (1, foobar(p1))
', "parameter 'p2' uses function")

  expect_error_readParameters('
p1 "" r (0, p3)
p2 "" r (1, p1)
p3 "" r (p2, 1)
', "cycle detected")

  expect_error_readParameters('
p1 "" r (0, 1)
p2 "" i (0.1, p1)
', "values must be integers")

})


checkConditionalAndDependency <- function(configuration, parameters)
{
  namesParameters <- names(parameters$conditions)
  for (p in namesParameters) {
    if (!irace:::conditionsSatisfied(parameters, configuration, p)) {
      expect(is.na(configuration[,p]),
             paste0("Conditional parameter '", p, 
                    "' is not active but it has a value '", configuration[,p], "' assigned."))
    } else if (parameters$isDependent[p]) {
      bounds <- irace:::getDependentBound(parameters, p, configuration)
      if (anyNA(bounds)) {
        expect(is.na(configuration[,p]),
               paste0("Dependent parameter '", p, 
                      "' has a value '", configuration[,p], "' but it should be inactive."))
        expect_true(anyNA(configuration[parameters$depends[[p]]]))
      } else {
        expect (configuration[,p] >= bounds[1],
                paste0("Parameter '", p, "=", configuration[,p], 
                       "' does not comply with dependency: ", parameters$depends[[p]],
                       " and lower bound: ", bounds[1]))
        expect (configuration[,p] <= bounds[2],
                paste0("Parameter '", p, " = ", configuration[,p], 
                       "' does not comply with dependency: ", parameters$depends[[p]],
                       " and upper bound: ", bounds[2]))
      }
    }
  }
}


test_that("test inactive dependent", {
  parameters <- readParameters(text='
p1 "" r (0,1)
p2 "" r (0, p1) | p1 < 0.5
p3 "" r (0, p2)
')
  confs <- irace:::sampleUniform(parameters, 50, digits = 2)
  for (i in 1:nrow(confs)) {
    checkConditionalAndDependency(confs[i,], parameters)
  }
})

test_that("checkDependencies", {

target.runner <- function(experiment, scenario)
  {
    configuration     <- experiment$configuration
    tmax <-  as.numeric(configuration[["real"]])
    if (configuration[["mode"]] %in% c("x1", "x2"))
      temp <-  as.numeric(configuration[["param1"]])
    else
      temp <- 1
    time <- max(1, abs(rnorm(1, mean=(tmax+temp)/10)))
    return(list(cost = time, time = time, call = toString(experiment)))
  }
  
test.checkDependencies <- function(parameterFile, ...)
{
  args <- list(...)
  weights <- rnorm(200, mean = 0.9, sd = 0.02)
  parameters <- readParameters(parameterFile)
  scenario <- list(targetRunner = target.runner, instances = weights, seed = 1234567, maxExperiments=200)
  scenario <- modifyList(scenario, args)
  scenario <- checkScenario (scenario)
 
  nconf <- 100
  conf <- irace:::sampleUniform(parameters, nconf, 4)
  conf <- cbind(seq(1,nrow(conf)), conf)
  names(conf)[1]<- ".ID."

  for (i in 1:nconf)
    checkConditionalAndDependency(conf[i,], parameters)
 
  model <- irace:::initialiseModel(parameters, conf, 4)
  conf2 <- irace:::sampleModel(parameters, conf, model, nconf, 4)
  for (i in 1:nconf)
    checkConditionalAndDependency(conf2[i,], parameters)

  confs <- irace(scenario = scenario, parameters = parameters)
  for (i in 1:nrow(confs)) {
    checkConditionalAndDependency(confs[i,], parameters)
  }
}
  test.checkDependencies(parameterFile="dependencies.txt")
  test.checkDependencies(parameterFile="dependencies2.txt")
})

}) # withr::with_output_sink()

Try the irace package in your browser

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

irace documentation built on Oct. 23, 2022, 5:06 p.m.