blob: b933591a0ecb3c4c7005c02a7a5f9747a0ec051c [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:
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
Jim Flynn906f9462019-05-10 13:55:21 +010034 bool IsConcatSupported(const std::vector<const TensorInfo*> inputs,
35 const TensorInfo& output,
Jim Flynne242f2d2019-05-22 14:24:13 +010036 const ConcatDescriptor& descriptor,
Jim Flynn906f9462019-05-10 13:55:21 +010037 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
38
arovir017ff76c52018-10-09 09:40:58 +010039 bool IsConstantSupported(const TensorInfo& output,
40 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
41
42 bool IsConvertFp16ToFp32Supported(const TensorInfo& input,
43 const TensorInfo& output,
44 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
45
46 bool IsConvertFp32ToFp16Supported(const TensorInfo& input,
47 const TensorInfo& output,
48 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
49
50 bool IsConvolution2dSupported(const TensorInfo& input,
51 const TensorInfo& output,
52 const Convolution2dDescriptor& descriptor,
53 const TensorInfo& weights,
54 const Optional<TensorInfo>& biases,
55 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
56
57 bool IsDepthwiseConvolutionSupported(const TensorInfo& input,
58 const TensorInfo& output,
59 const DepthwiseConvolution2dDescriptor& descriptor,
60 const TensorInfo& weights,
61 const Optional<TensorInfo>& biases,
62 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
63
Pablo Tellof0bd6832019-04-26 17:58:13 +010064 bool IsDilatedDepthwiseConvolutionSupported(const TensorInfo& input,
65 const TensorInfo& output,
66 const DepthwiseConvolution2dDescriptor& descriptor,
67 const TensorInfo& weights,
68 const Optional<TensorInfo>& biases,
69 Optional<std::string&> reason = EmptyOptional()) const override;
70
arovir017ff76c52018-10-09 09:40:58 +010071 bool IsFloorSupported(const TensorInfo& input,
72 const TensorInfo& output,
73 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
74
75 bool IsFullyConnectedSupported(const TensorInfo& input,
76 const TensorInfo& output,
77 const TensorInfo& weights,
78 const TensorInfo& biases,
79 const FullyConnectedDescriptor& descriptor,
80 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
81
kevmay01eed85922019-01-28 08:37:25 +000082 bool IsGreaterSupported(const TensorInfo& input0,
83 const TensorInfo& input1,
84 const TensorInfo& output,
85 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
86
arovir017ff76c52018-10-09 09:40:58 +010087 bool IsInputSupported(const TensorInfo& input,
88 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
89
90 bool IsL2NormalizationSupported(const TensorInfo& input,
91 const TensorInfo& output,
92 const L2NormalizationDescriptor& descriptor,
93 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
94
Nattapat Chaimanowong4e6597a2018-12-20 14:14:06 +000095 bool IsMaximumSupported(const TensorInfo& input0,
96 const TensorInfo& input1,
97 const TensorInfo& output,
98 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
99
arovir017ff76c52018-10-09 09:40:58 +0100100 bool IsMeanSupported(const TensorInfo& input,
101 const TensorInfo& output,
102 const MeanDescriptor& descriptor,
103 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
104
Matteo Martincigh992d6dc2019-01-10 17:34:20 +0000105 bool IsMemCopySupported(const TensorInfo& input,
106 const TensorInfo& output,
107 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
108
Jim Flynn906f9462019-05-10 13:55:21 +0100109 ARMNN_DEPRECATED_MSG("Use IsConcatSupported instead")
arovir017ff76c52018-10-09 09:40:58 +0100110 bool IsMergerSupported(const std::vector<const TensorInfo*> inputs,
Nikhil Raj8599a412018-11-19 14:51:07 +0000111 const TensorInfo& output,
Jim Flynne242f2d2019-05-22 14:24:13 +0100112 const MergerDescriptor& descriptor,
arovir017ff76c52018-10-09 09:40:58 +0100113 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
114
Conor Kennedy54b21692019-01-09 07:57:38 +0000115 bool IsMinimumSupported(const TensorInfo& input0,
116 const TensorInfo& input1,
117 const TensorInfo& output,
118 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
119
arovir017ff76c52018-10-09 09:40:58 +0100120 bool IsMultiplicationSupported(const TensorInfo& input0,
121 const TensorInfo& input1,
122 const TensorInfo& output,
123 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
124
125 bool IsNormalizationSupported(const TensorInfo& input,
126 const TensorInfo& output,
127 const NormalizationDescriptor& descriptor,
128 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
129
130 bool IsOutputSupported(const TensorInfo& output,
131 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
132
Éanna Ó Catháin12055742019-01-25 10:01:40 +0000133 bool IsPadSupported(const TensorInfo& input,
134 const TensorInfo& output,
135 const PadDescriptor& descriptor,
136 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
137
arovir017ff76c52018-10-09 09:40:58 +0100138 bool IsPermuteSupported(const TensorInfo& input,
139 const TensorInfo& output,
140 const PermuteDescriptor& descriptor,
141 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
142
143 bool IsPooling2dSupported(const TensorInfo& input,
144 const TensorInfo& output,
145 const Pooling2dDescriptor& descriptor,
146 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
147
Sadik Armaganfabc2892019-05-31 09:05:11 +0100148 bool IsQuantizeSupported(const TensorInfo& input,
149 const TensorInfo& output,
150 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
151
arovir017ff76c52018-10-09 09:40:58 +0100152 bool IsReshapeSupported(const TensorInfo& input,
Matteo Martincigh992d6dc2019-01-10 17:34:20 +0000153 const ReshapeDescriptor& descriptor,
arovir017ff76c52018-10-09 09:40:58 +0100154 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
155
Sadik Armaganc625f002018-12-17 11:32:16 +0000156 bool IsResizeBilinearSupported(const TensorInfo& input,
157 const TensorInfo& output,
158 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
159
arovir017ff76c52018-10-09 09:40:58 +0100160 bool IsSoftmaxSupported(const TensorInfo& input,
161 const TensorInfo& output,
162 const SoftmaxDescriptor& descriptor,
163 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
164
Narumol Prangnawarat15eb5832019-05-20 15:31:05 +0100165 ARMNN_DEPRECATED_MSG("Use IsSplitterSupported with outputs instead")
arovir017ff76c52018-10-09 09:40:58 +0100166 bool IsSplitterSupported(const TensorInfo& input,
167 const ViewsDescriptor& descriptor,
168 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
169
Narumol Prangnawarat15eb5832019-05-20 15:31:05 +0100170 bool IsSplitterSupported(const TensorInfo& input,
171 const std::vector<std::reference_wrapper<TensorInfo>>& outputs,
172 const ViewsDescriptor& descriptor,
173 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
174
arovir017ff76c52018-10-09 09:40:58 +0100175 bool IsSubtractionSupported(const TensorInfo& input0,
176 const TensorInfo& input1,
177 const TensorInfo& output,
178 Optional<std::string&> reasonIfUnsupported = EmptyOptional()) const override;
Aron Virginas-Tarfc824312018-10-15 15:00:13 +0100179}; // class NeonLayerSupport
arovir014424b0a2018-10-04 10:46:04 +0100180
arovir017ff76c52018-10-09 09:40:58 +0100181} // namespace armnn