blob: d84a9bf8bc05fc1d1f7fb2bfc8940a4c9f77c502 [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#include "ConstantTestImpl.hpp"
7
Aron Virginas-Tar48623a02019-10-22 10:00:28 +01008#include <QuantizeHelper.hpp>
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +01009#include <ResolveType.hpp>
10
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010011
Matteo Martincighe011d202019-11-28 11:35:47 +000012#include <armnnUtils/Permute.hpp>
13
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010014#include <backendsCommon/CpuTensorHandle.hpp>
15
16#include <backendsCommon/test/TensorCopyUtils.hpp>
17#include <backendsCommon/test/WorkloadTestUtils.hpp>
18
19#include <test/TensorHelpers.hpp>
20
21namespace
22{
23
24template<armnn::DataType ArmnnType, typename T = armnn::ResolveType<ArmnnType>>
25LayerTestResult<T, 4> ConstantTestImpl(
26 armnn::IWorkloadFactory& workloadFactory,
27 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager,
28 float qScale,
29 int32_t qOffset)
30{
Jan Eilers8eb25602020-03-09 12:13:48 +000031 IgnoreUnused(memoryManager);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010032 constexpr unsigned int inputWidth = 3;
33 constexpr unsigned int inputHeight = 4;
34 constexpr unsigned int inputChannels = 3;
35 constexpr unsigned int inputBatchSize = 2;
36
37 constexpr unsigned int outputWidth = inputWidth;
38 constexpr unsigned int outputHeight = inputHeight;
39 constexpr unsigned int outputChannels = inputChannels;
40 constexpr unsigned int outputBatchSize = inputBatchSize;
41
42 armnn::TensorInfo inputTensorInfo({ inputBatchSize, inputChannels, inputHeight, inputWidth },
43 ArmnnType, qScale, qOffset);
44
45 armnn::TensorInfo outputTensorInfo({ outputBatchSize, outputChannels, outputHeight, outputWidth },
46 ArmnnType, qScale, qOffset);
47
48 // Set quantization parameters if the requested type is a quantized type.
49 if(armnn::IsQuantizedType<T>())
50 {
51 inputTensorInfo.SetQuantizationScale(qScale);
52 inputTensorInfo.SetQuantizationOffset(qOffset);
53 outputTensorInfo.SetQuantizationScale(qScale);
54 outputTensorInfo.SetQuantizationOffset(qOffset);
55 }
56
57 auto input = MakeTensor<T, 4>(inputTensorInfo, std::vector<T>(
Aron Virginas-Tar48623a02019-10-22 10:00:28 +010058 armnnUtils::QuantizedVector<T>(
59 {
60 // Batch 0, Channel 0
61 235.0f, 46.0f, 178.0f,
62 100.0f, 123.0f, 19.0f,
63 172.0f, 74.0f, 250.0f,
64 6.0f, 195.0f, 80.0f,
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010065
Aron Virginas-Tar48623a02019-10-22 10:00:28 +010066 // Batch 0, Channel 1
67 113.0f, 95.0f, 202.0f,
68 77.0f, 114.0f, 71.0f,
69 122.0f, 246.0f, 166.0f,
70 82.0f, 28.0f, 37.0f,
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010071
Aron Virginas-Tar48623a02019-10-22 10:00:28 +010072 // Batch 0, Channel 2
73 56.0f, 170.0f, 162.0f,
74 194.0f, 89.0f, 254.0f,
75 12.0f, 209.0f, 200.0f,
76 1.0f, 64.0f, 54.0f,
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010077
Aron Virginas-Tar48623a02019-10-22 10:00:28 +010078 // Batch 1, Channel 0
79 67.0f, 90.0f, 49.0f,
80 7.0f, 163.0f, 18.0f,
81 25.0f, 117.0f, 103.0f,
82 247.0f, 59.0f, 189.0f,
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010083
Aron Virginas-Tar48623a02019-10-22 10:00:28 +010084 // Batch 1, Channel 1
85 239.0f, 104.0f, 199.0f,
86 17.0f, 124.0f, 153.0f,
87 222.0f, 217.0f, 75.0f,
88 32.0f, 126.0f, 21.0f,
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010089
Aron Virginas-Tar48623a02019-10-22 10:00:28 +010090 // Batch 1, Channel 2
91 97.0f, 145.0f, 215.0f,
92 115.0f, 116.0f, 238.0f,
93 226.0f, 16.0f, 132.0f,
94 92.0f, 125.0f, 88.0f,
95 },
96 qScale, qOffset)));
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +010097
98 LayerTestResult<T, 4> result(outputTensorInfo);
99 result.outputExpected = input;
Teresa Charlinfbf0e5b2020-08-17 01:01:06 +0100100 ARMNN_NO_DEPRECATE_WARN_BEGIN
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100101 std::unique_ptr<armnn::ITensorHandle> outputHandle = workloadFactory.CreateTensorHandle(outputTensorInfo);
Teresa Charlinfbf0e5b2020-08-17 01:01:06 +0100102 ARMNN_NO_DEPRECATE_WARN_END
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100103 armnn::ScopedCpuTensorHandle constantTensor(inputTensorInfo);
104 AllocateAndCopyDataToITensorHandle(&constantTensor, &input[0][0][0][0]);
105
106 armnn::ConstantQueueDescriptor descriptor;
107 descriptor.m_LayerOutput = &constantTensor;
108
109 armnn::WorkloadInfo info;
110 AddOutputToWorkload(descriptor, info, outputTensorInfo, outputHandle.get());
111
112 std::unique_ptr<armnn::IWorkload> workload = workloadFactory.CreateConstant(descriptor, info);
113
114 outputHandle->Allocate();
115
116 workload->PostAllocationConfigure();
117 workload->Execute();
118
119 CopyDataFromITensorHandle(&result.output[0][0][0][0], outputHandle.get());
120 return result;
121}
122
123} // anonymous namespace
124
125LayerTestResult<float, 4> ConstantTest(
126 armnn::IWorkloadFactory& workloadFactory,
127 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
128{
129 return ConstantTestImpl<armnn::DataType::Float32>(workloadFactory, memoryManager, 0.0f, 0);
130}
131
132LayerTestResult<int16_t, 4> ConstantInt16SimpleQuantizationScaleNoOffsetTest(
133 armnn::IWorkloadFactory& workloadFactory,
134 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
135{
Derek Lambertif90c56d2020-01-10 17:14:08 +0000136 return ConstantTestImpl<armnn::DataType::QSymmS16>(workloadFactory, memoryManager, 1.0f, 0);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100137}
138
139LayerTestResult<uint8_t, 4> ConstantUint8SimpleQuantizationScaleNoOffsetTest(
140 armnn::IWorkloadFactory& workloadFactory,
141 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
142{
Derek Lambertif90c56d2020-01-10 17:14:08 +0000143 return ConstantTestImpl<armnn::DataType::QAsymmU8>(workloadFactory, memoryManager, 1.0f, 0);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100144}
145
146LayerTestResult<uint8_t, 4> ConstantUint8CustomQuantizationScaleAndOffsetTest(
147 armnn::IWorkloadFactory& workloadFactory,
148 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
149{
Derek Lambertif90c56d2020-01-10 17:14:08 +0000150 return ConstantTestImpl<armnn::DataType::QAsymmU8>(workloadFactory, memoryManager, 2e-6f, 1);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100151}
152
153LayerTestResult<int16_t, 4> ConstantInt16CustomQuantizationScaleAndOffsetTest(
154 armnn::IWorkloadFactory& workloadFactory,
155 const armnn::IBackendInternal::IMemoryManagerSharedPtr& memoryManager)
156{
Derek Lambertif90c56d2020-01-10 17:14:08 +0000157 return ConstantTestImpl<armnn::DataType::QSymmS16>(workloadFactory, memoryManager, 2e-6f, 1);
Aron Virginas-Tar00d306e2019-08-28 18:08:46 +0100158}