blob: 75e90e000daee5c8ff5aaa21f2065d9db87e80e4 [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
telsoa01c577f2c2018-08-31 09:22:23 +01007#include <armnn/ArmNN.hpp>
telsoa014fcda012018-03-09 14:13:49 +00008
9namespace armnn
10{
arovir014424b0a2018-10-04 10:46:04 +010011
12class ClLayerSupport : public ILayerSupport
13{
arovir017c22c702018-10-09 11:16:46 +010014public:
15 bool IsActivationSupported(const TensorInfo& input,
16 const TensorInfo& output,
17 const ActivationDescriptor& descriptor,
18 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
19
20 bool IsAdditionSupported(const TensorInfo& input0,
21 const TensorInfo& input1,
22 const TensorInfo& output,
23 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
24
25 bool IsBatchNormalizationSupported(const TensorInfo& input,
26 const TensorInfo& output,
27 const TensorInfo& mean,
28 const TensorInfo& var,
29 const TensorInfo& beta,
30 const TensorInfo& gamma,
31 const BatchNormalizationDescriptor& descriptor,
32 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
33
34 bool IsConstantSupported(const TensorInfo& output,
35 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
36
37 bool IsConvertFp16ToFp32Supported(const TensorInfo& input,
38 const TensorInfo& output,
39 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
40
41 bool IsConvertFp32ToFp16Supported(const TensorInfo& input,
42 const TensorInfo& output,
43 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
44
45 bool IsConvolution2dSupported(const TensorInfo& input,
46 const TensorInfo& output,
47 const Convolution2dDescriptor& descriptor,
48 const TensorInfo& weights,
49 const Optional<TensorInfo>& biases,
50 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
51
52 bool IsDepthwiseConvolutionSupported(const TensorInfo& input,
53 const TensorInfo& output,
54 const DepthwiseConvolution2dDescriptor& descriptor,
55 const TensorInfo& weights,
56 const Optional<TensorInfo>& biases,
57 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
58
59 bool IsDivisionSupported(const TensorInfo& input0,
60 const TensorInfo& input1,
61 const TensorInfo& output,
62 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
63
64 bool IsFakeQuantizationSupported(const TensorInfo& input,
65 const FakeQuantizationDescriptor& descriptor,
66 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
67
68 bool IsFloorSupported(const TensorInfo& input,
69 const TensorInfo& output,
70 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
71
72 bool IsFullyConnectedSupported(const TensorInfo& input,
73 const TensorInfo& output,
74 const TensorInfo& weights,
75 const TensorInfo& biases,
76 const FullyConnectedDescriptor& descriptor,
77 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
78
79 bool IsInputSupported(const TensorInfo& input,
80 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
81
82 bool IsL2NormalizationSupported(const TensorInfo& input,
83 const TensorInfo& output,
84 const L2NormalizationDescriptor& descriptor,
85 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
86
87 bool IsLstmSupported(const TensorInfo& input,
88 const TensorInfo& outputStateIn,
89 const TensorInfo& cellStateIn,
90 const TensorInfo& scratchBuffer,
91 const TensorInfo& outputStateOut,
92 const TensorInfo& cellStateOut,
93 const TensorInfo& output,
94 const LstmDescriptor& descriptor,
95 const TensorInfo& inputToForgetWeights,
96 const TensorInfo& inputToCellWeights,
97 const TensorInfo& inputToOutputWeights,
98 const TensorInfo& recurrentToForgetWeights,
99 const TensorInfo& recurrentToCellWeights,
100 const TensorInfo& recurrentToOutputWeights,
101 const TensorInfo& forgetGateBias,
102 const TensorInfo& cellBias,
103 const TensorInfo& outputGateBias,
104 const TensorInfo* inputToInputWeights,
105 const TensorInfo* recurrentToInputWeights,
106 const TensorInfo* cellToInputWeights,
107 const TensorInfo* inputGateBias,
108 const TensorInfo* projectionWeights,
109 const TensorInfo* projectionBias,
110 const TensorInfo* cellToForgetWeights,
111 const TensorInfo* cellToOutputWeights,
112 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
113
114 bool IsMeanSupported(const TensorInfo& input,
115 const TensorInfo& output,
116 const MeanDescriptor& descriptor,
117 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
118
119 bool IsMergerSupported(const std::vector<const TensorInfo*> inputs,
120 const OriginsDescriptor& descriptor,
121 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
122
123 bool IsMultiplicationSupported(const TensorInfo& input0,
124 const TensorInfo& input1,
125 const TensorInfo& output,
126 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
127
128 bool IsNormalizationSupported(const TensorInfo& input,
129 const TensorInfo& output,
130 const NormalizationDescriptor& descriptor,
131 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
132
133 bool IsOutputSupported(const TensorInfo& output,
134 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
135
136 bool IsPadSupported(const TensorInfo& input,
137 const TensorInfo& output,
138 const PadDescriptor& descriptor,
139 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
140
141 bool IsPermuteSupported(const TensorInfo& input,
142 const TensorInfo& output,
143 const PermuteDescriptor& descriptor,
144 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
145
146 bool IsPooling2dSupported(const TensorInfo& input,
147 const TensorInfo& output,
148 const Pooling2dDescriptor& descriptor,
149 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
150
151 bool IsReshapeSupported(const TensorInfo& input,
152 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
153
154 bool IsResizeBilinearSupported(const TensorInfo& input,
155 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
156
157 bool IsSoftmaxSupported(const TensorInfo& input,
158 const TensorInfo& output,
159 const SoftmaxDescriptor& descriptor,
160 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
161
162 bool IsSplitterSupported(const TensorInfo& input,
163 const ViewsDescriptor& descriptor,
164 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
165
166 bool IsSubtractionSupported(const TensorInfo& input0,
167 const TensorInfo& input1,
168 const TensorInfo& output,
169 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
arovir014424b0a2018-10-04 10:46:04 +0100170};
171
telsoa014fcda012018-03-09 14:13:49 +0000172bool IsClDirectConvolution2dSupported(const TensorInfo& weightInfo, const Convolution2dDescriptor& desc);
arovir01085f0a42018-10-08 14:48:19 +0100173bool IsClDepthwiseConvolution2dDescParamsSupported(Optional<std::string&> reasonIfUnsupported,
telsoa014fcda012018-03-09 14:13:49 +0000174 const DepthwiseConvolution2dDescriptor& parameters,
175 const TensorInfo& weights);
176
177bool IsActivationSupportedCl(const TensorInfo& input,
telsoa01c577f2c2018-08-31 09:22:23 +0100178 const TensorInfo& output,
telsoa014fcda012018-03-09 14:13:49 +0000179 const ActivationDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100180 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000181
182bool IsAdditionSupportedCl(const TensorInfo& input0,
183 const TensorInfo& input1,
184 const TensorInfo& output,
arovir01085f0a42018-10-08 14:48:19 +0100185 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000186
187bool IsBatchNormalizationSupportedCl(const TensorInfo& input,
telsoa01c577f2c2018-08-31 09:22:23 +0100188 const TensorInfo& output,
189 const TensorInfo& mean,
190 const TensorInfo& var,
191 const TensorInfo& beta,
192 const TensorInfo& gamma,
telsoa014fcda012018-03-09 14:13:49 +0000193 const BatchNormalizationDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100194 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000195
196bool IsConstantSupportedCl(const TensorInfo& output,
arovir01085f0a42018-10-08 14:48:19 +0100197 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000198
199bool IsConvolution2dSupportedCl(const TensorInfo& input,
surmeh013537c2c2018-05-18 16:31:43 +0100200 const TensorInfo& output,
telsoa014fcda012018-03-09 14:13:49 +0000201 const Convolution2dDescriptor& descriptor,
202 const TensorInfo& weights,
David Beck5eec11d2018-10-04 15:43:17 +0100203 const Optional<TensorInfo>& biases,
arovir01085f0a42018-10-08 14:48:19 +0100204 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000205
206bool IsDepthwiseConvolutionSupportedCl(const TensorInfo& input,
telsoa01c577f2c2018-08-31 09:22:23 +0100207 const TensorInfo& output,
telsoa014fcda012018-03-09 14:13:49 +0000208 const DepthwiseConvolution2dDescriptor& descriptor,
209 const TensorInfo& weights,
David Beck5eec11d2018-10-04 15:43:17 +0100210 const Optional<TensorInfo>& biases,
arovir01085f0a42018-10-08 14:48:19 +0100211 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000212
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100213bool IsDivisionSupportedCl(const TensorInfo& input0,
214 const TensorInfo& input1,
215 const TensorInfo& output,
arovir01085f0a42018-10-08 14:48:19 +0100216 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100217
David Beckc2044fe2018-09-05 15:00:38 +0100218bool IsSubtractionSupportedCl(const TensorInfo& input0,
219 const TensorInfo& input1,
220 const TensorInfo& output,
arovir01085f0a42018-10-08 14:48:19 +0100221 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
David Beckc2044fe2018-09-05 15:00:38 +0100222
telsoa014fcda012018-03-09 14:13:49 +0000223bool IsFullyConnectedSupportedCl(const TensorInfo& input,
telsoa01c577f2c2018-08-31 09:22:23 +0100224 const TensorInfo& output,
225 const TensorInfo& weights,
226 const TensorInfo& biases,
telsoa014fcda012018-03-09 14:13:49 +0000227 const FullyConnectedDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100228 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000229
230bool IsInputSupportedCl(const TensorInfo& input,
arovir01085f0a42018-10-08 14:48:19 +0100231 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000232
233bool IsL2NormalizationSupportedCl(const TensorInfo& input,
telsoa01c577f2c2018-08-31 09:22:23 +0100234 const TensorInfo& output,
Matteo Martincighbcd3c852018-09-28 14:14:12 +0100235 const L2NormalizationDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100236 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000237
arovir01085f0a42018-10-08 14:48:19 +0100238bool IsLstmSupportedCl(const TensorInfo& input,
239 const TensorInfo& outputStateIn,
240 const TensorInfo& cellStateIn,
241 const TensorInfo& scratchBuffer,
242 const TensorInfo& outputStateOut,
243 const TensorInfo& cellStateOut,
244 const TensorInfo& output,
245 const LstmDescriptor& descriptor,
246 const TensorInfo& inputToForgetWeights,
247 const TensorInfo& inputToCellWeights,
248 const TensorInfo& inputToOutputWeights,
249 const TensorInfo& recurrentToForgetWeights,
250 const TensorInfo& recurrentToCellWeights,
251 const TensorInfo& recurrentToOutputWeights,
252 const TensorInfo& forgetGateBias,
253 const TensorInfo& cellBias,
254 const TensorInfo& outputGateBias,
255 const TensorInfo* inputToInputWeights,
256 const TensorInfo* recurrentToInputWeights,
257 const TensorInfo* cellToInputWeights,
258 const TensorInfo* inputGateBias,
259 const TensorInfo* projectionWeights,
260 const TensorInfo* projectionBias,
261 const TensorInfo* cellToForgetWeights,
262 const TensorInfo* cellToOutputWeights,
263 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa01c577f2c2018-08-31 09:22:23 +0100264
telsoa014fcda012018-03-09 14:13:49 +0000265bool IsMergerSupportedCl(const std::vector<const TensorInfo*> inputs,
266 const OriginsDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100267 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000268
269bool IsMultiplicationSupportedCl(const TensorInfo& input0,
270 const TensorInfo& input1,
telsoa01c577f2c2018-08-31 09:22:23 +0100271 const TensorInfo& output,
arovir01085f0a42018-10-08 14:48:19 +0100272 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000273
274bool IsNormalizationSupportedCl(const TensorInfo& input,
275 const TensorInfo& output,
276 const NormalizationDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100277 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000278
279bool IsOutputSupportedCl(const TensorInfo& output,
arovir01085f0a42018-10-08 14:48:19 +0100280 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
jimfly01e1fa50c2018-09-21 12:09:51 +0100281
telsoa014fcda012018-03-09 14:13:49 +0000282bool IsPermuteSupportedCl(const TensorInfo& input,
283 const TensorInfo& output,
284 const PermuteDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100285 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000286
287bool IsPooling2dSupportedCl(const TensorInfo& input,
288 const TensorInfo& output,
289 const Pooling2dDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100290 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000291
292bool IsResizeBilinearSupportedCl(const TensorInfo& input,
arovir01085f0a42018-10-08 14:48:19 +0100293 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000294
295bool IsSoftmaxSupportedCl(const TensorInfo& input,
telsoa01c577f2c2018-08-31 09:22:23 +0100296 const TensorInfo& output,
telsoa014fcda012018-03-09 14:13:49 +0000297 const SoftmaxDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100298 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000299
300bool IsSplitterSupportedCl(const TensorInfo& input,
301 const ViewsDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100302 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000303
304bool IsFakeQuantizationSupportedCl(const TensorInfo& input,
305 const FakeQuantizationDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100306 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000307
308bool IsReshapeSupportedCl(const TensorInfo& input,
arovir01085f0a42018-10-08 14:48:19 +0100309 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa014fcda012018-03-09 14:13:49 +0000310
311bool IsFloorSupportedCl(const TensorInfo& input,
312 const TensorInfo& output,
arovir01085f0a42018-10-08 14:48:19 +0100313 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
314
315bool IsConvertFp16ToFp32SupportedCl(const TensorInfo& input,
316 const TensorInfo& output,
317 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
318
319bool IsConvertFp32ToFp16SupportedCl(const TensorInfo& input,
320 const TensorInfo& output,
321 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa01c577f2c2018-08-31 09:22:23 +0100322
narpra0132b90462018-09-13 11:07:48 +0100323bool IsMeanSupportedCl(const TensorInfo& input,
324 const TensorInfo& output,
325 const MeanDescriptor& descriptor,
arovir01085f0a42018-10-08 14:48:19 +0100326 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
narpra0132b90462018-09-13 11:07:48 +0100327
arovir01085f0a42018-10-08 14:48:19 +0100328bool IsPadSupportedCl(const TensorInfo& input,
329 const TensorInfo& output,
330 const PadDescriptor& descriptor,
331 Optional<std::string&> reasonIfUnsupported = EmptyOptional());
telsoa01c577f2c2018-08-31 09:22:23 +0100332
telsoa014fcda012018-03-09 14:13:49 +0000333}