The hardware and bandwidth for this mirror is donated by METANET, the Webhosting and Full Service-Cloud Provider.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]metanet.ch.
additiveLet’s simulate a data using mgcv package, which is
automatically loaded by additive.
## Gu & Wahba 4 term additive modelIn a first step, we use the recipes package to prepare
(a recipe for) the data.
test_recipe <- dat |>
  recipe() |>
  update_role(y, new_role = "outcome") |>
  update_role(x0, x1, x2, x3, new_role = "predictor") |>
  step_normalize(all_numeric_predictors())## ## ── Recipe ──────────────────────────────────────────────────────────────────────## ## ── Inputs## Number of variables by role## outcome:         1
## predictor:       4
## undeclared role: 5## ## ── Operations## • Centering and scaling for: all_numeric_predictors()Above, we not only define the roles of the relevant variables but
also normalized all numeric predictors to facilitate model fitting later
on. In the next step, we use additive to set up a basic
model structure.
test_model <- additive(
    family = gaussian(),
    method = "REML"
  ) |>
  set_engine("mgcv") |>
  set_mode("regression")## Generalized Additive Model (GAM) Specification (regression)
## 
## Main Arguments:
##   family = gaussian()
##   method = REML
## 
## Computational engine: mgcvThe additive function is the main function of the
package to initialize a Generalized Additive Model (GAM). We can set up
a lot of the information directly within the function or update the
information later on, via the update method. For example,
if we didn’t specify the family initially or set it to something else
that we now wanted to change, we could use the update
method as follows
Next, we define a workflow via the workflows package, by
combining the above defined data processing recipe and the model plus
the actual model formula to be passed to the mgcv
engine.
test_workflow <- workflow() |>
  add_recipe(test_recipe) |>
  add_model(
    spec = test_model,
    formula = y ~ s(x0) + s(x1) + s(x2) + s(x3)
  )## ══ Workflow ════════════════════════════════════════════════════════════════════
## Preprocessor: Recipe
## Model: additive()
## 
## ── Preprocessor ────────────────────────────────────────────────────────────────
## 1 Recipe Step
## 
## • step_normalize()
## 
## ── Model ───────────────────────────────────────────────────────────────────────
## Generalized Additive Model (GAM) Specification (regression)
## 
## Main Arguments:
##   family = gaussian()
##   method = REML
## 
## Computational engine: mgcvWe are now ready to fit the model by calling the fit
method with the data set we want to train the model on.
## ══ Workflow [trained] ══════════════════════════════════════════════════════════
## Preprocessor: Recipe
## Model: additive()
## 
## ── Preprocessor ────────────────────────────────────────────────────────────────
## 1 Recipe Step
## 
## • step_normalize()
## 
## ── Model ───────────────────────────────────────────────────────────────────────
## 
## Family: gaussian 
## Link function: identity 
## 
## Formula:
## y ~ s(x0) + s(x1) + s(x2) + s(x3)
## 
## Estimated degrees of freedom:
## 4.24 3.25 8.26 2.22  total = 18.98 
## 
## REML score: 859.5808To extract the parsnip model fit from the workflow
The gamObject object can be extracted as follows
## [1] "gam" "glm" "lm"We can use the trained workflow, which includes the fitted model, to
conveniently predict using new data without having to worry
about all the data reprocessing, which is automatically applied using
the workflow preprocessor (recipe).
## # A tibble: 5 × 2
##   .pred_lower .pred_upper
##     <dbl[1d]>   <dbl[1d]>
## 1        2.60        4.45
## 2        4.90        6.48
## 3        8.74       10.5 
## 4        4.89        6.40
## 5        2.97        4.57To add the standard errors on the scale of the linear predictors
test_workflow_fit |>
  predict(
    new_data = newdata,
    type = "conf_int",
    level = 0.95,
    std_error = TRUE
  )## # A tibble: 5 × 3
##   .pred_lower .pred_upper .std_error
##     <dbl[1d]>   <dbl[1d]>  <dbl[1d]>
## 1        2.60        4.45      0.470
## 2        4.90        6.48      0.401
## 3        8.74       10.5       0.457
## 4        4.89        6.40      0.383
## 5        2.97        4.57      0.408These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.