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
- Alphabetic
- By Inheritance
- PolynomialExpansion
- Serializable
- Serializable
- DefaultParamsReadable
- MLReadable
- AnyRef
- Any
- Hide All
- Show All
- Public
- All
Value Members
-
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
- PolynomialExpansion → MLReadable
- Annotations
- @Since( "1.6.0" )
- Note
Implementing classes should override this to be Java-friendly.
-
def
read: MLReader[PolynomialExpansion]
Returns an
MLReader
instance for this class.Returns an
MLReader
instance for this class.- Definition Classes
- DefaultParamsReadable → MLReadable