Packages

object PolynomialExpansion extends DefaultParamsReadable[PolynomialExpansion] with Serializable

The expansion is done via recursion. Given n features and degree d, the size after expansion is (n + d choose d) (including 1 and first-order values). For example, let f([a, b, c], 3) be the function that expands [a, b, c] to their monomials of degree 3. We have the following recursion:

$$ f([a, b, c], 3) &= f([a, b], 3) ++ f([a, b], 2) * c ++ f([a, b], 1) * c^2 ++ [c^3] $$

To handle sparsity, if c is zero, we can skip all monomials that contain it. We remember the current index and increment it properly for sparse input.

Annotations
@Since( "1.6.0" )
Source
PolynomialExpansion.scala
Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. PolynomialExpansion
  2. Serializable
  3. Serializable
  4. DefaultParamsReadable
  5. MLReadable
  6. AnyRef
  7. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Value Members

  1. def load(path: String): PolynomialExpansion

    Reads an ML instance from the input path, a shortcut of read.load(path).

    Reads an ML instance from the input path, a shortcut of read.load(path).

    Definition Classes
    PolynomialExpansionMLReadable
    Annotations
    @Since( "1.6.0" )
    Note

    Implementing classes should override this to be Java-friendly.

  2. def read: MLReader[PolynomialExpansion]

    Returns an MLReader instance for this class.

    Returns an MLReader instance for this class.

    Definition Classes
    DefaultParamsReadableMLReadable