% Generated by roxygen2: do not edit by hand % Please edit documentation in R/xgb.Booster.R \name{coef.xgb.Booster} \alias{coef.xgb.Booster} \title{Extract coefficients from linear booster} \usage{ \method{coef}{xgb.Booster}(object, ...) } \arguments{ \item{object}{A fitted booster of 'gblinear' type.} \item{...}{Not used.} } \value{ The extracted coefficients:\itemize{ \item If there's only one coefficient per column in the data, will be returned as a vector, potentially containing the feature names if available, with the intercept as first column. \item If there's more than one coefficient per column in the data (e.g. when using \code{objective="multi:softmax"}), will be returned as a matrix with dimensions equal to \verb{[num_features, num_cols]}, with the intercepts as first row. Note that the column (classes in multi-class classification) dimension will not be named. } The intercept returned here will include the 'base_score' parameter (unlike the 'bias' or the last coefficient in the model dump, which doesn't have 'base_score' added to it), hence one should get the same values from calling \code{predict(..., outputmargin = TRUE)} and from performing a matrix multiplication with \code{model.matrix(~., ...)}. Be aware that the coefficients are obtained by first converting them to strings and back, so there will always be some very small lose of precision compared to the actual coefficients as used by \link{predict.xgb.Booster}. } \description{ Extracts the coefficients from a 'gblinear' booster object, as produced by \code{xgb.train} when using parameter \code{booster="gblinear"}. Note: this function will error out if passing a booster model which is not of "gblinear" type. } \examples{ library(xgboost) data(mtcars) y <- mtcars[, 1] x <- as.matrix(mtcars[, -1]) dm <- xgb.DMatrix(data = x, label = y, nthread = 1) params <- list(booster = "gblinear", nthread = 1) model <- xgb.train(data = dm, params = params, nrounds = 2) coef(model) }