22 #ifndef __LINEAR_REGRESSION_TRAINING_TYPES_H__
23 #define __LINEAR_REGRESSION_TRAINING_TYPES_H__
25 #include "algorithms/algorithm.h"
26 #include "data_management/data/numeric_table.h"
27 #include "algorithms/linear_regression/linear_regression_model.h"
28 #include "algorithms/linear_model/linear_model_training_types.h"
37 namespace linear_regression
67 data = linear_model::training::data,
68 dependentVariables = linear_model::training::dependentVariables,
69 lastInputId = dependentVariables
77 enum Step2MasterInputId
80 lastStep2MasterInputId = partialModels
90 lastPartialResultID = partialModel
99 model = linear_model::training::model,
119 virtual size_t getNumberOfFeatures()
const = 0;
125 virtual size_t getNumberOfDependentVariables()
const = 0;
127 virtual ~InputIface() {}
134 class DAAL_EXPORT Input :
public linear_model::training::Input,
public InputIface
139 Input(
const Input& other);
148 data_management::NumericTablePtr
get(InputId id)
const;
155 void set(InputId
id,
const data_management::NumericTablePtr &value);
161 size_t getNumberOfFeatures()
const DAAL_C11_OVERRIDE;
167 size_t getNumberOfDependentVariables()
const DAAL_C11_OVERRIDE;
176 services::Status check(
const daal::algorithms::Parameter *par,
int method)
const DAAL_C11_OVERRIDE;
183 template<ComputeStep step>
184 class DistributedInput
192 class DAAL_EXPORT PartialResult :
public linear_model::training::PartialResult
195 DECLARE_SERIALIZABLE_CAST(PartialResult);
203 daal::algorithms::linear_regression::ModelPtr
get(PartialResultID id)
const;
209 size_t getNumberOfFeatures()
const;
215 size_t getNumberOfDependentVariables()
const;
222 void set(PartialResultID
id,
const daal::algorithms::linear_regression::ModelPtr &value);
232 template <
typename algorithmFPType>
233 DAAL_EXPORT services::Status allocate(
const daal::algorithms::Input *input,
const daal::algorithms::Parameter *parameter,
const int method);
243 template <
typename algorithmFPType>
244 DAAL_EXPORT services::Status initialize(
const daal::algorithms::Input *input,
const daal::algorithms::Parameter *parameter,
const int method);
254 services::Status check(
const daal::algorithms::Input *input,
const daal::algorithms::Parameter *par,
int method)
const DAAL_C11_OVERRIDE;
263 services::Status check(
const daal::algorithms::Parameter *par,
int method)
const DAAL_C11_OVERRIDE;
267 template<
typename Archive,
bool onDeserialize>
268 services::Status serialImpl(Archive *arch)
270 return daal::algorithms::PartialResult::serialImpl<Archive, onDeserialize>(arch);
273 typedef services::SharedPtr<PartialResult> PartialResultPtr;
274 typedef services::SharedPtr<const PartialResult> PartialResultConstPtr;
281 template<>
class DAAL_EXPORT DistributedInput<step2Master> :
public daal::algorithms::Input,
public InputIface
284 DistributedInput<step2Master>();
291 data_management::DataCollectionPtr
get(Step2MasterInputId id)
const;
299 void set(Step2MasterInputId
id,
const data_management::DataCollectionPtr &ptr);
307 void add(Step2MasterInputId
id,
const PartialResultPtr &partialResult);
313 size_t getNumberOfFeatures()
const DAAL_C11_OVERRIDE;
319 size_t getNumberOfDependentVariables()
const DAAL_C11_OVERRIDE;
327 services::Status check(
const daal::algorithms::Parameter *parameter,
int method)
const DAAL_C11_OVERRIDE;
335 class DAAL_EXPORT Result :
public linear_model::training::Result
338 DECLARE_SERIALIZABLE_CAST(Result);
349 template<
typename algorithmFPType>
350 DAAL_EXPORT services::Status allocate(
const daal::algorithms::Input *input,
const Parameter *parameter,
const int method);
360 template<
typename algorithmFPType>
361 DAAL_EXPORT services::Status allocate(
const daal::algorithms::PartialResult *partialResult,
const Parameter *parameter,
const int method);
368 linear_regression::ModelPtr
get(ResultId id)
const;
375 void set(ResultId
id,
const linear_regression::ModelPtr &value);
385 services::Status check(
const daal::algorithms::Input *input,
const daal::algorithms::Parameter *par,
int method)
const DAAL_C11_OVERRIDE;
395 services::Status check(
const daal::algorithms::PartialResult *pr,
const daal::algorithms::Parameter *par,
int method)
const DAAL_C11_OVERRIDE;
399 template<
typename Archive,
bool onDeserialize>
400 services::Status serialImpl(Archive *arch)
402 return daal::algorithms::Result::serialImpl<Archive, onDeserialize>(arch);
405 typedef services::SharedPtr<Result> ResultPtr;
406 typedef services::SharedPtr<const Result> ResultConstPtr;
408 using interface1::InputIface;
409 using interface1::Input;
410 using interface1::DistributedInput;
411 using interface1::PartialResult;
412 using interface1::PartialResultPtr;
413 using interface1::PartialResultConstPtr;
414 using interface1::Result;
415 using interface1::ResultPtr;
416 using interface1::ResultConstPtr;
daal::algorithms::linear_regression::training::ResultId
ResultId
Available identifiers of the result of linear regression model-based training.
Definition: linear_regression_training_types.h:97
daal::algorithms::linear_regression::training::partialModel
Definition: linear_regression_training_types.h:89
daal
Definition: algorithm_base_common.h:31
daal::algorithms::linear_regression::training::data
Definition: linear_regression_training_types.h:67
daal::algorithms::linear_regression::training::PartialResultID
PartialResultID
Available identifiers of a partial result of linear regression model-based training.
Definition: linear_regression_training_types.h:87
daal::algorithms::linear_regression::training::normEqDense
Definition: linear_regression_training_types.h:57
daal::algorithms::linear_regression::training::partialModels
Definition: linear_regression_training_types.h:79
daal::algorithms::linear_regression::training::defaultDense
Definition: linear_regression_training_types.h:56
daal::algorithms::linear_regression::training::InputId
InputId
Available identifiers of input objects for linear regression model-based training.
Definition: linear_regression_training_types.h:65
daal::algorithms::linear_regression::training::interface1::Result
Provides methods to access the result obtained with the compute() method of linear regression model-b...
Definition: linear_regression_training_types.h:335
daal::algorithms::linear_regression::training::qrDense
Definition: linear_regression_training_types.h:58
daal::algorithms::linear_model::training::dependentVariables
Definition: linear_model_training_types.h:54
daal::algorithms::linear_regression::training::model
Definition: linear_regression_training_types.h:99
daal::algorithms::linear_regression::training::dependentVariables
Definition: linear_regression_training_types.h:68
daal::algorithms::linear_model::training::model
Definition: linear_model_training_types.h:64
daal::algorithms::linear_regression::training::interface1::PartialResult
Provides methods to access a partial result obtained with the compute() method of linear regression m...
Definition: linear_regression_training_types.h:192
daal::algorithms::linear_model::training::data
Definition: linear_model_training_types.h:53
daal::algorithms::linear_regression::training::Method
Method
Computation methods for linear regression model-based training.
Definition: linear_regression_training_types.h:54
daal::algorithms::math::abs::value
Definition: abs_types.h:86
daal::step2Master
Definition: daal_defines.h:122
daal::algorithms::linear_regression::training::Step2MasterInputId
Step2MasterInputId
Available identifiers of input objects for linear regression model-based training in the second step ...
Definition: linear_regression_training_types.h:77