R/Cinterp.R

Defines functions Cinterp

Documented in Cinterp

#' Interpolation in simplexes of the objective space
#'
#' proposes n new candidates by interpolation in simplexes of the objective space
#'
#' @param param : matrix [ NPoints , NPar ] of already evaluated parameters
#' @param crit : matrix [ Npoints , NObj ] of associated criteria
#' @param simplices : matrix [ NSimp , NObj+1 ] containing all or part of the triangulation of the space of the objectives
#' @param volume : matrix [ NSimp , 1 ] giving the volume of each simplex (measure of the probability of interpolating in this simplex)
#' @param n : number of new vectors to generate
#' @return xnew : matrix [ n , NPar ] of new vectors
#' @return pcrit : matrix [ n , NObj ] estimated positions of new sets in the goal space
#'
#' @examples
#' # Definition of the parameters
#' param <- matrix(rexp(100), 100, 1)
#' crit <- matrix(rexp(200), 100, 2)
#' simplices <- matrix(c(15,2,1,15,22,1,18,15,2,17,13,14), nrow = 4, ncol = 3)
#' volume <- runif(4)
#' n <- 5
#' # Call the function
#' res <- Cinterp(param, crit, simplices, volume, n)
#'
#' @author Fabrice Zaoui

Cinterp <- function(param, crit, simplices, volume, n) {

  ix <- rselect(n, volume)
  nobj <- dim(crit)[2]
  nvar <- dim(param)[2]

  xnew <- matrix(0, nrow = n, ncol = nvar)
  pcrit <- matrix(0, nrow = n, ncol = nobj)

  for (i in 1:n) {
    isimp <- ix[i]

    param_s <- param[simplices[isimp, ], ]
    crit_s <- crit[simplices[isimp, ], ]

    # Random drawing of a set of barycentric coordinates
    xb <- runif(nobj + 1)
    xb <- xb / sum(xb)

    xnew[i, ] <- xb %*% param_s # Coordinates in the space of the parameters
    pcrit[i, ] <- xb %*% crit_s  # Coordinates in the space of the criteria
  }
  return(list("xnew" = xnew, "pcrit" = pcrit))
}

Try the caRamel package in your browser

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

caRamel documentation built on March 18, 2022, 7:23 p.m.