blob: 183103c40cd38f0177f39b04db3fca8cd98ad454 [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//
Matthew Bentham4cefc412019-06-18 16:14:34 +01005#include <Layer.hpp>
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00006#include <backendsCommon/CpuTensorHandle.hpp>
7#include <backendsCommon/MemCopyWorkload.hpp>
8#include <backendsCommon/MakeWorkloadHelper.hpp>
telsoa014fcda012018-03-09 14:13:49 +00009#include "RefWorkloadFactory.hpp"
David Beck79141b92018-10-23 16:09:36 +010010#include "RefBackendId.hpp"
David Beckb4540be2018-09-24 13:18:27 +010011#include "workloads/RefWorkloads.hpp"
Matthew Bentham4cefc412019-06-18 16:14:34 +010012#include "RefTensorHandle.hpp"
telsoa014fcda012018-03-09 14:13:49 +000013
14#include <boost/log/trivial.hpp>
15
16namespace armnn
17{
18
David Beck79141b92018-10-23 16:09:36 +010019namespace
20{
21static const BackendId s_Id{RefBackendId()};
22}
telsoa014fcda012018-03-09 14:13:49 +000023template <typename F32Workload, typename U8Workload, typename QueueDescriptorType>
24std::unique_ptr<IWorkload> RefWorkloadFactory::MakeWorkload(const QueueDescriptorType& descriptor,
25 const WorkloadInfo& info) const
26{
kevmay012b4d88e2019-01-24 14:05:09 +000027 return armnn::MakeWorkloadHelper<NullWorkload, F32Workload, U8Workload, NullWorkload, NullWorkload>(descriptor,
28 info);
telsoa014fcda012018-03-09 14:13:49 +000029}
30
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010031template <DataType ArmnnType>
32bool IsDataType(const WorkloadInfo& info)
Jim Flynn82fbe7c2019-04-02 15:19:08 +010033{
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010034 auto checkType = [](const TensorInfo& tensorInfo) {return tensorInfo.GetDataType() == ArmnnType;};
35 auto it = std::find_if(std::begin(info.m_InputTensorInfos), std::end(info.m_InputTensorInfos), checkType);
Jim Flynn82fbe7c2019-04-02 15:19:08 +010036 if (it != std::end(info.m_InputTensorInfos))
37 {
38 return true;
39 }
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010040 it = std::find_if(std::begin(info.m_OutputTensorInfos), std::end(info.m_OutputTensorInfos), checkType);
Jim Flynn82fbe7c2019-04-02 15:19:08 +010041 if (it != std::end(info.m_OutputTensorInfos))
42 {
43 return true;
44 }
45 return false;
46}
47
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010048bool IsFloat16(const WorkloadInfo& info)
49{
50 return IsDataType<DataType::Float16>(info);
51}
52
Narumol Prangnawarat47cfee92019-07-04 10:29:00 +010053bool IsQSymm16(const WorkloadInfo& info)
nikraj0199a66312019-06-06 10:31:27 +010054{
Narumol Prangnawarat47cfee92019-07-04 10:29:00 +010055 return IsDataType<DataType::QuantisedSymm16>(info);
nikraj0199a66312019-06-06 10:31:27 +010056}
57
Matthew Bentham7c1603a2019-06-21 17:22:23 +010058RefWorkloadFactory::RefWorkloadFactory(const std::shared_ptr<RefMemoryManager>& memoryManager)
59 : m_MemoryManager(memoryManager)
60{
61}
62
telsoa01c577f2c2018-08-31 09:22:23 +010063RefWorkloadFactory::RefWorkloadFactory()
Matthew Bentham7c1603a2019-06-21 17:22:23 +010064 : m_MemoryManager(new RefMemoryManager())
telsoa014fcda012018-03-09 14:13:49 +000065{
66}
67
David Beck79141b92018-10-23 16:09:36 +010068const BackendId& RefWorkloadFactory::GetBackendId() const
69{
70 return s_Id;
71}
72
David Beck29c75de2018-10-23 13:35:58 +010073bool RefWorkloadFactory::IsLayerSupported(const Layer& layer,
74 Optional<DataType> dataType,
telsoa01c577f2c2018-08-31 09:22:23 +010075 std::string& outReasonIfUnsupported)
telsoa014fcda012018-03-09 14:13:49 +000076{
David Beck79141b92018-10-23 16:09:36 +010077 return IWorkloadFactory::IsLayerSupported(s_Id, layer, dataType, outReasonIfUnsupported);
telsoa014fcda012018-03-09 14:13:49 +000078}
79
80std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo) const
81{
Matthew Bentham7c1603a2019-06-21 17:22:23 +010082 return std::make_unique<RefTensorHandle>(tensorInfo, m_MemoryManager);
telsoa014fcda012018-03-09 14:13:49 +000083}
84
Francis Murtagh351d13d2018-09-24 15:01:18 +010085std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
86 DataLayout dataLayout) const
87{
Matthew Bentham7c1603a2019-06-21 17:22:23 +010088 return std::make_unique<RefTensorHandle>(tensorInfo, m_MemoryManager);
Francis Murtagh351d13d2018-09-24 15:01:18 +010089}
90
telsoa014fcda012018-03-09 14:13:49 +000091std::unique_ptr<IWorkload> RefWorkloadFactory::CreateInput(const InputQueueDescriptor& descriptor,
92 const WorkloadInfo& info) const
93{
94 if (info.m_InputTensorInfos.empty() )
95 {
96 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Input cannot be zero length");
97 }
98 if (info.m_OutputTensorInfos.empty())
99 {
100 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Output cannot be zero length");
101 }
102
103 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
104 {
105 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: data input and output differ in byte count.");
106 }
107
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100108 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000109}
110
111std::unique_ptr<IWorkload> RefWorkloadFactory::CreateOutput(const OutputQueueDescriptor& descriptor,
112 const WorkloadInfo& info) const
113{
114 if (info.m_InputTensorInfos.empty() )
115 {
116 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Input cannot be zero length");
117 }
118 if (info.m_OutputTensorInfos.empty())
119 {
120 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Output cannot be zero length");
121 }
122 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
123 {
124 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: data input and output differ in byte count.");
125 }
126
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100127 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000128}
129
130std::unique_ptr<IWorkload> RefWorkloadFactory::CreateActivation(const ActivationQueueDescriptor& descriptor,
131 const WorkloadInfo& info) const
132{
Nattapat Chaimanowongae2c5f02019-04-24 16:19:57 +0100133 if (IsFloat16(info))
134 {
135 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
136 }
137 return std::make_unique<RefActivationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000138}
139
140std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSoftmax(const SoftmaxQueueDescriptor& descriptor,
141 const WorkloadInfo& info) const
142{
nikraj01a121de32019-05-29 10:51:05 +0100143 if (IsFloat16(info))
144 {
145 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
146 }
147 return std::make_unique<RefSoftmaxWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000148}
149
150std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSplitter(const SplitterQueueDescriptor& descriptor,
151 const WorkloadInfo& info) const
152{
Ruomei Yan25339c32019-05-28 16:48:20 +0100153 if (IsFloat16(info))
154 {
155 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
156 }
157 return std::make_unique<RefSplitterWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000158}
159
160std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMerger(const MergerQueueDescriptor& descriptor,
161 const WorkloadInfo& info) const
162{
Jim Flynn4ed6c832019-05-20 11:02:46 +0100163 return CreateConcat(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000164}
165
166std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateFullyConnected(
167 const FullyConnectedQueueDescriptor& descriptor, const WorkloadInfo& info) const
168{
Francis Murtagh43aec582019-05-27 12:14:10 +0100169 return std::make_unique<RefFullyConnectedWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000170}
171
172std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePermute(const PermuteQueueDescriptor& descriptor,
173 const WorkloadInfo& info) const
174{
Narumol Prangnawarat86bb4e12019-07-08 11:36:05 +0100175 if (IsQSymm16(info))
176 {
177 return std::make_unique<RefPermuteQSymm16Workload>(descriptor, info);
178 }
179 return MakeWorkloadHelper<RefPermuteFloat16Workload, RefPermuteFloat32Workload, RefPermuteQAsymm8Workload,
kevmay012b4d88e2019-01-24 14:05:09 +0000180 NullWorkload, NullWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000181}
182
183std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePooling2d(const Pooling2dQueueDescriptor& descriptor,
184 const WorkloadInfo& info) const
185{
Teresa Charlina3b20472019-06-06 11:12:32 +0100186 if (IsFloat16(info))
187 {
188 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
189 }
190 return std::make_unique<RefPooling2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000191}
192
193std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConvolution2d(
194 const Convolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
195{
Mike Kelly9b398322019-05-22 17:21:49 +0100196 return std::make_unique<RefConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000197}
198
Ruomei Yan495852f2019-05-23 11:37:33 +0100199std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDepthwiseConvolution2d(
telsoa014fcda012018-03-09 14:13:49 +0000200 const DepthwiseConvolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
201{
Ruomei Yan495852f2019-05-23 11:37:33 +0100202 return std::make_unique<RefDepthwiseConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000203}
204
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000205std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDetectionPostProcess(
206 const armnn::DetectionPostProcessQueueDescriptor& descriptor, const armnn::WorkloadInfo& info) const
207{
Aron Virginas-Tar6331f912019-06-03 17:10:02 +0100208 return std::make_unique<RefDetectionPostProcessWorkload>(descriptor, info);
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000209}
210
telsoa014fcda012018-03-09 14:13:49 +0000211std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateNormalization(
212 const NormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
213{
Matteo Martincigh2fc70c52019-06-05 14:12:48 +0100214 return std::make_unique<RefNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000215}
216
217std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateAddition(const AdditionQueueDescriptor& descriptor,
218 const WorkloadInfo& info) const
219{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100220 if (IsFloat16(info))
221 {
222 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
223 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100224 return std::make_unique<RefAdditionWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000225}
226
227std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMultiplication(
228 const MultiplicationQueueDescriptor& descriptor, const WorkloadInfo& info) const
229{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100230 if (IsFloat16(info))
231 {
232 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
233 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100234 return std::make_unique<RefMultiplicationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000235}
236
237std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateBatchNormalization(
238 const BatchNormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
239{
Matteo Martincigh3122bd52019-06-03 16:54:25 +0100240 return std::make_unique<RefBatchNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000241}
242
243std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMemCopy(const MemCopyQueueDescriptor& descriptor,
244 const WorkloadInfo& info) const
245{
246 if (descriptor.m_Inputs.empty())
247 {
248 throw InvalidArgumentException("RefWorkloadFactory: CreateMemCopy() expected an input tensor.");
249 }
telsoa01c577f2c2018-08-31 09:22:23 +0100250 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000251}
252
Teresa Charlin970f43b2019-07-01 13:51:07 +0100253std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResize(const ResizeQueueDescriptor& descriptor,
254 const WorkloadInfo& info) const
255{
256 if (IsFloat16(info))
257 {
258 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
259 }
260 return std::make_unique<RefResizeWorkload>(descriptor, info);
261}
262
telsoa014fcda012018-03-09 14:13:49 +0000263std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResizeBilinear(const ResizeBilinearQueueDescriptor& descriptor,
264 const WorkloadInfo& info) const
265{
Aron Virginas-Tar169d2f12019-07-01 19:01:44 +0100266 ResizeQueueDescriptor resizeDescriptor;
267 resizeDescriptor.m_Parameters.m_Method = ResizeMethod::Bilinear;
268 resizeDescriptor.m_Parameters.m_DataLayout = descriptor.m_Parameters.m_DataLayout;
269 resizeDescriptor.m_Parameters.m_TargetWidth = descriptor.m_Parameters.m_TargetWidth;
270 resizeDescriptor.m_Parameters.m_TargetHeight = descriptor.m_Parameters.m_TargetHeight;
271
272 return CreateResize(resizeDescriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000273}
274
275std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFakeQuantization(
276 const FakeQuantizationQueueDescriptor& descriptor,
277 const WorkloadInfo& info) const
278{
279 return MakeWorkload<RefFakeQuantizationFloat32Workload, NullWorkload>(descriptor, info);
280}
281
282std::unique_ptr<IWorkload> RefWorkloadFactory::CreateL2Normalization(const L2NormalizationQueueDescriptor& descriptor,
283 const WorkloadInfo& info) const
284{
Ferran Balaguerc6138d82019-06-13 17:23:50 +0100285 if (IsFloat16(info))
Ferran Balaguerd73d14f2019-06-10 10:29:54 +0100286 {
287 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
288 }
289 return std::make_unique<RefL2NormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000290}
291
Jim Flynne242f2d2019-05-22 14:24:13 +0100292std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConcat(const ConcatQueueDescriptor& descriptor,
Jim Flynn4ed6c832019-05-20 11:02:46 +0100293 const WorkloadInfo& info) const
294{
295 if (IsFloat16(info))
296 {
297 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
298 }
299 return std::make_unique<RefConcatWorkload>(descriptor, info);
300}
301
telsoa014fcda012018-03-09 14:13:49 +0000302std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConstant(const ConstantQueueDescriptor& descriptor,
303 const WorkloadInfo& info) const
304{
Nina Drozd58ef2c62019-05-16 12:09:18 +0100305 return std::make_unique<RefConstantWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000306}
307
308std::unique_ptr<IWorkload> RefWorkloadFactory::CreateReshape(const ReshapeQueueDescriptor& descriptor,
309 const WorkloadInfo& info) const
310{
Nina Drozd2f2778f2019-05-27 10:37:05 +0100311 return std::make_unique<RefReshapeWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000312}
313
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000314std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToBatchNd(const SpaceToBatchNdQueueDescriptor& descriptor,
315 const WorkloadInfo& info) const
316{
nikraj0122f0f2b2019-05-30 17:29:32 +0100317 if (IsFloat16(info))
318 {
319 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
320 }
321 return std::make_unique<RefSpaceToBatchNdWorkload>(descriptor, info);
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000322}
323
Keith Davisa57eccb2019-06-14 17:33:22 +0100324std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToDepth(const armnn::SpaceToDepthQueueDescriptor& descriptor,
325 const armnn::WorkloadInfo& info) const
326{
327 if (IsFloat16(info))
328 {
329 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
330 }
331 return std::make_unique<RefSpaceToDepthWorkload>(descriptor, info);
332}
333
telsoa014fcda012018-03-09 14:13:49 +0000334std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFloor(const FloorQueueDescriptor& descriptor,
telsoa01c577f2c2018-08-31 09:22:23 +0100335 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000336{
James Conroy83735b12019-05-30 16:36:59 +0100337 return std::make_unique<RefFloorWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000338}
339
telsoa01c577f2c2018-08-31 09:22:23 +0100340std::unique_ptr<IWorkload> RefWorkloadFactory::CreateLstm(const LstmQueueDescriptor& descriptor,
341 const WorkloadInfo& info) const
342{
Nattapat Chaimanowongeb2b3292019-05-07 12:02:30 +0100343 return std::make_unique<RefLstmWorkload>(descriptor, info);
telsoa01c577f2c2018-08-31 09:22:23 +0100344}
345
346std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp16ToFp32(
347 const ConvertFp16ToFp32QueueDescriptor& descriptor,
348 const WorkloadInfo& info) const
349{
350 return std::make_unique<RefConvertFp16ToFp32Workload>(descriptor, info);
351}
352
353std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp32ToFp16(
354 const ConvertFp32ToFp16QueueDescriptor& descriptor,
355 const WorkloadInfo& info) const
356{
357 return std::make_unique<RefConvertFp32ToFp16Workload>(descriptor, info);
358}
359
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100360std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDivision(
361 const DivisionQueueDescriptor& descriptor, const WorkloadInfo& info) const
362{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100363 if (IsFloat16(info))
364 {
365 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
366 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100367 return std::make_unique<RefDivisionWorkload>(descriptor, info);
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100368}
369
David Beckc2044fe2018-09-05 15:00:38 +0100370std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateSubtraction(
371 const SubtractionQueueDescriptor& descriptor, const WorkloadInfo& info) const
372{
Jim Flynn82fbe7c2019-04-02 15:19:08 +0100373 if (IsFloat16(info))
374 {
375 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
376 }
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100377 return std::make_unique<RefSubtractionWorkload>(descriptor, info);
David Beckc2044fe2018-09-05 15:00:38 +0100378}
379
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000380std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMaximum(
381 const MaximumQueueDescriptor& descriptor, const WorkloadInfo& info) const
382{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100383 return std::make_unique<RefMaximumWorkload>(descriptor, info);
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000384}
385
narpra01a6bf9122018-09-10 09:50:09 +0100386std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMean(
387 const MeanQueueDescriptor& descriptor, const WorkloadInfo& info) const
388{
James Conroy4d1ff582019-06-10 17:06:39 +0100389 if (IsFloat16(info))
390 {
391 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
392 }
393 return std::make_unique<RefMeanWorkload>(descriptor, info);
narpra01a6bf9122018-09-10 09:50:09 +0100394}
395
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000396std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMinimum(
397 const MinimumQueueDescriptor& descriptor, const WorkloadInfo& info) const
398{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100399 return std::make_unique<RefMinimumWorkload>(descriptor, info);
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000400}
401
jimfly012c9322a2018-09-19 10:59:49 +0100402std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePad(const PadQueueDescriptor& descriptor,
403 const WorkloadInfo& info) const
404{
Narumol Prangnawarate6eaf662019-07-08 08:57:17 +0100405 if (IsQSymm16(info))
406 {
407 return std::make_unique<RefPadQSymm16Workload>(descriptor, info);
408 }
409 return MakeWorkload<RefPadFloat32Workload, RefPadQAsymm8Workload>(descriptor, info);
jimfly012c9322a2018-09-19 10:59:49 +0100410}
411
FrancisMurtagh20995952018-12-17 12:11:36 +0000412std::unique_ptr<IWorkload> RefWorkloadFactory::CreateEqual(const EqualQueueDescriptor& descriptor,
413 const WorkloadInfo& info) const
414{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100415 return std::make_unique<RefEqualWorkload>(descriptor, info);
FrancisMurtagh20995952018-12-17 12:11:36 +0000416}
417
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000418std::unique_ptr<IWorkload> RefWorkloadFactory::CreateBatchToSpaceNd(const BatchToSpaceNdQueueDescriptor& descriptor,
419 const WorkloadInfo& info) const
420{
Francis Murtagh47ea3c02019-06-20 12:07:19 +0100421 if (IsFloat16(info))
422 {
423 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
424 }
425 return std::make_unique<RefBatchToSpaceNdWorkload>(descriptor, info);
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000426}
jimfly012c9322a2018-09-19 10:59:49 +0100427
Conor Kennedy430b5d82018-11-14 15:28:28 +0000428std::unique_ptr<IWorkload> RefWorkloadFactory::CreateStridedSlice(const StridedSliceQueueDescriptor& descriptor,
429 const WorkloadInfo& info) const
430{
Matteo Martincighe851b3d2019-05-28 14:31:20 +0100431 return std::make_unique<RefStridedSliceWorkload>(descriptor, info);
Conor Kennedy430b5d82018-11-14 15:28:28 +0000432}
433
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000434std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGreater(const GreaterQueueDescriptor& descriptor,
435 const WorkloadInfo& info) const
436{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100437 return std::make_unique<RefGreaterWorkload>(descriptor, info);
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000438}
439
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000440std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDebug(const DebugQueueDescriptor& descriptor,
441 const WorkloadInfo& info) const
442{
Narumol Prangnawarat47cfee92019-07-04 10:29:00 +0100443 if (IsQSymm16(info))
444 {
445 return std::make_unique<RefDebugQSymm16Workload>(descriptor, info);
446 }
447 return MakeWorkload<RefDebugFloat32Workload, RefDebugQAsymm8Workload>(descriptor, info);
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000448}
449
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000450std::unique_ptr<IWorkload> RefWorkloadFactory::CreateRsqrt(const RsqrtQueueDescriptor& descriptor,
451 const WorkloadInfo& info) const
452{
nikraj0199a66312019-06-06 10:31:27 +0100453 if (IsFloat16(info))
454 {
455 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
456 }
nikraj0199a66312019-06-06 10:31:27 +0100457 return std::make_unique<RefRsqrtWorkload>(descriptor, info);
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000458}
459
narpra014951d842019-01-18 16:53:53 +0000460std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGather(const armnn::GatherQueueDescriptor& descriptor,
461 const armnn::WorkloadInfo& info) const
462{
Ellen Norris-Thompson6858d3f2019-06-21 15:50:00 +0100463 if (IsFloat16(info))
464 {
465 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
466 }
467 return std::make_unique<RefGatherWorkload>(descriptor, info);
narpra014951d842019-01-18 16:53:53 +0000468}
469
Matteo Martincigh49124022019-01-11 13:25:59 +0000470std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePreCompiled(const PreCompiledQueueDescriptor& descriptor,
471 const WorkloadInfo& info) const
472{
473 return nullptr;
474}
475
Derek Lamberti5f400d62019-03-25 15:41:58 +0000476std::unique_ptr<IWorkload> RefWorkloadFactory::CreateQuantize(const QuantizeQueueDescriptor& descriptor,
477 const WorkloadInfo& info) const
478{
479 return std::make_unique<RefQuantizeWorkload>(descriptor, info);
480}
481
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000482std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDequantize(const DequantizeQueueDescriptor& descriptor,
483 const WorkloadInfo& info) const
484{
Nattapat Chaimanowongafa4e3a2019-04-02 11:41:45 +0100485 return std::make_unique<RefDequantizeWorkload>(descriptor, info);
Nattapat Chaimanowong8a54ac02019-03-29 15:25:04 +0000486}
487
Matteo Martincighab9e5252019-06-13 17:27:46 +0100488std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePrelu(const PreluQueueDescriptor& descriptor,
489 const WorkloadInfo& info) const
490{
491 if (IsFloat16(info))
492 {
493 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
494 }
495 return std::make_unique<RefPreluWorkload>(descriptor, info);
496}
497
Aron Virginas-Tar735a4502019-06-26 15:02:47 +0100498std::unique_ptr<IWorkload> RefWorkloadFactory::CreateTransposeConvolution2d(
499 const TransposeConvolution2dQueueDescriptor& descriptor,
500 const WorkloadInfo& info) const
501{
Aron Virginas-Tar98180ef2019-06-26 15:02:47 +0100502 if (IsFloat16(info))
503 {
504 return MakeWorkload<NullWorkload, NullWorkload>(descriptor, info);
505 }
Aron Virginas-Tar735a4502019-06-26 15:02:47 +0100506 return std::make_unique<RefTransposeConvolution2dWorkload>(descriptor, info);
507}
508
Matteo Martincigh49124022019-01-11 13:25:59 +0000509} // namespace armnn