blob: 1ef88a090e122c15837ca1246477a64646f2c6ab [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
nikraj0199a66312019-06-06 10:31:27 +010046bool IsUint8(const WorkloadInfo& info)
47{
48 auto checkUint8 = [](const TensorInfo& tensorInfo) {return tensorInfo.GetDataType() == DataType::QuantisedAsymm8;};
49 auto it = std::find_if(std::begin(info.m_InputTensorInfos), std::end(info.m_InputTensorInfos), checkUint8);
50 if (it != std::end(info.m_InputTensorInfos))
51 {
52 return true;
53 }
54 it = std::find_if(std::begin(info.m_OutputTensorInfos), std::end(info.m_OutputTensorInfos), checkUint8);
55 if (it != std::end(info.m_OutputTensorInfos))
56 {
57 return true;
58 }
59 return false;
60}
61
telsoa01c577f2c2018-08-31 09:22:23 +010062RefWorkloadFactory::RefWorkloadFactory()
telsoa014fcda012018-03-09 14:13:49 +000063{
64}
65
David Beck79141b92018-10-23 16:09:36 +010066const BackendId& RefWorkloadFactory::GetBackendId() const
67{
68 return s_Id;
69}
70
David Beck29c75de2018-10-23 13:35:58 +010071bool RefWorkloadFactory::IsLayerSupported(const Layer& layer,
72 Optional<DataType> dataType,
telsoa01c577f2c2018-08-31 09:22:23 +010073 std::string& outReasonIfUnsupported)
telsoa014fcda012018-03-09 14:13:49 +000074{
David Beck79141b92018-10-23 16:09:36 +010075 return IWorkloadFactory::IsLayerSupported(s_Id, layer, dataType, outReasonIfUnsupported);
telsoa014fcda012018-03-09 14:13:49 +000076}
77
78std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo) const
79{
80 return std::make_unique<ScopedCpuTensorHandle>(tensorInfo);
81}
82
Francis Murtagh351d13d2018-09-24 15:01:18 +010083std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
84 DataLayout dataLayout) const
85{
86 return std::make_unique<ScopedCpuTensorHandle>(tensorInfo);
87}
88
telsoa014fcda012018-03-09 14:13:49 +000089std::unique_ptr<IWorkload> RefWorkloadFactory::CreateInput(const InputQueueDescriptor& descriptor,
90 const WorkloadInfo& info) const
91{
92 if (info.m_InputTensorInfos.empty() )
93 {
94 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Input cannot be zero length");
95 }
96 if (info.m_OutputTensorInfos.empty())
97 {
98 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Output cannot be zero length");
99 }
100
101 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
102 {
103 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: data input and output differ in byte count.");
104 }
105
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100106 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000107}
108
109std::unique_ptr<IWorkload> RefWorkloadFactory::CreateOutput(const OutputQueueDescriptor& descriptor,
110 const WorkloadInfo& info) const
111{
112 if (info.m_InputTensorInfos.empty() )
113 {
114 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Input cannot be zero length");
115 }
116 if (info.m_OutputTensorInfos.empty())
117 {
118 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Output cannot be zero length");
119 }
120 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
121 {
122 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: data input and output differ in byte count.");
123 }
124
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100125 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000126}
127
128std::unique_ptr<IWorkload> RefWorkloadFactory::CreateActivation(const ActivationQueueDescriptor& descriptor,
129 const WorkloadInfo& info) const
130{
Nattapat Chaimanowongae2c5f02019-04-24 16:19:57 +0100131 if (IsFloat16(info))
132 {
133 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
134 }
135 return std::make_unique<RefActivationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000136}
137
138std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSoftmax(const SoftmaxQueueDescriptor& descriptor,
139 const WorkloadInfo& info) const
140{
nikraj01a121de32019-05-29 10:51:05 +0100141 if (IsFloat16(info))
142 {
143 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
144 }
145 return std::make_unique<RefSoftmaxWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000146}
147
148std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSplitter(const SplitterQueueDescriptor& descriptor,
149 const WorkloadInfo& info) const
150{
Ruomei Yan25339c32019-05-28 16:48:20 +0100151 if (IsFloat16(info))
152 {
153 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
154 }
155 return std::make_unique<RefSplitterWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000156}
157
158std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMerger(const MergerQueueDescriptor& descriptor,
159 const WorkloadInfo& info) const
160{
Jim Flynn4ed6c832019-05-20 11:02:46 +0100161 return CreateConcat(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000162}
163
164std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateFullyConnected(
165 const FullyConnectedQueueDescriptor& descriptor, const WorkloadInfo& info) const
166{
Francis Murtagh43aec582019-05-27 12:14:10 +0100167 return std::make_unique<RefFullyConnectedWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000168}
169
170std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePermute(const PermuteQueueDescriptor& descriptor,
171 const WorkloadInfo& info) const
172{
narpra01db2b1602019-01-23 15:23:11 +0000173 return MakeWorkloadHelper<RefPermuteFloat16Workload, RefPermuteFloat32Workload, RefPermuteUint8Workload,
kevmay012b4d88e2019-01-24 14:05:09 +0000174 NullWorkload, NullWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000175}
176
177std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePooling2d(const Pooling2dQueueDescriptor& descriptor,
178 const WorkloadInfo& info) const
179{
Teresa Charlina3b20472019-06-06 11:12:32 +0100180 if (IsFloat16(info))
181 {
182 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
183 }
184 return std::make_unique<RefPooling2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000185}
186
187std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConvolution2d(
188 const Convolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
189{
Mike Kelly9b398322019-05-22 17:21:49 +0100190 return std::make_unique<RefConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000191}
192
Ruomei Yan495852f2019-05-23 11:37:33 +0100193std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDepthwiseConvolution2d(
telsoa014fcda012018-03-09 14:13:49 +0000194 const DepthwiseConvolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
195{
Ruomei Yan495852f2019-05-23 11:37:33 +0100196 return std::make_unique<RefDepthwiseConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000197}
198
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000199std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDetectionPostProcess(
200 const armnn::DetectionPostProcessQueueDescriptor& descriptor, const armnn::WorkloadInfo& info) const
201{
Aron Virginas-Tar6331f912019-06-03 17:10:02 +0100202 return std::make_unique<RefDetectionPostProcessWorkload>(descriptor, info);
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000203}
204
telsoa014fcda012018-03-09 14:13:49 +0000205std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateNormalization(
206 const NormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
207{
Matteo Martincigh2fc70c52019-06-05 14:12:48 +0100208 return std::make_unique<RefNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000209}
210
211std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateAddition(const AdditionQueueDescriptor& descriptor,
212 const WorkloadInfo& info) const
213{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100214 if (IsFloat16(info))
215 {
216 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
217 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100218 return std::make_unique<RefAdditionWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000219}
220
221std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMultiplication(
222 const MultiplicationQueueDescriptor& descriptor, const WorkloadInfo& info) const
223{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100224 if (IsFloat16(info))
225 {
226 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
227 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100228 return std::make_unique<RefMultiplicationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000229}
230
231std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateBatchNormalization(
232 const BatchNormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
233{
Matteo Martincigh3122bd52019-06-03 16:54:25 +0100234 return std::make_unique<RefBatchNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000235}
236
237std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMemCopy(const MemCopyQueueDescriptor& descriptor,
238 const WorkloadInfo& info) const
239{
240 if (descriptor.m_Inputs.empty())
241 {
242 throw InvalidArgumentException("RefWorkloadFactory: CreateMemCopy() expected an input tensor.");
243 }
telsoa01c577f2c2018-08-31 09:22:23 +0100244 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000245}
246
247std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResizeBilinear(const ResizeBilinearQueueDescriptor& descriptor,
248 const WorkloadInfo& info) const
249{
250 return MakeWorkload<RefResizeBilinearFloat32Workload, RefResizeBilinearUint8Workload>(descriptor, info);
251}
252
253std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFakeQuantization(
254 const FakeQuantizationQueueDescriptor& descriptor,
255 const WorkloadInfo& info) const
256{
257 return MakeWorkload<RefFakeQuantizationFloat32Workload, NullWorkload>(descriptor, info);
258}
259
260std::unique_ptr<IWorkload> RefWorkloadFactory::CreateL2Normalization(const L2NormalizationQueueDescriptor& descriptor,
261 const WorkloadInfo& info) const
262{
263 return MakeWorkload<RefL2NormalizationFloat32Workload, NullWorkload>(descriptor, info);
264}
265
Jim Flynne242f2d2019-05-22 14:24:13 +0100266std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConcat(const ConcatQueueDescriptor& descriptor,
Jim Flynn4ed6c832019-05-20 11:02:46 +0100267 const WorkloadInfo& info) const
268{
269 if (IsFloat16(info))
270 {
271 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
272 }
273 return std::make_unique<RefConcatWorkload>(descriptor, info);
274}
275
telsoa014fcda012018-03-09 14:13:49 +0000276std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConstant(const ConstantQueueDescriptor& descriptor,
277 const WorkloadInfo& info) const
278{
Nina Drozd58ef2c62019-05-16 12:09:18 +0100279 return std::make_unique<RefConstantWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000280}
281
282std::unique_ptr<IWorkload> RefWorkloadFactory::CreateReshape(const ReshapeQueueDescriptor& descriptor,
283 const WorkloadInfo& info) const
284{
Nina Drozd2f2778f2019-05-27 10:37:05 +0100285 return std::make_unique<RefReshapeWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000286}
287
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000288std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToBatchNd(const SpaceToBatchNdQueueDescriptor& descriptor,
289 const WorkloadInfo& info) const
290{
nikraj0122f0f2b2019-05-30 17:29:32 +0100291 if (IsFloat16(info))
292 {
293 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
294 }
295 return std::make_unique<RefSpaceToBatchNdWorkload>(descriptor, info);
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000296}
297
telsoa014fcda012018-03-09 14:13:49 +0000298std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFloor(const FloorQueueDescriptor& descriptor,
telsoa01c577f2c2018-08-31 09:22:23 +0100299 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000300{
James Conroy83735b12019-05-30 16:36:59 +0100301 return std::make_unique<RefFloorWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000302}
303
telsoa01c577f2c2018-08-31 09:22:23 +0100304std::unique_ptr<IWorkload> RefWorkloadFactory::CreateLstm(const LstmQueueDescriptor& descriptor,
305 const WorkloadInfo& info) const
306{
Nattapat Chaimanowongeb2b3292019-05-07 12:02:30 +0100307 return std::make_unique<RefLstmWorkload>(descriptor, info);
telsoa01c577f2c2018-08-31 09:22:23 +0100308}
309
310std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp16ToFp32(
311 const ConvertFp16ToFp32QueueDescriptor& descriptor,
312 const WorkloadInfo& info) const
313{
314 return std::make_unique<RefConvertFp16ToFp32Workload>(descriptor, info);
315}
316
317std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp32ToFp16(
318 const ConvertFp32ToFp16QueueDescriptor& descriptor,
319 const WorkloadInfo& info) const
320{
321 return std::make_unique<RefConvertFp32ToFp16Workload>(descriptor, info);
322}
323
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100324std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDivision(
325 const DivisionQueueDescriptor& descriptor, const WorkloadInfo& info) const
326{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100327 if (IsFloat16(info))
328 {
329 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
330 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100331 return std::make_unique<RefDivisionWorkload>(descriptor, info);
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100332}
333
David Beckc2044fe2018-09-05 15:00:38 +0100334std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateSubtraction(
335 const SubtractionQueueDescriptor& descriptor, const WorkloadInfo& info) const
336{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100337 if (IsFloat16(info))
338 {
339 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
340 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100341 return std::make_unique<RefSubtractionWorkload>(descriptor, info);
David Beckc2044fe2018-09-05 15:00:38 +0100342}
343
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000344std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMaximum(
345 const MaximumQueueDescriptor& descriptor, const WorkloadInfo& info) const
346{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100347 return std::make_unique<RefMaximumWorkload>(descriptor, info);
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000348}
349
narpra01a6bf9122018-09-10 09:50:09 +0100350std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMean(
351 const MeanQueueDescriptor& descriptor, const WorkloadInfo& info) const
352{
narpra011e4c31d2018-09-28 11:07:51 +0100353 return MakeWorkload<RefMeanFloat32Workload, RefMeanUint8Workload>(descriptor, info);
narpra01a6bf9122018-09-10 09:50:09 +0100354}
355
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000356std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMinimum(
357 const MinimumQueueDescriptor& descriptor, const WorkloadInfo& info) const
358{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100359 return std::make_unique<RefMinimumWorkload>(descriptor, info);
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000360}
361
jimfly012c9322a2018-09-19 10:59:49 +0100362std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePad(const PadQueueDescriptor& descriptor,
363 const WorkloadInfo& info) const
364{
Mohamed Nour Abouelseouddd6acea2018-10-18 12:26:19 +0100365 return MakeWorkload<RefPadFloat32Workload, RefPadUint8Workload>(descriptor, info);
jimfly012c9322a2018-09-19 10:59:49 +0100366}
367
FrancisMurtagh20995952018-12-17 12:11:36 +0000368std::unique_ptr<IWorkload> RefWorkloadFactory::CreateEqual(const EqualQueueDescriptor& descriptor,
369 const WorkloadInfo& info) const
370{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100371 return std::make_unique<RefEqualWorkload>(descriptor, info);
FrancisMurtagh20995952018-12-17 12:11:36 +0000372}
373
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000374std::unique_ptr<IWorkload> RefWorkloadFactory::CreateBatchToSpaceNd(const BatchToSpaceNdQueueDescriptor& descriptor,
375 const WorkloadInfo& info) const
376{
377 return MakeWorkload<RefBatchToSpaceNdFloat32Workload, RefBatchToSpaceNdUint8Workload>(descriptor, info);
378}
jimfly012c9322a2018-09-19 10:59:49 +0100379
Conor Kennedy430b5d82018-11-14 15:28:28 +0000380std::unique_ptr<IWorkload> RefWorkloadFactory::CreateStridedSlice(const StridedSliceQueueDescriptor& descriptor,
381 const WorkloadInfo& info) const
382{
Matteo Martincighe851b3d2019-05-28 14:31:20 +0100383 return std::make_unique<RefStridedSliceWorkload>(descriptor, info);
Conor Kennedy430b5d82018-11-14 15:28:28 +0000384}
385
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000386std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGreater(const GreaterQueueDescriptor& descriptor,
387 const WorkloadInfo& info) const
388{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100389 return std::make_unique<RefGreaterWorkload>(descriptor, info);
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000390}
391
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000392std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDebug(const DebugQueueDescriptor& descriptor,
393 const WorkloadInfo& info) const
394{
Nattapat Chaimanowongcfdcadf2018-12-06 11:54:33 +0000395 return MakeWorkload<RefDebugFloat32Workload, RefDebugUint8Workload>(descriptor, info);
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000396}
397
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000398std::unique_ptr<IWorkload> RefWorkloadFactory::CreateRsqrt(const RsqrtQueueDescriptor& descriptor,
399 const WorkloadInfo& info) const
400{
nikraj0199a66312019-06-06 10:31:27 +0100401 if (IsFloat16(info))
402 {
403 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
404 }
405 else if(IsUint8(info))
406 {
407 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
408 }
409 return std::make_unique<RefRsqrtWorkload>(descriptor, info);
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000410}
411
narpra014951d842019-01-18 16:53:53 +0000412std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGather(const armnn::GatherQueueDescriptor& descriptor,
413 const armnn::WorkloadInfo& info) const
414{
415 return MakeWorkload<RefGatherFloat32Workload, RefGatherUint8Workload>(descriptor, info);
416}
417
Matteo Martincigh49124022019-01-11 13:25:59 +0000418std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePreCompiled(const PreCompiledQueueDescriptor& descriptor,
419 const WorkloadInfo& info) const
420{
421 return nullptr;
422}
423
Derek Lamberti5f400d62019-03-25 15:41:58 +0000424std::unique_ptr<IWorkload> RefWorkloadFactory::CreateQuantize(const QuantizeQueueDescriptor& descriptor,
425 const WorkloadInfo& info) const
426{
427 return std::make_unique<RefQuantizeWorkload>(descriptor, info);
428}
429
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000430std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDequantize(const DequantizeQueueDescriptor& descriptor,
431 const WorkloadInfo& info) const
432{
Nattapat Chaimanowongafa4e3a2019-04-02 11:41:45 +0100433 return std::make_unique<RefDequantizeWorkload>(descriptor, info);
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000434}
435
Matteo Martincigh49124022019-01-11 13:25:59 +0000436} // namespace armnn