Publishing 2019 R1 content
[platform/upstream/dldt.git] / inference-engine / src / inference_engine / shape_infer / const_infer / ie_mul_const_infer.hpp
1 // Copyright (C) 2019 Intel Corporation
2 // SPDX-License-Identifier: Apache-2.0
3 //
4
5 #pragma once
6
7 #include <ie_blob.h>
8 #include <map>
9 #include <memory>
10 #include <string>
11 #include <vector>
12 #include <ie_layers.h>
13
14 namespace InferenceEngine {
15 namespace ShapeInfer {
16
17 /**
18  *@brief Implementation of Const inference for TBD layer
19  */
20 class MulConstInfer : public ConstInferImpl {
21 public:
22     explicit MulConstInfer(const std::string& type) : ConstInferImpl(type) {}
23
24     void inferImpl(const std::vector<Blob::CPtr>& inData,
25                    const std::map<std::string, std::string>& params,
26                    const std::map<std::string, Blob::Ptr>& blobs,
27                    std::vector<Blob::Ptr>& outData) override {
28         size_t numInputs = inData.size();
29         if (inData.size() != 2)
30             THROW_IE_EXCEPTION << "Unsupported number of inputs: " << numInputs << ". 2 inputs is supported";
31         auto* firstBlobBuffer = inData[0]->cbuffer().as<float*>();
32         auto* secondBlobBuffer = inData[1]->cbuffer().as<float*>();
33
34         if (!firstBlobBuffer || !secondBlobBuffer) {
35             THROW_IE_EXCEPTION << "empty input data";
36         }
37         auto outBlob = *outData.begin();
38         auto* outBuffer = outBlob->buffer().as<float*>();
39         if (!outBuffer) THROW_IE_EXCEPTION << "empty output data";
40         if (inData[0]->size() != inData[1]->size()) {
41             THROW_IE_EXCEPTION << "inputs with different shapes are not supported";
42         }
43         for (int i = 0; i < outBlob->size(); i++) {
44             outBuffer[i] = firstBlobBuffer[i] * secondBlobBuffer[i];
45         }
46     }
47 };
48
49 }  // namespace ShapeInfer
50 }  // namespace InferenceEngine