blob: 45c43a92ac321fec2f5608d65bcd9a38e3aa399b [file] [log] [blame]
telsoa014fcda012018-03-09 14:13:49 +00001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004//
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00005#include <backendsCommon/CpuTensorHandle.hpp>
6#include <backendsCommon/MemCopyWorkload.hpp>
7#include <backendsCommon/MakeWorkloadHelper.hpp>
telsoa014fcda012018-03-09 14:13:49 +00008#include "RefWorkloadFactory.hpp"
David Beck79141b92018-10-23 16:09:36 +01009#include "RefBackendId.hpp"
David Beckb4540be2018-09-24 13:18:27 +010010#include "workloads/RefWorkloads.hpp"
telsoa014fcda012018-03-09 14:13:49 +000011#include "Layer.hpp"
telsoa014fcda012018-03-09 14:13:49 +000012
13#include <boost/log/trivial.hpp>
14
15namespace armnn
16{
17
David Beck79141b92018-10-23 16:09:36 +010018namespace
19{
20static const BackendId s_Id{RefBackendId()};
21}
telsoa014fcda012018-03-09 14:13:49 +000022template <typename F32Workload, typename U8Workload, typename QueueDescriptorType>
23std::unique_ptr<IWorkload> RefWorkloadFactory::MakeWorkload(const QueueDescriptorType& descriptor,
24 const WorkloadInfo& info) const
25{
kevmay012b4d88e2019-01-24 14:05:09 +000026 return armnn::MakeWorkloadHelper<NullWorkload, F32Workload, U8Workload, NullWorkload, NullWorkload>(descriptor,
27 info);
telsoa014fcda012018-03-09 14:13:49 +000028}
29
Jim Flynn82fbe7c2019-04-02 15:19:08 +010030bool IsFloat16(const WorkloadInfo& info)
31{
32 auto checkFloat16 = [](const TensorInfo& tensorInfo) {return tensorInfo.GetDataType() == DataType::Float16;};
33 auto it = std::find_if(std::begin(info.m_InputTensorInfos), std::end(info.m_InputTensorInfos), checkFloat16);
34 if (it != std::end(info.m_InputTensorInfos))
35 {
36 return true;
37 }
38 it = std::find_if(std::begin(info.m_OutputTensorInfos), std::end(info.m_OutputTensorInfos), checkFloat16);
39 if (it != std::end(info.m_OutputTensorInfos))
40 {
41 return true;
42 }
43 return false;
44}
45
telsoa01c577f2c2018-08-31 09:22:23 +010046RefWorkloadFactory::RefWorkloadFactory()
telsoa014fcda012018-03-09 14:13:49 +000047{
48}
49
David Beck79141b92018-10-23 16:09:36 +010050const BackendId& RefWorkloadFactory::GetBackendId() const
51{
52 return s_Id;
53}
54
David Beck29c75de2018-10-23 13:35:58 +010055bool RefWorkloadFactory::IsLayerSupported(const Layer& layer,
56 Optional<DataType> dataType,
telsoa01c577f2c2018-08-31 09:22:23 +010057 std::string& outReasonIfUnsupported)
telsoa014fcda012018-03-09 14:13:49 +000058{
David Beck79141b92018-10-23 16:09:36 +010059 return IWorkloadFactory::IsLayerSupported(s_Id, layer, dataType, outReasonIfUnsupported);
telsoa014fcda012018-03-09 14:13:49 +000060}
61
62std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo) const
63{
64 return std::make_unique<ScopedCpuTensorHandle>(tensorInfo);
65}
66
Francis Murtagh351d13d2018-09-24 15:01:18 +010067std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
68 DataLayout dataLayout) const
69{
70 return std::make_unique<ScopedCpuTensorHandle>(tensorInfo);
71}
72
telsoa014fcda012018-03-09 14:13:49 +000073std::unique_ptr<IWorkload> RefWorkloadFactory::CreateInput(const InputQueueDescriptor& descriptor,
74 const WorkloadInfo& info) const
75{
76 if (info.m_InputTensorInfos.empty() )
77 {
78 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Input cannot be zero length");
79 }
80 if (info.m_OutputTensorInfos.empty())
81 {
82 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Output cannot be zero length");
83 }
84
85 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
86 {
87 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: data input and output differ in byte count.");
88 }
89
telsoa01c577f2c2018-08-31 09:22:23 +010090 return MakeWorkload<CopyMemGenericWorkload, CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +000091}
92
93std::unique_ptr<IWorkload> RefWorkloadFactory::CreateOutput(const OutputQueueDescriptor& descriptor,
94 const WorkloadInfo& info) const
95{
96 if (info.m_InputTensorInfos.empty() )
97 {
98 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Input cannot be zero length");
99 }
100 if (info.m_OutputTensorInfos.empty())
101 {
102 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Output cannot be zero length");
103 }
104 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
105 {
106 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: data input and output differ in byte count.");
107 }
108
kevmay012b4d88e2019-01-24 14:05:09 +0000109 return MakeWorkloadHelper<CopyMemGenericWorkload, CopyMemGenericWorkload,
110 CopyMemGenericWorkload, NullWorkload, CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000111}
112
113std::unique_ptr<IWorkload> RefWorkloadFactory::CreateActivation(const ActivationQueueDescriptor& descriptor,
114 const WorkloadInfo& info) const
115{
Nattapat Chaimanowongae2c5f02019-04-24 16:19:57 +0100116 if (IsFloat16(info))
117 {
118 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
119 }
120 return std::make_unique<RefActivationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000121}
122
123std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSoftmax(const SoftmaxQueueDescriptor& descriptor,
124 const WorkloadInfo& info) const
125{
126 return MakeWorkload<RefSoftmaxFloat32Workload, RefSoftmaxUint8Workload>(descriptor, info);
127}
128
129std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSplitter(const SplitterQueueDescriptor& descriptor,
130 const WorkloadInfo& info) const
131{
132 return MakeWorkload<RefSplitterFloat32Workload, RefSplitterUint8Workload>(descriptor, info);
133}
134
135std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMerger(const MergerQueueDescriptor& descriptor,
136 const WorkloadInfo& info) const
137{
Jim Flynncbb66aa2019-05-15 13:03:54 +0100138 if (IsFloat16(info))
139 {
140 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
141 }
Jim Flynn4ed34ed2019-05-17 15:32:17 +0100142 return std::make_unique<RefConcatWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000143}
144
145std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateFullyConnected(
146 const FullyConnectedQueueDescriptor& descriptor, const WorkloadInfo& info) const
147{
148 return MakeWorkload<RefFullyConnectedFloat32Workload, RefFullyConnectedUint8Workload>(descriptor, info);
149}
150
151std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePermute(const PermuteQueueDescriptor& descriptor,
152 const WorkloadInfo& info) const
153{
narpra01db2b1602019-01-23 15:23:11 +0000154 return MakeWorkloadHelper<RefPermuteFloat16Workload, RefPermuteFloat32Workload, RefPermuteUint8Workload,
kevmay012b4d88e2019-01-24 14:05:09 +0000155 NullWorkload, NullWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000156}
157
158std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePooling2d(const Pooling2dQueueDescriptor& descriptor,
159 const WorkloadInfo& info) const
160{
161 return MakeWorkload<RefPooling2dFloat32Workload, RefPooling2dUint8Workload>(descriptor, info);
162}
163
164std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConvolution2d(
165 const Convolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
166{
167 return MakeWorkload<RefConvolution2dFloat32Workload, RefConvolution2dUint8Workload>(descriptor, info);
168}
169
170std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDepthwiseConvolution2d(
171 const DepthwiseConvolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
172{
173 return MakeWorkload<RefDepthwiseConvolution2dFloat32Workload,
174 RefDepthwiseConvolution2dUint8Workload>(descriptor, info);
175}
176
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000177std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDetectionPostProcess(
178 const armnn::DetectionPostProcessQueueDescriptor& descriptor, const armnn::WorkloadInfo& info) const
179{
Narumol Prangnawarat6d302bf2019-02-04 11:46:26 +0000180 const DataType dataType = info.m_InputTensorInfos[0].GetDataType();
181 switch (dataType)
182 {
183 case DataType::Float32:
184 return std::make_unique<RefDetectionPostProcessFloat32Workload>(descriptor, info);
185 case DataType::QuantisedAsymm8:
186 return std::make_unique<RefDetectionPostProcessUint8Workload>(descriptor, info);
187 default:
188 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
189 }
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000190}
191
telsoa014fcda012018-03-09 14:13:49 +0000192std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateNormalization(
193 const NormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
194{
195 return MakeWorkload<RefNormalizationFloat32Workload, NullWorkload>(descriptor, info);
196}
197
198std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateAddition(const AdditionQueueDescriptor& descriptor,
199 const WorkloadInfo& info) const
200{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100201 if (IsFloat16(info))
202 {
203 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
204 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100205 return std::make_unique<RefAdditionWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000206}
207
208std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMultiplication(
209 const MultiplicationQueueDescriptor& descriptor, const WorkloadInfo& info) const
210{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100211 if (IsFloat16(info))
212 {
213 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
214 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100215 return std::make_unique<RefMultiplicationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000216}
217
218std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateBatchNormalization(
219 const BatchNormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
220{
221 return MakeWorkload<RefBatchNormalizationFloat32Workload, RefBatchNormalizationUint8Workload>(descriptor, info);
222}
223
224std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMemCopy(const MemCopyQueueDescriptor& descriptor,
225 const WorkloadInfo& info) const
226{
227 if (descriptor.m_Inputs.empty())
228 {
229 throw InvalidArgumentException("RefWorkloadFactory: CreateMemCopy() expected an input tensor.");
230 }
telsoa01c577f2c2018-08-31 09:22:23 +0100231 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000232}
233
234std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResizeBilinear(const ResizeBilinearQueueDescriptor& descriptor,
235 const WorkloadInfo& info) const
236{
237 return MakeWorkload<RefResizeBilinearFloat32Workload, RefResizeBilinearUint8Workload>(descriptor, info);
238}
239
240std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFakeQuantization(
241 const FakeQuantizationQueueDescriptor& descriptor,
242 const WorkloadInfo& info) const
243{
244 return MakeWorkload<RefFakeQuantizationFloat32Workload, NullWorkload>(descriptor, info);
245}
246
247std::unique_ptr<IWorkload> RefWorkloadFactory::CreateL2Normalization(const L2NormalizationQueueDescriptor& descriptor,
248 const WorkloadInfo& info) const
249{
250 return MakeWorkload<RefL2NormalizationFloat32Workload, NullWorkload>(descriptor, info);
251}
252
253std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConstant(const ConstantQueueDescriptor& descriptor,
254 const WorkloadInfo& info) const
255{
Nina Drozd58ef2c62019-05-16 12:09:18 +0100256 return std::make_unique<RefConstantWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000257}
258
259std::unique_ptr<IWorkload> RefWorkloadFactory::CreateReshape(const ReshapeQueueDescriptor& descriptor,
260 const WorkloadInfo& info) const
261{
262 return MakeWorkload<RefReshapeFloat32Workload, RefReshapeUint8Workload>(descriptor, info);
263}
264
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000265std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToBatchNd(const SpaceToBatchNdQueueDescriptor& descriptor,
266 const WorkloadInfo& info) const
267{
Nattapat Chaimanowong3ea76d52018-11-09 14:10:38 +0000268 return MakeWorkload<RefSpaceToBatchNdFloat32Workload, RefSpaceToBatchNdUint8Workload>(descriptor, info);
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000269}
270
telsoa014fcda012018-03-09 14:13:49 +0000271std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFloor(const FloorQueueDescriptor& descriptor,
telsoa01c577f2c2018-08-31 09:22:23 +0100272 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000273{
274 return MakeWorkload<RefFloorFloat32Workload, NullWorkload>(descriptor, info);
275}
276
telsoa01c577f2c2018-08-31 09:22:23 +0100277std::unique_ptr<IWorkload> RefWorkloadFactory::CreateLstm(const LstmQueueDescriptor& descriptor,
278 const WorkloadInfo& info) const
279{
Nattapat Chaimanowongeb2b3292019-05-07 12:02:30 +0100280 return std::make_unique<RefLstmWorkload>(descriptor, info);
telsoa01c577f2c2018-08-31 09:22:23 +0100281}
282
283std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp16ToFp32(
284 const ConvertFp16ToFp32QueueDescriptor& descriptor,
285 const WorkloadInfo& info) const
286{
287 return std::make_unique<RefConvertFp16ToFp32Workload>(descriptor, info);
288}
289
290std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp32ToFp16(
291 const ConvertFp32ToFp16QueueDescriptor& descriptor,
292 const WorkloadInfo& info) const
293{
294 return std::make_unique<RefConvertFp32ToFp16Workload>(descriptor, info);
295}
296
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100297std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDivision(
298 const DivisionQueueDescriptor& descriptor, const WorkloadInfo& info) const
299{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100300 if (IsFloat16(info))
301 {
302 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
303 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100304 return std::make_unique<RefDivisionWorkload>(descriptor, info);
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100305}
306
David Beckc2044fe2018-09-05 15:00:38 +0100307std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateSubtraction(
308 const SubtractionQueueDescriptor& descriptor, const WorkloadInfo& info) const
309{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100310 if (IsFloat16(info))
311 {
312 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
313 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100314 return std::make_unique<RefSubtractionWorkload>(descriptor, info);
David Beckc2044fe2018-09-05 15:00:38 +0100315}
316
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000317std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMaximum(
318 const MaximumQueueDescriptor& descriptor, const WorkloadInfo& info) const
319{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100320 return std::make_unique<RefMaximumWorkload>(descriptor, info);
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000321}
322
narpra01a6bf9122018-09-10 09:50:09 +0100323std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMean(
324 const MeanQueueDescriptor& descriptor, const WorkloadInfo& info) const
325{
narpra011e4c31d2018-09-28 11:07:51 +0100326 return MakeWorkload<RefMeanFloat32Workload, RefMeanUint8Workload>(descriptor, info);
narpra01a6bf9122018-09-10 09:50:09 +0100327}
328
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000329std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMinimum(
330 const MinimumQueueDescriptor& descriptor, const WorkloadInfo& info) const
331{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100332 return std::make_unique<RefMinimumWorkload>(descriptor, info);
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000333}
334
jimfly012c9322a2018-09-19 10:59:49 +0100335std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePad(const PadQueueDescriptor& descriptor,
336 const WorkloadInfo& info) const
337{
Mohamed Nour Abouelseouddd6acea2018-10-18 12:26:19 +0100338 return MakeWorkload<RefPadFloat32Workload, RefPadUint8Workload>(descriptor, info);
jimfly012c9322a2018-09-19 10:59:49 +0100339}
340
FrancisMurtagh20995952018-12-17 12:11:36 +0000341std::unique_ptr<IWorkload> RefWorkloadFactory::CreateEqual(const EqualQueueDescriptor& descriptor,
342 const WorkloadInfo& info) const
343{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100344 return std::make_unique<RefEqualWorkload>(descriptor, info);
FrancisMurtagh20995952018-12-17 12:11:36 +0000345}
346
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000347std::unique_ptr<IWorkload> RefWorkloadFactory::CreateBatchToSpaceNd(const BatchToSpaceNdQueueDescriptor& descriptor,
348 const WorkloadInfo& info) const
349{
350 return MakeWorkload<RefBatchToSpaceNdFloat32Workload, RefBatchToSpaceNdUint8Workload>(descriptor, info);
351}
jimfly012c9322a2018-09-19 10:59:49 +0100352
Conor Kennedy430b5d82018-11-14 15:28:28 +0000353std::unique_ptr<IWorkload> RefWorkloadFactory::CreateStridedSlice(const StridedSliceQueueDescriptor& descriptor,
354 const WorkloadInfo& info) const
355{
Nattapat Chaimanowong1216b582018-11-23 15:33:41 +0000356 return MakeWorkload<RefStridedSliceFloat32Workload, RefStridedSliceUint8Workload>(descriptor, info);
Conor Kennedy430b5d82018-11-14 15:28:28 +0000357}
358
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000359std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGreater(const GreaterQueueDescriptor& descriptor,
360 const WorkloadInfo& info) const
361{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100362 return std::make_unique<RefGreaterWorkload>(descriptor, info);
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000363}
364
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000365std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDebug(const DebugQueueDescriptor& descriptor,
366 const WorkloadInfo& info) const
367{
Nattapat Chaimanowongcfdcadf2018-12-06 11:54:33 +0000368 return MakeWorkload<RefDebugFloat32Workload, RefDebugUint8Workload>(descriptor, info);
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000369}
370
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000371std::unique_ptr<IWorkload> RefWorkloadFactory::CreateRsqrt(const RsqrtQueueDescriptor& descriptor,
372 const WorkloadInfo& info) const
373{
374 return MakeWorkload<RefRsqrtFloat32Workload, NullWorkload>(descriptor, info);
375}
376
narpra014951d842019-01-18 16:53:53 +0000377std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGather(const armnn::GatherQueueDescriptor& descriptor,
378 const armnn::WorkloadInfo& info) const
379{
380 return MakeWorkload<RefGatherFloat32Workload, RefGatherUint8Workload>(descriptor, info);
381}
382
Matteo Martincigh49124022019-01-11 13:25:59 +0000383std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePreCompiled(const PreCompiledQueueDescriptor& descriptor,
384 const WorkloadInfo& info) const
385{
386 return nullptr;
387}
388
Derek Lamberti5f400d62019-03-25 15:41:58 +0000389std::unique_ptr<IWorkload> RefWorkloadFactory::CreateQuantize(const QuantizeQueueDescriptor& descriptor,
390 const WorkloadInfo& info) const
391{
392 return std::make_unique<RefQuantizeWorkload>(descriptor, info);
393}
394
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000395std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDequantize(const DequantizeQueueDescriptor& descriptor,
396 const WorkloadInfo& info) const
397{
Nattapat Chaimanowongafa4e3a2019-04-02 11:41:45 +0100398 return std::make_unique<RefDequantizeWorkload>(descriptor, info);
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000399}
400
Matteo Martincigh49124022019-01-11 13:25:59 +0000401} // namespace armnn