R/convertDiscrete.R

Defines functions discreteValueToName discreteNameToValue

Documented in discreteNameToValue discreteValueToName

#' @title Convert encoding name(s) to discrete value(s).
#'
#' @description For a discrete parameter or discrete vector. If the `name` is
#' `NA`, indicating a missing parameter value due to unsatisfied requirements,
#' `NA` is returned.
#'
#' @template arg_par
#' @param name (`character`)\cr
#'   Name (string) encoding the value for a discrete
#'   parameter, or a character vector of names for a discrete vector.
#' @return [any]. Parameter value for a discrete parameter or a list of values
#'   for a discrete vector.
#' @examples
#' p = makeDiscreteParam("u", values = c(x1 = "a", x2 = "b", x3 = "b"))
#' discreteNameToValue(p, "x3")
#' @export
discreteNameToValue = function(par, name) {
  # handle missing parameter values (requires)
  if (isScalarNA(name)) {
    return(NA)
  }
  assertClass(par, "Param")
  assertChoice(par$type, c("discrete", "discretevector"))
  assertCharacter(name, len = ifelse(par$type == "discrete", 1L, par$len))
  d = setdiff(name, names(par$values))
  if (length(d) > 0L) {
    stopf("Names not used in values for parameter %s: %s", par$id, collapse(d))
  }
  if (par$type == "discrete") {
    par$values[[name]]
  } else if (par$type == "discretevector") {
    par$values[name]
  }
}

#' @title Convert discrete value(s) to encoding name(s).
#'
#' @description
#' For a discrete parameter or discrete vector.
#' If the value `x` is `NA`, indicating a missing parameter value due to unsatisfied requirements,
#' `NA` is returned.
#'
#' @template arg_par
#' @param x [any]\cr
#'   Parameter value or a list of values for a discrete vector.
#' @return [`character`]. Single name for a discrete parameter or a character vector of
#'   names for a discrete vector.
#' @examples
#' p = makeDiscreteParam("u", values = c(x1 = "a", x2 = "b", x3 = "c"))
#' discreteValueToName(p, "b")
#' @export
discreteValueToName = function(par, x) {
  # handle missing parameter values (requires)
  if (isScalarNA(x)) {
    return(NA_character_)
  }
  assertClass(par, "Param")
  assertChoice(par$type, c("discrete", "discretevector"))
  if (par$type == "discretevector" && length(x) != par$len) {
    stopf("Length of x must be %i!", par$len)
  }
  ns = names(par$values)
  getIndex = function(values, v) {
    j = which(vlapply(values, function(w) isTRUE(all.equal(w, v, tolerance = .Machine$double.eps))))
    if (length(j) == 0) {
      stop("Value not found!")
    }
    return(j)
  }
  if (par$type == "discrete") {
    ns[getIndex(par$values, x)]
  } else if (par$type == "discretevector") {
    ns[sapply(x, getIndex, values = par$values)]
  }
}

Try the ParamHelpers package in your browser

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

ParamHelpers documentation built on July 4, 2022, 5:07 p.m.