Flow
sklearn.ensemble._gb.GradientBoostingClassifier

sklearn.ensemble._gb.GradientBoostingClassifier

Visibility: public Uploaded 05-04-2023 by Takeaki Sakabe sklearn==1.2.2 numpy>=1.17.3 scipy>=1.3.2 joblib>=1.1.1 threadpoolctl>=2.0.0 0 runs
0 likes downloaded by 0 people 0 issues 0 downvotes , 0 total downloads
  • openml-python python scikit-learn sklearn sklearn_1.2.2
Issue #Downvotes for this reason By


Loading wiki
Help us complete this description Edit
Gradient Boosting for classification. This algorithm builds an additive model in a forward stage-wise fashion; it allows for the optimization of arbitrary differentiable loss functions. In each stage ``n_classes_`` regression trees are fit on the negative gradient of the loss function, e.g. binary or multiclass log loss. Binary classification is a special case where only a single regression tree is induced. :class:`sklearn.ensemble.HistGradientBoostingClassifier` is a much faster variant of this algorithm for intermediate datasets (`n_samples >= 10_000`).

Parameters

ccp_alphaComplexity parameter used for Minimal Cost-Complexity Pruning. The subtree with the largest cost complexity that is smaller than ``ccp_alpha`` will be chosen. By default, no pruning is performed Values must be in the range `[0.0, inf)` See :ref:`minimal_cost_complexity_pruning` for details .. versionadded:: 0.22default: 0.0
criteriondefault: "friedman_mse"
initAn estimator object that is used to compute the initial predictions ``init`` has to provide :meth:`fit` and :meth:`predict_proba`. If 'zero', the initial raw predictions are set to zero. By default, a ``DummyEstimator`` predicting the classes priors is useddefault: null
learning_rateLearning rate shrinks the contribution of each tree by `learning_rate` There is a trade-off between learning_rate and n_estimators Values must be in the range `[0.0, inf)`default: 0.1
lossdefault: "log_loss"
max_depthMaximum depth of the individual regression estimators. The maximum depth limits the number of nodes in the tree. Tune this parameter for best performance; the best value depends on the interaction of the input variables. If None, then nodes are expanded until all leaves are pure or until all leaves contain less than min_samples_split samples If int, values must be in the range `[1, inf)`default: 3
max_featuresdefault: null
max_leaf_nodesGrow trees with ``max_leaf_nodes`` in best-first fashion Best nodes are defined as relative reduction in impurity Values must be in the range `[2, inf)` If `None`, then unlimited number of leaf nodesdefault: null
min_impurity_decreaseA node will be split if this split induces a decrease of the impurity greater than or equal to this value Values must be in the range `[0.0, inf)` The weighted impurity decrease equation is the following:: N_t / N * (impurity - N_t_R / N_t * right_impurity - N_t_L / N_t * left_impurity) where ``N`` is the total number of samples, ``N_t`` is the number of samples at the current node, ``N_t_L`` is the number of samples in the left child, and ``N_t_R`` is the number of samples in the right child ``N``, ``N_t``, ``N_t_R`` and ``N_t_L`` all refer to the weighted sum, if ``sample_weight`` is passed .. versionadded:: 0.19default: 0.0
min_samples_leafThe minimum number of samples required to be at a leaf node A split point at any depth will only be considered if it leaves at least ``min_samples_leaf`` training samples in each of the left and right branches. This may have the effect of smoothing the model, especially in regression - If int, values must be in the range `[1, inf)` - If float, values must be in the range `(0.0, 1.0)` and `min_samples_leaf` will be `ceil(min_samples_leaf * n_samples)` .. versionchanged:: 0.18 Added float values for fractionsdefault: 1
min_samples_splitThe minimum number of samples required to split an internal node: - If int, values must be in the range `[2, inf)` - If float, values must be in the range `(0.0, 1.0]` and `min_samples_split` will be `ceil(min_samples_split * n_samples)` .. versionchanged:: 0.18 Added float values for fractionsdefault: 2
min_weight_fraction_leafThe minimum weighted fraction of the sum total of weights (of all the input samples) required to be at a leaf node. Samples have equal weight when sample_weight is not provided Values must be in the range `[0.0, 0.5]`default: 0.0
n_estimatorsThe number of boosting stages to perform. Gradient boosting is fairly robust to over-fitting so a large number usually results in better performance Values must be in the range `[1, inf)`default: 100
n_iter_no_change``n_iter_no_change`` is used to decide if early stopping will be used to terminate training when validation score is not improving. By default it is set to None to disable early stopping. If set to a number, it will set aside ``validation_fraction`` size of the training data as validation and terminate training when validation score is not improving in all of the previous ``n_iter_no_change`` numbers of iterations. The split is stratified Values must be in the range `[1, inf)` .. versionadded:: 0.20default: null
random_stateControls the random seed given to each Tree estimator at each boosting iteration In addition, it controls the random permutation of the features at each split (see Notes for more details) It also controls the random splitting of the training data to obtain a validation set if `n_iter_no_change` is not None Pass an int for reproducible output across multiple function calls See :term:`Glossary ` max_features : {'auto', 'sqrt', 'log2'}, int or float, default=None The number of features to consider when looking for the best split: - If int, values must be in the range `[1, inf)` - If float, values must be in the range `(0.0, 1.0]` and the features considered at each split will be `max(1, int(max_features * n_features_in_))` - If 'auto', then `max_features=sqrt(n_features)` - If 'sqrt', then `max_features=sqrt(n_features)` - If 'log2', then `max_features=log2(n_features)` - If None, then `max_features=n_features` Choosing `max_fe...default: null
subsampleThe fraction of samples to be used for fitting the individual base learners. If smaller than 1.0 this results in Stochastic Gradient Boosting. `subsample` interacts with the parameter `n_estimators` Choosing `subsample < 1.0` leads to a reduction of variance and an increase in bias Values must be in the range `(0.0, 1.0]` criterion : {'friedman_mse', 'squared_error'}, default='friedman_mse' The function to measure the quality of a split. Supported criteria are 'friedman_mse' for the mean squared error with improvement score by Friedman, 'squared_error' for mean squared error. The default value of 'friedman_mse' is generally the best as it can provide a better approximation in some cases .. versionadded:: 0.18default: 1.0
tolTolerance for the early stopping. When the loss is not improving by at least tol for ``n_iter_no_change`` iterations (if set to a number), the training stops Values must be in the range `[0.0, inf)` .. versionadded:: 0.20default: 0.0001
validation_fractionThe proportion of training data to set aside as validation set for early stopping. Values must be in the range `(0.0, 1.0)` Only used if ``n_iter_no_change`` is set to an integer .. versionadded:: 0.20default: 0.1
verboseEnable verbose output. If 1 then it prints progress and performance once in a while (the more trees the lower the frequency). If greater than 1 then it prints progress and performance for every tree Values must be in the range `[0, inf)`default: 0
warm_startWhen set to ``True``, reuse the solution of the previous call to fit and add more estimators to the ensemble, otherwise, just erase the previous solution. See :term:`the Glossary `default: false

0
Runs

List all runs
Parameter:
Rendering chart
Rendering table