Publishing 2019 R1 content
[platform/upstream/dldt.git] / inference-engine / src / mkldnn_plugin / nodes / mkldnn_concat_node.h
1 // Copyright (C) 2018-2019 Intel Corporation
2 // SPDX-License-Identifier: Apache-2.0
3 //
4
5 #pragma once
6
7 #include <ie_common.h>
8 #include <mkldnn_node.h>
9 #include <string>
10
11 namespace MKLDNNPlugin {
12
13 class MKLDNNConcatNode : public MKLDNNNode {
14 public:
15     MKLDNNConcatNode(const InferenceEngine::CNNLayerPtr& layer, const mkldnn::engine& eng);
16     ~MKLDNNConcatNode() override = default;
17
18     void getSupportedDescriptors() override;
19     void initSupportedPrimitiveDescriptors() override;
20     void initOptimalPrimitiveDescriptor() override;
21     void createPrimitive() override;
22     void selectOptimalPrimitiveDescriptor() override;
23     bool created() const override;
24     void execute(mkldnn::stream strm) override;
25
26     bool isOptimized() const;
27
28 private:
29     static Register<MKLDNNConcatNode> reg;
30     size_t axis = 0;
31
32     size_t inverseOrder(const InferenceEngine::SizeVector& order, size_t axis);
33 };
34
35 }  // namespace MKLDNNPlugin
36