blob: 254b221cc8bebe1cefff5020eff12e3a02fade51 [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
15#include <boost/log/trivial.hpp>
16
17namespace armnn
18{
19
David Beck79141b92018-10-23 16:09:36 +010020namespace
21{
22static const BackendId s_Id{RefBackendId()};
23}
telsoa014fcda012018-03-09 14:13:49 +000024template <typename F32Workload, typename U8Workload, typename QueueDescriptorType>
25std::unique_ptr<IWorkload> RefWorkloadFactory::MakeWorkload(const QueueDescriptorType& descriptor,
26 const WorkloadInfo& info) const
27{
kevmay012b4d88e2019-01-24 14:05:09 +000028 return armnn::MakeWorkloadHelper<NullWorkload, F32Workload, U8Workload, NullWorkload, NullWorkload>(descriptor,
29 info);
telsoa014fcda012018-03-09 14:13:49 +000030}
31
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010032template <DataType ArmnnType>
33bool IsDataType(const WorkloadInfo& info)
Jim Flynn82fbe7c2019-04-02 15:19:08 +010034{
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010035 auto checkType = [](const TensorInfo& tensorInfo) {return tensorInfo.GetDataType() == ArmnnType;};
36 auto it = std::find_if(std::begin(info.m_InputTensorInfos), std::end(info.m_InputTensorInfos), checkType);
Jim Flynn82fbe7c2019-04-02 15:19:08 +010037 if (it != std::end(info.m_InputTensorInfos))
38 {
39 return true;
40 }
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010041 it = std::find_if(std::begin(info.m_OutputTensorInfos), std::end(info.m_OutputTensorInfos), checkType);
Jim Flynn82fbe7c2019-04-02 15:19:08 +010042 if (it != std::end(info.m_OutputTensorInfos))
43 {
44 return true;
45 }
46 return false;
47}
48
Ferran Balaguerd73d14f2019-06-10 10:29:54 +010049bool IsFloat16(const WorkloadInfo& info)
50{
51 return IsDataType<DataType::Float16>(info);
52}
53
Narumol Prangnawarat47cfee92019-07-04 10:29:00 +010054bool IsQSymm16(const WorkloadInfo& info)
nikraj0199a66312019-06-06 10:31:27 +010055{
Narumol Prangnawarat47cfee92019-07-04 10:29:00 +010056 return IsDataType<DataType::QuantisedSymm16>(info);
nikraj0199a66312019-06-06 10:31:27 +010057}
58
Matthew Bentham7c1603a2019-06-21 17:22:23 +010059RefWorkloadFactory::RefWorkloadFactory(const std::shared_ptr<RefMemoryManager>& memoryManager)
60 : m_MemoryManager(memoryManager)
61{
62}
63
telsoa01c577f2c2018-08-31 09:22:23 +010064RefWorkloadFactory::RefWorkloadFactory()
Matthew Bentham7c1603a2019-06-21 17:22:23 +010065 : m_MemoryManager(new RefMemoryManager())
telsoa014fcda012018-03-09 14:13:49 +000066{
67}
68
David Beck79141b92018-10-23 16:09:36 +010069const BackendId& RefWorkloadFactory::GetBackendId() const
70{
71 return s_Id;
72}
73
David Beck29c75de2018-10-23 13:35:58 +010074bool RefWorkloadFactory::IsLayerSupported(const Layer& layer,
75 Optional<DataType> dataType,
telsoa01c577f2c2018-08-31 09:22:23 +010076 std::string& outReasonIfUnsupported)
telsoa014fcda012018-03-09 14:13:49 +000077{
David Beck79141b92018-10-23 16:09:36 +010078 return IWorkloadFactory::IsLayerSupported(s_Id, layer, dataType, outReasonIfUnsupported);
telsoa014fcda012018-03-09 14:13:49 +000079}
80
David Monahan3fb7e102019-08-20 11:25:29 +010081std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
82 const bool IsMemoryManaged) const
telsoa014fcda012018-03-09 14:13:49 +000083{
David Monahan3fb7e102019-08-20 11:25:29 +010084 // For Ref it is okay to make the TensorHandle memory managed as it can also store a pointer
85 // to unmanaged memory. This also ensures memory alignment.
Matthew Bentham7c1603a2019-06-21 17:22:23 +010086 return std::make_unique<RefTensorHandle>(tensorInfo, m_MemoryManager);
telsoa014fcda012018-03-09 14:13:49 +000087}
88
Francis Murtagh351d13d2018-09-24 15:01:18 +010089std::unique_ptr<ITensorHandle> RefWorkloadFactory::CreateTensorHandle(const TensorInfo& tensorInfo,
David Monahan3fb7e102019-08-20 11:25:29 +010090 DataLayout dataLayout,
91 const bool IsMemoryManaged) const
Francis Murtagh351d13d2018-09-24 15:01:18 +010092{
David Monahan3fb7e102019-08-20 11:25:29 +010093 // For Ref it is okay to make the TensorHandle memory managed as it can also store a pointer
94 // to unmanaged memory. This also ensures memory alignment.
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
telsoa014fcda012018-03-09 14:13:49 +000098std::unique_ptr<IWorkload> RefWorkloadFactory::CreateInput(const InputQueueDescriptor& descriptor,
99 const WorkloadInfo& info) const
100{
101 if (info.m_InputTensorInfos.empty() )
102 {
103 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Input cannot be zero length");
104 }
105 if (info.m_OutputTensorInfos.empty())
106 {
107 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: Output cannot be zero length");
108 }
109
110 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
111 {
112 throw InvalidArgumentException("RefWorkloadFactory::CreateInput: data input and output differ in byte count.");
113 }
114
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100115 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000116}
117
118std::unique_ptr<IWorkload> RefWorkloadFactory::CreateOutput(const OutputQueueDescriptor& descriptor,
119 const WorkloadInfo& info) const
120{
121 if (info.m_InputTensorInfos.empty() )
122 {
123 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Input cannot be zero length");
124 }
125 if (info.m_OutputTensorInfos.empty())
126 {
127 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: Output cannot be zero length");
128 }
129 if (info.m_InputTensorInfos[0].GetNumBytes() != info.m_OutputTensorInfos[0].GetNumBytes())
130 {
131 throw InvalidArgumentException("RefWorkloadFactory::CreateOutput: data input and output differ in byte count.");
132 }
133
Narumol Prangnawaratb6441e42019-06-04 11:22:00 +0100134 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000135}
136
137std::unique_ptr<IWorkload> RefWorkloadFactory::CreateActivation(const ActivationQueueDescriptor& descriptor,
138 const WorkloadInfo& info) const
139{
Nattapat Chaimanowongae2c5f02019-04-24 16:19:57 +0100140 return std::make_unique<RefActivationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000141}
142
Nikhil Raj68c2c902019-09-19 11:21:11 +0100143std::unique_ptr<IWorkload> RefWorkloadFactory::CreateArgMinMax(const ArgMinMaxQueueDescriptor& descriptor,
144 const WorkloadInfo& info) const
145{
146 return std::make_unique<RefArgMinMaxWorkload>(descriptor, info);
147}
148
telsoa014fcda012018-03-09 14:13:49 +0000149std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSoftmax(const SoftmaxQueueDescriptor& descriptor,
150 const WorkloadInfo& info) const
151{
nikraj01a121de32019-05-29 10:51:05 +0100152 return std::make_unique<RefSoftmaxWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000153}
154
155std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSplitter(const SplitterQueueDescriptor& descriptor,
156 const WorkloadInfo& info) const
157{
Ruomei Yan25339c32019-05-28 16:48:20 +0100158 return std::make_unique<RefSplitterWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000159}
160
161std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMerger(const MergerQueueDescriptor& descriptor,
162 const WorkloadInfo& info) const
163{
Jim Flynn4ed6c832019-05-20 11:02:46 +0100164 return CreateConcat(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000165}
166
167std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateFullyConnected(
168 const FullyConnectedQueueDescriptor& descriptor, const WorkloadInfo& info) const
169{
Francis Murtagh43aec582019-05-27 12:14:10 +0100170 return std::make_unique<RefFullyConnectedWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000171}
172
173std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePermute(const PermuteQueueDescriptor& descriptor,
174 const WorkloadInfo& info) const
175{
Narumol Prangnawarat86bb4e12019-07-08 11:36:05 +0100176 if (IsQSymm16(info))
177 {
178 return std::make_unique<RefPermuteQSymm16Workload>(descriptor, info);
179 }
180 return MakeWorkloadHelper<RefPermuteFloat16Workload, RefPermuteFloat32Workload, RefPermuteQAsymm8Workload,
kevmay012b4d88e2019-01-24 14:05:09 +0000181 NullWorkload, NullWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000182}
183
184std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreatePooling2d(const Pooling2dQueueDescriptor& descriptor,
185 const WorkloadInfo& info) const
186{
Teresa Charlina3b20472019-06-06 11:12:32 +0100187 return std::make_unique<RefPooling2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000188}
189
190std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConvolution2d(
191 const Convolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
192{
Mike Kelly9b398322019-05-22 17:21:49 +0100193 return std::make_unique<RefConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000194}
195
Aron Virginas-Tar73f66422019-09-23 19:11:59 +0100196std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDepthToSpace(const DepthToSpaceQueueDescriptor& descriptor,
197 const WorkloadInfo& info) const
198{
199 return std::make_unique<RefDepthToSpaceWorkload>(descriptor, info);
200}
201
Ruomei Yan495852f2019-05-23 11:37:33 +0100202std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDepthwiseConvolution2d(
telsoa014fcda012018-03-09 14:13:49 +0000203 const DepthwiseConvolution2dQueueDescriptor& descriptor, const WorkloadInfo& info) const
204{
Ruomei Yan495852f2019-05-23 11:37:33 +0100205 return std::make_unique<RefDepthwiseConvolution2dWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000206}
207
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000208std::unique_ptr<IWorkload> RefWorkloadFactory::CreateDetectionPostProcess(
209 const armnn::DetectionPostProcessQueueDescriptor& descriptor, const armnn::WorkloadInfo& info) const
210{
Aron Virginas-Tar6331f912019-06-03 17:10:02 +0100211 return std::make_unique<RefDetectionPostProcessWorkload>(descriptor, info);
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000212}
213
telsoa014fcda012018-03-09 14:13:49 +0000214std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateNormalization(
215 const NormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
216{
Matteo Martincigh2fc70c52019-06-05 14:12:48 +0100217 return std::make_unique<RefNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000218}
219
220std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateAddition(const AdditionQueueDescriptor& descriptor,
221 const WorkloadInfo& info) const
222{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100223 return std::make_unique<RefAdditionWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000224}
225
226std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMultiplication(
227 const MultiplicationQueueDescriptor& descriptor, const WorkloadInfo& info) const
228{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100229 return std::make_unique<RefMultiplicationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000230}
231
232std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateBatchNormalization(
233 const BatchNormalizationQueueDescriptor& descriptor, const WorkloadInfo& info) const
234{
Matteo Martincigh3122bd52019-06-03 16:54:25 +0100235 return std::make_unique<RefBatchNormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000236}
237
238std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMemCopy(const MemCopyQueueDescriptor& descriptor,
239 const WorkloadInfo& info) const
240{
241 if (descriptor.m_Inputs.empty())
242 {
243 throw InvalidArgumentException("RefWorkloadFactory: CreateMemCopy() expected an input tensor.");
244 }
telsoa01c577f2c2018-08-31 09:22:23 +0100245 return std::make_unique<CopyMemGenericWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000246}
247
Derek Lambertif674aa02019-08-01 15:56:25 +0100248std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMemImport(const MemImportQueueDescriptor& descriptor,
249 const WorkloadInfo& info) const
250{
251 if (descriptor.m_Inputs.empty())
252 {
253 throw InvalidArgumentException("RefWorkloadFactory: CreateMemImport() expected an input tensor.");
254 }
255 return std::make_unique<ImportMemGenericWorkload>(descriptor, info);
256}
257
Teresa Charlin970f43b2019-07-01 13:51:07 +0100258std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResize(const ResizeQueueDescriptor& descriptor,
259 const WorkloadInfo& info) const
260{
Teresa Charlin970f43b2019-07-01 13:51:07 +0100261 return std::make_unique<RefResizeWorkload>(descriptor, info);
262}
263
telsoa014fcda012018-03-09 14:13:49 +0000264std::unique_ptr<IWorkload> RefWorkloadFactory::CreateResizeBilinear(const ResizeBilinearQueueDescriptor& descriptor,
265 const WorkloadInfo& info) const
266{
Aron Virginas-Tar169d2f12019-07-01 19:01:44 +0100267 ResizeQueueDescriptor resizeDescriptor;
268 resizeDescriptor.m_Parameters.m_Method = ResizeMethod::Bilinear;
269 resizeDescriptor.m_Parameters.m_DataLayout = descriptor.m_Parameters.m_DataLayout;
270 resizeDescriptor.m_Parameters.m_TargetWidth = descriptor.m_Parameters.m_TargetWidth;
271 resizeDescriptor.m_Parameters.m_TargetHeight = descriptor.m_Parameters.m_TargetHeight;
272
273 return CreateResize(resizeDescriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000274}
275
276std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFakeQuantization(
277 const FakeQuantizationQueueDescriptor& descriptor,
278 const WorkloadInfo& info) const
279{
280 return MakeWorkload<RefFakeQuantizationFloat32Workload, NullWorkload>(descriptor, info);
281}
282
283std::unique_ptr<IWorkload> RefWorkloadFactory::CreateL2Normalization(const L2NormalizationQueueDescriptor& descriptor,
284 const WorkloadInfo& info) const
285{
Ferran Balaguerd73d14f2019-06-10 10:29:54 +0100286 return std::make_unique<RefL2NormalizationWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000287}
288
Jim Flynne242f2d2019-05-22 14:24:13 +0100289std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateConcat(const ConcatQueueDescriptor& descriptor,
Jim Flynn4ed6c832019-05-20 11:02:46 +0100290 const WorkloadInfo& info) const
291{
Jim Flynn4ed6c832019-05-20 11:02:46 +0100292 return std::make_unique<RefConcatWorkload>(descriptor, info);
293}
294
telsoa014fcda012018-03-09 14:13:49 +0000295std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConstant(const ConstantQueueDescriptor& descriptor,
296 const WorkloadInfo& info) const
297{
Nina Drozd58ef2c62019-05-16 12:09:18 +0100298 return std::make_unique<RefConstantWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000299}
300
301std::unique_ptr<IWorkload> RefWorkloadFactory::CreateReshape(const ReshapeQueueDescriptor& descriptor,
302 const WorkloadInfo& info) const
303{
Nina Drozd2f2778f2019-05-27 10:37:05 +0100304 return std::make_unique<RefReshapeWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000305}
306
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000307std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToBatchNd(const SpaceToBatchNdQueueDescriptor& descriptor,
308 const WorkloadInfo& info) const
309{
nikraj0122f0f2b2019-05-30 17:29:32 +0100310 return std::make_unique<RefSpaceToBatchNdWorkload>(descriptor, info);
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000311}
312
Keith Davisa57eccb2019-06-14 17:33:22 +0100313std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSpaceToDepth(const armnn::SpaceToDepthQueueDescriptor& descriptor,
314 const armnn::WorkloadInfo& info) const
315{
Keith Davisa57eccb2019-06-14 17:33:22 +0100316 return std::make_unique<RefSpaceToDepthWorkload>(descriptor, info);
317}
318
telsoa014fcda012018-03-09 14:13:49 +0000319std::unique_ptr<IWorkload> RefWorkloadFactory::CreateFloor(const FloorQueueDescriptor& descriptor,
telsoa01c577f2c2018-08-31 09:22:23 +0100320 const WorkloadInfo& info) const
telsoa014fcda012018-03-09 14:13:49 +0000321{
James Conroy83735b12019-05-30 16:36:59 +0100322 return std::make_unique<RefFloorWorkload>(descriptor, info);
telsoa014fcda012018-03-09 14:13:49 +0000323}
324
telsoa01c577f2c2018-08-31 09:22:23 +0100325std::unique_ptr<IWorkload> RefWorkloadFactory::CreateLstm(const LstmQueueDescriptor& descriptor,
326 const WorkloadInfo& info) const
327{
Nattapat Chaimanowongeb2b3292019-05-07 12:02:30 +0100328 return std::make_unique<RefLstmWorkload>(descriptor, info);
telsoa01c577f2c2018-08-31 09:22:23 +0100329}
330
331std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp16ToFp32(
332 const ConvertFp16ToFp32QueueDescriptor& descriptor,
333 const WorkloadInfo& info) const
334{
335 return std::make_unique<RefConvertFp16ToFp32Workload>(descriptor, info);
336}
337
338std::unique_ptr<IWorkload> RefWorkloadFactory::CreateConvertFp32ToFp16(
339 const ConvertFp32ToFp16QueueDescriptor& descriptor,
340 const WorkloadInfo& info) const
341{
342 return std::make_unique<RefConvertFp32ToFp16Workload>(descriptor, info);
343}
344
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100345std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateDivision(
346 const DivisionQueueDescriptor& descriptor, const WorkloadInfo& info) const
347{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100348 return std::make_unique<RefDivisionWorkload>(descriptor, info);
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100349}
350
David Beckc2044fe2018-09-05 15:00:38 +0100351std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateSubtraction(
352 const SubtractionQueueDescriptor& descriptor, const WorkloadInfo& info) const
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 return std::make_unique<RefMeanWorkload>(descriptor, info);
narpra01a6bf9122018-09-10 09:50:09 +0100367}
368
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000369std::unique_ptr<armnn::IWorkload> RefWorkloadFactory::CreateMinimum(
370 const MinimumQueueDescriptor& descriptor, const WorkloadInfo& info) const
371{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100372 return std::make_unique<RefMinimumWorkload>(descriptor, info);
Éanna Ó Catháin20e58802018-12-04 10:29:06 +0000373}
374
jimfly012c9322a2018-09-19 10:59:49 +0100375std::unique_ptr<IWorkload> RefWorkloadFactory::CreatePad(const PadQueueDescriptor& descriptor,
376 const WorkloadInfo& info) const
377{
Narumol Prangnawarate6eaf662019-07-08 08:57:17 +0100378 if (IsQSymm16(info))
379 {
380 return std::make_unique<RefPadQSymm16Workload>(descriptor, info);
381 }
Matthew Jackson252df3a2019-09-11 09:19:18 +0100382 else if (IsFloat16(info))
383 {
384 return std::make_unique<RefPadFloat16Workload>(descriptor, info);
385 }
Narumol Prangnawarate6eaf662019-07-08 08:57:17 +0100386 return MakeWorkload<RefPadFloat32Workload, RefPadQAsymm8Workload>(descriptor, info);
jimfly012c9322a2018-09-19 10:59:49 +0100387}
388
FrancisMurtagh20995952018-12-17 12:11:36 +0000389std::unique_ptr<IWorkload> RefWorkloadFactory::CreateEqual(const EqualQueueDescriptor& descriptor,
390 const WorkloadInfo& info) const
391{
Sadik Armagan2e6dc3a2019-04-03 17:48:18 +0100392 return std::make_unique<RefEqualWorkload>(descriptor, info);
FrancisMurtagh20995952018-12-17 12:11:36 +0000393}
394
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000395std::unique_ptr<IWorkload> RefWorkloadFactory::CreateBatchToSpaceNd(const BatchToSpaceNdQueueDescriptor& descriptor,
396 const WorkloadInfo& info) const
397{
Francis Murtagh47ea3c02019-06-20 12:07:19 +0100398 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{
Narumol Prangnawarat47cfee92019-07-04 10:29:00 +0100416 if (IsQSymm16(info))
417 {
418 return std::make_unique<RefDebugQSymm16Workload>(descriptor, info);
419 }
420 return MakeWorkload<RefDebugFloat32Workload, RefDebugQAsymm8Workload>(descriptor, info);
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000421}
422
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000423std::unique_ptr<IWorkload> RefWorkloadFactory::CreateRsqrt(const RsqrtQueueDescriptor& descriptor,
424 const WorkloadInfo& info) const
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{
Ellen Norris-Thompson6858d3f2019-06-21 15:50:00 +0100432 return std::make_unique<RefGatherWorkload>(descriptor, info);
narpra014951d842019-01-18 16:53:53 +0000433}
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{
Matteo Martincighab9e5252019-06-13 17:27:46 +0100456 return std::make_unique<RefPreluWorkload>(descriptor, info);
457}
458
Aron Virginas-Tar735a4502019-06-26 15:02:47 +0100459std::unique_ptr<IWorkload> RefWorkloadFactory::CreateTransposeConvolution2d(
460 const TransposeConvolution2dQueueDescriptor& descriptor,
461 const WorkloadInfo& info) const
462{
463 return std::make_unique<RefTransposeConvolution2dWorkload>(descriptor, info);
464}
465
Matthew Jackson81e601c2019-07-11 12:07:09 +0100466std::unique_ptr<IWorkload> RefWorkloadFactory::CreateStack(const StackQueueDescriptor& descriptor,
467 const WorkloadInfo& info) const
468{
Matthew Jackson81e601c2019-07-11 12:07:09 +0100469 return std::make_unique<RefStackWorkload>(descriptor, info);
470}
471
Sadik Armagan9199e582019-09-05 17:35:31 +0100472std::unique_ptr<IWorkload> RefWorkloadFactory::CreateAbs(const AbsQueueDescriptor& descriptor,
473 const WorkloadInfo& info) const
474{
Sadik Armagan9199e582019-09-05 17:35:31 +0100475 return std::make_unique<RefAbsWorkload>(descriptor, info);
476}
477
Aron Virginas-Tar92b9f872019-09-17 17:27:04 +0100478std::unique_ptr<IWorkload> RefWorkloadFactory::CreateSlice(const SliceQueueDescriptor& descriptor,
479 const WorkloadInfo& info) const
480{
481 return std::make_unique<RefSliceWorkload>(descriptor, info);
482}
483
Matteo Martincigh49124022019-01-11 13:25:59 +0000484} // namespace armnn