1 // Copyright (C) 2018-2019 Intel Corporation
2 // SPDX-License-Identifier: Apache-2.0
8 #include <mkldnn_node.h>
13 namespace MKLDNNPlugin {
15 class MKLDNNFullyConnectedNode : public MKLDNNNode {
17 MKLDNNFullyConnectedNode(const InferenceEngine::CNNLayerPtr& layer, const mkldnn::engine& eng);
18 ~MKLDNNFullyConnectedNode() override = default;
20 void getSupportedDescriptors() override;
21 void createPrimitive() override;
22 bool created() const override;
23 bool canBeInPlace() const override {
27 const std::vector<impl_desc_type>& getPrimitivesPriority() override;
28 void createDescriptor(const std::vector<InferenceEngine::TensorDesc>& inputDesc,
29 const std::vector<InferenceEngine::TensorDesc>& outputDesc) override;
32 std::shared_ptr<mkldnn::primitive_attr> initPrimitiveAttr() const override;
35 static Register<MKLDNNFullyConnectedNode> reg;
36 InferenceEngine::SizeVector weightsDims;
37 InferenceEngine::SizeVector biasesDims;
38 mkldnn::memory::format weightsFormatForSrcFormat(mkldnn::memory::format sourceFormat);
40 InferenceEngine::Blob::Ptr wScale, oScale;
43 } // namespace MKLDNNPlugin