R/mcalc.R

Defines functions mcalc

Documented in mcalc

#' mcalc
#'
#' Select values from a MAgPIE-object
#'
#' This functions only work for MAgPIE objects with named dimensions as the
#' dimension name (set_name) has to be used to indicate in which dimension the
#' entries should be searched for!
#'
#' @aliases mcalc mcalc<-
#' @param x MAgPIE object
#' @param f A formula describing the calculation that should be performed
#' @param dim The dimension in which the manipulation should take place. If set
#' to NULL function tries to detect the dimension automatically.
#' @param append If set to TRUE the result will be appended to x, otherwise the
#' result will be returned.
#' @return The calculated MAgPIE object in the case that append is set to
#' FALSE. Otherwise nothing is returned (as x is appended in place)
#' @author Jan Philipp Dietrich
#' @seealso \code{\link{mselect}}
#' @examples
#'
#' pop <- maxample("pop")
#' pop
#' mcalc(pop, X12 ~ A2 * B1, append = TRUE)
#' pop
#' mcalc(pop, `Nearly B1` ~ 0.5 * A2 + 99.5 * B1)
#' @export mcalc
#' @importFrom stats as.formula
mcalc <- function(x, f, dim = NULL, append = FALSE) {
  x <- clean_magpie(x)
  f <- as.formula(f)
  vars <- all.vars(f[[3]])

  if (is.null(dim)) dim <- getDim(vars, x, fullmatch = FALSE, dimCode = FALSE)
  if (length(dim) == 0) stop("Dimension not provided and automatic detection failed (no match)!")
  if (length(dim) > 1) stop("Dimension not provided and automatic detection failed (multiple matches)!")

  for (v in vars) {
    l <- list()
    l[dim] <- v
    tmp <- mselect(x, l, collapseNames = FALSE)
    getNames(tmp, dim = dim) <- all.vars(f[[2]])
    assign(v, tmp)
  }
  if (append) {
    assign(as.character(as.list(match.call())$x), mbind(x, eval(f[[3]])), envir =  parent.frame())
  } else {
    out <- eval(f[[3]])
    return(out)
  }
}
pik-piam/magclass documentation built on March 25, 2024, 11:07 p.m.