blob: bdc905d17ee0d5e457aed6faf8d84104f0614d12 [file] [log] [blame]
telsoa014fcda012018-03-09 14:13:49 +00001//
Keith Davis69e653f2020-07-02 11:49:26 +01002// Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004//
5#pragma once
6
Matteo Martincigh992d6dc2019-01-10 17:34:20 +00007#include <backendsCommon/LayerSupportBase.hpp>
telsoa014fcda012018-03-09 14:13:49 +00008
9namespace armnn
10{
11
Matteo Martincigh992d6dc2019-01-10 17:34:20 +000012class NeonLayerSupport : public LayerSupportBase
arovir014424b0a2018-10-04 10:46:04 +010013{
arovir017ff76c52018-10-09 09:40:58 +010014public:
josh minor4a3c6102020-01-06 16:40:46 -060015 ARMNN_DEPRECATED_MSG("Use IsElementwiseUnarySupported instead")
Aron Virginas-Tar914e4db2019-09-09 13:36:45 +010016 bool IsAbsSupported(const TensorInfo& input,
17 const TensorInfo& output,
18 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
19
arovir017ff76c52018-10-09 09:40:58 +010020 bool IsActivationSupported(const TensorInfo& input,
21 const TensorInfo& output,
22 const ActivationDescriptor& descriptor,
23 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
24
25 bool IsAdditionSupported(const TensorInfo& input0,
26 const TensorInfo& input1,
27 const TensorInfo& output,
28 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
29
James Conroyd47a0642019-09-17 14:22:06 +010030 bool IsArgMinMaxSupported(const TensorInfo& input,
31 const TensorInfo& output,
32 const ArgMinMaxDescriptor& descriptor,
33 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
34
arovir017ff76c52018-10-09 09:40:58 +010035 bool IsBatchNormalizationSupported(const TensorInfo& input,
36 const TensorInfo& output,
37 const TensorInfo& mean,
38 const TensorInfo& var,
39 const TensorInfo& beta,
40 const TensorInfo& gamma,
41 const BatchNormalizationDescriptor& descriptor,
42 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
43
Mike Kelly56858022020-01-27 12:14:47 +000044 bool IsBatchToSpaceNdSupported(const TensorInfo& input,
45 const TensorInfo& output,
46 const BatchToSpaceNdDescriptor& descriptor,
47 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
48
Aron Virginas-Tar77bfb5e2019-10-16 17:45:38 +010049 bool IsComparisonSupported(const TensorInfo& input0,
50 const TensorInfo& input1,
51 const TensorInfo& output,
52 const ComparisonDescriptor& descriptor,
53 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
54
Jim Flynn906f9462019-05-10 13:55:21 +010055 bool IsConcatSupported(const std::vector<const TensorInfo*> inputs,
56 const TensorInfo& output,
Jim Flynne242f2d2019-05-22 14:24:13 +010057 const ConcatDescriptor& descriptor,
Jim Flynn906f9462019-05-10 13:55:21 +010058 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
59
arovir017ff76c52018-10-09 09:40:58 +010060 bool IsConstantSupported(const TensorInfo& output,
61 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
62
Narumol Prangnawarat250d3922020-03-30 16:11:04 +010063 bool IsConvertBf16ToFp32Supported(const TensorInfo& input,
64 const TensorInfo& output,
65 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
66
arovir017ff76c52018-10-09 09:40:58 +010067 bool IsConvertFp16ToFp32Supported(const TensorInfo& input,
68 const TensorInfo& output,
69 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
70
Narumol Prangnawarat250d3922020-03-30 16:11:04 +010071 bool IsConvertFp32ToBf16Supported(const TensorInfo& input,
72 const TensorInfo& output,
73 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
74
arovir017ff76c52018-10-09 09:40:58 +010075 bool IsConvertFp32ToFp16Supported(const TensorInfo& input,
76 const TensorInfo& output,
77 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
78
79 bool IsConvolution2dSupported(const TensorInfo& input,
80 const TensorInfo& output,
81 const Convolution2dDescriptor& descriptor,
82 const TensorInfo& weights,
83 const Optional<TensorInfo>& biases,
84 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
85
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010086 bool IsDepthToSpaceSupported(const TensorInfo& input,
87 const TensorInfo& output,
88 const DepthToSpaceDescriptor& descriptor,
89 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
90
91
arovir017ff76c52018-10-09 09:40:58 +010092 bool IsDepthwiseConvolutionSupported(const TensorInfo& input,
93 const TensorInfo& output,
94 const DepthwiseConvolution2dDescriptor& descriptor,
95 const TensorInfo& weights,
96 const Optional<TensorInfo>& biases,
97 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
98
Narumol Prangnawarat01961a72019-05-30 16:47:12 +010099 bool IsDequantizeSupported(const TensorInfo& input,
100 const TensorInfo& output,
101 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
102
Pablo Tellof0bd6832019-04-26 17:58:13 +0100103 bool IsDilatedDepthwiseConvolutionSupported(const TensorInfo& input,
104 const TensorInfo& output,
105 const DepthwiseConvolution2dDescriptor& descriptor,
106 const TensorInfo& weights,
107 const Optional<TensorInfo>& biases,
108 Optional<std::string&> reason = EmptyOptional()) const override;
109
josh minor4a3c6102020-01-06 16:40:46 -0600110 bool IsElementwiseUnarySupported(const TensorInfo& input,
111 const TensorInfo& output,
112 const ElementwiseUnaryDescriptor& descriptor,
113 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
114
Sadik Armagana792a052020-06-23 16:22:23 +0100115 bool IsFillSupported(const TensorInfo& input,
116 const TensorInfo& output,
117 const FillDescriptor& descriptor,
118 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
119
arovir017ff76c52018-10-09 09:40:58 +0100120 bool IsFloorSupported(const TensorInfo& input,
121 const TensorInfo& output,
122 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
123
124 bool IsFullyConnectedSupported(const TensorInfo& input,
125 const TensorInfo& output,
126 const TensorInfo& weights,
127 const TensorInfo& biases,
128 const FullyConnectedDescriptor& descriptor,
129 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
130
Teresa Charlinf540eb82020-04-10 19:24:55 +0100131 bool IsGatherSupported(const TensorInfo& input0,
132 const TensorInfo& input1,
133 const TensorInfo& output,
Teresa Charlin52664732020-06-29 16:27:03 +0100134 const GatherDescriptor& descriptor,
Teresa Charlinf540eb82020-04-10 19:24:55 +0100135 Optional<std::string&> reasonIfUnsupported) const override;
136
Aron Virginas-Tar77bfb5e2019-10-16 17:45:38 +0100137 ARMNN_DEPRECATED_MSG("Use IsComparisonSupported instead")
kevmay01eed85922019-01-28 08:37:25 +0000138 bool IsGreaterSupported(const TensorInfo& input0,
139 const TensorInfo& input1,
140 const TensorInfo& output,
141 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
142
arovir017ff76c52018-10-09 09:40:58 +0100143 bool IsInputSupported(const TensorInfo& input,
144 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
145
Sadik Armagan0d4863d2019-10-09 14:26:32 +0100146 bool IsInstanceNormalizationSupported(const TensorInfo& input,
147 const TensorInfo& output,
148 const InstanceNormalizationDescriptor& descriptor,
149 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
150
arovir017ff76c52018-10-09 09:40:58 +0100151 bool IsL2NormalizationSupported(const TensorInfo& input,
152 const TensorInfo& output,
153 const L2NormalizationDescriptor& descriptor,
154 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
155
Keith Davis69e653f2020-07-02 11:49:26 +0100156 bool IsLogSoftmaxSupported(const TensorInfo& input,
157 const TensorInfo& output,
158 const LogSoftmaxDescriptor& descriptor,
159 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
160
Jan Eilersad5293a2019-07-08 09:57:55 +0100161 bool IsLstmSupported(const TensorInfo& input,
162 const TensorInfo& outputStateIn,
163 const TensorInfo& cellStateIn,
164 const TensorInfo& scratchBuffer,
165 const TensorInfo& outputStateOut,
166 const TensorInfo& cellStateOut,
167 const TensorInfo& output,
168 const LstmDescriptor& descriptor,
169 const LstmInputParamsInfo& paramsInfo,
170 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
171
Nattapat Chaimanowong4e6597a2018-12-20 14:14:06 +0000172 bool IsMaximumSupported(const TensorInfo& input0,
173 const TensorInfo& input1,
174 const TensorInfo& output,
175 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
176
arovir017ff76c52018-10-09 09:40:58 +0100177 bool IsMeanSupported(const TensorInfo& input,
178 const TensorInfo& output,
179 const MeanDescriptor& descriptor,
180 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
181
Jim Flynn906f9462019-05-10 13:55:21 +0100182 ARMNN_DEPRECATED_MSG("Use IsConcatSupported instead")
arovir017ff76c52018-10-09 09:40:58 +0100183 bool IsMergerSupported(const std::vector<const TensorInfo*> inputs,
Nikhil Raj8599a412018-11-19 14:51:07 +0000184 const TensorInfo& output,
Jim Flynne242f2d2019-05-22 14:24:13 +0100185 const MergerDescriptor& descriptor,
arovir017ff76c52018-10-09 09:40:58 +0100186 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
187
Conor Kennedy54b21692019-01-09 07:57:38 +0000188 bool IsMinimumSupported(const TensorInfo& input0,
189 const TensorInfo& input1,
190 const TensorInfo& output,
191 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
192
arovir017ff76c52018-10-09 09:40:58 +0100193 bool IsMultiplicationSupported(const TensorInfo& input0,
194 const TensorInfo& input1,
195 const TensorInfo& output,
196 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
197
Pablo Telloe61f0712020-01-23 10:37:17 +0000198 bool IsDivisionSupported(const TensorInfo& input0,
199 const TensorInfo& input1,
200 const TensorInfo& output,
201 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
202
arovir017ff76c52018-10-09 09:40:58 +0100203 bool IsNormalizationSupported(const TensorInfo& input,
204 const TensorInfo& output,
205 const NormalizationDescriptor& descriptor,
206 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
207
208 bool IsOutputSupported(const TensorInfo& output,
209 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
210
Éanna Ó Catháin12055742019-01-25 10:01:40 +0000211 bool IsPadSupported(const TensorInfo& input,
212 const TensorInfo& output,
213 const PadDescriptor& descriptor,
214 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
215
arovir017ff76c52018-10-09 09:40:58 +0100216 bool IsPermuteSupported(const TensorInfo& input,
217 const TensorInfo& output,
218 const PermuteDescriptor& descriptor,
219 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
220
221 bool IsPooling2dSupported(const TensorInfo& input,
222 const TensorInfo& output,
223 const Pooling2dDescriptor& descriptor,
224 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
225
Nikhil Raj9b461482019-07-03 15:58:31 +0100226 bool IsPreluSupported(const TensorInfo& input,
227 const TensorInfo& alpha,
228 const TensorInfo& output,
229 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
230
James Conroycc340932020-05-12 18:08:52 +0100231 bool IsQLstmSupported(const TensorInfo& input,
232 const TensorInfo& previousOutputIn,
233 const TensorInfo& previousCellStateIn,
234 const TensorInfo& outputStateOut,
235 const TensorInfo& cellStateOut,
236 const TensorInfo& output,
237 const QLstmDescriptor& descriptor,
238 const LstmInputParamsInfo& paramsInfo,
239 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
240
Sadik Armaganfabc2892019-05-31 09:05:11 +0100241 bool IsQuantizeSupported(const TensorInfo& input,
242 const TensorInfo& output,
243 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
244
Francis Murtagh4fc3c482019-08-02 13:20:54 +0100245 bool IsQuantizedLstmSupported(const TensorInfo& input,
246 const TensorInfo& cellStateIn,
247 const TensorInfo& outputStateIn,
248 const TensorInfo& cellStateOut,
249 const TensorInfo& outputStateOut,
250 const QuantizedLstmInputParamsInfo& paramsInfo,
251 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
252
arovir017ff76c52018-10-09 09:40:58 +0100253 bool IsReshapeSupported(const TensorInfo& input,
Kevin Maya023c402019-12-12 17:28:05 +0000254 const TensorInfo& output,
Matteo Martincigh992d6dc2019-01-10 17:34:20 +0000255 const ReshapeDescriptor& descriptor,
arovir017ff76c52018-10-09 09:40:58 +0100256 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
257
Aron Virginas-Tar169d2f12019-07-01 19:01:44 +0100258 bool IsResizeSupported(const TensorInfo& input,
259 const TensorInfo& output,
260 const ResizeDescriptor& descriptor,
261 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
262
263 ARMNN_DEPRECATED_MSG("Use IsResizeSupported instead")
Sadik Armaganc625f002018-12-17 11:32:16 +0000264 bool IsResizeBilinearSupported(const TensorInfo& input,
265 const TensorInfo& output,
266 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
267
josh minor4a3c6102020-01-06 16:40:46 -0600268 ARMNN_DEPRECATED_MSG("Use IsElementwiseUnarySupported instead")
Aron Virginas-Tar0dd3b432019-09-10 13:55:09 +0100269 bool IsRsqrtSupported(const TensorInfo& input,
270 const TensorInfo& output,
271 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
272
josh minor036f02d2019-11-15 14:53:22 -0600273 bool IsSliceSupported(const TensorInfo& input,
274 const TensorInfo& output,
275 const SliceDescriptor& descriptor,
276 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
277
arovir017ff76c52018-10-09 09:40:58 +0100278 bool IsSoftmaxSupported(const TensorInfo& input,
279 const TensorInfo& output,
280 const SoftmaxDescriptor& descriptor,
281 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
282
Mike Kelly0be3a882020-01-24 11:27:50 +0000283 bool IsSpaceToBatchNdSupported(const TensorInfo& input,
284 const TensorInfo& output,
285 const SpaceToBatchNdDescriptor& descriptor,
286 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
287
Ellen Norris-Thompson29794572019-06-26 16:40:36 +0100288 bool IsSpaceToDepthSupported(const TensorInfo& input,
289 const TensorInfo& output,
290 const SpaceToDepthDescriptor& descriptor,
291 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
292
Narumol Prangnawarat15eb5832019-05-20 15:31:05 +0100293 ARMNN_DEPRECATED_MSG("Use IsSplitterSupported with outputs instead")
arovir017ff76c52018-10-09 09:40:58 +0100294 bool IsSplitterSupported(const TensorInfo& input,
295 const ViewsDescriptor& descriptor,
296 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
297
Narumol Prangnawarat15eb5832019-05-20 15:31:05 +0100298 bool IsSplitterSupported(const TensorInfo& input,
299 const std::vector<std::reference_wrapper<TensorInfo>>& outputs,
300 const ViewsDescriptor& descriptor,
301 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
302
Matthew Jackson87f65ea2019-08-01 10:01:34 +0100303 bool IsStackSupported(const std::vector<const TensorInfo*>& inputs,
304 const TensorInfo& output,
305 const StackDescriptor& descriptor,
306 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
307
FinnWilliamsArm1fa19192019-08-02 17:26:31 +0100308 bool IsStridedSliceSupported(const TensorInfo& input,
309 const TensorInfo& output,
310 const StridedSliceDescriptor& descriptor,
311 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
312
arovir017ff76c52018-10-09 09:40:58 +0100313 bool IsSubtractionSupported(const TensorInfo& input0,
314 const TensorInfo& input1,
315 const TensorInfo& output,
316 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
Sadik Armagan581742d2019-08-12 14:11:37 +0100317
318 bool IsTransposeConvolution2dSupported(const TensorInfo& input,
319 const TensorInfo& output,
320 const TransposeConvolution2dDescriptor& descriptor,
321 const TensorInfo& weights,
322 const Optional<TensorInfo>& biases,
323 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
324
Mike Kellyc9ea45a2020-02-28 18:11:58 +0000325 bool IsTransposeSupported(const TensorInfo& input,
326 const TensorInfo& output,
327 const TransposeDescriptor& descriptor,
328 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
329
Aron Virginas-Tarfc824312018-10-15 15:00:13 +0100330}; // class NeonLayerSupport
arovir014424b0a2018-10-04 10:46:04 +0100331
arovir017ff76c52018-10-09 09:40:58 +0100332} // namespace armnn