blob: ba827b18608e939f77b1ef88df3467955bdc926e [file] [log] [blame]
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +01001//
Teresa Charlinfbf0e5b2020-08-17 01:01:06 +01002// Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +01003// SPDX-License-Identifier: MIT
4//
5
6#pragma once
7
8#include "LayerTestResult.hpp"
9
10#include <ResolveType.hpp>
11
Matteo Martincighe5b8eb92019-11-28 15:45:42 +000012#include <armnn/backends/IBackendInternal.hpp>
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010013#include <backendsCommon/WorkloadFactory.hpp>
14
15namespace
16{
17
18template<armnn::DataType ArmnnType, typename T, std::size_t InputDim, std::size_t OutputDim>
19LayerTestResult<T, OutputDim> MeanTestHelper(
20 armnn::IWorkloadFactory& workloadFactory,
21 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
Finn Williams826a5432020-08-27 16:15:20 +010022 const armnn::ITensorHandleFactory& tensorHandleFactory,
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010023 const unsigned int* inputShape,
24 const std::vector<float>& inputData,
25 const std::vector<unsigned int>& axis,
26 bool keepDims,
27 const unsigned int* outputShape,
28 const std::vector<float>& outputData,
29 float scale = 1.0f,
30 int32_t offset = 0)
31{
Jan Eilers8eb25602020-03-09 12:13:48 +000032 IgnoreUnused(memoryManager);
Derek Lambertic374ff02019-12-10 21:57:35 +000033
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010034 armnn::TensorInfo inputTensorInfo(InputDim, inputShape, ArmnnType);
35 armnn::TensorInfo outputTensorInfo(OutputDim, outputShape, ArmnnType);
36
37 inputTensorInfo.SetQuantizationScale(scale);
38 inputTensorInfo.SetQuantizationOffset(offset);
39
40 outputTensorInfo.SetQuantizationScale(scale);
41 outputTensorInfo.SetQuantizationOffset(offset);
42
43 auto input = MakeTensor<T, InputDim>(inputTensorInfo, ConvertToDataType<ArmnnType>(inputData, inputTensorInfo));
44
45 LayerTestResult<T, OutputDim> result(outputTensorInfo);
46 result.outputExpected = MakeTensor<T, OutputDim>(
47 outputTensorInfo, ConvertToDataType<ArmnnType>(outputData, outputTensorInfo));
48
Finn Williams826a5432020-08-27 16:15:20 +010049 std::unique_ptr<armnn::ITensorHandle> inputHandle = tensorHandleFactory.CreateTensorHandle(inputTensorInfo);
50 std::unique_ptr<armnn::ITensorHandle> outputHandle = tensorHandleFactory.CreateTensorHandle(outputTensorInfo);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010051
52 armnn::MeanQueueDescriptor data;
53 data.m_Parameters.m_Axis = axis;
54 data.m_Parameters.m_KeepDims = keepDims;
55 armnn::WorkloadInfo info;
56 AddInputToWorkload(data, info, inputTensorInfo, inputHandle.get());
57 AddOutputToWorkload(data, info, outputTensorInfo, outputHandle.get());
58
59 std::unique_ptr<armnn::IWorkload> workload = workloadFactory.CreateMean(data, info);
60
61 inputHandle->Allocate();
62 outputHandle->Allocate();
63
64 CopyDataToITensorHandle(inputHandle.get(), input.origin());
65
66 workload->PostAllocationConfigure();
67 workload->Execute();
68
69 CopyDataFromITensorHandle(result.output.origin(), outputHandle.get());
70
71 return result;
72}
73
74} // anonymous namespace
75
76template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
77LayerTestResult<T, 1> MeanSimpleTest(
78 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +010079 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
80 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010081{
82 const unsigned int inputShape[] = { 3, 2 };
83 const unsigned int outputShape[] = { 1 };
84
85 std::vector<float> input({ 1.5f, 1.5f, 2.5f, 2.5f, 3.5f, 3.5f });
86 std::vector<float> output({ 2.5f });
87
88 return MeanTestHelper<ArmnnType, T, 2, 1>(
Finn Williams826a5432020-08-27 16:15:20 +010089 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, {}, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010090}
91
92template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
93LayerTestResult<T, 3> MeanSimpleAxisTest(
94 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +010095 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
96 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010097{
98 const unsigned int inputShape[] = { 2, 3, 1, 2 };
99 const unsigned int outputShape[] = { 3, 1, 2 };
100
101 std::vector<float> input({ 1.5f, 2.5f, 3.5f, 4.5f, 5.5f, 6.5f, 1.5f, 2.5f, 3.5f, 4.5f, 5.5f, 6.5f });
102 std::vector<float> output({ 1.5f, 2.5f, 3.5f, 4.5f, 5.5f, 6.5f });
103
104 return MeanTestHelper<ArmnnType, T, 4, 3>(
Finn Williams826a5432020-08-27 16:15:20 +0100105 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, { 0 }, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100106}
107
108template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
109LayerTestResult<T, 4> MeanKeepDimsTest(
110 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100111 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
112 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100113{
114 const unsigned int inputShape[] = { 1, 1, 3, 2 };
115 const unsigned int outputShape[] = { 1, 1, 1, 2 };
116
117 std::vector<float> input({ 1.5f, 1.5f, 2.5f, 2.5f, 3.5f, 3.5f });
118 std::vector<float> output({ 2.5f, 2.5f });
119
120 return MeanTestHelper<ArmnnType, T, 4, 4>(
Finn Williams826a5432020-08-27 16:15:20 +0100121 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, { 2 }, true, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100122}
123
124template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
125LayerTestResult<T, 4> MeanMultipleDimsTest(
126 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100127 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
128 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100129{
130 const unsigned int inputShape[] = { 2, 3, 1, 2 };
131 const unsigned int outputShape[] = { 1, 3, 1, 1 };
132
133 std::vector<float> input({ 1.5f, 2.5f, 3.5f, 4.5f, 5.5f, 6.5f, 1.5f, 2.5f, 3.5f, 4.5f, 5.5f, 6.5 });
134 std::vector<float> output({ 2.0f, 4.0f, 6.0f });
135
136 return MeanTestHelper<ArmnnType, T, 4, 4>(
Finn Williams826a5432020-08-27 16:15:20 +0100137 workloadFactory, memoryManager, tensorHandleFactory,
138 inputShape, input, { 0, 3 }, true, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100139}
140
141template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
142LayerTestResult<T, 1> MeanVts1Test(
143 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100144 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
145 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100146{
147 const unsigned int inputShape[] = { 4, 3, 2 };
148 const unsigned int outputShape[] = { 2 };
149
150 std::vector<float> input({ 1.0f, 2.0f, 3.0f, 4.0f, 5.0f, 6.0f, 7.0f, 8.0f, 9.0f, 10.0f, 11.0f, 12.0f, 13.0f, 14.0f,
151 15.0f, 16.0f, 17.0f, 18.0f, 19.0f, 20.0f, 21.0f, 22.0f, 23.0f, 24.0f });
152 std::vector<float> output({ 12.0f, 13.0f });
153
154 return MeanTestHelper<ArmnnType, T, 3, 1>(
Finn Williams826a5432020-08-27 16:15:20 +0100155 workloadFactory, memoryManager, tensorHandleFactory,
156 inputShape, input, { 0, 1 }, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100157}
158
159template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
160LayerTestResult<T, 3> MeanVts2Test(
161 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100162 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
163 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100164{
165 const unsigned int inputShape[] = { 4, 3, 2 };
166 const unsigned int outputShape[] = { 1, 3, 1 };
167
168 std::vector<float> input({ 1.0f, 2.0f, 3.0f, 4.0f, 5.0f, 6.0f, 7.0f, 8.0f, 9.0f, 10.0f, 11.0f, 12.0f, 13.0f, 14.0f,
169 15.0f, 16.0f, 17.0f, 18.0f, 19.0f, 20.0f, 21.0f, 22.0f, 23.0f, 24.0f });
170 std::vector<float> output({ 10.5f, 12.5f, 14.5f });
171
172 return MeanTestHelper<ArmnnType, T, 3, 3>(
Finn Williams826a5432020-08-27 16:15:20 +0100173 workloadFactory, memoryManager, tensorHandleFactory,
174 inputShape, input, { 0, 2 }, true, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100175}
176
177template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
178LayerTestResult<T, 3> MeanVts3Test(
179 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100180 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
181 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100182{
183 const unsigned int inputShape[] = { 1, 2, 2, 1 };
184 const unsigned int outputShape[] = { 1, 2, 1 };
185
186 std::vector<float> input({ 1.0f, 2.0f, 3.0f, 4.0f });
187 std::vector<float> output({ 1.5f, 3.5f });
188
189 return MeanTestHelper<ArmnnType, T, 4, 3>(
Finn Williams826a5432020-08-27 16:15:20 +0100190 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, { 2 }, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100191}