C++ API Reference for Intel® Data Analytics Acceleration Library 2019

split_layer_forward.h
1 /* file: split_layer_forward.h */
2 /*******************************************************************************
3 * Copyright 2014-2018 Intel Corporation.
4 *
5 * This software and the related documents are Intel copyrighted materials, and
6 * your use of them is governed by the express license under which they were
7 * provided to you (License). Unless the License provides otherwise, you may not
8 * use, modify, copy, publish, distribute, disclose or transmit this software or
9 * the related documents without Intel's prior written permission.
10 *
11 * This software and the related documents are provided as is, with no express
12 * or implied warranties, other than those that are expressly stated in the
13 * License.
14 *******************************************************************************/
15 
16 /*
17 //++
18 // Implementation of the interface for the forward split layer in the batch
19 // processing mode
20 //--
21 */
22 
23 #ifndef __SPLIT_LAYER_FORWARD_H__
24 #define __SPLIT_LAYER_FORWARD_H__
25 
26 #include "algorithms/algorithm.h"
27 #include "data_management/data/tensor.h"
28 #include "services/daal_defines.h"
29 #include "algorithms/neural_networks/layers/layer.h"
30 #include "algorithms/neural_networks/layers/split/split_layer_types.h"
31 #include "algorithms/neural_networks/layers/split/split_layer_forward_types.h"
32 
33 namespace daal
34 {
35 namespace algorithms
36 {
37 namespace neural_networks
38 {
39 namespace layers
40 {
44 namespace split
45 {
49 namespace forward
50 {
51 namespace interface1
52 {
68 template<typename algorithmFPType, Method method, CpuType cpu>
69 class DAAL_EXPORT BatchContainer : public layers::forward::LayerContainerIfaceImpl
70 {
71 public:
77  BatchContainer(daal::services::Environment::env *daalEnv);
79  ~BatchContainer();
85  services::Status compute() DAAL_C11_OVERRIDE;
86 };
87 
105 template<typename algorithmFPType = DAAL_ALGORITHM_FP_TYPE, Method method = defaultDense>
106 class Batch : public layers::forward::LayerIfaceImpl
107 {
108 public:
109  typedef layers::forward::LayerIfaceImpl super;
110 
111  typedef algorithms::neural_networks::layers::split::forward::Input InputType;
112  typedef algorithms::neural_networks::layers::split::Parameter ParameterType;
113  typedef algorithms::neural_networks::layers::split::forward::Result ResultType;
114 
115  ParameterType &parameter;
116  InputType input;
119  Batch() : parameter(_defaultParameter)
120  {
121  initialize();
122  };
123 
129  Batch(ParameterType& parameter) : parameter(parameter), _defaultParameter(parameter)
130  {
131  initialize();
132  }
133 
139  Batch(const Batch<algorithmFPType, method> &other) : super(other),
140  _defaultParameter(other.parameter), parameter(_defaultParameter), input(other.input)
141  {
142  initialize();
143  }
144 
149  virtual int getMethod() const DAAL_C11_OVERRIDE { return(int) method; }
150 
155  virtual InputType *getLayerInput() DAAL_C11_OVERRIDE { return &input; }
156 
161  virtual ParameterType *getLayerParameter() DAAL_C11_OVERRIDE { return &parameter; };
162 
167  layers::forward::ResultPtr getLayerResult() DAAL_C11_OVERRIDE
168  {
169  return getResult();
170  }
171 
176  ResultPtr getResult()
177  {
178  return _result;
179  }
180 
187  services::Status setResult(const ResultPtr& result)
188  {
189  DAAL_CHECK(result, services::ErrorNullResult)
190  _result = result;
191  _res = _result.get();
192  return services::Status();
193  }
194 
200  services::SharedPtr<Batch<algorithmFPType, method> > clone() const
201  {
202  return services::SharedPtr<Batch<algorithmFPType, method> >(cloneImpl());
203  }
204 
210  virtual services::Status allocateResult() DAAL_C11_OVERRIDE
211  {
212  services::Status s = this->_result->template allocate<algorithmFPType>(&(this->input), &parameter, (int) method);
213  this->_res = this->_result.get();
214  return s;
215  }
216 
217 protected:
218  virtual Batch<algorithmFPType, method> *cloneImpl() const DAAL_C11_OVERRIDE
219  {
220  return new Batch<algorithmFPType, method>(*this);
221  }
222 
223  void initialize()
224  {
225  Analysis<batch>::_ac = new __DAAL_ALGORITHM_LAYER_CONTAINER(BatchContainer, algorithmFPType, method)(&_env);
226  _in = &input;
227  _par = &parameter;
228  _result.reset(new ResultType());
229  }
230 
231 private:
232  ResultPtr _result;
233  ParameterType _defaultParameter;
234 };
236 } // namespace interface1
237 using interface1::BatchContainer;
238 using interface1::Batch;
239 } // namespace forward
240 } // namespace split
241 } // namespace layers
242 } // namespace neural_networks
243 } // namespace algorithms
244 } // namespace daal
245 #endif
daal
Definition: algorithm_base_common.h:31
daal::algorithms::neural_networks::layers::split::forward::interface1::BatchContainer
Provides methods to run implementations of the of the forward split layer This class is associated wi...
Definition: split_layer_forward.h:69
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::getLayerInput
virtual InputType * getLayerInput() DAAL_C11_OVERRIDE
Definition: split_layer_forward.h:155
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::parameter
ParameterType & parameter
Definition: split_layer_forward.h:115
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::allocateResult
virtual services::Status allocateResult() DAAL_C11_OVERRIDE
Definition: split_layer_forward.h:210
daal_defines.h
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::input
InputType input
Definition: split_layer_forward.h:116
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::Batch
Batch(ParameterType &parameter)
Definition: split_layer_forward.h:129
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::getLayerResult
layers::forward::ResultPtr getLayerResult() DAAL_C11_OVERRIDE
Definition: split_layer_forward.h:167
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::clone
services::SharedPtr< Batch< algorithmFPType, method > > clone() const
Definition: split_layer_forward.h:200
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::setResult
services::Status setResult(const ResultPtr &result)
Definition: split_layer_forward.h:187
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::Batch
Batch(const Batch< algorithmFPType, method > &other)
Definition: split_layer_forward.h:139
daal::algorithms::Analysis
Provides methods for execution of operations over data, such as computation of Summary Statistics est...
Definition: analysis.h:68
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch
Computes the results of the forward split layer in the batch processing mode.
Definition: split_layer_forward.h:106
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::Batch
Batch()
Default constructor.
Definition: split_layer_forward.h:119
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::getResult
ResultPtr getResult()
Definition: split_layer_forward.h:176
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::getLayerParameter
virtual ParameterType * getLayerParameter() DAAL_C11_OVERRIDE
Definition: split_layer_forward.h:161
daal::algorithms::neural_networks::layers::split::forward::interface1::Batch::getMethod
virtual int getMethod() const DAAL_C11_OVERRIDE
Definition: split_layer_forward.h:149
daal::services::ErrorNullResult
Definition: error_indexes.h:96

For more complete information about compiler optimizations, see our Optimization Notice.