22 #ifndef __DECISION_TREE_CLASSIFICATION_MODEL_H__
23 #define __DECISION_TREE_CLASSIFICATION_MODEL_H__
25 #include "algorithms/classifier/classifier_model.h"
26 #include "algorithms/classifier/tree_traverse.h"
27 #include "data_management/data/aos_numeric_table.h"
28 #include "data_management/data/soa_numeric_table.h"
29 #include "data_management/data/homogen_numeric_table.h"
30 #include "decision_tree_model.h"
46 namespace decision_tree
52 namespace classification
81 struct DAAL_EXPORT Parameter :
public daal::algorithms::classifier::Parameter
87 Parameter(
size_t nClasses = 2) : daal::algorithms::classifier::Parameter(nClasses),
88 pruning(reducedErrorPruning), maxTreeDepth(0), minObservationsInLeafNodes(1),
89 splitCriterion(infoGain) {}
94 services::Status check() const DAAL_C11_OVERRIDE;
96 SplitCriterion splitCriterion;
99 size_t minObservationsInLeafNodes;
112 class DAAL_EXPORT Model : public daal::algorithms::classifier::Model
115 DECLARE_MODEL_IFACE(Model, classifier::Model);
122 Model(
size_t nFeatures = 0);
129 static services::SharedPtr<Model> create(
size_t nFeatures = 0, services::Status *stat = NULL);
134 typedef services::SharedPtr<ModelImpl> ModelImplPtr;
140 const ModelImpl * impl()
const {
return _impl.get(); }
146 ModelImpl * impl() {
return _impl.get(); }
152 size_t getNumberOfFeatures() const DAAL_C11_OVERRIDE;
158 void traverseDF(classifier::TreeNodeVisitor& visitor) const;
164 void traverseBF(classifier::TreeNodeVisitor& visitor) const;
167 Model(
size_t nFeatures, services::Status &st);
169 services::Status serializeImpl(data_management::InputDataArchive * arch) DAAL_C11_OVERRIDE;
171 services::Status deserializeImpl(const data_management::OutputDataArchive * arch) DAAL_C11_OVERRIDE;
177 typedef services::SharedPtr<Model> ModelPtr;
178 typedef services::SharedPtr<const Model> ModelConstPtr;
182 using interface1::Parameter;
183 using interface1::Model;
184 using interface1::ModelPtr;
185 using interface1::ModelConstPtr;
daal
Definition: algorithm_base_common.h:31
daal::algorithms::decision_tree::reducedErrorPruning
Definition: decision_tree_model.h:50
daal::algorithms::decision_tree::classification::SplitCriterion
SplitCriterion
Split criterion for Decision tree classification algorithm.
Definition: decision_tree_classification_model.h:59
daal::algorithms::decision_tree::classification::interface1::Model
Base class for models trained with the Decision tree algorithm
Definition: decision_tree_classification_model.h:112
daal::algorithms::decision_tree::Pruning
Pruning
Pruning method for Decision tree algorithm.
Definition: decision_tree_model.h:47
daal::algorithms::decision_tree::classification::infoGain
Definition: decision_tree_classification_model.h:62
daal::algorithms::decision_tree::classification::interface1::Parameter
Decision tree algorithm parameters.
Definition: decision_tree_classification_model.h:81
daal::algorithms::decision_tree::classification::interface1::Model::impl
const ModelImpl * impl() const
Definition: decision_tree_classification_model.h:140
daal::algorithms::decision_tree::classification::gini
Definition: decision_tree_classification_model.h:61
daal::algorithms::decision_tree::classification::interface1::Model::impl
ModelImpl * impl()
Definition: decision_tree_classification_model.h:146
daal::algorithms::decision_tree::classification::interface1::Parameter::Parameter
Parameter(size_t nClasses=2)
Definition: decision_tree_classification_model.h:87