R/get_times.R

Defines functions get_times_seq

#' Get output times
#'
#' @param x (vector of) [scenario] objects
#'
#' @return (list of) times vector
#' @aliases get_times,ANY-method get_times,list-method  get_times,EffectScenario-method
#'   get_times,ScenarioSequence-method
#' @seealso [set_times()]
#' @include class-EffectScenario.R sequence.R
#' @export
#'
#' @examples
#' # Create a scenario
#' myscenario <- GUTS_RED_IT() %>% set_times(0:5)
#' # Returns the defined output times
#' get_times(myscenario)
setGeneric("get_times", function(x) standardGeneric("get_times"))

#' @export
setMethod("get_times", "ANY", function(x) stop("Object type is not supported"))

#' @export
setMethod("get_times", "list", function(x) lapply(x, get_times))

#' @export
setMethod("get_times", "EffectScenario", function(x) return(x@times))

#' @export
setMethod("get_times", "ScenarioSequence", function(x) get_times_seq(x))

get_times_seq <- function(x) {
  # for backwards compatibility, since v1.5.0
  if(methods::.hasSlot(x, "inc_start")) {
    inc_start <- x@inc_start
    inc_end <- x@inc_end
  } else {
    inc_start <- c(TRUE, rep(FALSE, length(x) - 1))
    inc_end <- rep(TRUE, length(x))
  }

  times <- c()
  for(i in seq_along(x)) {
    tms <- get_times(x[[i]])
    if(!inc_start[[i]]) {
      tms <- tms[ tms != tms[1] ]
    }
    if(!inc_end[[i]]) {
      tms <- tms[ tms != tms[length(tms)] ]
    }
    times <- c(times, tms)
  }
  times
}

Try the cvasi package in your browser

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

cvasi documentation built on Sept. 11, 2025, 5:11 p.m.