blob: e96edc831760fbda579b73decbdc0ed6f7244427 [file] [log] [blame]
narpra01b9546cf2018-11-20 15:21:28 +00001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
Matteo Martincighf02e6cd2019-05-17 12:15:30 +01005
narpra01b9546cf2018-11-20 15:21:28 +00006#pragma once
7
8#include <Graph.hpp>
Matteo Martincighf02e6cd2019-05-17 12:15:30 +01009#include <SubgraphView.hpp>
10#include <SubgraphViewSelector.hpp>
narpra01b9546cf2018-11-20 15:21:28 +000011
Matteo Martincighc601aa62019-10-29 15:03:22 +000012#include <armnn/BackendRegistry.hpp>
13
Matteo Martincighf02e6cd2019-05-17 12:15:30 +010014#include <backendsCommon/CpuTensorHandle.hpp>
narpra01b9546cf2018-11-20 15:21:28 +000015
Matteo Martincighbf0e7222019-06-20 17:17:45 +010016#include <test/TestUtils.hpp>
Matteo Martincighf02e6cd2019-05-17 12:15:30 +010017
Matteo Martincighbf0e7222019-06-20 17:17:45 +010018#include <algorithm>
Matteo Martincighf02e6cd2019-05-17 12:15:30 +010019
20// Checks that two collections have the exact same contents (in any order)
21// The given collections do not have to contain duplicates
22// Cannot use std::sort here because std lists have their own std::list::sort method
23template <typename CollectionType>
24bool AreEqual(const CollectionType& lhs, const CollectionType& rhs)
narpra01b9546cf2018-11-20 15:21:28 +000025{
Matteo Martincighf02e6cd2019-05-17 12:15:30 +010026 if (lhs.size() != rhs.size())
27 {
28 return false;
29 }
narpra01b9546cf2018-11-20 15:21:28 +000030
Matteo Martincighf02e6cd2019-05-17 12:15:30 +010031 auto lhs_it = std::find_if(lhs.begin(), lhs.end(), [&rhs](auto& item)
32 {
33 return std::find(rhs.begin(), rhs.end(), item) == rhs.end();
34 });
35
36 return lhs_it == lhs.end();
narpra01b9546cf2018-11-20 15:21:28 +000037}
38
Matteo Martincighf02e6cd2019-05-17 12:15:30 +010039// Checks that the given collection contains the specified item
40template <typename CollectionType>
41bool Contains(const CollectionType& collection, const typename CollectionType::value_type& item)
42{
43 return std::find(collection.begin(), collection.end(), item) != collection.end();
narpra01b9546cf2018-11-20 15:21:28 +000044}
Matteo Martincighf02e6cd2019-05-17 12:15:30 +010045
46// Checks that the given map contains the specified key
47template <typename MapType>
48bool Contains(const MapType& map, const typename MapType::key_type& key)
49{
50 return map.find(key) != map.end();
51}
52
53template <typename ConvolutionLayer>
54void SetWeightAndBias(ConvolutionLayer* layer, const armnn::TensorInfo& weightInfo, const armnn::TensorInfo& biasInfo)
55{
56 layer->m_Weight = std::make_unique<armnn::ScopedCpuTensorHandle>(weightInfo);
57 layer->m_Bias = std::make_unique<armnn::ScopedCpuTensorHandle>(biasInfo);
58
59 layer->m_Weight->Allocate();
60 layer->m_Bias->Allocate();
61}
62
63armnn::SubgraphView::InputSlots CreateInputsFrom(const std::vector<armnn::Layer*>& layers);
64
65armnn::SubgraphView::OutputSlots CreateOutputsFrom(const std::vector<armnn::Layer*>& layers);
66
67armnn::SubgraphView::SubgraphViewPtr CreateSubgraphViewFrom(armnn::SubgraphView::InputSlots&& inputs,
68 armnn::SubgraphView::OutputSlots&& outputs,
69 armnn::SubgraphView::Layers&& layers);
70
71armnn::IBackendInternalUniquePtr CreateBackendObject(const armnn::BackendId& backendId);
Aron Virginas-Tar735a4502019-06-26 15:02:47 +010072
73armnn::TensorShape MakeTensorShape(unsigned int batches,
74 unsigned int channels,
75 unsigned int height,
76 unsigned int width,
Matteo Martincighc601aa62019-10-29 15:03:22 +000077 armnn::DataLayout layout);