R/marshal.caret.R

Defines functions marshallable.train unmarshal_train marshal.train

Documented in marshallable.train marshal.train

#' Marshalling of 'caret:train' objects
#'
#' @param train
#' A [caret::train] object.
#'
#' @param \dots Not used.
#'
#' @return
#' A `marshalled` object as described in [marshal()].
#'
#' @details
#' [bundle::bundle()] is used to produce a marshalled version
#' of the original object.
#' [bundle::unbundle()] is used to reconstruct a version of the
#' original object from the marshalled object.
#'
# @example incl/marshal.train.R
#'
#' @rdname marshal.caret
#' @aliases marshal.train
#' @export
marshal.train <- function(train, ...) {
  res <- list(
    marshalled = bundle::bundle(train)
  )
  class(res) <- marshal_class(train)
  
  ## IMPORTANT: We don't want any of the input arguments
  ## to be part of the unmarshal() environment
  rm(list = c("train", names(list(...))))
  
  res[["unmarshal"]] <- unmarshal_train
  assert_no_references(res)
  res
  
}

unmarshal_train <- function(train, ...) {
  object <- train[["marshalled"]]
  res <- bundle::unbundle(object, ...)
  stopifnot(all.equal(class(res), marshal_unclass(train), check.attributes = FALSE))
  res
}


#' @rdname marshal.caret
#' @aliases marshallable.train
#' @export
marshallable.train <- function(...) {
  TRUE
}
HenrikBengtsson/marshal documentation built on June 11, 2024, 11:35 a.m.