1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
|
#' Create a Validation Split for Tuning
#'
#' @param split An object of class `initial_validation_split`, such as resulting
#' from [initial_validation_split()] or [group_initial_validation_split()].
#' @param x An `rsplit` object produced by `validation_set()`.
#' @inheritParams rlang::args_dots_empty
#'
#' @return An tibble with classes `validation_set`, `rset`, `tbl_df`, `tbl`, and
#' `data.frame`. The results include a column for the data split object and a
#' column called `id` that has a character string with the resample identifier.
#' @export
#'
#' @examples
#' set.seed(1353)
#' car_split <- initial_validation_split(mtcars)
#' car_set <- validation_set(car_split)
validation_set <- function(split, ...) {
rlang::check_dots_empty()
train_and_val <- dplyr::bind_rows(
training(split),
validation(split)
)
n_train <- length(split$train_id)
val_split <- rsplit(
data = train_and_val,
in_id = seq_len(n_train),
out_id = NA
)
# this is same class as via the alternative `validation_split()`
class(val_split) <- c("val_split", "rsplit")
val_att <- attr(split, "val_att")
val_att[["origin_3way"]] <- TRUE
new_rset(
splits = list(val_split),
ids = "validation",
attrib = val_att,
subclass = c("validation_set", "rset")
)
}
# accessor methods for the rsplit -----------------------------------------
#' @rdname validation_set
#' @export
analysis.val_split <- function(x, ...) {
as.data.frame(x, data = "analysis", ...)
}
#' @rdname validation_set
#' @export
assessment.val_split <- function(x, ...) {
as.data.frame(x, data = "assessment", ...)
}
#' @rdname validation_set
#' @export
training.val_split <- function(x, ...) {
analysis(x, ...)
}
#' @rdname validation_set
#' @export
validation.val_split <- function(x, ...) {
assessment(x, ...)
}
#' @rdname validation_set
#' @export
testing.val_split <- function(x, ...) {
rlang::abort(
"The testing data is not part of the validation set object.",
i = "It is part of the result of the initial 3-way split, e.g., with `initial_validation_split()`."
)
}
|