1 // 2 // Copyright © 2023 Arm Ltd and Contributors. All rights reserved. 3 // SPDX-License-Identifier: MIT 4 // 5 6 #pragma once 7 8 #include "LayerWithParameters.hpp" 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 49