pub struct FittedPolynomialFeatures<F> { /* private fields */ }Expand description
A fitted PolynomialFeatures.
PolynomialFeatures.fit (sklearn _polynomial.py:306-400, “Compute number
of output features”) learns NO numeric statistics — it records only the
shape metadata derivable from n_features_in_ and the configured params:
n_features_in_, n_output_features_ (the number of output columns), and
the powers_ exponent matrix. The fitted type’s Transform::transform
REUSES the very same combination enumeration ([PolynomialFeatures:: feature_combinations]) and value math ([generate_poly_features]) as the
stateless PolynomialFeatures path, so the two paths are bit-identical;
it additionally enforces the transform-time feature-count check against
n_features_in_ (sklearn X has N features, but ... expecting M).
Implementations§
Source§impl<F: Float + Send + Sync + 'static> FittedPolynomialFeatures<F>
impl<F: Float + Send + Sync + 'static> FittedPolynomialFeatures<F>
Sourcepub fn n_features_in(&self) -> usize
pub fn n_features_in(&self) -> usize
Return the number of features (columns) seen during Fit::fit.
Mirrors scikit-learn’s PolynomialFeatures.n_features_in_
(_polynomial.py:323).
Sourcepub fn n_output_features(&self) -> usize
pub fn n_output_features(&self) -> usize
Return the total number of polynomial output columns.
Mirrors scikit-learn’s PolynomialFeatures.n_output_features_
(_polynomial.py:362).
Sourcepub fn powers(&self) -> &Array2<usize>
pub fn powers(&self) -> &Array2<usize>
Return the powers_ exponent matrix of shape
(n_output_features_, n_features_in_).
powers_[i, j] is the exponent of input feature j in output feature
i, mirroring scikit-learn’s PolynomialFeatures.powers_
(_polynomial.py:250-264).
Sourcepub fn interaction_only(&self) -> bool
pub fn interaction_only(&self) -> bool
Return whether only interaction terms are generated.
Sourcepub fn include_bias(&self) -> bool
pub fn include_bias(&self) -> bool
Return whether a bias column is included.
Trait Implementations§
Source§impl<F: Clone> Clone for FittedPolynomialFeatures<F>
impl<F: Clone> Clone for FittedPolynomialFeatures<F>
Source§fn clone(&self) -> FittedPolynomialFeatures<F>
fn clone(&self) -> FittedPolynomialFeatures<F>
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<F: Debug> Debug for FittedPolynomialFeatures<F>
impl<F: Debug> Debug for FittedPolynomialFeatures<F>
Source§impl<F: Float + Send + Sync + 'static> Transform<ArrayBase<OwnedRepr<F>, Dim<[usize; 2]>>> for FittedPolynomialFeatures<F>
impl<F: Float + Send + Sync + 'static> Transform<ArrayBase<OwnedRepr<F>, Dim<[usize; 2]>>> for FittedPolynomialFeatures<F>
Source§fn transform(&self, x: &Array2<F>) -> Result<Array2<F>, FerroError>
fn transform(&self, x: &Array2<F>) -> Result<Array2<F>, FerroError>
Generate polynomial features, delegating to the SAME combination
enumeration + value math as the stateless PolynomialFeatures path.
First applies the REQ-8 check_array guards (min-samples / min-features
/ finite) and generates the polynomial matrix, THEN validates that x
has the same number of columns recorded during Fit::fit. This ORDER
matches sklearn’s _validate_data(reset=False), which runs check_array
BEFORE the n_features_in_ consistency check (_polynomial.py:433-435,
#2207): a NaN / ±inf / zero-sample / zero-feature input raises its
check_array error EVEN when the column count is also wrong. Only after
that does the feature-count comparison fire. Because the combinations are
re-enumerated from the SAME params (degree / interaction_only /
include_bias) and the value math is the shared [generate_poly_features],
the output is byte-identical to PolynomialFeatures::transform.
§Errors
Returns FerroError::ShapeMismatch if the column count differs from
n_features_in_ (sklearn ValueError: X has N features, but PolynomialFeatures is expecting M features as input.,
_polynomial.py:402-435). Returns FerroError::InsufficientSamples
for zero rows and FerroError::InvalidParameter for zero features or
any non-finite value (REQ-8, via [validate_poly_input]).
Source§type Error = FerroError
type Error = FerroError
transform.Auto Trait Implementations§
impl<F> Freeze for FittedPolynomialFeatures<F>
impl<F> RefUnwindSafe for FittedPolynomialFeatures<F>where
F: RefUnwindSafe,
impl<F> Send for FittedPolynomialFeatures<F>where
F: Send,
impl<F> Sync for FittedPolynomialFeatures<F>where
F: Sync,
impl<F> Unpin for FittedPolynomialFeatures<F>where
F: Unpin,
impl<F> UnsafeUnpin for FittedPolynomialFeatures<F>
impl<F> UnwindSafe for FittedPolynomialFeatures<F>where
F: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> DistributionExt for Twhere
T: ?Sized,
impl<T> DistributionExt for Twhere
T: ?Sized,
impl<T, U> Imply<T> for U
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§unsafe fn to_subset_unchecked(&self) -> SS
unsafe fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.