blob: 5b035553220f5d7d1cdf55508c152bc4a54a3115 [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
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010030template <DataType ArmnnType>
31bool IsDataType(const WorkloadInfo& info)
Jim Flynn82fbe7c2019-04-02 15:19:08 +010032{
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010033 auto checkType = [](const TensorInfo& tensorInfo) {return tensorInfo.GetDataType() == ArmnnType;};
34 auto it = std::find_if(std::begin(info.m_InputTensorInfos), std::end(info.m_InputTensorInfos), checkType);
Jim Flynn82fbe7c2019-04-02 15:19:08 +010035 if (it != std::end(info.m_InputTensorInfos))
36 {
37 return true;
38 }
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010039 it = std::find_if(std::begin(info.m_OutputTensorInfos), std::end(info.m_OutputTensorInfos), checkType);
Jim Flynn82fbe7c2019-04-02 15:19:08 +010040 if (it != std::end(info.m_OutputTensorInfos))
41 {
42 return true;
43 }
44 return false;
45}
46
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010047bool IsFloat16(const WorkloadInfo& info)
48{
49 return IsDataType<DataType::Float16>(info);
50}
51
nikraj0199a66312019-06-06 10:31:27 +010052bool IsUint8(const WorkloadInfo& info)
53{
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010054 return IsDataType<DataType::QuantisedAsymm8>(info);
nikraj0199a66312019-06-06 10:31:27 +010055}
56
telsoa01c577f2c2018-08-31 09:22:23 +010057RefWorkloadFactory::RefWorkloadFactory()
telsoa014fcda012018-03-09 14:13:49 +000058{
59}
60
David Beck79141b92018-10-23 16:09:36 +010061const BackendId& RefWorkloadFactory::GetBackendId() const
62{
63 return s_Id;
64}
65
David Beck29c75de2018-10-23 13:35:58 +010066bool RefWorkloadFactory::IsLayerSupported(const Layer& layer,
67 Optional<DataType> dataType,
telsoa01c577f2c2018-08-31 09:22:23 +010068 std::string& outReasonIfUnsupported)
telsoa014fcda012018-03-09 14:13:49 +000069{
David Beck79141b92018-10-23 16:09:36 +010070 return IWorkloadFactory::IsLayerSupported(s_Id, layer, dataType, outReasonIfUnsupported);
telsoa014fcda012018-03-09 14:13:49 +000071}
72
73std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo) const
74{
75 return std::make_unique<ScopedCpuTensorHandle>(tensorInfo);
76}
77
Francis Murtagh351d13d2018-09-24 15:01:18 +010078std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
79 DataLayout dataLayout) const
80{
81 return std::make_unique<ScopedCpuTensorHandle>(tensorInfo);
82}
83
telsoa014fcda012018-03-09 14:13:49 +000084std::unique_ptr<IWorkload> RefWorkloadFactory::CreateInput(const InputQueueDescriptor& descriptor,
85 const WorkloadInfo& info) const
86{
87 if (info.m_InputTensorInfos.empty() )
88 {
89 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Input cannot be zero length");
90 }
91 if (info.m_OutputTensorInfos.empty())
92 {
93 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Output cannot be zero length");
94 }
95
96 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
97 {
98 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: data input and output differ in byte count.");
99 }
100
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100101 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000102}
103
104std::unique_ptr<IWorkload> RefWorkloadFactory::CreateOutput(const OutputQueueDescriptor& descriptor,
105 const WorkloadInfo& info) const
106{
107 if (info.m_InputTensorInfos.empty() )
108 {
109 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Input cannot be zero length");
110 }
111 if (info.m_OutputTensorInfos.empty())
112 {
113 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Output cannot be zero length");
114 }
115 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
116 {
117 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: data input and output differ in byte count.");
118 }
119
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100120 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000121}
122
123std::unique_ptr<IWorkload> RefWorkloadFactory::CreateActivation(const ActivationQueueDescriptor& descriptor,
124 const WorkloadInfo& info) const
125{
Nattapat Chaimanowongae2c5f02019-04-24 16:19:57 +0100126 if (IsFloat16(info))
127 {
128 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
129 }
130 return std::make_unique<RefActivationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000131}
132
133std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSoftmax(const SoftmaxQueueDescriptor& descriptor,
134 const WorkloadInfo& info) const
135{
nikraj01a121de32019-05-29 10:51:05 +0100136 if (IsFloat16(info))
137 {
138 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
139 }
140 return std::make_unique<RefSoftmaxWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000141}
142
143std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSplitter(const SplitterQueueDescriptor& descriptor,
144 const WorkloadInfo& info) const
145{
Ruomei Yan25339c32019-05-28 16:48:20 +0100146 if (IsFloat16(info))
147 {
148 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
149 }
150 return std::make_unique<RefSplitterWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000151}
152
153std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMerger(const MergerQueueDescriptor& descriptor,
154 const WorkloadInfo& info) const
155{
Jim Flynn4ed6c832019-05-20 11:02:46 +0100156 return CreateConcat(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000157}
158
159std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateFullyConnected(
160 const FullyConnectedQueueDescriptor& descriptor, const WorkloadInfo& info) const
161{
Francis Murtagh43aec582019-05-27 12:14:10 +0100162 return std::make_unique<RefFullyConnectedWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000163}
164
165std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePermute(const PermuteQueueDescriptor& descriptor,
166 const WorkloadInfo& info) const
167{
narpra01db2b1602019-01-23 15:23:11 +0000168 return MakeWorkloadHelper<RefPermuteFloat16Workload, RefPermuteFloat32Workload, RefPermuteUint8Workload,
kevmay012b4d88e2019-01-24 14:05:09 +0000169 NullWorkload, NullWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000170}
171
172std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePooling2d(const Pooling2dQueueDescriptor& descriptor,
173 const WorkloadInfo& info) const
174{
Teresa Charlina3b20472019-06-06 11:12:32 +0100175 if (IsFloat16(info))
176 {
177 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
178 }
179 return std::make_unique<RefPooling2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000180}
181
182std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConvolution2d(
183 const Convolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
184{
Mike Kelly9b398322019-05-22 17:21:49 +0100185 return std::make_unique<RefConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000186}
187
Ruomei Yan495852f2019-05-23 11:37:33 +0100188std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDepthwiseConvolution2d(
telsoa014fcda012018-03-09 14:13:49 +0000189 const DepthwiseConvolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
190{
Ruomei Yan495852f2019-05-23 11:37:33 +0100191 return std::make_unique<RefDepthwiseConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000192}
193
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000194std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDetectionPostProcess(
195 const armnn::DetectionPostProcessQueueDescriptor& descriptor, const armnn::WorkloadInfo& info) const
196{
Aron Virginas-Tar6331f912019-06-03 17:10:02 +0100197 return std::make_unique<RefDetectionPostProcessWorkload>(descriptor, info);
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000198}
199
telsoa014fcda012018-03-09 14:13:49 +0000200std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateNormalization(
201 const NormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
202{
Matteo Martincigh2fc70c52019-06-05 14:12:48 +0100203 return std::make_unique<RefNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000204}
205
206std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateAddition(const AdditionQueueDescriptor& descriptor,
207 const WorkloadInfo& info) const
208{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100209 if (IsFloat16(info))
210 {
211 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
212 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100213 return std::make_unique<RefAdditionWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000214}
215
216std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMultiplication(
217 const MultiplicationQueueDescriptor& descriptor, const WorkloadInfo& info) const
218{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100219 if (IsFloat16(info))
220 {
221 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
222 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100223 return std::make_unique<RefMultiplicationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000224}
225
226std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateBatchNormalization(
227 const BatchNormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
228{
Matteo Martincigh3122bd52019-06-03 16:54:25 +0100229 return std::make_unique<RefBatchNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000230}
231
232std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMemCopy(const MemCopyQueueDescriptor& descriptor,
233 const WorkloadInfo& info) const
234{
235 if (descriptor.m_Inputs.empty())
236 {
237 throw InvalidArgumentException("RefWorkloadFactory: CreateMemCopy() expected an input tensor.");
238 }
telsoa01c577f2c2018-08-31 09:22:23 +0100239 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000240}
241
242std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResizeBilinear(const ResizeBilinearQueueDescriptor& descriptor,
243 const WorkloadInfo& info) const
244{
Ellen Norris-Thompson719d2a92019-06-12 10:23:57 +0100245 if (IsFloat16(info))
246 {
247 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
248 }
249 return std::make_unique<RefResizeBilinearWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000250}
251
252std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFakeQuantization(
253 const FakeQuantizationQueueDescriptor& descriptor,
254 const WorkloadInfo& info) const
255{
256 return MakeWorkload<RefFakeQuantizationFloat32Workload, NullWorkload>(descriptor, info);
257}
258
259std::unique_ptr<IWorkload> RefWorkloadFactory::CreateL2Normalization(const L2NormalizationQueueDescriptor& descriptor,
260 const WorkloadInfo& info) const
261{
Ferran Balaguerc6138d82019-06-13 17:23:50 +0100262 if (IsFloat16(info))
Ferran Balaguerd73d14f2019-06-10 10:29:54 +0100263 {
264 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
265 }
266 return std::make_unique<RefL2NormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000267}
268
Jim Flynne242f2d2019-05-22 14:24:13 +0100269std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConcat(const ConcatQueueDescriptor& descriptor,
Jim Flynn4ed6c832019-05-20 11:02:46 +0100270 const WorkloadInfo& info) const
271{
272 if (IsFloat16(info))
273 {
274 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
275 }
276 return std::make_unique<RefConcatWorkload>(descriptor, info);
277}
278
telsoa014fcda012018-03-09 14:13:49 +0000279std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConstant(const ConstantQueueDescriptor& descriptor,
280 const WorkloadInfo& info) const
281{
Nina Drozd58ef2c62019-05-16 12:09:18 +0100282 return std::make_unique<RefConstantWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000283}
284
285std::unique_ptr<IWorkload> RefWorkloadFactory::CreateReshape(const ReshapeQueueDescriptor& descriptor,
286 const WorkloadInfo& info) const
287{
Nina Drozd2f2778f2019-05-27 10:37:05 +0100288 return std::make_unique<RefReshapeWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000289}
290
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000291std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToBatchNd(const SpaceToBatchNdQueueDescriptor& descriptor,
292 const WorkloadInfo& info) const
293{
nikraj0122f0f2b2019-05-30 17:29:32 +0100294 if (IsFloat16(info))
295 {
296 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
297 }
298 return std::make_unique<RefSpaceToBatchNdWorkload>(descriptor, info);
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000299}
300
Keith Davisa57eccb2019-06-14 17:33:22 +0100301std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToDepth(const armnn::SpaceToDepthQueueDescriptor& descriptor,
302 const armnn::WorkloadInfo& info) const
303{
304 if (IsFloat16(info))
305 {
306 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
307 }
308 return std::make_unique<RefSpaceToDepthWorkload>(descriptor, info);
309}
310
telsoa014fcda012018-03-09 14:13:49 +0000311std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFloor(const FloorQueueDescriptor& descriptor,
telsoa01c577f2c2018-08-31 09:22:23 +0100312 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000313{
James Conroy83735b12019-05-30 16:36:59 +0100314 return std::make_unique<RefFloorWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000315}
316
telsoa01c577f2c2018-08-31 09:22:23 +0100317std::unique_ptr<IWorkload> RefWorkloadFactory::CreateLstm(const LstmQueueDescriptor& descriptor,
318 const WorkloadInfo& info) const
319{
Nattapat Chaimanowongeb2b3292019-05-07 12:02:30 +0100320 return std::make_unique<RefLstmWorkload>(descriptor, info);
telsoa01c577f2c2018-08-31 09:22:23 +0100321}
322
323std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp16ToFp32(
324 const ConvertFp16ToFp32QueueDescriptor& descriptor,
325 const WorkloadInfo& info) const
326{
327 return std::make_unique<RefConvertFp16ToFp32Workload>(descriptor, info);
328}
329
330std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp32ToFp16(
331 const ConvertFp32ToFp16QueueDescriptor& descriptor,
332 const WorkloadInfo& info) const
333{
334 return std::make_unique<RefConvertFp32ToFp16Workload>(descriptor, info);
335}
336
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100337std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDivision(
338 const DivisionQueueDescriptor& descriptor, const WorkloadInfo& info) const
339{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100340 if (IsFloat16(info))
341 {
342 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
343 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100344 return std::make_unique<RefDivisionWorkload>(descriptor, info);
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100345}
346
David Beckc2044fe2018-09-05 15:00:38 +0100347std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateSubtraction(
348 const SubtractionQueueDescriptor& descriptor, const WorkloadInfo& info) const
349{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100350 if (IsFloat16(info))
351 {
352 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
353 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100354 return std::make_unique<RefSubtractionWorkload>(descriptor, info);
David Beckc2044fe2018-09-05 15:00:38 +0100355}
356
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000357std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMaximum(
358 const MaximumQueueDescriptor& descriptor, const WorkloadInfo& info) const
359{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100360 return std::make_unique<RefMaximumWorkload>(descriptor, info);
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000361}
362
narpra01a6bf9122018-09-10 09:50:09 +0100363std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMean(
364 const MeanQueueDescriptor& descriptor, const WorkloadInfo& info) const
365{
James Conroy4d1ff582019-06-10 17:06:39 +0100366 if (IsFloat16(info))
367 {
368 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
369 }
370 return std::make_unique<RefMeanWorkload>(descriptor, info);
narpra01a6bf9122018-09-10 09:50:09 +0100371}
372
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000373std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMinimum(
374 const MinimumQueueDescriptor& descriptor, const WorkloadInfo& info) const
375{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100376 return std::make_unique<RefMinimumWorkload>(descriptor, info);
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000377}
378
jimfly012c9322a2018-09-19 10:59:49 +0100379std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePad(const PadQueueDescriptor& descriptor,
380 const WorkloadInfo& info) const
381{
Mohamed Nour Abouelseouddd6acea2018-10-18 12:26:19 +0100382 return MakeWorkload<RefPadFloat32Workload, RefPadUint8Workload>(descriptor, info);
jimfly012c9322a2018-09-19 10:59:49 +0100383}
384
FrancisMurtagh20995952018-12-17 12:11:36 +0000385std::unique_ptr<IWorkload> RefWorkloadFactory::CreateEqual(const EqualQueueDescriptor& descriptor,
386 const WorkloadInfo& info) const
387{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100388 return std::make_unique<RefEqualWorkload>(descriptor, info);
FrancisMurtagh20995952018-12-17 12:11:36 +0000389}
390
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000391std::unique_ptr<IWorkload> RefWorkloadFactory::CreateBatchToSpaceNd(const BatchToSpaceNdQueueDescriptor& descriptor,
392 const WorkloadInfo& info) const
393{
Francis Murtagh47ea3c02019-06-20 12:07:19 +0100394 if (IsFloat16(info))
395 {
396 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
397 }
398 return std::make_unique<RefBatchToSpaceNdWorkload>(descriptor, info);
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000399}
jimfly012c9322a2018-09-19 10:59:49 +0100400
Conor Kennedy430b5d82018-11-14 15:28:28 +0000401std::unique_ptr<IWorkload> RefWorkloadFactory::CreateStridedSlice(const StridedSliceQueueDescriptor& descriptor,
402 const WorkloadInfo& info) const
403{
Matteo Martincighe851b3d2019-05-28 14:31:20 +0100404 return std::make_unique<RefStridedSliceWorkload>(descriptor, info);
Conor Kennedy430b5d82018-11-14 15:28:28 +0000405}
406
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000407std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGreater(const GreaterQueueDescriptor& descriptor,
408 const WorkloadInfo& info) const
409{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100410 return std::make_unique<RefGreaterWorkload>(descriptor, info);
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000411}
412
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000413std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDebug(const DebugQueueDescriptor& descriptor,
414 const WorkloadInfo& info) const
415{
Nattapat Chaimanowongcfdcadf2018-12-06 11:54:33 +0000416 return MakeWorkload<RefDebugFloat32Workload, RefDebugUint8Workload>(descriptor, info);
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000417}
418
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000419std::unique_ptr<IWorkload> RefWorkloadFactory::CreateRsqrt(const RsqrtQueueDescriptor& descriptor,
420 const WorkloadInfo& info) const
421{
nikraj0199a66312019-06-06 10:31:27 +0100422 if (IsFloat16(info))
423 {
424 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
425 }
nikraj0199a66312019-06-06 10:31:27 +0100426 return std::make_unique<RefRsqrtWorkload>(descriptor, info);
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000427}
428
narpra014951d842019-01-18 16:53:53 +0000429std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGather(const armnn::GatherQueueDescriptor& descriptor,
430 const armnn::WorkloadInfo& info) const
431{
432 return MakeWorkload<RefGatherFloat32Workload, RefGatherUint8Workload>(descriptor, info);
433}
434
Matteo Martincigh49124022019-01-11 13:25:59 +0000435std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePreCompiled(const PreCompiledQueueDescriptor& descriptor,
436 const WorkloadInfo& info) const
437{
438 return nullptr;
439}
440
Derek Lamberti5f400d62019-03-25 15:41:58 +0000441std::unique_ptr<IWorkload> RefWorkloadFactory::CreateQuantize(const QuantizeQueueDescriptor& descriptor,
442 const WorkloadInfo& info) const
443{
444 return std::make_unique<RefQuantizeWorkload>(descriptor, info);
445}
446
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000447std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDequantize(const DequantizeQueueDescriptor& descriptor,
448 const WorkloadInfo& info) const
449{
Nattapat Chaimanowongafa4e3a2019-04-02 11:41:45 +0100450 return std::make_unique<RefDequantizeWorkload>(descriptor, info);
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000451}
452
Matteo Martincighab9e5252019-06-13 17:27:46 +0100453std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePrelu(const PreluQueueDescriptor& descriptor,
454 const WorkloadInfo& info) const
455{
456 if (IsFloat16(info))
457 {
458 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
459 }
460 return std::make_unique<RefPreluWorkload>(descriptor, info);
461}
462
Matteo Martincigh49124022019-01-11 13:25:59 +0000463} // namespace armnn