ArmNN
 20.08
CommonTestUtils.hpp
Go to the documentation of this file.
1 //
2 // Copyright © 2017 Arm Ltd. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #pragma once
7 
8 #include <Graph.hpp>
9 #include <SubgraphView.hpp>
10 #include <SubgraphViewSelector.hpp>
11 #include <ResolveType.hpp>
12 
14 
15 #include <armnn/Types.hpp>
17 
18 #include <test/TestUtils.hpp>
19 
20 #include <algorithm>
21 
22 // Checks that two collections have the exact same contents (in any order)
23 // The given collections do not have to contain duplicates
24 // Cannot use std::sort here because std lists have their own std::list::sort method
25 template <typename CollectionType>
26 bool AreEqual(const CollectionType& lhs, const CollectionType& rhs)
27 {
28  if (lhs.size() != rhs.size())
29  {
30  return false;
31  }
32 
33  auto lhs_it = std::find_if(lhs.begin(), lhs.end(), [&rhs](auto& item)
34  {
35  return std::find(rhs.begin(), rhs.end(), item) == rhs.end();
36  });
37 
38  return lhs_it == lhs.end();
39 }
40 
41 // Checks that the given collection contains the specified item
42 template <typename CollectionType>
43 bool Contains(const CollectionType& collection, const typename CollectionType::value_type& item)
44 {
45  return std::find(collection.begin(), collection.end(), item) != collection.end();
46 }
47 
48 // Checks that the given map contains the specified key
49 template <typename MapType>
50 bool Contains(const MapType& map, const typename MapType::key_type& key)
51 {
52  return map.find(key) != map.end();
53 }
54 
55 // Utility template for comparing tensor elements
56 template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
57 bool Compare(T a, T b, float tolerance = 0.000001f)
58 {
59  if (ArmnnType == armnn::DataType::Boolean)
60  {
61  // NOTE: Boolean is represented as uint8_t (with zero equals
62  // false and everything else equals true), therefore values
63  // need to be casted to bool before comparing them
64  return static_cast<bool>(a) == static_cast<bool>(b);
65  }
66 
67  // NOTE: All other types can be cast to float and compared with
68  // a certain level of tolerance
69  return std::fabs(static_cast<float>(a) - static_cast<float>(b)) <= tolerance;
70 }
71 
72 template <typename ConvolutionLayer>
73 void SetWeightAndBias(ConvolutionLayer* layer, const armnn::TensorInfo& weightInfo, const armnn::TensorInfo& biasInfo)
74 {
75  layer->m_Weight = std::make_unique<armnn::ScopedCpuTensorHandle>(weightInfo);
76  layer->m_Bias = std::make_unique<armnn::ScopedCpuTensorHandle>(biasInfo);
77 
78  layer->m_Weight->Allocate();
79  layer->m_Bias->Allocate();
80 }
81 
82 armnn::SubgraphView::InputSlots CreateInputsFrom(const std::vector<armnn::Layer*>& layers);
83 
84 armnn::SubgraphView::OutputSlots CreateOutputsFrom(const std::vector<armnn::Layer*>& layers);
85 
89 
91 
92 armnn::TensorShape MakeTensorShape(unsigned int batches,
93  unsigned int channels,
94  unsigned int height,
95  unsigned int width,
96  armnn::DataLayout layout);
DataLayout
Definition: Types.hpp:49
armnn::SubgraphView::InputSlots CreateInputsFrom(const std::vector< armnn::Layer *> &layers)
armnn::SubgraphView::SubgraphViewPtr CreateSubgraphViewFrom(armnn::SubgraphView::InputSlots &&inputs, armnn::SubgraphView::OutputSlots &&outputs, armnn::SubgraphView::Layers &&layers)
armnn::IBackendInternalUniquePtr CreateBackendObject(const armnn::BackendId &backendId)
bool AreEqual(const CollectionType &lhs, const CollectionType &rhs)
armnn::TensorShape MakeTensorShape(unsigned int batches, unsigned int channels, unsigned int height, unsigned int width, armnn::DataLayout layout)
std::vector< OutputSlot * > OutputSlots
armnn::SubgraphView::OutputSlots CreateOutputsFrom(const std::vector< armnn::Layer *> &layers)
std::unique_ptr< SubgraphView > SubgraphViewPtr
bool Contains(const CollectionType &collection, const typename CollectionType::value_type &item)
std::vector< InputSlot * > InputSlots
void SetWeightAndBias(ConvolutionLayer *layer, const armnn::TensorInfo &weightInfo, const armnn::TensorInfo &biasInfo)
std::unique_ptr< IBackendInternal > IBackendInternalUniquePtr
std::list< Layer * > Layers
bool Compare(T a, T b, float tolerance=0.000001f)