ArmNN
 22.08
ConvertConstDequantisationLayersToConstLayersTest.cpp File Reference
#include "LayersFwd.hpp"
#include <Network.hpp>
#include <TestUtils.hpp>
#include <doctest/doctest.h>
#include <armnn/backends/TensorHandle.hpp>
#include <Optimizer.hpp>

Go to the source code of this file.

Functions

 TEST_SUITE ("Optimizer")
 

Function Documentation

◆ TEST_SUITE()

TEST_SUITE ( "Optimizer"  )

Definition at line 13 of file ConvertConstDequantisationLayersToConstLayersTest.cpp.

References Graph::AddLayer(), Graph::cbegin(), Graph::cend(), CheckSequence(), OutputSlot::Connect(), armnn::Float16, armnn::Float32, Layer::GetInputSlot(), TensorInfo::GetNumElements(), Layer::GetOutputSlot(), ConstantLayer::m_LayerOutput, armnn::MakeOptimizations(), Optimizer::Pass(), armnn::QAsymmS8, and OutputSlot::SetTensorInfo().

14 {
15 using namespace armnn;
16 using namespace armnn::optimizations;
17 
18 TEST_CASE("ConvertConstFloat16DequantizeToConstFloat32")
19 {
20  Graph graph;
21  const unsigned int shape[] = {1, 2, 2, 3};
22 
23  const TensorInfo constTensorInfo(4, shape, DataType::Float16, 1.0, 0, true);
24  const TensorInfo outputDequantizeInfo(4, shape, DataType::Float32, 1.0, 0, true);
25 
26  ConstantLayer *constantLayer = graph.AddLayer<ConstantLayer>("constant");
27  std::vector<float> constantValues(constTensorInfo.GetNumElements(), 4.5f);
28  ConstTensor constTensor(constTensorInfo, constantValues.data());
29  constantLayer->m_LayerOutput = std::make_shared<ScopedTensorHandle>(constTensor);
30  constantLayer->GetOutputSlot().SetTensorInfo(constTensorInfo);
31 
32  DequantizeLayer *dequantizeLayer = graph.AddLayer<DequantizeLayer>("dequantize");
33  dequantizeLayer->GetOutputSlot().SetTensorInfo(outputDequantizeInfo);
34 
35  OutputLayer *output = graph.AddLayer<OutputLayer>(0, "output");
36 
37  // Connect up constant -> dequantize -> output
38  constantLayer->GetOutputSlot().Connect(dequantizeLayer->GetInputSlot(0));
39  dequantizeLayer->GetOutputSlot().Connect(output->GetInputSlot(0));
40 
41  auto checkConstantFloat16 = [](const armnn::Layer *const layer) -> bool {
42  return IsLayerOfType<ConstantLayer>(layer) &&
43  (layer->GetDataType() == DataType::Float16);
44  };
45  auto checkConstantFloat32 = [](const armnn::Layer *const layer) -> bool {
46  return IsLayerOfType<ConstantLayer>(layer) &&
47  (layer->GetDataType() == DataType::Float32);
48  };
49 
50  CHECK(CheckSequence(graph.cbegin(), graph.cend(),
51  checkConstantFloat16,
52  &IsLayerOfType<DequantizeLayer>,
53  &IsLayerOfType<OutputLayer>));
54 
56 
57  CHECK(CheckSequence(graph.cbegin(), graph.cend(),
58  checkConstantFloat32,
59  &IsLayerOfType<OutputLayer>));
60 }
61 
62 TEST_CASE("ConvertConstInt8DequantizeToConstFloat32")
63 {
64  Graph graph;
65  const unsigned int shape[] = {1, 2, 2, 3};
66 
67  const TensorInfo constTensorInfo(4, shape, DataType::QAsymmS8, 1.0, 0, true);
68  const TensorInfo outputDequantizeInfo(4, shape, DataType::Float32, 1.0, 0, true);
69 
70  ConstantLayer *constantLayer = graph.AddLayer<ConstantLayer>("constant");
71  std::vector<int8_t> constantValues(constTensorInfo.GetNumElements(), 5);
72  ConstTensor constTensor(constTensorInfo, constantValues.data());
73  constantLayer->m_LayerOutput = std::make_shared<ScopedTensorHandle>(constTensor);
74  constantLayer->GetOutputSlot().SetTensorInfo(constTensorInfo);
75 
76  DequantizeLayer *dequantizeLayer = graph.AddLayer<DequantizeLayer>("dequantize");
77  dequantizeLayer->GetOutputSlot().SetTensorInfo(outputDequantizeInfo);
78 
79  OutputLayer *output = graph.AddLayer<OutputLayer>(0, "output");
80 
81  // Connect up constant -> dequantize -> output
82  constantLayer->GetOutputSlot().Connect(dequantizeLayer->GetInputSlot(0));
83  dequantizeLayer->GetOutputSlot().Connect(output->GetInputSlot(0));
84 
85  auto checkConstantQAsymmS8 = [](const armnn::Layer *const layer) -> bool {
86  return IsLayerOfType<ConstantLayer>(layer) &&
87  (layer->GetDataType() == DataType::QAsymmS8);
88  };
89  auto checkConstantFloat32 = [](const armnn::Layer *const layer) -> bool {
90  return IsLayerOfType<ConstantLayer>(layer) &&
91  (layer->GetDataType() == DataType::Float32);
92  };
93 
94  CHECK(CheckSequence(graph.cbegin(), graph.cend(),
95  checkConstantQAsymmS8,
96  &IsLayerOfType<DequantizeLayer>,
97  &IsLayerOfType<OutputLayer>));
98 
100 
101  CHECK(CheckSequence(graph.cbegin(), graph.cend(),
102  checkConstantFloat32,
103  &IsLayerOfType<OutputLayer>));
104 }
105 }
A layer that the constant data can be bound to.
Optimizer::Optimizations MakeOptimizations(Args &&... args)
Definition: Optimizer.hpp:43
bool CheckSequence(const armnn::Graph::ConstIterator first, const armnn::Graph::ConstIterator last)
Definition: TestUtils.hpp:21
std::shared_ptr< ConstTensorHandle > m_LayerOutput
LayerT * AddLayer(Args &&... args)
Adds a new layer, of type LayerType, to the graph constructed with the arguments passed.
Definition: Graph.hpp:456
ConstIterator cbegin() const
Returns const iterator pointing to the beginning of the list. Lowercase for range-based for loops...
Definition: Graph.hpp:179
int Connect(InputSlot &destination)
Definition: Layer.cpp:112
static void Pass(Graph &graph, const Optimizations &optimizations)
Definition: Optimizer.cpp:16
Copyright (c) 2021 ARM Limited and Contributors.
const InputSlot & GetInputSlot(unsigned int index) const override
Get a const input slot handle by slot index.
Definition: Layer.hpp:324
A layer user-provided data can be bound to (e.g. inputs, outputs).
Definition: OutputLayer.hpp:13
This layer dequantizes the input tensor.
A tensor defined by a TensorInfo (shape and data type) and an immutable backing store.
Definition: Tensor.hpp:327
void SetTensorInfo(const TensorInfo &tensorInfo) override
Definition: Layer.cpp:87
const OutputSlot & GetOutputSlot(unsigned int index=0) const override
Get the const output slot handle by slot index.
Definition: Layer.hpp:326
ConstIterator cend() const
Returns const iterator pointing to the end of the list. Lowercase for range-based for loops...
Definition: Graph.hpp:181
OptimizeForConnection< ConstantLayer, DequantizeLayer, ConvertConstDequantisationLayersToConstLayersImpl > ConvertConstDequantisationLayersToConstLayers