xref: /aosp_15_r20/external/armnn/src/armnn/SubgraphViewSelector.hpp (revision 89c4ff92f2867872bb9e2354d150bf0c8c502810)
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