1*89c4ff92SAndroid Build Coastguard Worker // 2*89c4ff92SAndroid Build Coastguard Worker // Copyright © 2017 Arm Ltd and Contributors. All rights reserved. 3*89c4ff92SAndroid Build Coastguard Worker // SPDX-License-Identifier: MIT 4*89c4ff92SAndroid Build Coastguard Worker // 5*89c4ff92SAndroid Build Coastguard Worker #pragma once 6*89c4ff92SAndroid Build Coastguard Worker 7*89c4ff92SAndroid Build Coastguard Worker #include "LayerWithParameters.hpp" 8*89c4ff92SAndroid Build Coastguard Worker 9*89c4ff92SAndroid Build Coastguard Worker namespace armnn 10*89c4ff92SAndroid Build Coastguard Worker { 11*89c4ff92SAndroid Build Coastguard Worker 12*89c4ff92SAndroid Build Coastguard Worker /// This layer represents a split operation. 13*89c4ff92SAndroid Build Coastguard Worker class SplitterLayer : public LayerWithParameters<ViewsDescriptor> 14*89c4ff92SAndroid Build Coastguard Worker { 15*89c4ff92SAndroid Build Coastguard Worker public: 16*89c4ff92SAndroid Build Coastguard Worker /// Makes a workload for the Splitter type. 17*89c4ff92SAndroid Build Coastguard Worker /// @param [in] graph The graph where this layer can be found. 18*89c4ff92SAndroid Build Coastguard Worker /// @param [in] factory The workload factory which will create the workload. 19*89c4ff92SAndroid Build Coastguard Worker /// @return A pointer to the created workload, or nullptr if not created. 20*89c4ff92SAndroid Build Coastguard Worker virtual std::unique_ptr<IWorkload> CreateWorkload(const IWorkloadFactory& factory) const override; 21*89c4ff92SAndroid Build Coastguard Worker 22*89c4ff92SAndroid Build Coastguard Worker /// Set the outputs to be appropriate sub tensors of the input if sub tensors are supported 23*89c4ff92SAndroid Build Coastguard Worker /// otherwise creates tensor handlers. 24*89c4ff92SAndroid Build Coastguard Worker /// @param [in] registry Contains all the registered tensor handle factories available for use. 25*89c4ff92SAndroid Build Coastguard Worker /// @param [in] factory The workload factory which will create the workload. 26*89c4ff92SAndroid Build Coastguard Worker /// @param [in] IsMemoryManaged Determine whether or not to assign a memory manager during creation 27*89c4ff92SAndroid Build Coastguard Worker virtual void CreateTensorHandles(const TensorHandleFactoryRegistry& registry, 28*89c4ff92SAndroid Build Coastguard Worker const IWorkloadFactory& factory, 29*89c4ff92SAndroid Build Coastguard Worker const bool IsMemoryManaged = true) override; 30*89c4ff92SAndroid Build Coastguard Worker 31*89c4ff92SAndroid Build Coastguard Worker /// Creates a dynamically-allocated copy of this layer. 32*89c4ff92SAndroid Build Coastguard Worker /// @param [in] graph The graph into which this layer is being cloned. 33*89c4ff92SAndroid Build Coastguard Worker SplitterLayer* Clone(Graph& graph) const override; 34*89c4ff92SAndroid Build Coastguard Worker 35*89c4ff92SAndroid Build Coastguard Worker /// Check if the input tensor shape(s) 36*89c4ff92SAndroid Build Coastguard Worker /// will lead to a valid configuration of @ref SplitterLayer. 37*89c4ff92SAndroid Build Coastguard Worker /// @param [in] shapeInferenceMethod Indicates if output shape shall be overwritten or just validated. 38*89c4ff92SAndroid Build Coastguard Worker void ValidateTensorShapesFromInputs() override; 39*89c4ff92SAndroid Build Coastguard Worker 40*89c4ff92SAndroid Build Coastguard Worker /// By default returns inputShapes if the number of inputs are equal to number of outputs, 41*89c4ff92SAndroid Build Coastguard Worker /// otherwise infers the output shapes from given input shapes and layer properties. 42*89c4ff92SAndroid Build Coastguard Worker /// @param [in] inputShapes The input shapes layer has. 43*89c4ff92SAndroid Build Coastguard Worker /// @return A vector to the inferred output shape. 44*89c4ff92SAndroid Build Coastguard Worker std::vector<TensorShape> InferOutputShapes(const std::vector<TensorShape>& inputShapes) const override; 45*89c4ff92SAndroid Build Coastguard Worker 46*89c4ff92SAndroid Build Coastguard Worker void ExecuteStrategy(IStrategy& strategy) const override; 47*89c4ff92SAndroid Build Coastguard Worker 48*89c4ff92SAndroid Build Coastguard Worker 49*89c4ff92SAndroid Build Coastguard Worker protected: 50*89c4ff92SAndroid Build Coastguard Worker /// Constructor to create a SplitterLayer. 51*89c4ff92SAndroid Build Coastguard Worker /// @param [in] param ViewsDescriptor to configure the splitter operation. 52*89c4ff92SAndroid Build Coastguard Worker /// @param [in] name Optional name for the layer. 53*89c4ff92SAndroid Build Coastguard Worker SplitterLayer(const ViewsDescriptor& param, const char* name); 54*89c4ff92SAndroid Build Coastguard Worker 55*89c4ff92SAndroid Build Coastguard Worker /// Default destructor 56*89c4ff92SAndroid Build Coastguard Worker ~SplitterLayer() = default; 57*89c4ff92SAndroid Build Coastguard Worker 58*89c4ff92SAndroid Build Coastguard Worker private: 59*89c4ff92SAndroid Build Coastguard Worker template <typename FactoryType> 60*89c4ff92SAndroid Build Coastguard Worker void CreateTensors(const TensorHandleFactoryRegistry& registry, const FactoryType& factory, bool isMemoryManaged); 61*89c4ff92SAndroid Build Coastguard Worker }; 62*89c4ff92SAndroid Build Coastguard Worker 63*89c4ff92SAndroid Build Coastguard Worker } // namespace 64