blob: 2db47d35c2f147b8164f13cf4f2fdef1ba87198b [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>
Derek Lambertif674aa02019-08-01 15:56:25 +01008#include <backendsCommon/MemImportWorkload.hpp>
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00009#include <backendsCommon/MakeWorkloadHelper.hpp>
telsoa014fcda012018-03-09 14:13:49 +000010#include "RefWorkloadFactory.hpp"
David Beck79141b92018-10-23 16:09:36 +010011#include "RefBackendId.hpp"
David Beckb4540be2018-09-24 13:18:27 +010012#include "workloads/RefWorkloads.hpp"
Matthew Bentham4cefc412019-06-18 16:14:34 +010013#include "RefTensorHandle.hpp"
telsoa014fcda012018-03-09 14:13:49 +000014
telsoa014fcda012018-03-09 14:13:49 +000015
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,
Aron Virginas-Tare662a942019-10-14 15:12:00 +010025 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +000026{
Aron Virginas-Tare662a942019-10-14 15:12:00 +010027 return MakeWorkloadHelper<NullWorkload, F32Workload, U8Workload, NullWorkload, NullWorkload>(descriptor, 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
Narumol Prangnawarat47cfee92019-07-04 10:29:00 +010052bool IsQSymm16(const WorkloadInfo& info)
nikraj0199a66312019-06-06 10:31:27 +010053{
Derek Lambertif90c56d2020-01-10 17:14:08 +000054 return IsDataType<DataType::QSymmS16>(info);
nikraj0199a66312019-06-06 10:31:27 +010055}
56
Matthew Bentham7c1603a2019-06-21 17:22:23 +010057RefWorkloadFactory::RefWorkloadFactory(const std::shared_ptr<RefMemoryManager>& memoryManager)
58 : m_MemoryManager(memoryManager)
59{
60}
61
telsoa01c577f2c2018-08-31 09:22:23 +010062RefWorkloadFactory::RefWorkloadFactory()
Matthew Bentham7c1603a2019-06-21 17:22:23 +010063 : m_MemoryManager(new RefMemoryManager())
telsoa014fcda012018-03-09 14:13:49 +000064{
65}
66
David Beck79141b92018-10-23 16:09:36 +010067const BackendId& RefWorkloadFactory::GetBackendId() const
68{
69 return s_Id;
70}
71
David Beck29c75de2018-10-23 13:35:58 +010072bool RefWorkloadFactory::IsLayerSupported(const Layer& layer,
73 Optional<DataType> dataType,
telsoa01c577f2c2018-08-31 09:22:23 +010074 std::string& outReasonIfUnsupported)
telsoa014fcda012018-03-09 14:13:49 +000075{
David Beck79141b92018-10-23 16:09:36 +010076 return IWorkloadFactory::IsLayerSupported(s_Id, layer, dataType, outReasonIfUnsupported);
telsoa014fcda012018-03-09 14:13:49 +000077}
78
David Monahan3fb7e102019-08-20 11:25:29 +010079std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
Derek Lamberti901ea112019-12-10 22:07:09 +000080 const bool isMemoryManaged) const
telsoa014fcda012018-03-09 14:13:49 +000081{
David Monahan3fb7e102019-08-20 11:25:29 +010082 // For Ref it is okay to make the TensorHandle memory managed as it can also store a pointer
83 // to unmanaged memory. This also ensures memory alignment.
Derek Lamberti901ea112019-12-10 22:07:09 +000084 boost::ignore_unused(isMemoryManaged);
Matthew Bentham7c1603a2019-06-21 17:22:23 +010085 return std::make_unique<RefTensorHandle>(tensorInfo, m_MemoryManager);
telsoa014fcda012018-03-09 14:13:49 +000086}
87
Francis Murtagh351d13d2018-09-24 15:01:18 +010088std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
David Monahan3fb7e102019-08-20 11:25:29 +010089 DataLayout dataLayout,
Derek Lamberti901ea112019-12-10 22:07:09 +000090 const bool isMemoryManaged) const
Francis Murtagh351d13d2018-09-24 15:01:18 +010091{
David Monahan3fb7e102019-08-20 11:25:29 +010092 // For Ref it is okay to make the TensorHandle memory managed as it can also store a pointer
93 // to unmanaged memory. This also ensures memory alignment.
Derek Lamberti901ea112019-12-10 22:07:09 +000094 boost::ignore_unused(isMemoryManaged, dataLayout);
Matthew Bentham7c1603a2019-06-21 17:22:23 +010095 return std::make_unique<RefTensorHandle>(tensorInfo, m_MemoryManager);
Francis Murtagh351d13d2018-09-24 15:01:18 +010096}
97
Aron Virginas-Tare662a942019-10-14 15:12:00 +010098std::unique_ptr<IWorkload> RefWorkloadFactory::CreateAbs(const AbsQueueDescriptor& descriptor,
99 const WorkloadInfo& info) const
100{
101 return std::make_unique<RefAbsWorkload>(descriptor, info);
102}
103
104std::unique_ptr<IWorkload> RefWorkloadFactory::CreateActivation(const ActivationQueueDescriptor& descriptor,
105 const WorkloadInfo& info) const
106{
107 return std::make_unique<RefActivationWorkload>(descriptor, info);
108}
109
110std::unique_ptr<IWorkload> RefWorkloadFactory::CreateAddition(const AdditionQueueDescriptor& descriptor,
111 const WorkloadInfo& info) const
112{
113 return std::make_unique<RefAdditionWorkload>(descriptor, info);
114}
115
116std::unique_ptr<IWorkload> RefWorkloadFactory::CreateArgMinMax(const ArgMinMaxQueueDescriptor& descriptor,
117 const WorkloadInfo& info) const
118{
119 return std::make_unique<RefArgMinMaxWorkload>(descriptor, info);
120}
121
122std::unique_ptr<IWorkload> RefWorkloadFactory::CreateBatchNormalization(
123 const BatchNormalizationQueueDescriptor& descriptor,
124 const WorkloadInfo& info) const
125{
126 return std::make_unique<RefBatchNormalizationWorkload>(descriptor, info);
127}
128
129std::unique_ptr<IWorkload> RefWorkloadFactory::CreateBatchToSpaceNd(const BatchToSpaceNdQueueDescriptor& descriptor,
130 const WorkloadInfo& info) const
131{
132 return std::make_unique<RefBatchToSpaceNdWorkload>(descriptor, info);
133}
134
Aron Virginas-Tar77bfb5e2019-10-16 17:45:38 +0100135std::unique_ptr<IWorkload> RefWorkloadFactory::CreateComparison(const ComparisonQueueDescriptor& descriptor,
136 const WorkloadInfo& info) const
137{
138 return std::make_unique<RefComparisonWorkload>(descriptor, info);
139}
140
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100141std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConcat(const ConcatQueueDescriptor& descriptor,
142 const WorkloadInfo& info) const
143{
144 return std::make_unique<RefConcatWorkload>(descriptor, info);
145}
146
147std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConstant(const ConstantQueueDescriptor& descriptor,
148 const WorkloadInfo& info) const
149{
150 return std::make_unique<RefConstantWorkload>(descriptor, info);
151}
152
153std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp16ToFp32(
154 const ConvertFp16ToFp32QueueDescriptor& descriptor,
155 const WorkloadInfo& info) const
156{
157 return std::make_unique<RefConvertFp16ToFp32Workload>(descriptor, info);
158}
159
160std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp32ToFp16(
161 const ConvertFp32ToFp16QueueDescriptor& descriptor,
162 const WorkloadInfo& info) const
163{
164 return std::make_unique<RefConvertFp32ToFp16Workload>(descriptor, info);
165}
166
167std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvolution2d(const Convolution2dQueueDescriptor& descriptor,
168 const WorkloadInfo& info) const
169{
170 return std::make_unique<RefConvolution2dWorkload>(descriptor, info);
171}
172
173std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDebug(const DebugQueueDescriptor& descriptor,
174 const WorkloadInfo& info) const
175{
Aron Virginas-Tardb1a2832019-11-12 16:15:11 +0000176 if (IsFloat16(info))
177 {
178 return std::make_unique<RefDebugFloat16Workload>(descriptor, info);
179 }
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100180 if (IsQSymm16(info))
181 {
182 return std::make_unique<RefDebugQSymm16Workload>(descriptor, info);
183 }
Narumol Prangnawaratd2d917d2020-01-09 10:16:39 +0000184 if (IsDataType<DataType::Signed32>(info))
185 {
186 return std::make_unique<RefDebugSigned32Workload>(descriptor, info);
187 }
Aron Virginas-Tardb1a2832019-11-12 16:15:11 +0000188
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100189 return MakeWorkload<RefDebugFloat32Workload, RefDebugQAsymm8Workload>(descriptor, info);
190}
191
192std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDepthToSpace(const DepthToSpaceQueueDescriptor& descriptor,
193 const WorkloadInfo& info) const
194{
195 return std::make_unique<RefDepthToSpaceWorkload>(descriptor, info);
196}
197
198std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDepthwiseConvolution2d(
199 const DepthwiseConvolution2dQueueDescriptor& descriptor,
200 const WorkloadInfo& info) const
201{
202 return std::make_unique<RefDepthwiseConvolution2dWorkload>(descriptor, info);
203}
204
205std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDequantize(const DequantizeQueueDescriptor& descriptor,
206 const WorkloadInfo& info) const
207{
208 return std::make_unique<RefDequantizeWorkload>(descriptor, info);
209}
210
211std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDetectionPostProcess(
212 const DetectionPostProcessQueueDescriptor& descriptor,
213 const WorkloadInfo& info) const
214{
215 return std::make_unique<RefDetectionPostProcessWorkload>(descriptor, info);
216}
217
218std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDivision(const DivisionQueueDescriptor& descriptor,
219 const WorkloadInfo& info) const
220{
221 return std::make_unique<RefDivisionWorkload>(descriptor, info);
222}
223
224std::unique_ptr<IWorkload> RefWorkloadFactory::CreateEqual(const EqualQueueDescriptor& descriptor,
225 const WorkloadInfo& info) const
226{
Derek Lamberti901ea112019-12-10 22:07:09 +0000227 boost::ignore_unused(descriptor);
Aron Virginas-Tar77bfb5e2019-10-16 17:45:38 +0100228 ComparisonQueueDescriptor comparisonDescriptor;
229 comparisonDescriptor.m_Parameters.m_Operation = ComparisonOperation::Equal;
230
231 return CreateComparison(comparisonDescriptor, info);
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100232}
233
234std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFakeQuantization(
235 const FakeQuantizationQueueDescriptor& descriptor,
236 const WorkloadInfo& info) const
237{
238 return MakeWorkload<RefFakeQuantizationFloat32Workload, NullWorkload>(descriptor, info);
239}
240
241std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFloor(const FloorQueueDescriptor& descriptor,
242 const WorkloadInfo& info) const
243{
244 return std::make_unique<RefFloorWorkload>(descriptor, info);
245}
246
247std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFullyConnected(
248 const FullyConnectedQueueDescriptor& descriptor,
249 const WorkloadInfo& info) const
250{
251 return std::make_unique<RefFullyConnectedWorkload>(descriptor, info);
252}
253
254std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGather(const GatherQueueDescriptor& descriptor,
255 const WorkloadInfo& info) const
256{
257 return std::make_unique<RefGatherWorkload>(descriptor, info);
258}
259
260std::unique_ptr<IWorkload> RefWorkloadFactory::CreateGreater(const GreaterQueueDescriptor& descriptor,
261 const WorkloadInfo& info) const
262{
Derek Lamberti901ea112019-12-10 22:07:09 +0000263 boost::ignore_unused(descriptor);
Aron Virginas-Tar77bfb5e2019-10-16 17:45:38 +0100264 ComparisonQueueDescriptor comparisonDescriptor;
265 comparisonDescriptor.m_Parameters.m_Operation = ComparisonOperation::Greater;
266
267 return CreateComparison(comparisonDescriptor, info);
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100268}
269
telsoa014fcda012018-03-09 14:13:49 +0000270std::unique_ptr<IWorkload> RefWorkloadFactory::CreateInput(const InputQueueDescriptor& descriptor,
271 const WorkloadInfo& info) const
272{
273 if (info.m_InputTensorInfos.empty() )
274 {
275 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Input cannot be zero length");
276 }
277 if (info.m_OutputTensorInfos.empty())
278 {
279 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Output cannot be zero length");
280 }
281
282 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
283 {
284 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: data input and output differ in byte count.");
285 }
286
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100287 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000288}
289
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100290std::unique_ptr<IWorkload> RefWorkloadFactory::CreateInstanceNormalization(
291 const InstanceNormalizationQueueDescriptor& descriptor,
292 const WorkloadInfo& info) const
293{
294 return std::make_unique<RefInstanceNormalizationWorkload>(descriptor, info);
295}
296
297std::unique_ptr<IWorkload> RefWorkloadFactory::CreateL2Normalization(const L2NormalizationQueueDescriptor& descriptor,
298 const WorkloadInfo& info) const
299{
300 return std::make_unique<RefL2NormalizationWorkload>(descriptor, info);
301}
302
303std::unique_ptr<IWorkload> RefWorkloadFactory::CreateLogSoftmax(const LogSoftmaxQueueDescriptor& descriptor,
304 const WorkloadInfo& info) const
305{
306 return std::make_unique<RefLogSoftmaxWorkload>(descriptor, info);
307}
308
309std::unique_ptr<IWorkload> RefWorkloadFactory::CreateLstm(const LstmQueueDescriptor& descriptor,
310 const WorkloadInfo& info) const
311{
312 return std::make_unique<RefLstmWorkload>(descriptor, info);
313}
314
315std::unique_ptr<IWorkload> RefWorkloadFactory::CreateMaximum(const MaximumQueueDescriptor& descriptor,
316 const WorkloadInfo& info) const
317{
318 return std::make_unique<RefMaximumWorkload>(descriptor, info);
319}
320
321std::unique_ptr<IWorkload> RefWorkloadFactory::CreateMean(const MeanQueueDescriptor& descriptor,
322 const WorkloadInfo& info) const
323{
324 return std::make_unique<RefMeanWorkload>(descriptor, info);
325}
326
327std::unique_ptr<IWorkload> RefWorkloadFactory::CreateMemCopy(const MemCopyQueueDescriptor& descriptor,
328 const WorkloadInfo& info) const
329{
330 if (descriptor.m_Inputs.empty())
331 {
332 throw InvalidArgumentException("RefWorkloadFactory: CreateMemCopy() expected an input tensor.");
333 }
334 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
335}
336
337std::unique_ptr<IWorkload> RefWorkloadFactory::CreateMemImport(const MemImportQueueDescriptor& descriptor,
338 const WorkloadInfo& info) const
339{
340 if (descriptor.m_Inputs.empty())
341 {
342 throw InvalidArgumentException("RefWorkloadFactory: CreateMemImport() expected an input tensor.");
343 }
344 return std::make_unique<ImportMemGenericWorkload>(descriptor, info);
345}
346
347std::unique_ptr<IWorkload> RefWorkloadFactory::CreateMerger(const MergerQueueDescriptor& descriptor,
348 const WorkloadInfo& info) const
349{
350 return CreateConcat(descriptor, info);
351}
352
353std::unique_ptr<IWorkload> RefWorkloadFactory::CreateMinimum(const MinimumQueueDescriptor& descriptor,
354 const WorkloadInfo& info) const
355{
356 return std::make_unique<RefMinimumWorkload>(descriptor, info);
357}
358
359std::unique_ptr<IWorkload> RefWorkloadFactory::CreateMultiplication(const MultiplicationQueueDescriptor& descriptor,
360 const WorkloadInfo& info) const
361{
362 return std::make_unique<RefMultiplicationWorkload>(descriptor, info);
363}
364
365std::unique_ptr<IWorkload> RefWorkloadFactory::CreateNormalization(const NormalizationQueueDescriptor& descriptor,
366 const WorkloadInfo& info) const
367{
368 return std::make_unique<RefNormalizationWorkload>(descriptor, info);
369}
370
telsoa014fcda012018-03-09 14:13:49 +0000371std::unique_ptr<IWorkload> RefWorkloadFactory::CreateOutput(const OutputQueueDescriptor& descriptor,
372 const WorkloadInfo& info) const
373{
374 if (info.m_InputTensorInfos.empty() )
375 {
376 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Input cannot be zero length");
377 }
378 if (info.m_OutputTensorInfos.empty())
379 {
380 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Output cannot be zero length");
381 }
382 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
383 {
384 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: data input and output differ in byte count.");
385 }
386
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100387 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000388}
389
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100390std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePad(const PadQueueDescriptor& descriptor,
391 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000392{
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100393 if (IsQSymm16(info))
394 {
395 return std::make_unique<RefPadQSymm16Workload>(descriptor, info);
396 }
397 else if (IsFloat16(info))
398 {
399 return std::make_unique<RefPadFloat16Workload>(descriptor, info);
400 }
401 return MakeWorkload<RefPadFloat32Workload, RefPadQAsymm8Workload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000402}
403
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100404std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePermute(const PermuteQueueDescriptor& descriptor,
405 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000406{
Narumol Prangnawarat86bb4e12019-07-08 11:36:05 +0100407 if (IsQSymm16(info))
408 {
409 return std::make_unique<RefPermuteQSymm16Workload>(descriptor, info);
410 }
411 return MakeWorkloadHelper<RefPermuteFloat16Workload, RefPermuteFloat32Workload, RefPermuteQAsymm8Workload,
kevmay012b4d88e2019-01-24 14:05:09 +0000412 NullWorkload, NullWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000413}
414
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100415std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePooling2d(const Pooling2dQueueDescriptor& descriptor,
416 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000417{
Teresa Charlina3b20472019-06-06 11:12:32 +0100418 return std::make_unique<RefPooling2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000419}
420
Derek Lamberti901ea112019-12-10 22:07:09 +0000421std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePreCompiled(const PreCompiledQueueDescriptor& /*descriptor*/,
422 const WorkloadInfo& /*info*/) const
telsoa014fcda012018-03-09 14:13:49 +0000423{
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100424 return nullptr;
telsoa014fcda012018-03-09 14:13:49 +0000425}
426
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100427std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePrelu(const PreluQueueDescriptor& descriptor,
428 const WorkloadInfo& info) const
Aron Virginas-Tar73f66422019-09-23 19:11:59 +0100429{
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100430 return std::make_unique<RefPreluWorkload>(descriptor, info);
Aron Virginas-Tar73f66422019-09-23 19:11:59 +0100431}
432
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100433std::unique_ptr<IWorkload> RefWorkloadFactory::CreateQuantize(const QuantizeQueueDescriptor& descriptor,
434 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000435{
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100436 return std::make_unique<RefQuantizeWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000437}
438
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100439std::unique_ptr<IWorkload> RefWorkloadFactory::CreateReshape(const ReshapeQueueDescriptor& descriptor,
440 const WorkloadInfo& info) const
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000441{
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100442 return std::make_unique<RefReshapeWorkload>(descriptor, info);
Derek Lambertif674aa02019-08-01 15:56:25 +0100443}
444
Teresa Charlin970f43b2019-07-01 13:51:07 +0100445std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResize(const ResizeQueueDescriptor& descriptor,
446 const WorkloadInfo& info) const
447{
Teresa Charlin970f43b2019-07-01 13:51:07 +0100448 return std::make_unique<RefResizeWorkload>(descriptor, info);
449}
450
telsoa014fcda012018-03-09 14:13:49 +0000451std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResizeBilinear(const ResizeBilinearQueueDescriptor& descriptor,
452 const WorkloadInfo& info) const
453{
Aron Virginas-Tar169d2f12019-07-01 19:01:44 +0100454 ResizeQueueDescriptor resizeDescriptor;
455 resizeDescriptor.m_Parameters.m_Method = ResizeMethod::Bilinear;
456 resizeDescriptor.m_Parameters.m_DataLayout = descriptor.m_Parameters.m_DataLayout;
457 resizeDescriptor.m_Parameters.m_TargetWidth = descriptor.m_Parameters.m_TargetWidth;
458 resizeDescriptor.m_Parameters.m_TargetHeight = descriptor.m_Parameters.m_TargetHeight;
459
460 return CreateResize(resizeDescriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000461}
462
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000463std::unique_ptr<IWorkload> RefWorkloadFactory::CreateRsqrt(const RsqrtQueueDescriptor& descriptor,
464 const WorkloadInfo& info) const
465{
nikraj0199a66312019-06-06 10:31:27 +0100466 return std::make_unique<RefRsqrtWorkload>(descriptor, info);
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000467}
468
Aron Virginas-Tar92b9f872019-09-17 17:27:04 +0100469std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSlice(const SliceQueueDescriptor& descriptor,
470 const WorkloadInfo& info) const
471{
472 return std::make_unique<RefSliceWorkload>(descriptor, info);
473}
474
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100475std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSoftmax(const SoftmaxQueueDescriptor& descriptor,
476 const WorkloadInfo& info) const
Kevin May09ca49c2019-10-09 12:37:34 +0100477{
Aron Virginas-Tare662a942019-10-14 15:12:00 +0100478 return std::make_unique<RefSoftmaxWorkload>(descriptor, info);
479}
480
481std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToBatchNd(const SpaceToBatchNdQueueDescriptor& descriptor,
482 const WorkloadInfo& info) const
483{
484 return std::make_unique<RefSpaceToBatchNdWorkload>(descriptor, info);
485}
486
487std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToDepth(const SpaceToDepthQueueDescriptor& descriptor,
488 const WorkloadInfo& info) const
489{
490 return std::make_unique<RefSpaceToDepthWorkload>(descriptor, info);
491}
492
493std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSplitter(const SplitterQueueDescriptor& descriptor,
494 const WorkloadInfo& info) const
495{
496 return std::make_unique<RefSplitterWorkload>(descriptor, info);
497}
498
499std::unique_ptr<IWorkload> RefWorkloadFactory::CreateStack(const StackQueueDescriptor& descriptor,
500 const WorkloadInfo& info) const
501{
502 return std::make_unique<RefStackWorkload>(descriptor, info);
503}
504
505std::unique_ptr<IWorkload> RefWorkloadFactory::CreateStridedSlice(const StridedSliceQueueDescriptor& descriptor,
506 const WorkloadInfo& info) const
507{
508 return std::make_unique<RefStridedSliceWorkload>(descriptor, info);
509}
510
511std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSubtraction(const SubtractionQueueDescriptor& descriptor,
512 const WorkloadInfo& info) const
513{
514 return std::make_unique<RefSubtractionWorkload>(descriptor, info);
515}
516
517std::unique_ptr<IWorkload> RefWorkloadFactory::CreateTransposeConvolution2d(
518 const TransposeConvolution2dQueueDescriptor& descriptor,
519 const WorkloadInfo& info) const
520{
521 return std::make_unique<RefTransposeConvolution2dWorkload>(descriptor, info);
Kevin May09ca49c2019-10-09 12:37:34 +0100522}
523
Matteo Martincigh49124022019-01-11 13:25:59 +0000524} // namespace armnn