blob: 9cc45e2e69cc1b27d3ac4b8e61e43045cf091743 [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
Sadik Armagana097d2a2021-11-24 15:47:28 +00008#include <armnnTestUtils/LayerTestResult.hpp>
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +01009
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
Sadik Armagan483c8112021-06-01 09:24:52 +010043 auto input = ConvertToDataType<ArmnnType>(inputData, inputTensorInfo);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010044
Sadik Armagan483c8112021-06-01 09:24:52 +010045 std::vector<T> actualOutput(outputTensorInfo.GetNumElements());
46 std::vector<T> expectedOutput = ConvertToDataType<ArmnnType>(outputData, outputTensorInfo);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010047
Finn Williams826a5432020-08-27 16:15:20 +010048 std::unique_ptr<armnn::ITensorHandle> inputHandle = tensorHandleFactory.CreateTensorHandle(inputTensorInfo);
49 std::unique_ptr<armnn::ITensorHandle> outputHandle = tensorHandleFactory.CreateTensorHandle(outputTensorInfo);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010050
51 armnn::MeanQueueDescriptor data;
52 data.m_Parameters.m_Axis = axis;
53 data.m_Parameters.m_KeepDims = keepDims;
54 armnn::WorkloadInfo info;
55 AddInputToWorkload(data, info, inputTensorInfo, inputHandle.get());
56 AddOutputToWorkload(data, info, outputTensorInfo, outputHandle.get());
57
58 std::unique_ptr<armnn::IWorkload> workload = workloadFactory.CreateMean(data, info);
59
60 inputHandle->Allocate();
61 outputHandle->Allocate();
62
Sadik Armagan483c8112021-06-01 09:24:52 +010063 CopyDataToITensorHandle(inputHandle.get(), input.data());
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010064
65 workload->PostAllocationConfigure();
66 workload->Execute();
67
Sadik Armagan483c8112021-06-01 09:24:52 +010068 CopyDataFromITensorHandle(actualOutput.data(), outputHandle.get());
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010069
Sadik Armagan483c8112021-06-01 09:24:52 +010070 return LayerTestResult<T, OutputDim>(actualOutput,
71 expectedOutput,
72 outputHandle->GetShape(),
73 outputTensorInfo.GetShape());
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010074}
75
76} // anonymous namespace
77
78template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
79LayerTestResult<T, 1> MeanSimpleTest(
80 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +010081 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
82 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010083{
84 const unsigned int inputShape[] = { 3, 2 };
85 const unsigned int outputShape[] = { 1 };
86
87 std::vector<float> input({ 1.5f, 1.5f, 2.5f, 2.5f, 3.5f, 3.5f });
88 std::vector<float> output({ 2.5f });
89
90 return MeanTestHelper<ArmnnType, T, 2, 1>(
Finn Williams826a5432020-08-27 16:15:20 +010091 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, {}, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010092}
93
94template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
95LayerTestResult<T, 3> MeanSimpleAxisTest(
96 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +010097 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
98 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010099{
100 const unsigned int inputShape[] = { 2, 3, 1, 2 };
101 const unsigned int outputShape[] = { 3, 1, 2 };
102
103 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 });
104 std::vector<float> output({ 1.5f, 2.5f, 3.5f, 4.5f, 5.5f, 6.5f });
105
106 return MeanTestHelper<ArmnnType, T, 4, 3>(
Finn Williams826a5432020-08-27 16:15:20 +0100107 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, { 0 }, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100108}
109
110template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
111LayerTestResult<T, 4> MeanKeepDimsTest(
112 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100113 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
114 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100115{
116 const unsigned int inputShape[] = { 1, 1, 3, 2 };
117 const unsigned int outputShape[] = { 1, 1, 1, 2 };
118
119 std::vector<float> input({ 1.5f, 1.5f, 2.5f, 2.5f, 3.5f, 3.5f });
120 std::vector<float> output({ 2.5f, 2.5f });
121
122 return MeanTestHelper<ArmnnType, T, 4, 4>(
Finn Williams826a5432020-08-27 16:15:20 +0100123 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, { 2 }, true, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100124}
125
126template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
127LayerTestResult<T, 4> MeanMultipleDimsTest(
128 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100129 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
130 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100131{
132 const unsigned int inputShape[] = { 2, 3, 1, 2 };
133 const unsigned int outputShape[] = { 1, 3, 1, 1 };
134
135 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 });
136 std::vector<float> output({ 2.0f, 4.0f, 6.0f });
137
138 return MeanTestHelper<ArmnnType, T, 4, 4>(
Finn Williams826a5432020-08-27 16:15:20 +0100139 workloadFactory, memoryManager, tensorHandleFactory,
140 inputShape, input, { 0, 3 }, true, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100141}
142
143template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
144LayerTestResult<T, 1> MeanVts1Test(
145 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100146 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
147 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100148{
149 const unsigned int inputShape[] = { 4, 3, 2 };
150 const unsigned int outputShape[] = { 2 };
151
152 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,
153 15.0f, 16.0f, 17.0f, 18.0f, 19.0f, 20.0f, 21.0f, 22.0f, 23.0f, 24.0f });
154 std::vector<float> output({ 12.0f, 13.0f });
155
156 return MeanTestHelper<ArmnnType, T, 3, 1>(
Finn Williams826a5432020-08-27 16:15:20 +0100157 workloadFactory, memoryManager, tensorHandleFactory,
158 inputShape, input, { 0, 1 }, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100159}
160
161template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
162LayerTestResult<T, 3> MeanVts2Test(
163 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100164 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
165 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100166{
167 const unsigned int inputShape[] = { 4, 3, 2 };
168 const unsigned int outputShape[] = { 1, 3, 1 };
169
170 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,
171 15.0f, 16.0f, 17.0f, 18.0f, 19.0f, 20.0f, 21.0f, 22.0f, 23.0f, 24.0f });
172 std::vector<float> output({ 10.5f, 12.5f, 14.5f });
173
174 return MeanTestHelper<ArmnnType, T, 3, 3>(
Finn Williams826a5432020-08-27 16:15:20 +0100175 workloadFactory, memoryManager, tensorHandleFactory,
176 inputShape, input, { 0, 2 }, true, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100177}
178
179template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
180LayerTestResult<T, 3> MeanVts3Test(
181 armnn::IWorkloadFactory& workloadFactory,
Finn Williams826a5432020-08-27 16:15:20 +0100182 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
183 const armnn::ITensorHandleFactory& tensorHandleFactory)
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100184{
185 const unsigned int inputShape[] = { 1, 2, 2, 1 };
186 const unsigned int outputShape[] = { 1, 2, 1 };
187
188 std::vector<float> input({ 1.0f, 2.0f, 3.0f, 4.0f });
189 std::vector<float> output({ 1.5f, 3.5f });
190
191 return MeanTestHelper<ArmnnType, T, 4, 3>(
Finn Williams826a5432020-08-27 16:15:20 +0100192 workloadFactory, memoryManager, tensorHandleFactory, inputShape, input, { 2 }, false, outputShape, output);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100193}