34 lines
1.0 KiB
R
34 lines
1.0 KiB
R
setClass('xgb.DMatrix')
|
|
|
|
#' Get a new DMatrix containing the specified rows of
|
|
#' orginal xgb.DMatrix object
|
|
#'
|
|
#' Get a new DMatrix containing the specified rows of
|
|
#' orginal xgb.DMatrix object
|
|
#'
|
|
#' @examples
|
|
#' data(agaricus.train, package='xgboost')
|
|
#' train <- agaricus.train
|
|
#' dtrain <- xgb.DMatrix(train$data, label=train$label)
|
|
#' dsub <- slice(dtrain, 1:3)
|
|
#' @rdname slice
|
|
#' @export
|
|
#'
|
|
slice <- function(object, ...){
|
|
UseMethod("slice")
|
|
}
|
|
|
|
#' @param object Object of class "xgb.DMatrix"
|
|
#' @param idxset a integer vector of indices of rows needed
|
|
#' @param ... other parameters
|
|
#' @rdname slice
|
|
#' @method slice xgb.DMatrix
|
|
setMethod("slice", signature = "xgb.DMatrix",
|
|
definition = function(object, idxset, ...) {
|
|
if (class(object) != "xgb.DMatrix") {
|
|
stop("slice: first argument dtrain must be xgb.DMatrix")
|
|
}
|
|
ret <- .Call("XGDMatrixSliceDMatrix_R", object, idxset, PACKAGE = "xgboost")
|
|
return(structure(ret, class = "xgb.DMatrix"))
|
|
})
|