svm_poly() defines a support vector machine model. For classification, the model tries to maximize the width of the margin between classes. For regression, the model optimizes a robust loss function that is only affected by very large model residuals.

This SVM model uses a nonlinear function, specifically a polynomial function, to create the decision boundary or regression line.

There are different ways to fit this model. See the engine-specific pages for more details:

More information on how parsnip is used for modeling is at

  mode = "unknown",
  engine = "kernlab",
  cost = NULL,
  degree = NULL,
  scale_factor = NULL,
  margin = NULL



A single character string for the prediction outcome mode. Possible values for this model are "unknown", "regression", or "classification".


A single character string specifying what computational engine to use for fitting.


A positive number for the cost of predicting a sample within or on the wrong side of the margin


A positive number for polynomial degree.


A positive number for the polynomial scaling factor.


A positive number for the epsilon in the SVM insensitive loss function (regression only)


This function only defines what type of model is being fit. Once an engine is specified, the method to fit the model is also defined.

The model is not trained or fit until the fit.model_spec() function is used with the data.

References, Tidy Models with R

See also


#> # A tibble: 2 × 2 #> engine mode #> <chr> <chr> #> 1 kernlab classification #> 2 kernlab regression
svm_poly(mode = "classification", degree = 1.2)
#> Polynomial Support Vector Machine Specification (classification) #> #> Main Arguments: #> degree = 1.2 #> #> Computational engine: kernlab #>