Polynomial Features

Description

The polynomial features transformer maps a vector into the polynomial feature space of degree $d$.The dimension of the input vector determines the number of polynomial factors whose values are the respective vector entries.Given a vector $(x, y, z, \ldots)^T$ the resulting feature vector looks like:

Flink’s implementation orders the polynomials in decreasing order of their degree.

Given the vector $\left(3,2\right)^T$, the polynomial features vector of degree 3 would look like

This transformer can be prepended to all Transformer and Predictor implementations which expect an input of type LabeledVector or any sub-type of Vector.

Operations

PolynomialFeatures is a Transformer.As such, it supports the fit and transform operation.

Fit

PolynomialFeatures is not trained on data and, thus, supports all types of input data.

Transform

PolynomialFeatures transforms all subtypes of Vector and LabeledVector into their respective types:

  • transform[T <: Vector]: DataSet[T] => DataSet[T]
  • transform: DataSet[LabeledVector] => DataSet[LabeledVector]

Parameters

The polynomial features transformer can be controlled by the following parameters:

ParametersDescription
DegreeThe maximum polynomial degree.(Default value: 10)

Examples

  1. // Obtain the training data set
  2. val trainingDS: DataSet[LabeledVector] = ...
  3. // Setup polynomial feature transformer of degree 3
  4. val polyFeatures = PolynomialFeatures()
  5. .setDegree(3)
  6. // Setup the multiple linear regression learner
  7. val mlr = MultipleLinearRegression()
  8. // Control the learner via the parameter map
  9. val parameters = ParameterMap()
  10. .add(MultipleLinearRegression.Iterations, 20)
  11. .add(MultipleLinearRegression.Stepsize, 0.5)
  12. // Create pipeline PolynomialFeatures -> MultipleLinearRegression
  13. val pipeline = polyFeatures.chainPredictor(mlr)
  14. // train the model
  15. pipeline.fit(trainingDS)

Back to top