if (requireNamespace("GenSA")) {
  search_space = domain = ps(x = p_dbl(lower = -1, upper = 1))
  codomain = ps(y = p_dbl(tags = "minimize"))
  objective_function = function(xs) {
    list(y = as.numeric(xs)^2)
  }
  objective = ObjectiveRFun$new(
    fun = objective_function,
    domain = domain,
    codomain = codomain)
  instance = OptimInstanceSingleCrit$new(
    objective = objective,
    search_space = search_space,
    terminator = trm("evals", n_evals = 10))
  optimizer = opt("gensa")
  # Modifies the instance by reference
  optimizer$optimize(instance)
  # Returns best scoring evaluation
  instance$result
  # Allows access of data.table of full path of all evaluations
  as.data.table(instance$archive$data)
}
Run the code above in your browser using DataLab