1*89c4ff92SAndroid Build Coastguard Worker // 2*89c4ff92SAndroid Build Coastguard Worker // Copyright © 2017, 2023 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 <armnn/backends/SubgraphView.hpp> 8*89c4ff92SAndroid Build Coastguard Worker #include <functional> 9*89c4ff92SAndroid Build Coastguard Worker #include <memory> 10*89c4ff92SAndroid Build Coastguard Worker 11*89c4ff92SAndroid Build Coastguard Worker namespace armnn 12*89c4ff92SAndroid Build Coastguard Worker { 13*89c4ff92SAndroid Build Coastguard Worker 14*89c4ff92SAndroid Build Coastguard Worker class Layer; 15*89c4ff92SAndroid Build Coastguard Worker class Graph; 16*89c4ff92SAndroid Build Coastguard Worker 17*89c4ff92SAndroid Build Coastguard Worker /// Algorithm that splits a Graph into Subgraphs based on a filtering of layers (e.g. which layers are appropriate for 18*89c4ff92SAndroid Build Coastguard Worker /// a certain backend). The resulting subgraphs are guaranteed to be form a DAG (i.e. there are no dependency loops). 19*89c4ff92SAndroid Build Coastguard Worker /// 20*89c4ff92SAndroid Build Coastguard Worker /// The algorithm aims to produce as few subgraphs as possible. 21*89c4ff92SAndroid Build Coastguard Worker class SubgraphViewSelector final 22*89c4ff92SAndroid Build Coastguard Worker { 23*89c4ff92SAndroid Build Coastguard Worker public: 24*89c4ff92SAndroid Build Coastguard Worker using Subgraphs = std::vector<SubgraphView::SubgraphViewPtr>; 25*89c4ff92SAndroid Build Coastguard Worker using LayerSelectorFunction = std::function<bool(const Layer&)>; 26*89c4ff92SAndroid Build Coastguard Worker 27*89c4ff92SAndroid Build Coastguard Worker /// Selects subgraphs from a graph based on the selector function and the algorithm. 28*89c4ff92SAndroid Build Coastguard Worker /// Since the Subgraphs object returns modifiable pointers to the input and output slots of the graph: 29*89c4ff92SAndroid Build Coastguard Worker /// 1) the graph/sub-graph cannot be const 30*89c4ff92SAndroid Build Coastguard Worker /// 2) the caller needs to make sure that the Subgraphs lifetime is shorter than the parent graph's 31*89c4ff92SAndroid Build Coastguard Worker static Subgraphs SelectSubgraphs(Graph& graph, const LayerSelectorFunction& selector); 32*89c4ff92SAndroid Build Coastguard Worker static Subgraphs SelectSubgraphs(SubgraphView& subgraph, const LayerSelectorFunction& selector); 33*89c4ff92SAndroid Build Coastguard Worker 34*89c4ff92SAndroid Build Coastguard Worker private: 35*89c4ff92SAndroid Build Coastguard Worker // this is a utility class, don't construct or copy 36*89c4ff92SAndroid Build Coastguard Worker SubgraphViewSelector() = delete; 37*89c4ff92SAndroid Build Coastguard Worker SubgraphViewSelector(const SubgraphViewSelector&) = delete; 38*89c4ff92SAndroid Build Coastguard Worker SubgraphViewSelector & operator=(const SubgraphViewSelector&) = delete; 39*89c4ff92SAndroid Build Coastguard Worker }; 40*89c4ff92SAndroid Build Coastguard Worker 41*89c4ff92SAndroid Build Coastguard Worker } // namespace armnn 42