blob: 283bfd9502bdcb7f811b63ea101edd6e7af3a36f [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,
22 const unsigned int* inputShape,
23 const std::vector<float>& inputData,
24 const std::vector<unsigned int>& axis,
25 bool keepDims,
26 const unsigned int* outputShape,
27 const std::vector<float>& outputData,
28 float scale = 1.0f,
29 int32_t offset = 0)
30{
Jan Eilers8eb25602020-03-09 12:13:48 +000031 IgnoreUnused(memoryManager);
Derek Lambertic374ff02019-12-10 21:57:35 +000032
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010033 armnn::TensorInfo inputTensorInfo(InputDim, inputShape, ArmnnType);
34 armnn::TensorInfo outputTensorInfo(OutputDim, outputShape, ArmnnType);
35
36 inputTensorInfo.SetQuantizationScale(scale);
37 inputTensorInfo.SetQuantizationOffset(offset);
38
39 outputTensorInfo.SetQuantizationScale(scale);
40 outputTensorInfo.SetQuantizationOffset(offset);
41
42 auto input = MakeTensor<T, InputDim>(inputTensorInfo, ConvertToDataType<ArmnnType>(inputData, inputTensorInfo));
43
44 LayerTestResult<T, OutputDim> result(outputTensorInfo);
45 result.outputExpected = MakeTensor<T, OutputDim>(
46 outputTensorInfo, ConvertToDataType<ArmnnType>(outputData, outputTensorInfo));
47
Teresa Charlinfbf0e5b2020-08-17 01:01:06 +010048 ARMNN_NO_DEPRECATE_WARN_BEGIN
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010049 std::unique_ptr<armnn::ITensorHandle> inputHandle = workloadFactory.CreateTensorHandle(inputTensorInfo);
50 std::unique_ptr<armnn::ITensorHandle> outputHandle = workloadFactory.CreateTensorHandle(outputTensorInfo);
Teresa Charlinfbf0e5b2020-08-17 01:01:06 +010051 ARMNN_NO_DEPRECATE_WARN_END
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010052
53 armnn::MeanQueueDescriptor data;
54 data.m_Parameters.m_Axis = axis;
55 data.m_Parameters.m_KeepDims = keepDims;
56 armnn::WorkloadInfo info;
57 AddInputToWorkload(data, info, inputTensorInfo, inputHandle.get());
58 AddOutputToWorkload(data, info, outputTensorInfo, outputHandle.get());
59
60 std::unique_ptr<armnn::IWorkload> workload = workloadFactory.CreateMean(data, info);
61
62 inputHandle->Allocate();
63 outputHandle->Allocate();
64
65 CopyDataToITensorHandle(inputHandle.get(), input.origin());
66
67 workload->PostAllocationConfigure();
68 workload->Execute();
69
70 CopyDataFromITensorHandle(result.output.origin(), outputHandle.get());
71
72 return result;
73}
74
75} // anonymous namespace
76
77template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
78LayerTestResult<T, 1> MeanSimpleTest(
79 armnn::IWorkloadFactory& workloadFactory,
80 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
81{
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>(
89 workloadFactory, memoryManager, inputShape, input, {}, false, outputShape, output);
90}
91
92template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
93LayerTestResult<T, 3> MeanSimpleAxisTest(
94 armnn::IWorkloadFactory& workloadFactory,
95 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
96{
97 const unsigned int inputShape[] = { 2, 3, 1, 2 };
98 const unsigned int outputShape[] = { 3, 1, 2 };
99
100 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 });
101 std::vector<float> output({ 1.5f, 2.5f, 3.5f, 4.5f, 5.5f, 6.5f });
102
103 return MeanTestHelper<ArmnnType, T, 4, 3>(
104 workloadFactory, memoryManager, inputShape, input, { 0 }, false, outputShape, output);
105}
106
107template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
108LayerTestResult<T, 4> MeanKeepDimsTest(
109 armnn::IWorkloadFactory& workloadFactory,
110 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
111{
112 const unsigned int inputShape[] = { 1, 1, 3, 2 };
113 const unsigned int outputShape[] = { 1, 1, 1, 2 };
114
115 std::vector<float> input({ 1.5f, 1.5f, 2.5f, 2.5f, 3.5f, 3.5f });
116 std::vector<float> output({ 2.5f, 2.5f });
117
118 return MeanTestHelper<ArmnnType, T, 4, 4>(
119 workloadFactory, memoryManager, inputShape, input, { 2 }, true, outputShape, output);
120}
121
122template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
123LayerTestResult<T, 4> MeanMultipleDimsTest(
124 armnn::IWorkloadFactory& workloadFactory,
125 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
126{
127 const unsigned int inputShape[] = { 2, 3, 1, 2 };
128 const unsigned int outputShape[] = { 1, 3, 1, 1 };
129
130 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 });
131 std::vector<float> output({ 2.0f, 4.0f, 6.0f });
132
133 return MeanTestHelper<ArmnnType, T, 4, 4>(
134 workloadFactory, memoryManager, inputShape, input, { 0, 3 }, true, outputShape, output);
135}
136
137template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
138LayerTestResult<T, 1> MeanVts1Test(
139 armnn::IWorkloadFactory& workloadFactory,
140 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
141{
142 const unsigned int inputShape[] = { 4, 3, 2 };
143 const unsigned int outputShape[] = { 2 };
144
145 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,
146 15.0f, 16.0f, 17.0f, 18.0f, 19.0f, 20.0f, 21.0f, 22.0f, 23.0f, 24.0f });
147 std::vector<float> output({ 12.0f, 13.0f });
148
149 return MeanTestHelper<ArmnnType, T, 3, 1>(
150 workloadFactory, memoryManager, inputShape, input, { 0, 1 }, false, outputShape, output);
151}
152
153template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
154LayerTestResult<T, 3> MeanVts2Test(
155 armnn::IWorkloadFactory& workloadFactory,
156 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
157{
158 const unsigned int inputShape[] = { 4, 3, 2 };
159 const unsigned int outputShape[] = { 1, 3, 1 };
160
161 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,
162 15.0f, 16.0f, 17.0f, 18.0f, 19.0f, 20.0f, 21.0f, 22.0f, 23.0f, 24.0f });
163 std::vector<float> output({ 10.5f, 12.5f, 14.5f });
164
165 return MeanTestHelper<ArmnnType, T, 3, 3>(
166 workloadFactory, memoryManager, inputShape, input, { 0, 2 }, true, outputShape, output);
167}
168
169template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
170LayerTestResult<T, 3> MeanVts3Test(
171 armnn::IWorkloadFactory& workloadFactory,
172 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
173{
174 const unsigned int inputShape[] = { 1, 2, 2, 1 };
175 const unsigned int outputShape[] = { 1, 2, 1 };
176
177 std::vector<float> input({ 1.0f, 2.0f, 3.0f, 4.0f });
178 std::vector<float> output({ 1.5f, 3.5f });
179
180 return MeanTestHelper<ArmnnType, T, 4, 3>(
181 workloadFactory, memoryManager, inputShape, input, { 2 }, false, outputShape, output);
182}