1 // Copyright (C) 2018-2019 Intel Corporation
2 // SPDX-License-Identifier: Apache-2.0
8 #include <mkldnn_node.h>
13 namespace MKLDNNPlugin {
15 class MKLDNNConvolutionNode : public MKLDNNNode {
17 MKLDNNConvolutionNode(const InferenceEngine::CNNLayerPtr& layer, const mkldnn::engine& eng);
18 ~MKLDNNConvolutionNode() override = default;
20 void getSupportedDescriptors() override;
21 void createDescriptor(const std::vector<InferenceEngine::TensorDesc>& inputDesc,
22 const std::vector<InferenceEngine::TensorDesc>& outputDesc) override;
23 void initDescriptor(const InferenceEngine::LayerConfig& config) override;
24 void createPrimitive() override;
25 void initSupportedPrimitiveDescriptors() override;
26 bool created() const override;
27 bool canBeInPlace() const override {
30 void setPostOps(mkldnn::primitive_attr &attr, bool initWeights);
33 void addScaleToPrimitiveAttr(mkldnn::primitive_attr attr) const;
36 static Register<MKLDNNConvolutionNode> reg;
43 std::vector<ptrdiff_t> stride;
44 std::vector<ptrdiff_t> dilation;
45 std::vector<ptrdiff_t> paddingL;
46 std::vector<ptrdiff_t> paddingR;
47 InferenceEngine::SizeVector weightDims;
48 InferenceEngine::SizeVector biasesDims;
53 std::vector<ptrdiff_t> dw_conv_kernel;
54 std::vector<ptrdiff_t> dw_conv_strides;
55 std::vector<MKLDNNMemoryPtr> PostOpsIntBlobMemory;
57 InferenceEngine::ConvolutionLayer* convLayer;
58 InferenceEngine::Blob::Ptr wScale, oScale;
61 } // namespace MKLDNNPlugin