ArmNN
 21.11
Convolution2dLayer.hpp
Go to the documentation of this file.
1 //
2 // Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 #pragma once
6 
8 
9 namespace armnn
10 {
11 
12 class ScopedTensorHandle;
13 
14 /// This layer represents a convolution 2d operation.
15 class Convolution2dLayer : public LayerWithParameters<Convolution2dDescriptor>
16 {
17 public:
18 
19  /// A unique pointer to store Weight values.
20  std::shared_ptr<ConstTensorHandle> m_Weight;
21  /// A unique pointer to store Bias values.
22  std::shared_ptr<ConstTensorHandle> m_Bias;
23 
24  /// Makes a workload for the Convolution2d type.
25  /// @param [in] graph The graph where this layer can be found.
26  /// @param [in] factory The workload factory which will create the workload.
27  /// @return A pointer to the created workload, or nullptr if not created.
28  virtual std::unique_ptr<IWorkload> CreateWorkload(const IWorkloadFactory& factory) const override;
29 
30  /// Creates a dynamically-allocated copy of this layer.
31  /// @param [in] graph The graph into which this layer is being cloned.
32  Convolution2dLayer* Clone(Graph& graph) const override;
33 
34  /// Check if the input tensor shape(s)
35  /// will lead to a valid configuration of @ref Convolution2dLayer.
36  /// @param [in] shapeInferenceMethod Indicates if output shape shall be overwritten or just validated.
37  void ValidateTensorShapesFromInputs() override;
38 
39  /// By default returns inputShapes if the number of inputs are equal to number of outputs,
40  /// otherwise infers the output shapes from given input shapes and layer properties.
41  /// @param [in] inputShapes The input shapes layer has.
42  /// @return A vector to the inferred output shape.
43  std::vector<TensorShape> InferOutputShapes(const std::vector<TensorShape>& inputShapes) const override;
44 
46  void Accept(ILayerVisitor& visitor) const override;
48 
49  void ExecuteStrategy(IStrategy& strategy) const override;
50 
52 
53 protected:
54  /// Constructor to create a Convolution2dLayer.
55  /// @param [in] param Convolution2dDescriptor to configure the convolution2d operation.
56  /// @param [in] name Optional name for the layer.
57  Convolution2dLayer(const Convolution2dDescriptor& param, const char* name);
58 
59  /// Default destructor
60  ~Convolution2dLayer() = default;
61 
62  /// Retrieve the handles to the constant values stored by the layer.
63  /// @return A vector of the constant tensors stored by this layer.
65 };
66 
67 } // namespace
#define ARMNN_NO_DEPRECATE_WARN_BEGIN
Definition: Deprecated.hpp:33
~Convolution2dLayer()=default
Default destructor.
A Convolution2dDescriptor for the Convolution2dLayer.
std::shared_ptr< ConstTensorHandle > m_Weight
A unique pointer to store Weight values.
Convolution2dLayer(const Convolution2dDescriptor &param, const char *name)
Constructor to create a Convolution2dLayer.
Copyright (c) 2021 ARM Limited and Contributors.
void ValidateTensorShapesFromInputs() override
Check if the input tensor shape(s) will lead to a valid configuration of Convolution2dLayer.
std::vector< std::reference_wrapper< std::shared_ptr< ConstTensorHandle > >> ConstantTensors
Definition: Layer.hpp:393
#define ARMNN_NO_DEPRECATE_WARN_END
Definition: Deprecated.hpp:34
Convolution2dLayer * Clone(Graph &graph) const override
Creates a dynamically-allocated copy of this layer.
ARMNN_NO_DEPRECATE_WARN_END void ExecuteStrategy(IStrategy &strategy) const override
Apply a visitor to this layer.
ConstantTensors GetConstantTensorsByRef() override
Retrieve the handles to the constant values stored by the layer.
std::shared_ptr< ConstTensorHandle > m_Bias
A unique pointer to store Bias values.
virtual std::unique_ptr< IWorkload > CreateWorkload(const IWorkloadFactory &factory) const override
Makes a workload for the Convolution2d type.
void SerializeLayerParameters(ParameterStringifyFunction &fn) const override
Helper to serialize the layer parameters to string.
ARMNN_NO_DEPRECATE_WARN_BEGIN void Accept(ILayerVisitor &visitor) const override
This layer represents a convolution 2d operation.
std::vector< TensorShape > InferOutputShapes(const std::vector< TensorShape > &inputShapes) const override
By default returns inputShapes if the number of inputs are equal to number of outputs, otherwise infers the output shapes from given input shapes and layer properties.
std::function< void(const std::string &name, const std::string &value)> ParameterStringifyFunction