blob: d4f005155d002b90a1e4b827b0086edc8cc7de6b [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//
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
63 bool IsConvertFp16ToFp32Supported(const TensorInfo& input,
64 const TensorInfo& output,
65 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
66
67 bool IsConvertFp32ToFp16Supported(const TensorInfo& input,
68 const TensorInfo& output,
69 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
70
71 bool IsConvolution2dSupported(const TensorInfo& input,
72 const TensorInfo& output,
73 const Convolution2dDescriptor& descriptor,
74 const TensorInfo& weights,
75 const Optional<TensorInfo>& biases,
76 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
77
Aron Virginas-Tar2f00b742019-09-30 13:28:08 +010078 bool IsDepthToSpaceSupported(const TensorInfo& input,
79 const TensorInfo& output,
80 const DepthToSpaceDescriptor& descriptor,
81 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
82
83
arovir017ff76c52018-10-09 09:40:58 +010084 bool IsDepthwiseConvolutionSupported(const TensorInfo& input,
85 const TensorInfo& output,
86 const DepthwiseConvolution2dDescriptor& descriptor,
87 const TensorInfo& weights,
88 const Optional<TensorInfo>& biases,
89 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
90
Narumol Prangnawarat01961a72019-05-30 16:47:12 +010091 bool IsDequantizeSupported(const TensorInfo& input,
92 const TensorInfo& output,
93 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
94
Derek Lamberti6a5e5e82019-12-05 14:41:20 +000095 bool IsDetectionPostProcessSupported(const TensorInfo& boxEncodings,
96 const TensorInfo& scores,
97 const TensorInfo& anchors,
98 const TensorInfo& detectionBoxes,
99 const TensorInfo& detectionClasses,
100 const TensorInfo& detectionScores,
101 const TensorInfo& numDetections,
102 const DetectionPostProcessDescriptor& descriptor,
103 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
104
Pablo Tellof0bd6832019-04-26 17:58:13 +0100105 bool IsDilatedDepthwiseConvolutionSupported(const TensorInfo& input,
106 const TensorInfo& output,
107 const DepthwiseConvolution2dDescriptor& descriptor,
108 const TensorInfo& weights,
109 const Optional<TensorInfo>& biases,
110 Optional<std::string&> reason = EmptyOptional()) const override;
111
josh minor4a3c6102020-01-06 16:40:46 -0600112 bool IsElementwiseUnarySupported(const TensorInfo& input,
113 const TensorInfo& output,
114 const ElementwiseUnaryDescriptor& descriptor,
115 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
116
arovir017ff76c52018-10-09 09:40:58 +0100117 bool IsFloorSupported(const TensorInfo& input,
118 const TensorInfo& output,
119 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
120
121 bool IsFullyConnectedSupported(const TensorInfo& input,
122 const TensorInfo& output,
123 const TensorInfo& weights,
124 const TensorInfo& biases,
125 const FullyConnectedDescriptor& descriptor,
126 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
127
Aron Virginas-Tar77bfb5e2019-10-16 17:45:38 +0100128 ARMNN_DEPRECATED_MSG("Use IsComparisonSupported instead")
kevmay01eed85922019-01-28 08:37:25 +0000129 bool IsGreaterSupported(const TensorInfo& input0,
130 const TensorInfo& input1,
131 const TensorInfo& output,
132 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
133
arovir017ff76c52018-10-09 09:40:58 +0100134 bool IsInputSupported(const TensorInfo& input,
135 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
136
Sadik Armagan0d4863d2019-10-09 14:26:32 +0100137 bool IsInstanceNormalizationSupported(const TensorInfo& input,
138 const TensorInfo& output,
139 const InstanceNormalizationDescriptor& descriptor,
140 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
141
arovir017ff76c52018-10-09 09:40:58 +0100142 bool IsL2NormalizationSupported(const TensorInfo& input,
143 const TensorInfo& output,
144 const L2NormalizationDescriptor& descriptor,
145 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
146
Jan Eilersad5293a2019-07-08 09:57:55 +0100147 bool IsLstmSupported(const TensorInfo& input,
148 const TensorInfo& outputStateIn,
149 const TensorInfo& cellStateIn,
150 const TensorInfo& scratchBuffer,
151 const TensorInfo& outputStateOut,
152 const TensorInfo& cellStateOut,
153 const TensorInfo& output,
154 const LstmDescriptor& descriptor,
155 const LstmInputParamsInfo& paramsInfo,
156 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
157
Nattapat Chaimanowong4e6597a2018-12-20 14:14:06 +0000158 bool IsMaximumSupported(const TensorInfo& input0,
159 const TensorInfo& input1,
160 const TensorInfo& output,
161 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
162
arovir017ff76c52018-10-09 09:40:58 +0100163 bool IsMeanSupported(const TensorInfo& input,
164 const TensorInfo& output,
165 const MeanDescriptor& descriptor,
166 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
167
Jim Flynn906f9462019-05-10 13:55:21 +0100168 ARMNN_DEPRECATED_MSG("Use IsConcatSupported instead")
arovir017ff76c52018-10-09 09:40:58 +0100169 bool IsMergerSupported(const std::vector<const TensorInfo*> inputs,
Nikhil Raj8599a412018-11-19 14:51:07 +0000170 const TensorInfo& output,
Jim Flynne242f2d2019-05-22 14:24:13 +0100171 const MergerDescriptor& descriptor,
arovir017ff76c52018-10-09 09:40:58 +0100172 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
173
Conor Kennedy54b21692019-01-09 07:57:38 +0000174 bool IsMinimumSupported(const TensorInfo& input0,
175 const TensorInfo& input1,
176 const TensorInfo& output,
177 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
178
arovir017ff76c52018-10-09 09:40:58 +0100179 bool IsMultiplicationSupported(const TensorInfo& input0,
180 const TensorInfo& input1,
181 const TensorInfo& output,
182 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
183
Pablo Telloe61f0712020-01-23 10:37:17 +0000184 bool IsDivisionSupported(const TensorInfo& input0,
185 const TensorInfo& input1,
186 const TensorInfo& output,
187 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
188
arovir017ff76c52018-10-09 09:40:58 +0100189 bool IsNormalizationSupported(const TensorInfo& input,
190 const TensorInfo& output,
191 const NormalizationDescriptor& descriptor,
192 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
193
194 bool IsOutputSupported(const TensorInfo& output,
195 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
196
Éanna Ó Catháin12055742019-01-25 10:01:40 +0000197 bool IsPadSupported(const TensorInfo& input,
198 const TensorInfo& output,
199 const PadDescriptor& descriptor,
200 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
201
arovir017ff76c52018-10-09 09:40:58 +0100202 bool IsPermuteSupported(const TensorInfo& input,
203 const TensorInfo& output,
204 const PermuteDescriptor& descriptor,
205 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
206
207 bool IsPooling2dSupported(const TensorInfo& input,
208 const TensorInfo& output,
209 const Pooling2dDescriptor& descriptor,
210 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
211
Nikhil Raj9b461482019-07-03 15:58:31 +0100212 bool IsPreluSupported(const TensorInfo& input,
213 const TensorInfo& alpha,
214 const TensorInfo& output,
215 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
216
Sadik Armaganfabc2892019-05-31 09:05:11 +0100217 bool IsQuantizeSupported(const TensorInfo& input,
218 const TensorInfo& output,
219 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
220
Francis Murtagh4fc3c482019-08-02 13:20:54 +0100221 bool IsQuantizedLstmSupported(const TensorInfo& input,
222 const TensorInfo& cellStateIn,
223 const TensorInfo& outputStateIn,
224 const TensorInfo& cellStateOut,
225 const TensorInfo& outputStateOut,
226 const QuantizedLstmInputParamsInfo& paramsInfo,
227 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
228
arovir017ff76c52018-10-09 09:40:58 +0100229 bool IsReshapeSupported(const TensorInfo& input,
Kevin Maya023c402019-12-12 17:28:05 +0000230 const TensorInfo& output,
Matteo Martincigh992d6dc2019-01-10 17:34:20 +0000231 const ReshapeDescriptor& descriptor,
arovir017ff76c52018-10-09 09:40:58 +0100232 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
233
Aron Virginas-Tar169d2f12019-07-01 19:01:44 +0100234 bool IsResizeSupported(const TensorInfo& input,
235 const TensorInfo& output,
236 const ResizeDescriptor& descriptor,
237 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
238
239 ARMNN_DEPRECATED_MSG("Use IsResizeSupported instead")
Sadik Armaganc625f002018-12-17 11:32:16 +0000240 bool IsResizeBilinearSupported(const TensorInfo& input,
241 const TensorInfo& output,
242 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
243
josh minor4a3c6102020-01-06 16:40:46 -0600244 ARMNN_DEPRECATED_MSG("Use IsElementwiseUnarySupported instead")
Aron Virginas-Tar0dd3b432019-09-10 13:55:09 +0100245 bool IsRsqrtSupported(const TensorInfo& input,
246 const TensorInfo& output,
247 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
248
josh minor036f02d2019-11-15 14:53:22 -0600249 bool IsSliceSupported(const TensorInfo& input,
250 const TensorInfo& output,
251 const SliceDescriptor& descriptor,
252 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
253
arovir017ff76c52018-10-09 09:40:58 +0100254 bool IsSoftmaxSupported(const TensorInfo& input,
255 const TensorInfo& output,
256 const SoftmaxDescriptor& descriptor,
257 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
258
Mike Kelly0be3a882020-01-24 11:27:50 +0000259 bool IsSpaceToBatchNdSupported(const TensorInfo& input,
260 const TensorInfo& output,
261 const SpaceToBatchNdDescriptor& descriptor,
262 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
263
Ellen Norris-Thompson29794572019-06-26 16:40:36 +0100264 bool IsSpaceToDepthSupported(const TensorInfo& input,
265 const TensorInfo& output,
266 const SpaceToDepthDescriptor& descriptor,
267 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
268
Narumol Prangnawarat15eb5832019-05-20 15:31:05 +0100269 ARMNN_DEPRECATED_MSG("Use IsSplitterSupported with outputs instead")
arovir017ff76c52018-10-09 09:40:58 +0100270 bool IsSplitterSupported(const TensorInfo& input,
271 const ViewsDescriptor& descriptor,
272 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
273
Narumol Prangnawarat15eb5832019-05-20 15:31:05 +0100274 bool IsSplitterSupported(const TensorInfo& input,
275 const std::vector<std::reference_wrapper<TensorInfo>>& outputs,
276 const ViewsDescriptor& descriptor,
277 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
278
Matthew Jackson87f65ea2019-08-01 10:01:34 +0100279 bool IsStackSupported(const std::vector<const TensorInfo*>& inputs,
280 const TensorInfo& output,
281 const StackDescriptor& descriptor,
282 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
283
FinnWilliamsArm1fa19192019-08-02 17:26:31 +0100284 bool IsStridedSliceSupported(const TensorInfo& input,
285 const TensorInfo& output,
286 const StridedSliceDescriptor& descriptor,
287 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
288
arovir017ff76c52018-10-09 09:40:58 +0100289 bool IsSubtractionSupported(const TensorInfo& input0,
290 const TensorInfo& input1,
291 const TensorInfo& output,
292 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
Sadik Armagan581742d2019-08-12 14:11:37 +0100293
294 bool IsTransposeConvolution2dSupported(const TensorInfo& input,
295 const TensorInfo& output,
296 const TransposeConvolution2dDescriptor& descriptor,
297 const TensorInfo& weights,
298 const Optional<TensorInfo>& biases,
299 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
300
Aron Virginas-Tarfc824312018-10-15 15:00:13 +0100301}; // class NeonLayerSupport
arovir014424b0a2018-10-04 10:46:04 +0100302
arovir017ff76c52018-10-09 09:40:58 +0100303} // namespace armnn