ArmNN
 24.02
ElementwiseBinaryLayer.hpp
Go to the documentation of this file.
1 //
2 // Copyright © 2023 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #pragma once
7 
9 
10 namespace armnn
11 {
12 
13 /// This layer represents a elementwiseBinary operation.
14 class ElementwiseBinaryLayer : public LayerWithParameters<ElementwiseBinaryDescriptor>
15 {
16 public:
17  /// Makes a workload for the elementwiseBinary type
18  /// @param [in] graph The graph where this layer can be found
19  /// @param [in] factory The workload factory which will create the workload
20  /// @return A pointer to the created workload, or nullptr if not created
21  virtual std::unique_ptr<IWorkload> CreateWorkload(const IWorkloadFactory& factory) const override;
22 
23  /// Creates a dynamically-allocated copy of this layer
24  /// @param [in] graph The graph into which this layer is being cloned
25  ElementwiseBinaryLayer* Clone(Graph& graph) const override;
26 
27  /// Returns inputShapes by default.
28  /// @param [in] inputShapes The input shapes layer has.
29  /// @return A vector to the inferred output shape.
30  std::vector<TensorShape> InferOutputShapes(const std::vector<TensorShape>& inputShapes) const override;
31 
32  /// Check if the input tensor shape(s) will lead to a valid configuration
33  /// of @ref ElementwiseBinaryLayer
34  void ValidateTensorShapesFromInputs() override;
35 
36  void ExecuteStrategy(IStrategy& strategy) const override;
37 
38 protected:
39  /// Constructor to create a ElementwiseBinaryLayer
40  /// @param [in] param ElementwiseBinaryDescriptor to configure the ElementwiseBinaryLayer
41  /// @param [in] name Optional name for the layer
42  ElementwiseBinaryLayer(const ElementwiseBinaryDescriptor& param, const char* name);
43 
44  /// Default destructor
45  ~ElementwiseBinaryLayer() = default;
46 };
47 
48 } // namespace armnn
armnn::ElementwiseBinaryLayer::InferOutputShapes
std::vector< TensorShape > InferOutputShapes(const std::vector< TensorShape > &inputShapes) const override
Returns inputShapes by default.
Definition: ElementwiseBinaryLayer.cpp:31
armnn::IStrategy
Definition: IStrategy.hpp:16
armnn::LayerWithParameters
Definition: LayerWithParameters.hpp:14
armnn::ElementwiseBinaryDescriptor
A ElementwiseBinaryDescriptor for the ElementwiseBinaryLayer.
Definition: Descriptors.hpp:109
armnn::ElementwiseBinaryLayer::ValidateTensorShapesFromInputs
void ValidateTensorShapesFromInputs() override
Check if the input tensor shape(s) will lead to a valid configuration of ElementwiseBinaryLayer.
Definition: ElementwiseBinaryLayer.cpp:69
armnn::ElementwiseBinaryLayer::Clone
ElementwiseBinaryLayer * Clone(Graph &graph) const override
Creates a dynamically-allocated copy of this layer.
Definition: ElementwiseBinaryLayer.cpp:26
armnn::ElementwiseBinaryLayer::CreateWorkload
virtual std::unique_ptr< IWorkload > CreateWorkload(const IWorkloadFactory &factory) const override
Makes a workload for the elementwiseBinary type.
Definition: ElementwiseBinaryLayer.cpp:18
armnn::IWorkloadFactory
Definition: WorkloadFactory.hpp:22
armnn::ElementwiseBinaryLayer
This layer represents a elementwiseBinary operation.
Definition: ElementwiseBinaryLayer.hpp:14
LayerWithParameters.hpp
armnn::ElementwiseBinaryLayer::~ElementwiseBinaryLayer
~ElementwiseBinaryLayer()=default
Default destructor.
armnn::ElementwiseBinaryLayer::ExecuteStrategy
void ExecuteStrategy(IStrategy &strategy) const override
Apply a visitor to this layer.
Definition: ElementwiseBinaryLayer.cpp:85
armnn
Copyright (c) 2021 ARM Limited and Contributors.
Definition: 01_00_quick_start.dox:6
armnn::ElementwiseBinaryLayer::ElementwiseBinaryLayer
ElementwiseBinaryLayer(const ElementwiseBinaryDescriptor &param, const char *name)
Constructor to create a ElementwiseBinaryLayer.
Definition: ElementwiseBinaryLayer.cpp:13
armnn::Graph
Definition: Graph.hpp:30