From 161d29ca4091bb1ff79736a416978b49989fc622 Mon Sep 17 00:00:00 2001 From: Derek Lamberti Date: Mon, 7 Dec 2020 13:54:12 +0000 Subject: Sort subgraphview layers on construction Make it easier for backends to traverse the subgraph during optimization Change-Id: I140cb11f78bab5f19c801a5b55efffb38c63837f Signed-off-by: Derek Lamberti --- src/armnn/SubgraphView.cpp | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'src/armnn/SubgraphView.cpp') diff --git a/src/armnn/SubgraphView.cpp b/src/armnn/SubgraphView.cpp index 92ba5dfe1f..0d41889e15 100644 --- a/src/armnn/SubgraphView.cpp +++ b/src/armnn/SubgraphView.cpp @@ -45,6 +45,7 @@ SubgraphView::SubgraphView(Graph& graph) , m_OutputSlots{} , m_Layers(graph.begin(), graph.end()) { + ArrangeBySortOrder(); CheckSubgraph(); } @@ -53,6 +54,7 @@ SubgraphView::SubgraphView(InputSlots&& inputs, OutputSlots&& outputs, Layers&& , m_OutputSlots{outputs} , m_Layers{layers} { + ArrangeBySortOrder(); CheckSubgraph(); } @@ -61,6 +63,7 @@ SubgraphView::SubgraphView(const SubgraphView& subgraph) , m_OutputSlots(subgraph.m_OutputSlots.begin(), subgraph.m_OutputSlots.end()) , m_Layers(subgraph.m_Layers.begin(), subgraph.m_Layers.end()) { + ArrangeBySortOrder(); CheckSubgraph(); } @@ -69,6 +72,7 @@ SubgraphView::SubgraphView(SubgraphView&& subgraph) , m_OutputSlots(std::move(subgraph.m_OutputSlots)) , m_Layers(std::move(subgraph.m_Layers)) { + ArrangeBySortOrder(); CheckSubgraph(); } @@ -199,4 +203,15 @@ void SubgraphView::Clear() m_Layers.clear(); } +void SubgraphView::ArrangeBySortOrder() +{ + using LayerList = std::list; + auto compareLayerPriority = [](const LayerList::value_type& layerA, const LayerList::value_type& layerB) + { + return layerA->GetPriority() < layerB->GetPriority(); + }; + + m_Layers.sort(compareLayerPriority); +} + } // namespace armnn -- cgit v1.2.1