R/cleanProfiles.R

Defines functions cleanProfileResults

Documented in cleanProfileResults

# cleanProfileResults function
#' @name cleanProfileResults
#' @author Dario Azzimonti
#' @title Clean a profile extrema object
#' @description The function cleanProfileResults cleans a profile extrema object to partially redo some computations.
#' @param object a list containing profile extrema results.
#' @param level an integer 1-4 denoting how much it should be removed from \code{object}. See Value for details.
#' @return returns \code{object} with the deleted parts as selected by \code{level}. In particular \itemize{
#' \item{\code{1:}}{keep only \code{profMean_full}.}
#' \item{\code{2:}}{keep \code{profMean_full} and \code{profMean_approx}. Remove all UQ results.}
#' \item{\code{3:}}{keep \code{profMean_full} and \code{profMean_approx} and the pilot points. Remove all UQ simulations.}
#' \item{\code{4:}}{Remove only the bound computations.}
#' }
#'
#' @examples
#' if (!requireNamespace("DiceKriging", quietly = TRUE)) {
#' stop("DiceKriging needed for this example to work. Please install it.",
#'      call. = FALSE)
#' }
#' # Compute a kriging model from 50 evaluations of the Branin function
#' # Define the function
#' g=function(x){
#'   return(-branin(x))
#' }
#' gp_des<-lhs::maximinLHS(20,2)
#' reals<-apply(gp_des,1,g)
#' kmModel<-km(design = gp_des,response = reals,covtype = "matern3_2")
#'
#' threshold=-10
#'
#' # Compute coordinate profiles on the posterior mean
#' # Increase multistart and size of designs for more precise results
#' options_full<-list(multistart=2,heavyReturn=TRUE, Design = replicate(2,seq(0,1,,50)))
#' init_des<-lhs::maximinLHS(12,2)
#' options_approx<- list(multistart=2,heavyReturn=TRUE,initDesign=init_des,fullDesignSize=50)
#' cProfilesMean<-coordinateProfiles(object=kmModel,threshold=threshold,options_full=options_full,
#'                                   options_approx=options_approx,uq_computations=FALSE,
#'                                   plot_level=3,plot_options=NULL,CI_const=NULL,return_level=2)
#'
#' # If we want to run again the computation of approximate coordinate profiles
#' # we delete that result and run again the coordinate profiles function
#' cProfiles_full <- cleanProfileResults(cProfilesMean,level=1)
#' \dontrun{
#' # Coordinate profiles with UQ with approximate profiles
#' plot_options<-list(save=FALSE, titleProf = "Coordinate profiles",
#'                    title2d = "Posterior mean",qq_fill=TRUE)
#' cProfilesUQ<-coordinateProfiles(object=cProfilesMean,threshold=threshold,options_full=options_full,
#'                                   options_approx=options_approx,uq_computations=TRUE,
#'                                   plot_level=3,plot_options=NULL,CI_const=NULL,return_level=2)
#' # If we would like to remove all UQ results
#' cProf_noUQ <- cleanProfileResults(cProfilesUQ,level=2)
#'
#' # If we would like to remove the simulations but keep the pilot points
#' cProf_noSims <- cleanProfileResults(cProfilesUQ,level=3)
#' # the line above is useful, for example, if we need a more accurate UQ. In that case
#' # we obtain more simulations with the same pilot points and then combine the results.
#'
#' }
#' @export
cleanProfileResults = function(object,level = 1){
  if(level <= 4){
    object$res_UQ$bound$bound <- NULL
    object$res_UQ$bound$approx <- NULL
    if(level <=3){
      object$res_UQ$profSups <- NULL
      object$res_UQ$profInfs <- NULL
      object$res_UQ$more <- NULL
      object$res_UQ$prof_quantiles_approx <- NULL
      if(level <= 2){
        object$res_UQ <- NULL
        if(level <=1){
          object$profMean_approx <- NULL
          object$more$times$approx <- NULL
          object$more$abs_err<- NULL
        }
      }
    }
  }
  return(object)
}

Try the profExtrema package in your browser

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

profExtrema documentation built on March 22, 2020, 1:07 a.m.