pub struct DecisionTreeClassifier<F> {
pub max_depth: Option<usize>,
pub min_samples_split: usize,
pub min_samples_leaf: usize,
pub criterion: ClassificationCriterion,
/* private fields */
}Expand description
CART decision tree classifier.
Builds a binary tree by recursively finding the feature and threshold that maximises the reduction in the chosen impurity criterion (Gini or Entropy).
§Type Parameters
F: The floating-point type (f32orf64).
Fields§
§max_depth: Option<usize>Maximum depth of the tree. None means unlimited.
min_samples_split: usizeMinimum number of samples required to split an internal node.
min_samples_leaf: usizeMinimum number of samples required in a leaf node.
criterion: ClassificationCriterionSplitting criterion.
Implementations§
Source§impl<F: Float> DecisionTreeClassifier<F>
impl<F: Float> DecisionTreeClassifier<F>
Sourcepub fn new() -> Self
pub fn new() -> Self
Create a new DecisionTreeClassifier with default settings.
Defaults: max_depth = None, min_samples_split = 2,
min_samples_leaf = 1, criterion = Gini.
Sourcepub fn with_max_depth(self, max_depth: Option<usize>) -> Self
pub fn with_max_depth(self, max_depth: Option<usize>) -> Self
Set the maximum tree depth.
Sourcepub fn with_min_samples_split(self, min_samples_split: usize) -> Self
pub fn with_min_samples_split(self, min_samples_split: usize) -> Self
Set the minimum number of samples required to split a node.
Sourcepub fn with_min_samples_leaf(self, min_samples_leaf: usize) -> Self
pub fn with_min_samples_leaf(self, min_samples_leaf: usize) -> Self
Set the minimum number of samples required in a leaf node.
Sourcepub fn with_criterion(self, criterion: ClassificationCriterion) -> Self
pub fn with_criterion(self, criterion: ClassificationCriterion) -> Self
Set the splitting criterion.
Trait Implementations§
Source§impl<F: Clone> Clone for DecisionTreeClassifier<F>
impl<F: Clone> Clone for DecisionTreeClassifier<F>
Source§fn clone(&self) -> DecisionTreeClassifier<F>
fn clone(&self) -> DecisionTreeClassifier<F>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<F: Debug> Debug for DecisionTreeClassifier<F>
impl<F: Debug> Debug for DecisionTreeClassifier<F>
Source§impl<F: Float> Default for DecisionTreeClassifier<F>
impl<F: Float> Default for DecisionTreeClassifier<F>
Source§impl<'de, F> Deserialize<'de> for DecisionTreeClassifier<F>
impl<'de, F> Deserialize<'de> for DecisionTreeClassifier<F>
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl<F: Float + Send + Sync + 'static> Fit<ArrayBase<OwnedRepr<F>, Dim<[usize; 2]>>, ArrayBase<OwnedRepr<usize>, Dim<[usize; 1]>>> for DecisionTreeClassifier<F>
impl<F: Float + Send + Sync + 'static> Fit<ArrayBase<OwnedRepr<F>, Dim<[usize; 2]>>, ArrayBase<OwnedRepr<usize>, Dim<[usize; 1]>>> for DecisionTreeClassifier<F>
Source§fn fit(
&self,
x: &Array2<F>,
y: &Array1<usize>,
) -> Result<FittedDecisionTreeClassifier<F>, FerroError>
fn fit( &self, x: &Array2<F>, y: &Array1<usize>, ) -> Result<FittedDecisionTreeClassifier<F>, FerroError>
Fit the decision tree classifier on the training data.
§Errors
Returns FerroError::ShapeMismatch if x and y have different
numbers of samples.
Returns FerroError::InsufficientSamples if there are no samples.
Returns FerroError::InvalidParameter if hyperparameters are invalid.
Source§type Fitted = FittedDecisionTreeClassifier<F>
type Fitted = FittedDecisionTreeClassifier<F>
fit.Source§type Error = FerroError
type Error = FerroError
fit.Source§impl<F: Float + ToPrimitive + FromPrimitive + Send + Sync + 'static> PipelineEstimator<F> for DecisionTreeClassifier<F>
impl<F: Float + ToPrimitive + FromPrimitive + Send + Sync + 'static> PipelineEstimator<F> for DecisionTreeClassifier<F>
Source§fn fit_pipeline(
&self,
x: &Array2<F>,
y: &Array1<F>,
) -> Result<Box<dyn FittedPipelineEstimator<F>>, FerroError>
fn fit_pipeline( &self, x: &Array2<F>, y: &Array1<F>, ) -> Result<Box<dyn FittedPipelineEstimator<F>>, FerroError>
Auto Trait Implementations§
impl<F> Freeze for DecisionTreeClassifier<F>
impl<F> RefUnwindSafe for DecisionTreeClassifier<F>where
F: RefUnwindSafe,
impl<F> Send for DecisionTreeClassifier<F>where
F: Send,
impl<F> Sync for DecisionTreeClassifier<F>where
F: Sync,
impl<F> Unpin for DecisionTreeClassifier<F>where
F: Unpin,
impl<F> UnsafeUnpin for DecisionTreeClassifier<F>
impl<F> UnwindSafe for DecisionTreeClassifier<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,
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 more