aboutsummaryrefslogtreecommitdiff
path: root/Documentation/_cl_layer_support_8cpp_source.html
blob: 4361b7ccf27300b7e7f0e7d8416fc6cdf82c6451 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.13"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>ArmNN: src/backends/cl/ClLayerSupport.cpp Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
  $(document).ready(initResizable);
</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectalign" style="padding-left: 0.5em;">
   <div id="projectname">ArmNN
   &#160;<span id="projectnumber">NotReleased</span>
   </div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.13 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
$(function() {
  initMenu('',true,false,'search.php','Search');
  $(document).ready(function() { init_search(); });
});
</script>
<div id="main-nav"></div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
      <div id="nav-sync" class="sync"></div>
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;" 
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('_cl_layer_support_8cpp_source.html','');});
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

<div class="header">
  <div class="headertitle">
<div class="title">ClLayerSupport.cpp</div>  </div>
</div><!--header-->
<div class="contents">
<a href="_cl_layer_support_8cpp.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno">    1</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00002"></a><span class="lineno">    2</span>&#160;<span class="comment">// Copyright © 2017 Arm Ltd. All rights reserved.</span></div><div class="line"><a name="l00003"></a><span class="lineno">    3</span>&#160;<span class="comment">// SPDX-License-Identifier: MIT</span></div><div class="line"><a name="l00004"></a><span class="lineno">    4</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00005"></a><span class="lineno">    5</span>&#160;</div><div class="line"><a name="l00006"></a><span class="lineno">    6</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_layer_support_8hpp.html">ClLayerSupport.hpp</a>&quot;</span></div><div class="line"><a name="l00007"></a><span class="lineno">    7</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_backend_id_8hpp.html">ClBackendId.hpp</a>&quot;</span></div><div class="line"><a name="l00008"></a><span class="lineno">    8</span>&#160;</div><div class="line"><a name="l00009"></a><span class="lineno">    9</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_descriptors_8hpp.html">armnn/Descriptors.hpp</a>&gt;</span></div><div class="line"><a name="l00010"></a><span class="lineno">   10</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_backend_registry_8hpp.html">armnn/BackendRegistry.hpp</a>&gt;</span></div><div class="line"><a name="l00011"></a><span class="lineno">   11</span>&#160;</div><div class="line"><a name="l00012"></a><span class="lineno">   12</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_internal_types_8hpp.html">InternalTypes.hpp</a>&gt;</span></div><div class="line"><a name="l00013"></a><span class="lineno">   13</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_layer_support_common_8hpp.html">LayerSupportCommon.hpp</a>&gt;</span></div><div class="line"><a name="l00014"></a><span class="lineno">   14</span>&#160;</div><div class="line"><a name="l00015"></a><span class="lineno">   15</span>&#160;<span class="preprocessor">#include &lt;boost/core/ignore_unused.hpp&gt;</span></div><div class="line"><a name="l00016"></a><span class="lineno">   16</span>&#160;</div><div class="line"><a name="l00017"></a><span class="lineno">   17</span>&#160;<span class="preprocessor">#if defined(ARMCOMPUTECL_ENABLED)</span></div><div class="line"><a name="l00018"></a><span class="lineno">   18</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_arm_compute_utils_8hpp.html">aclCommon/ArmComputeUtils.hpp</a>&gt;</span></div><div class="line"><a name="l00019"></a><span class="lineno">   19</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_arm_compute_tensor_utils_8hpp.html">aclCommon/ArmComputeTensorUtils.hpp</a>&gt;</span></div><div class="line"><a name="l00020"></a><span class="lineno">   20</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_abs_workload_8hpp.html">workloads/ClAbsWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00021"></a><span class="lineno">   21</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_addition_workload_8hpp.html">workloads/ClAdditionWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00022"></a><span class="lineno">   22</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_activation_workload_8hpp.html">workloads/ClActivationWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00023"></a><span class="lineno">   23</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_arg_min_max_workload_8hpp.html">workloads/ClArgMinMaxWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00024"></a><span class="lineno">   24</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_batch_normalization_float_workload_8hpp.html">workloads/ClBatchNormalizationFloatWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00025"></a><span class="lineno">   25</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_batch_to_space_nd_workload_8hpp.html">workloads/ClBatchToSpaceNdWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00026"></a><span class="lineno">   26</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_convert_fp16_to_fp32_workload_8hpp.html">workloads/ClConvertFp16ToFp32Workload.hpp</a>&quot;</span></div><div class="line"><a name="l00027"></a><span class="lineno">   27</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_convert_fp32_to_fp16_workload_8hpp.html">workloads/ClConvertFp32ToFp16Workload.hpp</a>&quot;</span></div><div class="line"><a name="l00028"></a><span class="lineno">   28</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_convolution2d_workload_8hpp.html">workloads/ClConvolution2dWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00029"></a><span class="lineno">   29</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_depth_to_space_workload_8hpp.html">workloads/ClDepthToSpaceWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00030"></a><span class="lineno">   30</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_depthwise_convolution_workload_8hpp.html">workloads/ClDepthwiseConvolutionWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00031"></a><span class="lineno">   31</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_dequantize_workload_8hpp.html">workloads/ClDequantizeWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00032"></a><span class="lineno">   32</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_division_float_workload_8hpp.html">workloads/ClDivisionFloatWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00033"></a><span class="lineno">   33</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_floor_float_workload_8hpp.html">workloads/ClFloorFloatWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00034"></a><span class="lineno">   34</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_fully_connected_workload_8hpp.html">workloads/ClFullyConnectedWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00035"></a><span class="lineno">   35</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_greater_workload_8hpp.html">workloads/ClGreaterWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00036"></a><span class="lineno">   36</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_instance_normalization_workload_8hpp.html">workloads/ClInstanceNormalizationWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00037"></a><span class="lineno">   37</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_l2_normalization_float_workload_8hpp.html">workloads/ClL2NormalizationFloatWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00038"></a><span class="lineno">   38</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_lstm_float_workload_8hpp.html">workloads/ClLstmFloatWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00039"></a><span class="lineno">   39</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_maximum_workload_8hpp.html">workloads/ClMaximumWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00040"></a><span class="lineno">   40</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_mean_workload_8hpp.html">workloads/ClMeanWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00041"></a><span class="lineno">   41</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_concat_workload_8hpp.html">workloads/ClConcatWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00042"></a><span class="lineno">   42</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_minimum_workload_8hpp.html">workloads/ClMinimumWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00043"></a><span class="lineno">   43</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_multiplication_workload_8hpp.html">workloads/ClMultiplicationWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00044"></a><span class="lineno">   44</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_normalization_float_workload_8hpp.html">workloads/ClNormalizationFloatWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00045"></a><span class="lineno">   45</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_pad_workload_8hpp.html">workloads/ClPadWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00046"></a><span class="lineno">   46</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_permute_workload_8hpp.html">workloads/ClPermuteWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00047"></a><span class="lineno">   47</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_pooling2d_workload_8hpp.html">workloads/ClPooling2dWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00048"></a><span class="lineno">   48</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_prelu_workload_8hpp.html">workloads/ClPreluWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00049"></a><span class="lineno">   49</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_reshape_workload_8hpp.html">workloads/ClReshapeWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00050"></a><span class="lineno">   50</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_resize_workload_8hpp.html">workloads/ClResizeWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00051"></a><span class="lineno">   51</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_rsqrt_workload_8hpp.html">workloads/ClRsqrtWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00052"></a><span class="lineno">   52</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_quantized_lstm_workload_8hpp.html">workloads/ClQuantizedLstmWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00053"></a><span class="lineno">   53</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_quantize_workload_8hpp.html">workloads/ClQuantizeWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00054"></a><span class="lineno">   54</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_slice_workload_8hpp.html">workloads/ClSliceWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00055"></a><span class="lineno">   55</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_softmax_base_workload_8hpp.html">workloads/ClSoftmaxBaseWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00056"></a><span class="lineno">   56</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_space_to_batch_nd_workload_8hpp.html">workloads/ClSpaceToBatchNdWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00057"></a><span class="lineno">   57</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_space_to_depth_workload_8hpp.html">workloads/ClSpaceToDepthWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00058"></a><span class="lineno">   58</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_splitter_workload_8hpp.html">workloads/ClSplitterWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00059"></a><span class="lineno">   59</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_stack_workload_8hpp.html">workloads/ClStackWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00060"></a><span class="lineno">   60</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_strided_slice_workload_8hpp.html">workloads/ClStridedSliceWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00061"></a><span class="lineno">   61</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_subtraction_workload_8hpp.html">workloads/ClSubtractionWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00062"></a><span class="lineno">   62</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="_cl_transpose_convolution2d_workload_8hpp.html">workloads/ClTransposeConvolution2dWorkload.hpp</a>&quot;</span></div><div class="line"><a name="l00063"></a><span class="lineno">   63</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00064"></a><span class="lineno">   64</span>&#160;</div><div class="line"><a name="l00065"></a><span class="lineno">   65</span>&#160;<span class="keyword">using namespace </span><a class="code" href="namespaceboost.html">boost</a>;</div><div class="line"><a name="l00066"></a><span class="lineno">   66</span>&#160;</div><div class="line"><a name="l00067"></a><span class="lineno">   67</span>&#160;<span class="keyword">namespace </span><a class="code" href="namespacearmnn.html">armnn</a></div><div class="line"><a name="l00068"></a><span class="lineno">   68</span>&#160;{</div><div class="line"><a name="l00069"></a><span class="lineno">   69</span>&#160;</div><div class="line"><a name="l00070"></a><span class="lineno">   70</span>&#160;<span class="keyword">namespace</span></div><div class="line"><a name="l00071"></a><span class="lineno">   71</span>&#160;{</div><div class="line"><a name="l00072"></a><span class="lineno">   72</span>&#160;</div><div class="line"><a name="l00073"></a><span class="lineno">   73</span>&#160;<span class="keyword">template</span>&lt;<span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> FilterSize&gt;</div><div class="line"><a name="l00074"></a><span class="lineno">   74</span>&#160;<span class="keywordtype">bool</span> IsMatchingSize2d(<span class="keyword">const</span> TensorInfo&amp; weightInfo)</div><div class="line"><a name="l00075"></a><span class="lineno">   75</span>&#160;{</div><div class="line"><a name="l00076"></a><span class="lineno">   76</span>&#160;    <span class="comment">// Width &amp; Height must match.</span></div><div class="line"><a name="l00077"></a><span class="lineno">   77</span>&#160;    <span class="keywordflow">return</span> (weightInfo.GetShape()[3] == FilterSize) &amp;&amp; (weightInfo.GetShape()[2] == FilterSize);</div><div class="line"><a name="l00078"></a><span class="lineno">   78</span>&#160;}</div><div class="line"><a name="l00079"></a><span class="lineno">   79</span>&#160;</div><div class="line"><a name="l00080"></a><span class="lineno">   80</span>&#160;<span class="keyword">template</span>&lt;u<span class="keywordtype">int</span>32_t Val<span class="keywordtype">id</span>Str<span class="keywordtype">id</span>e&gt;</div><div class="line"><a name="l00081"></a><span class="lineno">   81</span>&#160;<span class="keywordtype">bool</span> IsMatchingStride(uint32_t actualStride)</div><div class="line"><a name="l00082"></a><span class="lineno">   82</span>&#160;{</div><div class="line"><a name="l00083"></a><span class="lineno">   83</span>&#160;    <span class="keywordflow">return</span> ValidStride == actualStride;</div><div class="line"><a name="l00084"></a><span class="lineno">   84</span>&#160;}</div><div class="line"><a name="l00085"></a><span class="lineno">   85</span>&#160;</div><div class="line"><a name="l00086"></a><span class="lineno">   86</span>&#160;<span class="keyword">template</span>&lt;uint32_t FirstStride, uint32_t SecondStride, uint32_t... ValidStrides&gt;</div><div class="line"><a name="l00087"></a><span class="lineno">   87</span>&#160;<span class="keywordtype">bool</span> IsMatchingStride(uint32_t actualStride)</div><div class="line"><a name="l00088"></a><span class="lineno">   88</span>&#160;{</div><div class="line"><a name="l00089"></a><span class="lineno">   89</span>&#160;    <span class="keywordflow">return</span> IsMatchingStride&lt;FirstStride&gt;(actualStride) || IsMatchingStride&lt;SecondStride, ValidStrides...&gt;(actualStride);</div><div class="line"><a name="l00090"></a><span class="lineno">   90</span>&#160;}</div><div class="line"><a name="l00091"></a><span class="lineno">   91</span>&#160;</div><div class="line"><a name="l00092"></a><span class="lineno">   92</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">typename</span> ... Args&gt;</div><div class="line"><a name="l00093"></a><span class="lineno">   93</span>&#160;<span class="keywordtype">bool</span> IsClBackendSupported(Optional&lt;std::string&amp;&gt; reasonIfUnsupported, Args... args)</div><div class="line"><a name="l00094"></a><span class="lineno">   94</span>&#160;{</div><div class="line"><a name="l00095"></a><span class="lineno">   95</span>&#160;    boost::ignore_unused(reasonIfUnsupported, (args)...);</div><div class="line"><a name="l00096"></a><span class="lineno">   96</span>&#160;<span class="preprocessor">#if defined(ARMCOMPUTECL_ENABLED)</span></div><div class="line"><a name="l00097"></a><span class="lineno">   97</span>&#160;    <span class="keywordflow">return</span> <span class="keyword">true</span>;</div><div class="line"><a name="l00098"></a><span class="lineno">   98</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00099"></a><span class="lineno">   99</span>&#160;    <span class="keywordflow">if</span> (reasonIfUnsupported)</div><div class="line"><a name="l00100"></a><span class="lineno">  100</span>&#160;    {</div><div class="line"><a name="l00101"></a><span class="lineno">  101</span>&#160;        reasonIfUnsupported.value() = <span class="stringliteral">&quot;The armnn library has been built without CL support&quot;</span>;</div><div class="line"><a name="l00102"></a><span class="lineno">  102</span>&#160;    }</div><div class="line"><a name="l00103"></a><span class="lineno">  103</span>&#160;    <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00104"></a><span class="lineno">  104</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00105"></a><span class="lineno">  105</span>&#160;}</div><div class="line"><a name="l00106"></a><span class="lineno">  106</span>&#160;</div><div class="line"><a name="l00107"></a><span class="lineno">  107</span>&#160;<span class="preprocessor">#if defined(ARMCOMPUTECL_ENABLED)</span></div><div class="line"><a name="l00108"></a><span class="lineno"><a class="line" href="_cl_layer_support_8cpp.html#a5cced62cc843be3b7f0614fc73d2c93b">  108</a></span>&#160;<span class="preprocessor">#define FORWARD_CL_LAYER_SUPPORT_FUNC(expr) (expr)</span></div><div class="line"><a name="l00109"></a><span class="lineno">  109</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00110"></a><span class="lineno">  110</span>&#160;<span class="preprocessor">#define FORWARD_CL_LAYER_SUPPORT_FUNC(expr) IsClBackendSupported(reasonIfUnsupported)</span></div><div class="line"><a name="l00111"></a><span class="lineno">  111</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00112"></a><span class="lineno">  112</span>&#160;</div><div class="line"><a name="l00113"></a><span class="lineno">  113</span>&#160;<span class="preprocessor">#if defined(ARMCOMPUTECL_ENABLED)</span></div><div class="line"><a name="l00114"></a><span class="lineno">  114</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">class </span>FuncType, <span class="keyword">class</span>... Args&gt;</div><div class="line"><a name="l00115"></a><span class="lineno">  115</span>&#160;<span class="keyword">inline</span> <span class="keywordtype">bool</span> IsWorkloadSupported(FuncType&amp;&amp; func, Optional&lt;std::string&amp;&gt; reasonIfUnsupported, Args&amp;&amp;... args)</div><div class="line"><a name="l00116"></a><span class="lineno">  116</span>&#160;{</div><div class="line"><a name="l00117"></a><span class="lineno">  117</span>&#160;    <a class="code" href="namespacearmnn.html#a67a0db04d321a74b7e7fcfd3f1a3f70b">arm_compute::Status</a> aclStatus = func(std::forward&lt;Args&gt;(args)...);</div><div class="line"><a name="l00118"></a><span class="lineno">  118</span>&#160;    <span class="keyword">const</span> <span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a02847c99a2acae3b267615479f93ab55">supported</a> = (aclStatus.error_code() == arm_compute::ErrorCode::OK);</div><div class="line"><a name="l00119"></a><span class="lineno">  119</span>&#160;    <span class="keywordflow">if</span> (!supported &amp;&amp; reasonIfUnsupported)</div><div class="line"><a name="l00120"></a><span class="lineno">  120</span>&#160;    {</div><div class="line"><a name="l00121"></a><span class="lineno">  121</span>&#160;        reasonIfUnsupported.value() = aclStatus.error_description();</div><div class="line"><a name="l00122"></a><span class="lineno">  122</span>&#160;    }</div><div class="line"><a name="l00123"></a><span class="lineno">  123</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="namespacearmnn.html#a02847c99a2acae3b267615479f93ab55">supported</a>;</div><div class="line"><a name="l00124"></a><span class="lineno">  124</span>&#160;}</div><div class="line"><a name="l00125"></a><span class="lineno">  125</span>&#160;</div><div class="line"><a name="l00126"></a><span class="lineno"><a class="line" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">  126</a></span>&#160;<span class="preprocessor">#define FORWARD_WORKLOAD_VALIDATE_FUNC(func, reasonIfUnsupported, ...) \</span></div><div class="line"><a name="l00127"></a><span class="lineno">  127</span>&#160;<span class="preprocessor">    return IsWorkloadSupported(func, reasonIfUnsupported, __VA_ARGS__);</span></div><div class="line"><a name="l00128"></a><span class="lineno">  128</span>&#160;<span class="preprocessor">#else</span></div><div class="line"><a name="l00129"></a><span class="lineno">  129</span>&#160;<span class="preprocessor">#define FORWARD_WORKLOAD_VALIDATE_FUNC(func, reasonIfUnsupported, ...) \</span></div><div class="line"><a name="l00130"></a><span class="lineno">  130</span>&#160;<span class="preprocessor">    return IsClBackendSupported(reasonIfUnsupported, __VA_ARGS__);</span></div><div class="line"><a name="l00131"></a><span class="lineno">  131</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00132"></a><span class="lineno">  132</span>&#160;</div><div class="line"><a name="l00133"></a><span class="lineno">  133</span>&#160;<span class="keyword">template</span>&lt;<span class="keyword">typename</span> FloatFunc, <span class="keyword">typename</span> Uint8Func, <span class="keyword">typename</span> ... Params&gt;</div><div class="line"><a name="l00134"></a><span class="lineno">  134</span>&#160;<span class="keywordtype">bool</span> IsSupportedForDataTypeCl(Optional&lt;std::string&amp;&gt; reasonIfUnsupported,</div><div class="line"><a name="l00135"></a><span class="lineno">  135</span>&#160;                              <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> dataType,</div><div class="line"><a name="l00136"></a><span class="lineno">  136</span>&#160;                              FloatFunc floatFuncPtr,</div><div class="line"><a name="l00137"></a><span class="lineno">  137</span>&#160;                              Uint8Func uint8FuncPtr,</div><div class="line"><a name="l00138"></a><span class="lineno">  138</span>&#160;                              Params&amp;&amp;... params)</div><div class="line"><a name="l00139"></a><span class="lineno">  139</span>&#160;{</div><div class="line"><a name="l00140"></a><span class="lineno">  140</span>&#160;    <span class="keywordflow">return</span> IsClBackendSupported(reasonIfUnsupported) &amp;&amp;</div><div class="line"><a name="l00141"></a><span class="lineno">  141</span>&#160;        <a class="code" href="namespacearmnn.html#af6dbe371ec651a8e0063624fdf32afc0">IsSupportedForDataTypeGeneric</a>(reasonIfUnsupported,</div><div class="line"><a name="l00142"></a><span class="lineno">  142</span>&#160;                                      dataType,</div><div class="line"><a name="l00143"></a><span class="lineno">  143</span>&#160;                                      floatFuncPtr,</div><div class="line"><a name="l00144"></a><span class="lineno">  144</span>&#160;                                      floatFuncPtr,</div><div class="line"><a name="l00145"></a><span class="lineno">  145</span>&#160;                                      uint8FuncPtr,</div><div class="line"><a name="l00146"></a><span class="lineno">  146</span>&#160;                                      &amp;FalseFunc&lt;&gt;,</div><div class="line"><a name="l00147"></a><span class="lineno">  147</span>&#160;                                      &amp;FalseFunc&lt;&gt;,</div><div class="line"><a name="l00148"></a><span class="lineno">  148</span>&#160;                                      std::forward&lt;Params&gt;(params)...);</div><div class="line"><a name="l00149"></a><span class="lineno">  149</span>&#160;}</div><div class="line"><a name="l00150"></a><span class="lineno">  150</span>&#160;} <span class="comment">// anonymous namespace</span></div><div class="line"><a name="l00151"></a><span class="lineno">  151</span>&#160;</div><div class="line"><a name="l00152"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#abd7fa8c2233f8a653e30ae2f3b839d92">  152</a></span>&#160;<span class="keywordtype">bool</span> ClLayerSupport::IsAbsSupported(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00153"></a><span class="lineno">  153</span>&#160;                                    <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00154"></a><span class="lineno">  154</span>&#160;                                    <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00155"></a><span class="lineno">  155</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00156"></a><span class="lineno">  156</span>&#160;    <a class="code" href="structarmnn_1_1_elementwise_unary_descriptor.html">ElementwiseUnaryDescriptor</a> descriptor(UnaryOperation::Abs);</div><div class="line"><a name="l00157"></a><span class="lineno">  157</span>&#160;    <span class="keywordflow">return</span> IsElementwiseUnarySupported(input, output, descriptor, reasonIfUnsupported);</div><div class="line"><a name="l00158"></a><span class="lineno">  158</span>&#160;}</div><div class="line"><a name="l00159"></a><span class="lineno">  159</span>&#160;</div><div class="line"><a name="l00160"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ab3adb3a28736529682e4ff0ea976dcd3">  160</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a58bfb9626d373249745d78b95543116e">ClLayerSupport::IsActivationSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00161"></a><span class="lineno">  161</span>&#160;                                           <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00162"></a><span class="lineno">  162</span>&#160;                                           <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_activation_descriptor.html">ActivationDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00163"></a><span class="lineno">  163</span>&#160;                                           <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00164"></a><span class="lineno">  164</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00165"></a><span class="lineno">  165</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a42ef3cee193102dc7755193579209cca">ClActivationWorkloadValidate</a>,</div><div class="line"><a name="l00166"></a><span class="lineno">  166</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00167"></a><span class="lineno">  167</span>&#160;                                   input,</div><div class="line"><a name="l00168"></a><span class="lineno">  168</span>&#160;                                   output,</div><div class="line"><a name="l00169"></a><span class="lineno">  169</span>&#160;                                   descriptor);</div><div class="line"><a name="l00170"></a><span class="lineno">  170</span>&#160;}</div><div class="line"><a name="l00171"></a><span class="lineno">  171</span>&#160;</div><div class="line"><a name="l00172"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a48177e22e47448adb3d83e145dadf735">  172</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a1b01771dc5a057d09f8cd82492154a1f">ClLayerSupport::IsAdditionSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00173"></a><span class="lineno">  173</span>&#160;                                         <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00174"></a><span class="lineno">  174</span>&#160;                                         <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00175"></a><span class="lineno">  175</span>&#160;                                         <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00176"></a><span class="lineno">  176</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00177"></a><span class="lineno">  177</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#aefc82adf365ff14b0095dafdd2df6afc">ClAdditionValidate</a>,</div><div class="line"><a name="l00178"></a><span class="lineno">  178</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00179"></a><span class="lineno">  179</span>&#160;                                   input0,</div><div class="line"><a name="l00180"></a><span class="lineno">  180</span>&#160;                                   input1,</div><div class="line"><a name="l00181"></a><span class="lineno">  181</span>&#160;                                   output);</div><div class="line"><a name="l00182"></a><span class="lineno">  182</span>&#160;}</div><div class="line"><a name="l00183"></a><span class="lineno">  183</span>&#160;</div><div class="line"><a name="l00184"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a0f4841f89f21fd794786b4c03c2425fd">  184</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#aa8d5d17d1edd51d899fe699eb6156b58">ClLayerSupport::IsArgMinMaxSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00185"></a><span class="lineno">  185</span>&#160;                                          <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00186"></a><span class="lineno">  186</span>&#160;                                          <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_arg_min_max_descriptor.html">ArgMinMaxDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00187"></a><span class="lineno">  187</span>&#160;                                          <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00188"></a><span class="lineno">  188</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00189"></a><span class="lineno">  189</span>&#160;</div><div class="line"><a name="l00190"></a><span class="lineno">  190</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#ab80423b306d8e0436b9a316922911d4d">ClArgMinMaxWorkloadValidate</a>,</div><div class="line"><a name="l00191"></a><span class="lineno">  191</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00192"></a><span class="lineno">  192</span>&#160;                                   input,</div><div class="line"><a name="l00193"></a><span class="lineno">  193</span>&#160;                                   output,</div><div class="line"><a name="l00194"></a><span class="lineno">  194</span>&#160;                                   descriptor);</div><div class="line"><a name="l00195"></a><span class="lineno">  195</span>&#160;}</div><div class="line"><a name="l00196"></a><span class="lineno">  196</span>&#160;</div><div class="line"><a name="l00197"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a67c970dd054b991e14369de523ca3a5a">  197</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a7d18d6613bb865b66b05d4d6e0391934">ClLayerSupport::IsBatchNormalizationSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00198"></a><span class="lineno">  198</span>&#160;                                                   <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00199"></a><span class="lineno">  199</span>&#160;                                                   <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; mean,</div><div class="line"><a name="l00200"></a><span class="lineno">  200</span>&#160;                                                   <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; var,</div><div class="line"><a name="l00201"></a><span class="lineno">  201</span>&#160;                                                   <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; beta,</div><div class="line"><a name="l00202"></a><span class="lineno">  202</span>&#160;                                                   <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; gamma,</div><div class="line"><a name="l00203"></a><span class="lineno">  203</span>&#160;                                                   <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_batch_normalization_descriptor.html">BatchNormalizationDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00204"></a><span class="lineno">  204</span>&#160;                                                   <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00205"></a><span class="lineno">  205</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00206"></a><span class="lineno">  206</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#ad6cb42ca5150bb96c151e4a4e6557d70">ClBatchNormalizationValidate</a>,</div><div class="line"><a name="l00207"></a><span class="lineno">  207</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00208"></a><span class="lineno">  208</span>&#160;                                   input,</div><div class="line"><a name="l00209"></a><span class="lineno">  209</span>&#160;                                   output,</div><div class="line"><a name="l00210"></a><span class="lineno">  210</span>&#160;                                   mean,</div><div class="line"><a name="l00211"></a><span class="lineno">  211</span>&#160;                                   var,</div><div class="line"><a name="l00212"></a><span class="lineno">  212</span>&#160;                                   beta,</div><div class="line"><a name="l00213"></a><span class="lineno">  213</span>&#160;                                   gamma,</div><div class="line"><a name="l00214"></a><span class="lineno">  214</span>&#160;                                   descriptor);</div><div class="line"><a name="l00215"></a><span class="lineno">  215</span>&#160;}</div><div class="line"><a name="l00216"></a><span class="lineno">  216</span>&#160;</div><div class="line"><a name="l00217"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#adc5695cc25f4055c7ed54bdc8604a098">  217</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a2399052d9cbb2b88720b07511a2e362f">ClLayerSupport::IsBatchToSpaceNdSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00218"></a><span class="lineno">  218</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00219"></a><span class="lineno">  219</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_batch_to_space_nd_descriptor.html">BatchToSpaceNdDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00220"></a><span class="lineno">  220</span>&#160;                                               <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00221"></a><span class="lineno">  221</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00222"></a><span class="lineno">  222</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a67957983877fb2c720a2ad7f88c45a3c">ClBatchToSpaceNdWorkloadValidate</a>,</div><div class="line"><a name="l00223"></a><span class="lineno">  223</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00224"></a><span class="lineno">  224</span>&#160;                                   input,</div><div class="line"><a name="l00225"></a><span class="lineno">  225</span>&#160;                                   output,</div><div class="line"><a name="l00226"></a><span class="lineno">  226</span>&#160;                                   descriptor);</div><div class="line"><a name="l00227"></a><span class="lineno">  227</span>&#160;}</div><div class="line"><a name="l00228"></a><span class="lineno">  228</span>&#160;</div><div class="line"><a name="l00229"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ad16b29b7f1c73187775e7b1d044d7bc0">  229</a></span>&#160;<span class="keywordtype">bool</span> ClLayerSupport::IsComparisonSupported(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00230"></a><span class="lineno">  230</span>&#160;                                           <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00231"></a><span class="lineno">  231</span>&#160;                                           <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00232"></a><span class="lineno">  232</span>&#160;                                           <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_comparison_descriptor.html">ComparisonDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00233"></a><span class="lineno">  233</span>&#160;                                           <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00234"></a><span class="lineno">  234</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00235"></a><span class="lineno">  235</span>&#160;    <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_comparison_descriptor.html#a865dc4f43cb0ff01a1dcf78036912fd1">m_Operation</a> == ComparisonOperation::Greater)</div><div class="line"><a name="l00236"></a><span class="lineno">  236</span>&#160;    {</div><div class="line"><a name="l00237"></a><span class="lineno">  237</span>&#160;        <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#acf69869c2242e5e3741c4f9252099393">ClGreaterWorkloadValidate</a>,</div><div class="line"><a name="l00238"></a><span class="lineno">  238</span>&#160;                                       reasonIfUnsupported,</div><div class="line"><a name="l00239"></a><span class="lineno">  239</span>&#160;                                       input0,</div><div class="line"><a name="l00240"></a><span class="lineno">  240</span>&#160;                                       input1,</div><div class="line"><a name="l00241"></a><span class="lineno">  241</span>&#160;                                       output);</div><div class="line"><a name="l00242"></a><span class="lineno">  242</span>&#160;    }</div><div class="line"><a name="l00243"></a><span class="lineno">  243</span>&#160;</div><div class="line"><a name="l00244"></a><span class="lineno">  244</span>&#160;    <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00245"></a><span class="lineno">  245</span>&#160;}</div><div class="line"><a name="l00246"></a><span class="lineno">  246</span>&#160;</div><div class="line"><a name="l00247"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a3dca8ffbcb5f3afa1799aa7d354a3016">  247</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a757df85e956e425c1a082d35a98ca4a9">ClLayerSupport::IsConcatSupported</a>(<span class="keyword">const</span> std::vector&lt;const TensorInfo*&gt; inputs,</div><div class="line"><a name="l00248"></a><span class="lineno">  248</span>&#160;                                       <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00249"></a><span class="lineno">  249</span>&#160;                                       <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_origins_descriptor.html">ConcatDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00250"></a><span class="lineno">  250</span>&#160;                                       <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00251"></a><span class="lineno">  251</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00252"></a><span class="lineno">  252</span>&#160;    <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_origins_descriptor.html#a78e8266be865fdd92cadd04d6e25ae1f">GetNumDimensions</a>() &lt;= descriptor.<a class="code" href="structarmnn_1_1_origins_descriptor.html#a379929e3b277f1ef94f3ce645870589d">GetConcatAxis</a>())</div><div class="line"><a name="l00253"></a><span class="lineno">  253</span>&#160;    {</div><div class="line"><a name="l00254"></a><span class="lineno">  254</span>&#160;        <a class="code" href="namespacearmnn.html#a13c7d751e4d37f65a6d40c3c6e50d2b8">SetValueChecked</a>(reasonIfUnsupported, <span class="stringliteral">&quot;Cl Concat: Concat axis &gt; Number of dimensions.&quot;</span>);</div><div class="line"><a name="l00255"></a><span class="lineno">  255</span>&#160;        <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00256"></a><span class="lineno">  256</span>&#160;    }</div><div class="line"><a name="l00257"></a><span class="lineno">  257</span>&#160;</div><div class="line"><a name="l00258"></a><span class="lineno">  258</span>&#160;    <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> concatInnerAxis = (descriptor.<a class="code" href="structarmnn_1_1_origins_descriptor.html#a78e8266be865fdd92cadd04d6e25ae1f">GetNumDimensions</a>() - descriptor.<a class="code" href="structarmnn_1_1_origins_descriptor.html#a379929e3b277f1ef94f3ce645870589d">GetConcatAxis</a>()) - 1;</div><div class="line"><a name="l00259"></a><span class="lineno">  259</span>&#160;    <span class="keywordflow">if</span>(concatInnerAxis &lt; 3) <span class="comment">// Width, height, or channels</span></div><div class="line"><a name="l00260"></a><span class="lineno">  260</span>&#160;    {</div><div class="line"><a name="l00261"></a><span class="lineno">  261</span>&#160;        <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a7782f0809076f14363eacb4a38964b9f">ClConcatWorkloadValidate</a>,</div><div class="line"><a name="l00262"></a><span class="lineno">  262</span>&#160;                                       reasonIfUnsupported,</div><div class="line"><a name="l00263"></a><span class="lineno">  263</span>&#160;                                       inputs,</div><div class="line"><a name="l00264"></a><span class="lineno">  264</span>&#160;                                       output,</div><div class="line"><a name="l00265"></a><span class="lineno">  265</span>&#160;                                       descriptor);</div><div class="line"><a name="l00266"></a><span class="lineno">  266</span>&#160;    }</div><div class="line"><a name="l00267"></a><span class="lineno">  267</span>&#160;    <span class="keywordflow">else</span> <span class="keywordflow">if</span> (concatInnerAxis == 3)</div><div class="line"><a name="l00268"></a><span class="lineno">  268</span>&#160;    {</div><div class="line"><a name="l00269"></a><span class="lineno">  269</span>&#160;        <span class="comment">// We rely on the sub-tensor optimization to handle the batch dimension for 4D tensors. If we can&#39;t use</span></div><div class="line"><a name="l00270"></a><span class="lineno">  270</span>&#160;        <span class="comment">// sub-tensors for this then we can&#39;t support it. Here is where we check that the sub-tensors will work.</span></div><div class="line"><a name="l00271"></a><span class="lineno">  271</span>&#160;        <span class="keywordflow">for</span> (<span class="keyword">auto</span>&amp; input : inputs)</div><div class="line"><a name="l00272"></a><span class="lineno">  272</span>&#160;        {</div><div class="line"><a name="l00273"></a><span class="lineno">  273</span>&#160;            <span class="keywordflow">if</span> (input &amp;&amp; !output.<a class="code" href="classarmnn_1_1_tensor_info.html#a22f377fc4e10dc1773a3f979061e85f1">IsTypeSpaceMatch</a>(*input)) <span class="comment">// Cannot use sub-tensors if the types are not same space</span></div><div class="line"><a name="l00274"></a><span class="lineno">  274</span>&#160;            {</div><div class="line"><a name="l00275"></a><span class="lineno">  275</span>&#160;                <a class="code" href="namespacearmnn.html#a13c7d751e4d37f65a6d40c3c6e50d2b8">SetValueChecked</a>(reasonIfUnsupported, <span class="stringliteral">&quot;Cl Concat: Types and quantization parameters must match.&quot;</span>);</div><div class="line"><a name="l00276"></a><span class="lineno">  276</span>&#160;                <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00277"></a><span class="lineno">  277</span>&#160;            }</div><div class="line"><a name="l00278"></a><span class="lineno">  278</span>&#160;        }</div><div class="line"><a name="l00279"></a><span class="lineno">  279</span>&#160;        <span class="keywordflow">return</span> <span class="keyword">true</span>; <span class="comment">// Sub-tensors support concat along batch</span></div><div class="line"><a name="l00280"></a><span class="lineno">  280</span>&#160;    }</div><div class="line"><a name="l00281"></a><span class="lineno">  281</span>&#160;    <span class="keywordflow">else</span> <span class="comment">// &gt; 4 dimensions not supported.</span></div><div class="line"><a name="l00282"></a><span class="lineno">  282</span>&#160;    {</div><div class="line"><a name="l00283"></a><span class="lineno">  283</span>&#160;        <a class="code" href="namespacearmnn.html#a13c7d751e4d37f65a6d40c3c6e50d2b8">SetValueChecked</a>(reasonIfUnsupported, <span class="stringliteral">&quot;Cl Concat: Maximum of 4 dimensions supported.&quot;</span>);</div><div class="line"><a name="l00284"></a><span class="lineno">  284</span>&#160;        <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00285"></a><span class="lineno">  285</span>&#160;    }</div><div class="line"><a name="l00286"></a><span class="lineno">  286</span>&#160;}</div><div class="line"><a name="l00287"></a><span class="lineno">  287</span>&#160;</div><div class="line"><a name="l00288"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#adf18c4fa8fc9e0cdae1967990aa90fe8">  288</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#acc76cdec78906a3457a9c2293a453869">ClLayerSupport::IsConstantSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00289"></a><span class="lineno">  289</span>&#160;                                         <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00290"></a><span class="lineno">  290</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00291"></a><span class="lineno">  291</span>&#160;    <span class="keywordflow">return</span> IsSupportedForDataTypeCl(reasonIfUnsupported,</div><div class="line"><a name="l00292"></a><span class="lineno">  292</span>&#160;                                    output.<a class="code" href="classarmnn_1_1_tensor_info.html#aea909c7327109228ef618d459015def3">GetDataType</a>(),</div><div class="line"><a name="l00293"></a><span class="lineno">  293</span>&#160;                                    &amp;TrueFunc&lt;&gt;,</div><div class="line"><a name="l00294"></a><span class="lineno">  294</span>&#160;                                    &amp;TrueFunc&lt;&gt;);</div><div class="line"><a name="l00295"></a><span class="lineno">  295</span>&#160;}</div><div class="line"><a name="l00296"></a><span class="lineno">  296</span>&#160;</div><div class="line"><a name="l00297"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a1efcaf6f02892442fefca09f49ea3d7c">  297</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#aaa152f86599af5189c9d637fe7ade6d0">ClLayerSupport::IsConvertFp16ToFp32Supported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00298"></a><span class="lineno">  298</span>&#160;                                                  <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00299"></a><span class="lineno">  299</span>&#160;                                                  <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00300"></a><span class="lineno">  300</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00301"></a><span class="lineno">  301</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a46efae0191388fd33db4e95c5d79e2be">ClConvertFp16ToFp32WorkloadValidate</a>,</div><div class="line"><a name="l00302"></a><span class="lineno">  302</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00303"></a><span class="lineno">  303</span>&#160;                                   input,</div><div class="line"><a name="l00304"></a><span class="lineno">  304</span>&#160;                                   output);</div><div class="line"><a name="l00305"></a><span class="lineno">  305</span>&#160;}</div><div class="line"><a name="l00306"></a><span class="lineno">  306</span>&#160;</div><div class="line"><a name="l00307"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a91fb5f44d8b9427dc45443aa9ebfe13e">  307</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a98994026cec1578ceb7aa74c834b00d9">ClLayerSupport::IsConvertFp32ToFp16Supported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00308"></a><span class="lineno">  308</span>&#160;                                                  <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00309"></a><span class="lineno">  309</span>&#160;                                                  <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00310"></a><span class="lineno">  310</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00311"></a><span class="lineno">  311</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a37f6946bfb7a9c7d64881b7a2e13945f">ClConvertFp32ToFp16WorkloadValidate</a>,</div><div class="line"><a name="l00312"></a><span class="lineno">  312</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00313"></a><span class="lineno">  313</span>&#160;                                   input,</div><div class="line"><a name="l00314"></a><span class="lineno">  314</span>&#160;                                   output);</div><div class="line"><a name="l00315"></a><span class="lineno">  315</span>&#160;}</div><div class="line"><a name="l00316"></a><span class="lineno">  316</span>&#160;</div><div class="line"><a name="l00317"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#af7ff06bd8115a6a9cc6d41e5c762798e">  317</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#af22d4421773ce95e0f2324fc1a66c0d9">ClLayerSupport::IsConvolution2dSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00318"></a><span class="lineno">  318</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00319"></a><span class="lineno">  319</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_convolution2d_descriptor.html">Convolution2dDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00320"></a><span class="lineno">  320</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; weights,</div><div class="line"><a name="l00321"></a><span class="lineno">  321</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;TensorInfo&gt;</a>&amp; biases,</div><div class="line"><a name="l00322"></a><span class="lineno">  322</span>&#160;                                              <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00323"></a><span class="lineno">  323</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00324"></a><span class="lineno">  324</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#acd1146eb56f1473a0bf4561bcc1d1529">ClConvolution2dWorkloadValidate</a>,</div><div class="line"><a name="l00325"></a><span class="lineno">  325</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00326"></a><span class="lineno">  326</span>&#160;                                   input,</div><div class="line"><a name="l00327"></a><span class="lineno">  327</span>&#160;                                   output,</div><div class="line"><a name="l00328"></a><span class="lineno">  328</span>&#160;                                   descriptor,</div><div class="line"><a name="l00329"></a><span class="lineno">  329</span>&#160;                                   weights,</div><div class="line"><a name="l00330"></a><span class="lineno">  330</span>&#160;                                   biases);</div><div class="line"><a name="l00331"></a><span class="lineno">  331</span>&#160;}</div><div class="line"><a name="l00332"></a><span class="lineno">  332</span>&#160;</div><div class="line"><a name="l00333"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a2e89c72cf60df7c2d2d7e5d98822b672">  333</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#ac92dceabfbc1e46fe74f699f733886a8">ClLayerSupport::IsDequantizeSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00334"></a><span class="lineno">  334</span>&#160;                                           <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00335"></a><span class="lineno">  335</span>&#160;                                           <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00336"></a><span class="lineno">  336</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00337"></a><span class="lineno">  337</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a75045734c29d7d6635342c05adbc151b">ClDequantizeWorkloadValidate</a>,</div><div class="line"><a name="l00338"></a><span class="lineno">  338</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00339"></a><span class="lineno">  339</span>&#160;                                   input,</div><div class="line"><a name="l00340"></a><span class="lineno">  340</span>&#160;                                   output);</div><div class="line"><a name="l00341"></a><span class="lineno">  341</span>&#160;}</div><div class="line"><a name="l00342"></a><span class="lineno">  342</span>&#160;</div><div class="line"><a name="l00343"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a128fb9890897e08251a3f621e570cd23">  343</a></span>&#160;<span class="keywordtype">bool</span> ClLayerSupport::IsDepthToSpaceSupported(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00344"></a><span class="lineno">  344</span>&#160;                                             <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00345"></a><span class="lineno">  345</span>&#160;                                             <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_space_to_depth_descriptor.html">DepthToSpaceDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00346"></a><span class="lineno">  346</span>&#160;                                             <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00347"></a><span class="lineno">  347</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00348"></a><span class="lineno">  348</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a5634af98b603236c6748adb5ac92e766">ClDepthToSpaceWorkloadValidate</a>,</div><div class="line"><a name="l00349"></a><span class="lineno">  349</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00350"></a><span class="lineno">  350</span>&#160;                                   input,</div><div class="line"><a name="l00351"></a><span class="lineno">  351</span>&#160;                                   output,</div><div class="line"><a name="l00352"></a><span class="lineno">  352</span>&#160;                                   descriptor);</div><div class="line"><a name="l00353"></a><span class="lineno">  353</span>&#160;}</div><div class="line"><a name="l00354"></a><span class="lineno">  354</span>&#160;</div><div class="line"><a name="l00355"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#adc84390751f227fe03a115b5fa10b0fc">  355</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a399d38872500c6ac84ae031673176ef3">ClLayerSupport::IsDepthwiseConvolutionSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00356"></a><span class="lineno">  356</span>&#160;                                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00357"></a><span class="lineno">  357</span>&#160;                                                     <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_depthwise_convolution2d_descriptor.html">DepthwiseConvolution2dDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00358"></a><span class="lineno">  358</span>&#160;                                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; weights,</div><div class="line"><a name="l00359"></a><span class="lineno">  359</span>&#160;                                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;TensorInfo&gt;</a>&amp; biases,</div><div class="line"><a name="l00360"></a><span class="lineno">  360</span>&#160;                                                     <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00361"></a><span class="lineno">  361</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00362"></a><span class="lineno">  362</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a4ec5dfcb3e419ddce1fcb3b799f312e1">ClDepthwiseConvolutionWorkloadValidate</a>,</div><div class="line"><a name="l00363"></a><span class="lineno">  363</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00364"></a><span class="lineno">  364</span>&#160;                                   input,</div><div class="line"><a name="l00365"></a><span class="lineno">  365</span>&#160;                                   output,</div><div class="line"><a name="l00366"></a><span class="lineno">  366</span>&#160;                                   descriptor,</div><div class="line"><a name="l00367"></a><span class="lineno">  367</span>&#160;                                   weights,</div><div class="line"><a name="l00368"></a><span class="lineno">  368</span>&#160;                                   biases);</div><div class="line"><a name="l00369"></a><span class="lineno">  369</span>&#160;}</div><div class="line"><a name="l00370"></a><span class="lineno">  370</span>&#160;</div><div class="line"><a name="l00371"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a16c8cd49a7fa487b904b5c9cc83673e7">  371</a></span>&#160;<span class="keywordtype">bool</span> ClLayerSupport::IsDilatedDepthwiseConvolutionSupported(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00372"></a><span class="lineno">  372</span>&#160;                                                            <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00373"></a><span class="lineno">  373</span>&#160;                                                            <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_depthwise_convolution2d_descriptor.html">DepthwiseConvolution2dDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00374"></a><span class="lineno">  374</span>&#160;                                                            <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; weights,</div><div class="line"><a name="l00375"></a><span class="lineno">  375</span>&#160;                                                            <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;TensorInfo&gt;</a>&amp; biases,</div><div class="line"><a name="l00376"></a><span class="lineno">  376</span>&#160;                                                            <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00377"></a><span class="lineno">  377</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00378"></a><span class="lineno">  378</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a4ec5dfcb3e419ddce1fcb3b799f312e1">ClDepthwiseConvolutionWorkloadValidate</a>,</div><div class="line"><a name="l00379"></a><span class="lineno">  379</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00380"></a><span class="lineno">  380</span>&#160;                                   input,</div><div class="line"><a name="l00381"></a><span class="lineno">  381</span>&#160;                                   output,</div><div class="line"><a name="l00382"></a><span class="lineno">  382</span>&#160;                                   descriptor,</div><div class="line"><a name="l00383"></a><span class="lineno">  383</span>&#160;                                   weights,</div><div class="line"><a name="l00384"></a><span class="lineno">  384</span>&#160;                                   biases);</div><div class="line"><a name="l00385"></a><span class="lineno">  385</span>&#160;}</div><div class="line"><a name="l00386"></a><span class="lineno">  386</span>&#160;</div><div class="line"><a name="l00387"></a><span class="lineno">  387</span>&#160;</div><div class="line"><a name="l00388"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a08f55136b1f0907e7083d70d719f697f">  388</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a29b4b6b364a31632597970d0bad3d78f">ClLayerSupport::IsDivisionSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00389"></a><span class="lineno">  389</span>&#160;                                         <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00390"></a><span class="lineno">  390</span>&#160;                                         <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00391"></a><span class="lineno">  391</span>&#160;                                         <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00392"></a><span class="lineno">  392</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00393"></a><span class="lineno">  393</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a6a0edac987d58b405636df2eb2ee525d">ClDivisionWorkloadValidate</a>,</div><div class="line"><a name="l00394"></a><span class="lineno">  394</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00395"></a><span class="lineno">  395</span>&#160;                                   input0,</div><div class="line"><a name="l00396"></a><span class="lineno">  396</span>&#160;                                   input1,</div><div class="line"><a name="l00397"></a><span class="lineno">  397</span>&#160;                                   output);</div><div class="line"><a name="l00398"></a><span class="lineno">  398</span>&#160;}</div><div class="line"><a name="l00399"></a><span class="lineno">  399</span>&#160;</div><div class="line"><a name="l00400"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a5d99bdae7b6b2d5d1243f21cd59befb8">  400</a></span>&#160;<span class="keywordtype">bool</span> ClLayerSupport::IsElementwiseUnarySupported(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00401"></a><span class="lineno">  401</span>&#160;                                                 <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00402"></a><span class="lineno">  402</span>&#160;                                                 <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_elementwise_unary_descriptor.html">ElementwiseUnaryDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00403"></a><span class="lineno">  403</span>&#160;                                                 <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00404"></a><span class="lineno">  404</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00405"></a><span class="lineno">  405</span>&#160;    <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_elementwise_unary_descriptor.html#afe768be66897eb3d73284424e3239b23">m_Operation</a> == UnaryOperation::Abs)</div><div class="line"><a name="l00406"></a><span class="lineno">  406</span>&#160;    {</div><div class="line"><a name="l00407"></a><span class="lineno">  407</span>&#160;        <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a1391582cd6e145b67c98f3410667968e">ClAbsWorkloadValidate</a>,</div><div class="line"><a name="l00408"></a><span class="lineno">  408</span>&#160;                                       reasonIfUnsupported,</div><div class="line"><a name="l00409"></a><span class="lineno">  409</span>&#160;                                       input,</div><div class="line"><a name="l00410"></a><span class="lineno">  410</span>&#160;                                       output);</div><div class="line"><a name="l00411"></a><span class="lineno">  411</span>&#160;    }</div><div class="line"><a name="l00412"></a><span class="lineno">  412</span>&#160;    <span class="keywordflow">else</span> <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_elementwise_unary_descriptor.html#afe768be66897eb3d73284424e3239b23">m_Operation</a> == UnaryOperation::Rsqrt)</div><div class="line"><a name="l00413"></a><span class="lineno">  413</span>&#160;    {</div><div class="line"><a name="l00414"></a><span class="lineno">  414</span>&#160;        <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a3f6f9f0d3567ae04b49ea88727845900">ClRsqrtWorkloadValidate</a>,</div><div class="line"><a name="l00415"></a><span class="lineno">  415</span>&#160;                                       reasonIfUnsupported,</div><div class="line"><a name="l00416"></a><span class="lineno">  416</span>&#160;                                       input,</div><div class="line"><a name="l00417"></a><span class="lineno">  417</span>&#160;                                       output);</div><div class="line"><a name="l00418"></a><span class="lineno">  418</span>&#160;    }</div><div class="line"><a name="l00419"></a><span class="lineno">  419</span>&#160;</div><div class="line"><a name="l00420"></a><span class="lineno">  420</span>&#160;    <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00421"></a><span class="lineno">  421</span>&#160;}</div><div class="line"><a name="l00422"></a><span class="lineno">  422</span>&#160;</div><div class="line"><a name="l00423"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a53c7593d1aa26207eac5d5814a9d56dc">  423</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a89e9c52419c572f05bf9737a7a60b267">ClLayerSupport::IsFloorSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00424"></a><span class="lineno">  424</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00425"></a><span class="lineno">  425</span>&#160;                                      <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00426"></a><span class="lineno">  426</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00427"></a><span class="lineno">  427</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a8874961260f35da85229554f92e16ca9">ClFloorWorkloadValidate</a>,</div><div class="line"><a name="l00428"></a><span class="lineno">  428</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00429"></a><span class="lineno">  429</span>&#160;                                   input,</div><div class="line"><a name="l00430"></a><span class="lineno">  430</span>&#160;                                   output);</div><div class="line"><a name="l00431"></a><span class="lineno">  431</span>&#160;}</div><div class="line"><a name="l00432"></a><span class="lineno">  432</span>&#160;</div><div class="line"><a name="l00433"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#aeaf971dd9dffd6f6bc7e5a1ae6b6af5c">  433</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#aa2f4e75d4a4f61b24de0dfe150952c80">ClLayerSupport::IsFullyConnectedSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00434"></a><span class="lineno">  434</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00435"></a><span class="lineno">  435</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; weights,</div><div class="line"><a name="l00436"></a><span class="lineno">  436</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; biases,</div><div class="line"><a name="l00437"></a><span class="lineno">  437</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_fully_connected_descriptor.html">FullyConnectedDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00438"></a><span class="lineno">  438</span>&#160;                                               <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00439"></a><span class="lineno">  439</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00440"></a><span class="lineno">  440</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a00ef2c55913f952924a3e23556655285">ClFullyConnectedWorkloadValidate</a>,</div><div class="line"><a name="l00441"></a><span class="lineno">  441</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00442"></a><span class="lineno">  442</span>&#160;                                   input,</div><div class="line"><a name="l00443"></a><span class="lineno">  443</span>&#160;                                   output,</div><div class="line"><a name="l00444"></a><span class="lineno">  444</span>&#160;                                   weights,</div><div class="line"><a name="l00445"></a><span class="lineno">  445</span>&#160;                                   biases,</div><div class="line"><a name="l00446"></a><span class="lineno">  446</span>&#160;                                   descriptor);</div><div class="line"><a name="l00447"></a><span class="lineno">  447</span>&#160;}</div><div class="line"><a name="l00448"></a><span class="lineno">  448</span>&#160;</div><div class="line"><a name="l00449"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a7303c2656e267e10252a171e8bbc1d94">  449</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#adffa596b4bdecd54ca460853cd1439e2">ClLayerSupport::IsGreaterSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00450"></a><span class="lineno">  450</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00451"></a><span class="lineno">  451</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00452"></a><span class="lineno">  452</span>&#160;                                        <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00453"></a><span class="lineno">  453</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00454"></a><span class="lineno">  454</span>&#160;    <a class="code" href="structarmnn_1_1_comparison_descriptor.html">ComparisonDescriptor</a> descriptor(ComparisonOperation::Greater);</div><div class="line"><a name="l00455"></a><span class="lineno">  455</span>&#160;    <span class="keywordflow">return</span> IsComparisonSupported(input0, input1, output, descriptor, reasonIfUnsupported);</div><div class="line"><a name="l00456"></a><span class="lineno">  456</span>&#160;}</div><div class="line"><a name="l00457"></a><span class="lineno">  457</span>&#160;</div><div class="line"><a name="l00458"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ad29d99ecd719c640ed22dcf5c688c6a5">  458</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a197a353aa963497d29a07796268ea5c1">ClLayerSupport::IsInputSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00459"></a><span class="lineno">  459</span>&#160;                                      <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00460"></a><span class="lineno">  460</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00461"></a><span class="lineno">  461</span>&#160;    <span class="keywordflow">return</span> IsClBackendSupported(reasonIfUnsupported, input);</div><div class="line"><a name="l00462"></a><span class="lineno">  462</span>&#160;}</div><div class="line"><a name="l00463"></a><span class="lineno">  463</span>&#160;</div><div class="line"><a name="l00464"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a0813546a09bf2caba6794014d1960624">  464</a></span>&#160;<span class="keywordtype">bool</span> ClLayerSupport::IsInstanceNormalizationSupported(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00465"></a><span class="lineno">  465</span>&#160;                                                      <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00466"></a><span class="lineno">  466</span>&#160;                                                      <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_instance_normalization_descriptor.html">InstanceNormalizationDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00467"></a><span class="lineno">  467</span>&#160;                                                      <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00468"></a><span class="lineno">  468</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00469"></a><span class="lineno">  469</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a79d362f0c6e04d51807e0d81b5b05f3a">ClInstanceNormalizationWorkloadValidate</a>,</div><div class="line"><a name="l00470"></a><span class="lineno">  470</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00471"></a><span class="lineno">  471</span>&#160;                                   input,</div><div class="line"><a name="l00472"></a><span class="lineno">  472</span>&#160;                                   output,</div><div class="line"><a name="l00473"></a><span class="lineno">  473</span>&#160;                                   descriptor);</div><div class="line"><a name="l00474"></a><span class="lineno">  474</span>&#160;}</div><div class="line"><a name="l00475"></a><span class="lineno">  475</span>&#160;</div><div class="line"><a name="l00476"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#aca4acda7ab553edfda828658d8f3882b">  476</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a0906736b90464c0eb3ce5a87e05ebeee">ClLayerSupport::IsL2NormalizationSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00477"></a><span class="lineno">  477</span>&#160;                                                <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00478"></a><span class="lineno">  478</span>&#160;                                                <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_l2_normalization_descriptor.html">L2NormalizationDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00479"></a><span class="lineno">  479</span>&#160;                                                <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00480"></a><span class="lineno">  480</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00481"></a><span class="lineno">  481</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#aef334cdb24000c330f4d2e5f1b384784">ClL2NormalizationWorkloadValidate</a>,</div><div class="line"><a name="l00482"></a><span class="lineno">  482</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00483"></a><span class="lineno">  483</span>&#160;                                   input,</div><div class="line"><a name="l00484"></a><span class="lineno">  484</span>&#160;                                   output,</div><div class="line"><a name="l00485"></a><span class="lineno">  485</span>&#160;                                   descriptor);</div><div class="line"><a name="l00486"></a><span class="lineno">  486</span>&#160;}</div><div class="line"><a name="l00487"></a><span class="lineno">  487</span>&#160;</div><div class="line"><a name="l00488"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a862535721737220f62a49f14ff494dd5">  488</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a3e8b3af7771ffb37ede50aa2d9cc3af6">ClLayerSupport::IsLstmSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00489"></a><span class="lineno">  489</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; outputStateIn,</div><div class="line"><a name="l00490"></a><span class="lineno">  490</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; cellStateIn,</div><div class="line"><a name="l00491"></a><span class="lineno">  491</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; scratchBuffer,</div><div class="line"><a name="l00492"></a><span class="lineno">  492</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; outputStateOut,</div><div class="line"><a name="l00493"></a><span class="lineno">  493</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; cellStateOut,</div><div class="line"><a name="l00494"></a><span class="lineno">  494</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00495"></a><span class="lineno">  495</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_lstm_descriptor.html">LstmDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00496"></a><span class="lineno">  496</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_lstm_input_params_info.html">LstmInputParamsInfo</a>&amp; paramsInfo,</div><div class="line"><a name="l00497"></a><span class="lineno">  497</span>&#160;                                     <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00498"></a><span class="lineno">  498</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00499"></a><span class="lineno">  499</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a90ab88fe4c7aa9466c4653404a6b2213">ClLstmFloatWorkloadValidate</a>,</div><div class="line"><a name="l00500"></a><span class="lineno">  500</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00501"></a><span class="lineno">  501</span>&#160;                                   input,</div><div class="line"><a name="l00502"></a><span class="lineno">  502</span>&#160;                                   outputStateIn,</div><div class="line"><a name="l00503"></a><span class="lineno">  503</span>&#160;                                   cellStateIn,</div><div class="line"><a name="l00504"></a><span class="lineno">  504</span>&#160;                                   scratchBuffer,</div><div class="line"><a name="l00505"></a><span class="lineno">  505</span>&#160;                                   outputStateOut,</div><div class="line"><a name="l00506"></a><span class="lineno">  506</span>&#160;                                   cellStateOut,</div><div class="line"><a name="l00507"></a><span class="lineno">  507</span>&#160;                                   output,</div><div class="line"><a name="l00508"></a><span class="lineno">  508</span>&#160;                                   descriptor,</div><div class="line"><a name="l00509"></a><span class="lineno">  509</span>&#160;                                   paramsInfo);</div><div class="line"><a name="l00510"></a><span class="lineno">  510</span>&#160;}</div><div class="line"><a name="l00511"></a><span class="lineno">  511</span>&#160;</div><div class="line"><a name="l00512"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#afef9436c86b37b973471f2ae546ac00a">  512</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a3b85a270baf98ea6b040bd395c2d700a">ClLayerSupport::IsMaximumSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00513"></a><span class="lineno">  513</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00514"></a><span class="lineno">  514</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00515"></a><span class="lineno">  515</span>&#160;                                        <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00516"></a><span class="lineno">  516</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00517"></a><span class="lineno">  517</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a553706c6338ffc52b0d916859f642587">ClMaximumWorkloadValidate</a>,</div><div class="line"><a name="l00518"></a><span class="lineno">  518</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00519"></a><span class="lineno">  519</span>&#160;                                   input0,</div><div class="line"><a name="l00520"></a><span class="lineno">  520</span>&#160;                                   input1,</div><div class="line"><a name="l00521"></a><span class="lineno">  521</span>&#160;                                   output);</div><div class="line"><a name="l00522"></a><span class="lineno">  522</span>&#160;}</div><div class="line"><a name="l00523"></a><span class="lineno">  523</span>&#160;</div><div class="line"><a name="l00524"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ab268618580d4f53bf5e9b5a47dee3f6a">  524</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a0cdc60b4988b2193b97590e35f34a07e">ClLayerSupport::IsMeanSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00525"></a><span class="lineno">  525</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00526"></a><span class="lineno">  526</span>&#160;                                     <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_mean_descriptor.html">MeanDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00527"></a><span class="lineno">  527</span>&#160;                                     <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00528"></a><span class="lineno">  528</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00529"></a><span class="lineno">  529</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#aa1fff3c5bdebee27ad33aacc6d110d32">ClMeanValidate</a>,</div><div class="line"><a name="l00530"></a><span class="lineno">  530</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00531"></a><span class="lineno">  531</span>&#160;                                   input,</div><div class="line"><a name="l00532"></a><span class="lineno">  532</span>&#160;                                   output,</div><div class="line"><a name="l00533"></a><span class="lineno">  533</span>&#160;                                   descriptor);</div><div class="line"><a name="l00534"></a><span class="lineno">  534</span>&#160;}</div><div class="line"><a name="l00535"></a><span class="lineno">  535</span>&#160;</div><div class="line"><a name="l00536"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#aa9309ea64f9f7447efe3567f77417d29">  536</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a6e2c7ec2b8d47bde2bc9fa04bb2091f6">ClLayerSupport::IsMergerSupported</a>(<span class="keyword">const</span> std::vector&lt;const TensorInfo*&gt; inputs,</div><div class="line"><a name="l00537"></a><span class="lineno">  537</span>&#160;                                       <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00538"></a><span class="lineno">  538</span>&#160;                                       <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_origins_descriptor.html">MergerDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00539"></a><span class="lineno">  539</span>&#160;                                       <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00540"></a><span class="lineno">  540</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00541"></a><span class="lineno">  541</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="namespacearmnn.html#a757df85e956e425c1a082d35a98ca4a9">IsConcatSupported</a>(inputs, output, descriptor, reasonIfUnsupported);</div><div class="line"><a name="l00542"></a><span class="lineno">  542</span>&#160;}</div><div class="line"><a name="l00543"></a><span class="lineno">  543</span>&#160;</div><div class="line"><a name="l00544"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a3d0eafb3de560b3482f857b56b2b2116">  544</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#ab99d3d944b80f47bd1be70f63cc60abb">ClLayerSupport::IsMinimumSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00545"></a><span class="lineno">  545</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00546"></a><span class="lineno">  546</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00547"></a><span class="lineno">  547</span>&#160;                                        <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00548"></a><span class="lineno">  548</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00549"></a><span class="lineno">  549</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a8c04c8e796a4fbec706df42ed9c27e4e">ClMinimumWorkloadValidate</a>,</div><div class="line"><a name="l00550"></a><span class="lineno">  550</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00551"></a><span class="lineno">  551</span>&#160;                                   input0,</div><div class="line"><a name="l00552"></a><span class="lineno">  552</span>&#160;                                   input1,</div><div class="line"><a name="l00553"></a><span class="lineno">  553</span>&#160;                                   output);</div><div class="line"><a name="l00554"></a><span class="lineno">  554</span>&#160;}</div><div class="line"><a name="l00555"></a><span class="lineno">  555</span>&#160;</div><div class="line"><a name="l00556"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a421e1f3865d99d52613003048342c49a">  556</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a56ff60c2946bf0b7e772007acce0d7ec">ClLayerSupport::IsMultiplicationSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00557"></a><span class="lineno">  557</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00558"></a><span class="lineno">  558</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00559"></a><span class="lineno">  559</span>&#160;                                               <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00560"></a><span class="lineno">  560</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00561"></a><span class="lineno">  561</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a674a280a55c3760374a05ee24e9e3e74">ClMultiplicationWorkloadValidate</a>,</div><div class="line"><a name="l00562"></a><span class="lineno">  562</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00563"></a><span class="lineno">  563</span>&#160;                                   input0,</div><div class="line"><a name="l00564"></a><span class="lineno">  564</span>&#160;                                   input1,</div><div class="line"><a name="l00565"></a><span class="lineno">  565</span>&#160;                                   output);</div><div class="line"><a name="l00566"></a><span class="lineno">  566</span>&#160;}</div><div class="line"><a name="l00567"></a><span class="lineno">  567</span>&#160;</div><div class="line"><a name="l00568"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a994c2065561141bf37fcd2ff7bb4af4d">  568</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a754b0ac19fd6341ce2b5f480c3b35e8e">ClLayerSupport::IsNormalizationSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00569"></a><span class="lineno">  569</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00570"></a><span class="lineno">  570</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_normalization_descriptor.html">NormalizationDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00571"></a><span class="lineno">  571</span>&#160;                                              <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00572"></a><span class="lineno">  572</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00573"></a><span class="lineno">  573</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a144c2e243a255715f309999077ed1792">ClNormalizationWorkloadValidate</a>, reasonIfUnsupported, input, output, descriptor);</div><div class="line"><a name="l00574"></a><span class="lineno">  574</span>&#160;}</div><div class="line"><a name="l00575"></a><span class="lineno">  575</span>&#160;</div><div class="line"><a name="l00576"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#aef3244c0ef64c8f2f352d21ce0c06985">  576</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a701cecec7714cf8bc9dca804f473610d">ClLayerSupport::IsOutputSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00577"></a><span class="lineno">  577</span>&#160;                                       <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00578"></a><span class="lineno">  578</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00579"></a><span class="lineno">  579</span>&#160;    <span class="keywordflow">return</span> IsClBackendSupported(reasonIfUnsupported, output);</div><div class="line"><a name="l00580"></a><span class="lineno">  580</span>&#160;}</div><div class="line"><a name="l00581"></a><span class="lineno">  581</span>&#160;</div><div class="line"><a name="l00582"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a0534291adf9f3436ba331552eba29a43">  582</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a515e8a98d7ef9ecda64a2e1e5298461a">ClLayerSupport::IsPadSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00583"></a><span class="lineno">  583</span>&#160;                                    <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00584"></a><span class="lineno">  584</span>&#160;                                    <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_pad_descriptor.html">PadDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00585"></a><span class="lineno">  585</span>&#160;                                    <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00586"></a><span class="lineno">  586</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00587"></a><span class="lineno">  587</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#adcf7b7d939bac1cfaeb333c7b3175bb8">ClPadValidate</a>,</div><div class="line"><a name="l00588"></a><span class="lineno">  588</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00589"></a><span class="lineno">  589</span>&#160;                                   input,</div><div class="line"><a name="l00590"></a><span class="lineno">  590</span>&#160;                                   output,</div><div class="line"><a name="l00591"></a><span class="lineno">  591</span>&#160;                                   descriptor);</div><div class="line"><a name="l00592"></a><span class="lineno">  592</span>&#160;}</div><div class="line"><a name="l00593"></a><span class="lineno">  593</span>&#160;</div><div class="line"><a name="l00594"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a9d553495d9a94fa55588ae159d8bda30">  594</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#aa3a1bea3b3cd5611f13c06020dababc4">ClLayerSupport::IsPermuteSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00595"></a><span class="lineno">  595</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00596"></a><span class="lineno">  596</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_permute_descriptor.html">PermuteDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00597"></a><span class="lineno">  597</span>&#160;                                        <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00598"></a><span class="lineno">  598</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00599"></a><span class="lineno">  599</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a26c25df9e2271333ab4d4ef71db41dca">ClPermuteWorkloadValidate</a>, reasonIfUnsupported, input, output, descriptor);</div><div class="line"><a name="l00600"></a><span class="lineno">  600</span>&#160;}</div><div class="line"><a name="l00601"></a><span class="lineno">  601</span>&#160;</div><div class="line"><a name="l00602"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#aa955675303d67b1d1fb51fb7f09d8c21">  602</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#aea548aa1485adbeeb3e393a13bb6bff8">ClLayerSupport::IsPooling2dSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00603"></a><span class="lineno">  603</span>&#160;                                          <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00604"></a><span class="lineno">  604</span>&#160;                                          <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_pooling2d_descriptor.html">Pooling2dDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00605"></a><span class="lineno">  605</span>&#160;                                          <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00606"></a><span class="lineno">  606</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00607"></a><span class="lineno">  607</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a8a21bb33f7f054ce7b48a8c7df9e6d4a">ClPooling2dWorkloadValidate</a>, reasonIfUnsupported, input, output, descriptor);</div><div class="line"><a name="l00608"></a><span class="lineno">  608</span>&#160;}</div><div class="line"><a name="l00609"></a><span class="lineno">  609</span>&#160;</div><div class="line"><a name="l00610"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a4b36dcedd5edbd5142b3548967aadc2f">  610</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a5a0c1871f7e4822adb8b15e8ae76bca0">ClLayerSupport::IsPreluSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">armnn::TensorInfo</a> &amp;input,</div><div class="line"><a name="l00611"></a><span class="lineno">  611</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">armnn::TensorInfo</a> &amp;alpha,</div><div class="line"><a name="l00612"></a><span class="lineno">  612</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">armnn::TensorInfo</a> &amp;output,</div><div class="line"><a name="l00613"></a><span class="lineno">  613</span>&#160;                                      <a class="code" href="classarmnn_1_1_optional.html">armnn::Optional&lt;std::string &amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00614"></a><span class="lineno">  614</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00615"></a><span class="lineno">  615</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#ae58d1f4437a779274037bc86efac9e26">ClPreluWorkloadValidate</a>, reasonIfUnsupported, input, alpha, output);</div><div class="line"><a name="l00616"></a><span class="lineno">  616</span>&#160;}</div><div class="line"><a name="l00617"></a><span class="lineno">  617</span>&#160;</div><div class="line"><a name="l00618"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#af1be52d9f968bfab069344756bf232c4">  618</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a4069381c4737d57fc7fd299a61ad9ca1">ClLayerSupport::IsQuantizedLstmSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00619"></a><span class="lineno">  619</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; previousCellStateIn,</div><div class="line"><a name="l00620"></a><span class="lineno">  620</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; previousOutputIn,</div><div class="line"><a name="l00621"></a><span class="lineno">  621</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; cellStateOut,</div><div class="line"><a name="l00622"></a><span class="lineno">  622</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00623"></a><span class="lineno">  623</span>&#160;                                              <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_quantized_lstm_input_params_info.html">QuantizedLstmInputParamsInfo</a>&amp; paramsInfo,</div><div class="line"><a name="l00624"></a><span class="lineno">  624</span>&#160;                                              <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00625"></a><span class="lineno">  625</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00626"></a><span class="lineno">  626</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a5fb7fe07abfb2373103d842b47a24726">ClQuantizedLstmWorkloadValidate</a>,</div><div class="line"><a name="l00627"></a><span class="lineno">  627</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00628"></a><span class="lineno">  628</span>&#160;                                   input,</div><div class="line"><a name="l00629"></a><span class="lineno">  629</span>&#160;                                   previousCellStateIn,</div><div class="line"><a name="l00630"></a><span class="lineno">  630</span>&#160;                                   previousOutputIn,</div><div class="line"><a name="l00631"></a><span class="lineno">  631</span>&#160;                                   cellStateOut,</div><div class="line"><a name="l00632"></a><span class="lineno">  632</span>&#160;                                   output,</div><div class="line"><a name="l00633"></a><span class="lineno">  633</span>&#160;                                   paramsInfo);</div><div class="line"><a name="l00634"></a><span class="lineno">  634</span>&#160;}</div><div class="line"><a name="l00635"></a><span class="lineno">  635</span>&#160;</div><div class="line"><a name="l00636"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ad2c7be6b84b04444e514f52f593b3df7">  636</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a599a95f708fa0b6a6230dc6c9e73ea3e">ClLayerSupport::IsQuantizeSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00637"></a><span class="lineno">  637</span>&#160;                                         <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00638"></a><span class="lineno">  638</span>&#160;                                         <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00639"></a><span class="lineno">  639</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00640"></a><span class="lineno">  640</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a9c1b478e30a1e8a4ecac874cf15f13d4">ClQuantizeWorkloadValidate</a>,</div><div class="line"><a name="l00641"></a><span class="lineno">  641</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00642"></a><span class="lineno">  642</span>&#160;                                   input,</div><div class="line"><a name="l00643"></a><span class="lineno">  643</span>&#160;                                   output);</div><div class="line"><a name="l00644"></a><span class="lineno">  644</span>&#160;}</div><div class="line"><a name="l00645"></a><span class="lineno">  645</span>&#160;</div><div class="line"><a name="l00646"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#aa02f01bbcb48c67f5b2efc4132ec5e86">  646</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#af5014cbc003abcf201d4372b0012734c">ClLayerSupport::IsReshapeSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00647"></a><span class="lineno">  647</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00648"></a><span class="lineno">  648</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_reshape_descriptor.html">ReshapeDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00649"></a><span class="lineno">  649</span>&#160;                                        <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00650"></a><span class="lineno">  650</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00651"></a><span class="lineno">  651</span>&#160;    ignore_unused(descriptor);</div><div class="line"><a name="l00652"></a><span class="lineno">  652</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#af5bb7a834a74983cbbc249785d0c392b">ClReshapeWorkloadValidate</a>, reasonIfUnsupported, input, output);</div><div class="line"><a name="l00653"></a><span class="lineno">  653</span>&#160;}</div><div class="line"><a name="l00654"></a><span class="lineno">  654</span>&#160;</div><div class="line"><a name="l00655"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a3d27a3fc6a7df0b68d80cb113aff8b6c">  655</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a90a1aadb53c7537f225252afd681ff22">ClLayerSupport::IsResizeSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00656"></a><span class="lineno">  656</span>&#160;                                       <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00657"></a><span class="lineno">  657</span>&#160;                                       <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_resize_descriptor.html">ResizeDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00658"></a><span class="lineno">  658</span>&#160;                                       <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00659"></a><span class="lineno">  659</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00660"></a><span class="lineno">  660</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a95b187d3c6b7b46f4fbdc60be69fc02c">ClResizeWorkloadValidate</a>, reasonIfUnsupported, input, output, descriptor);</div><div class="line"><a name="l00661"></a><span class="lineno">  661</span>&#160;}</div><div class="line"><a name="l00662"></a><span class="lineno">  662</span>&#160;</div><div class="line"><a name="l00663"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a0f29f31e1ba46a52eedcdecd34f4cc24">  663</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a936d3f949a334668f839fb0bdd170b72">ClLayerSupport::IsResizeBilinearSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00664"></a><span class="lineno">  664</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00665"></a><span class="lineno">  665</span>&#160;                                               <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00666"></a><span class="lineno">  666</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00667"></a><span class="lineno">  667</span>&#160;    <a class="code" href="structarmnn_1_1_resize_descriptor.html">ResizeDescriptor</a> descriptor;</div><div class="line"><a name="l00668"></a><span class="lineno">  668</span>&#160;    descriptor.<a class="code" href="structarmnn_1_1_resize_descriptor.html#a869254cb56968986a78a79e1d6d4a86b">m_Method</a>     = ResizeMethod::Bilinear;</div><div class="line"><a name="l00669"></a><span class="lineno">  669</span>&#160;    descriptor.<a class="code" href="structarmnn_1_1_resize_descriptor.html#a6089e1ca91914015777ea780a513131a">m_DataLayout</a> = DataLayout::NCHW;</div><div class="line"><a name="l00670"></a><span class="lineno">  670</span>&#160;</div><div class="line"><a name="l00671"></a><span class="lineno">  671</span>&#160;    <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_shape.html">TensorShape</a>&amp; outputShape = output.<a class="code" href="classarmnn_1_1_tensor_info.html#a8b5d0f8a24e9d9238f412260a552acf8">GetShape</a>();</div><div class="line"><a name="l00672"></a><span class="lineno">  672</span>&#160;    descriptor.<a class="code" href="structarmnn_1_1_resize_descriptor.html#a46c3fa15c46fb0d1dcdc24d0ea5cb5cd">m_TargetHeight</a> = outputShape[2];</div><div class="line"><a name="l00673"></a><span class="lineno">  673</span>&#160;    descriptor.<a class="code" href="structarmnn_1_1_resize_descriptor.html#adcf5037208faac36c0788239a073f75c">m_TargetWidth</a>  = outputShape[3];</div><div class="line"><a name="l00674"></a><span class="lineno">  674</span>&#160;</div><div class="line"><a name="l00675"></a><span class="lineno">  675</span>&#160;    <span class="keywordflow">return</span> <a class="code" href="namespacearmnn.html#a90a1aadb53c7537f225252afd681ff22">IsResizeSupported</a>(input, output, descriptor, reasonIfUnsupported);</div><div class="line"><a name="l00676"></a><span class="lineno">  676</span>&#160;}</div><div class="line"><a name="l00677"></a><span class="lineno">  677</span>&#160;</div><div class="line"><a name="l00678"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a10ae4d84b0d31580f6fcd5107322ebcf">  678</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#accc42ba9679a474e75b43cdf1efa9422">ClLayerSupport::IsRsqrtSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00679"></a><span class="lineno">  679</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00680"></a><span class="lineno">  680</span>&#160;                                      <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00681"></a><span class="lineno">  681</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00682"></a><span class="lineno">  682</span>&#160;    <a class="code" href="structarmnn_1_1_elementwise_unary_descriptor.html">ElementwiseUnaryDescriptor</a> descriptor(UnaryOperation::Rsqrt);</div><div class="line"><a name="l00683"></a><span class="lineno">  683</span>&#160;    <span class="keywordflow">return</span> IsElementwiseUnarySupported(input, output, descriptor, reasonIfUnsupported);</div><div class="line"><a name="l00684"></a><span class="lineno">  684</span>&#160;}</div><div class="line"><a name="l00685"></a><span class="lineno">  685</span>&#160;</div><div class="line"><a name="l00686"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a0e14dafa85cfcd4a6b6b752284b51e63">  686</a></span>&#160;<span class="keywordtype">bool</span> ClLayerSupport::IsSliceSupported(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00687"></a><span class="lineno">  687</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00688"></a><span class="lineno">  688</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_slice_descriptor.html">SliceDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00689"></a><span class="lineno">  689</span>&#160;                                      <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00690"></a><span class="lineno">  690</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00691"></a><span class="lineno">  691</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a6d85d2806d0a90140832ad8113c1d350">ClSliceWorkloadValidate</a>, reasonIfUnsupported, input, output, descriptor);</div><div class="line"><a name="l00692"></a><span class="lineno">  692</span>&#160;}</div><div class="line"><a name="l00693"></a><span class="lineno">  693</span>&#160;</div><div class="line"><a name="l00694"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a8385cf8227907904a6a86fac318fc099">  694</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a477695b3df8c0abd2efcf02051f61065">ClLayerSupport::IsSoftmaxSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00695"></a><span class="lineno">  695</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00696"></a><span class="lineno">  696</span>&#160;                                        <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_softmax_descriptor.html">SoftmaxDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00697"></a><span class="lineno">  697</span>&#160;                                        <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00698"></a><span class="lineno">  698</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00699"></a><span class="lineno">  699</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#abc6f7e5fe77e5aed3f7842755dd34073">ClSoftmaxWorkloadValidate</a>, reasonIfUnsupported, input, output, descriptor);</div><div class="line"><a name="l00700"></a><span class="lineno">  700</span>&#160;}</div><div class="line"><a name="l00701"></a><span class="lineno">  701</span>&#160;</div><div class="line"><a name="l00702"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a3adfc31e079a970e028e537ec05fabf5">  702</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a4b3a41e24d4b9e2b4cb431dc90c48970">ClLayerSupport::IsSpaceToBatchNdSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00703"></a><span class="lineno">  703</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00704"></a><span class="lineno">  704</span>&#160;                                               <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_space_to_batch_nd_descriptor.html">SpaceToBatchNdDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00705"></a><span class="lineno">  705</span>&#160;                                               <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00706"></a><span class="lineno">  706</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00707"></a><span class="lineno">  707</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a534b28fd4b345bbc938d055ff5b8970f">ClSpaceToBatchNdWorkloadValidate</a>,</div><div class="line"><a name="l00708"></a><span class="lineno">  708</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00709"></a><span class="lineno">  709</span>&#160;                                   input,</div><div class="line"><a name="l00710"></a><span class="lineno">  710</span>&#160;                                   output,</div><div class="line"><a name="l00711"></a><span class="lineno">  711</span>&#160;                                   descriptor);</div><div class="line"><a name="l00712"></a><span class="lineno">  712</span>&#160;}</div><div class="line"><a name="l00713"></a><span class="lineno">  713</span>&#160;</div><div class="line"><a name="l00714"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ab2af1e7da9490d29e569d271e16b0d5c">  714</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#addffaddb4bdb6ec506fe08debcce9b75">ClLayerSupport::IsSpaceToDepthSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00715"></a><span class="lineno">  715</span>&#160;                                             <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00716"></a><span class="lineno">  716</span>&#160;                                             <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_space_to_depth_descriptor.html">SpaceToDepthDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00717"></a><span class="lineno">  717</span>&#160;                                             <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00718"></a><span class="lineno">  718</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00719"></a><span class="lineno">  719</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a5f81bc4e5533cfe99932865bd102735c">ClSpaceToDepthWorkloadValidate</a>,</div><div class="line"><a name="l00720"></a><span class="lineno">  720</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00721"></a><span class="lineno">  721</span>&#160;                                   input,</div><div class="line"><a name="l00722"></a><span class="lineno">  722</span>&#160;                                   output,</div><div class="line"><a name="l00723"></a><span class="lineno">  723</span>&#160;                                   descriptor);</div><div class="line"><a name="l00724"></a><span class="lineno">  724</span>&#160;}</div><div class="line"><a name="l00725"></a><span class="lineno">  725</span>&#160;</div><div class="line"><a name="l00726"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a17dd12822d49a23d24198f425a6fb9c4">  726</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a7ce5f7168bf0d1e7efe269d59ed564ba">ClLayerSupport::IsSplitterSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00727"></a><span class="lineno">  727</span>&#160;                                         <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_views_descriptor.html">ViewsDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00728"></a><span class="lineno">  728</span>&#160;                                         <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00729"></a><span class="lineno">  729</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00730"></a><span class="lineno">  730</span>&#160;    ignore_unused(descriptor);</div><div class="line"><a name="l00731"></a><span class="lineno">  731</span>&#160;    <span class="keywordflow">return</span> IsSupportedForDataTypeCl(reasonIfUnsupported,</div><div class="line"><a name="l00732"></a><span class="lineno">  732</span>&#160;                                    input.<a class="code" href="classarmnn_1_1_tensor_info.html#aea909c7327109228ef618d459015def3">GetDataType</a>(),</div><div class="line"><a name="l00733"></a><span class="lineno">  733</span>&#160;                                    &amp;TrueFunc&lt;&gt;,</div><div class="line"><a name="l00734"></a><span class="lineno">  734</span>&#160;                                    &amp;TrueFunc&lt;&gt;);</div><div class="line"><a name="l00735"></a><span class="lineno">  735</span>&#160;}</div><div class="line"><a name="l00736"></a><span class="lineno">  736</span>&#160;</div><div class="line"><a name="l00737"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#aa746e752ce8874669ea549f8e50896da">  737</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a7ce5f7168bf0d1e7efe269d59ed564ba">ClLayerSupport::IsSplitterSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00738"></a><span class="lineno">  738</span>&#160;                                         <span class="keyword">const</span> std::vector&lt;std::reference_wrapper&lt;TensorInfo&gt;&gt;&amp; outputs,</div><div class="line"><a name="l00739"></a><span class="lineno">  739</span>&#160;                                         <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_views_descriptor.html">ViewsDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00740"></a><span class="lineno">  740</span>&#160;                                         <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00741"></a><span class="lineno">  741</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00742"></a><span class="lineno">  742</span>&#160;<span class="preprocessor">#if defined(ARMCOMPUTECL_ENABLED)</span></div><div class="line"><a name="l00743"></a><span class="lineno">  743</span>&#160;    <span class="comment">// Split along the last dimension, cannot use sub-tensors</span></div><div class="line"><a name="l00744"></a><span class="lineno">  744</span>&#160;    <span class="comment">// as width and height of the sub-tensors do not match</span></div><div class="line"><a name="l00745"></a><span class="lineno">  745</span>&#160;    <span class="comment">// the width and height of the parent tensor</span></div><div class="line"><a name="l00746"></a><span class="lineno">  746</span>&#160;    <span class="comment">// in case of input with more than 2D.</span></div><div class="line"><a name="l00747"></a><span class="lineno">  747</span>&#160;    std::set&lt;unsigned int&gt; splitAxis = <a class="code" href="namespacearmnn.html#a8cbabc875597b3bed0ccdc0adb289fde">ComputeSplitAxis</a>(descriptor, input.<a class="code" href="classarmnn_1_1_tensor_info.html#a8b5d0f8a24e9d9238f412260a552acf8">GetShape</a>());</div><div class="line"><a name="l00748"></a><span class="lineno">  748</span>&#160;    <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_views_descriptor.html#a78e8266be865fdd92cadd04d6e25ae1f">GetNumDimensions</a>() &gt; 2 &amp;&amp; splitAxis.size() == 1 &amp;&amp;</div><div class="line"><a name="l00749"></a><span class="lineno">  749</span>&#160;        *splitAxis.begin() == descriptor.<a class="code" href="structarmnn_1_1_views_descriptor.html#a78e8266be865fdd92cadd04d6e25ae1f">GetNumDimensions</a>() - 1 )</div><div class="line"><a name="l00750"></a><span class="lineno">  750</span>&#160;    {</div><div class="line"><a name="l00751"></a><span class="lineno">  751</span>&#160;        <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a3ac8a60f837b19b20987e4fd238ce0cd">ClSplitterWorkloadValidate</a>,</div><div class="line"><a name="l00752"></a><span class="lineno">  752</span>&#160;                                       reasonIfUnsupported,</div><div class="line"><a name="l00753"></a><span class="lineno">  753</span>&#160;                                       input,</div><div class="line"><a name="l00754"></a><span class="lineno">  754</span>&#160;                                       outputs,</div><div class="line"><a name="l00755"></a><span class="lineno">  755</span>&#160;                                       *splitAxis.begin());</div><div class="line"><a name="l00756"></a><span class="lineno">  756</span>&#160;    }</div><div class="line"><a name="l00757"></a><span class="lineno">  757</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00758"></a><span class="lineno">  758</span>&#160;    boost::ignore_unused(descriptor);</div><div class="line"><a name="l00759"></a><span class="lineno">  759</span>&#160;    <span class="keywordflow">for</span> (<span class="keyword">auto</span> output : outputs)</div><div class="line"><a name="l00760"></a><span class="lineno">  760</span>&#160;    {</div><div class="line"><a name="l00761"></a><span class="lineno">  761</span>&#160;        <span class="keywordflow">if</span> (!input.<a class="code" href="classarmnn_1_1_tensor_info.html#a22f377fc4e10dc1773a3f979061e85f1">IsTypeSpaceMatch</a>(output)) <span class="comment">// Cannot use sub-tensors if the types are not same space</span></div><div class="line"><a name="l00762"></a><span class="lineno">  762</span>&#160;        {</div><div class="line"><a name="l00763"></a><span class="lineno">  763</span>&#160;            <a class="code" href="namespacearmnn.html#a13c7d751e4d37f65a6d40c3c6e50d2b8">SetValueChecked</a>(reasonIfUnsupported, <span class="stringliteral">&quot;Cl Splitter: Types and quantization parameters must match.&quot;</span>);</div><div class="line"><a name="l00764"></a><span class="lineno">  764</span>&#160;            <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00765"></a><span class="lineno">  765</span>&#160;        }</div><div class="line"><a name="l00766"></a><span class="lineno">  766</span>&#160;    }</div><div class="line"><a name="l00767"></a><span class="lineno">  767</span>&#160;    <span class="keywordflow">return</span> <span class="keyword">true</span>;</div><div class="line"><a name="l00768"></a><span class="lineno">  768</span>&#160;}</div><div class="line"><a name="l00769"></a><span class="lineno">  769</span>&#160;</div><div class="line"><a name="l00770"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ab4609f1baf5fcd295951f3c8abdffd90">  770</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#a10e8442be2b8596afd5770e98b904caa">ClLayerSupport::IsStackSupported</a>(<span class="keyword">const</span> std::vector&lt;const TensorInfo*&gt;&amp; inputs,</div><div class="line"><a name="l00771"></a><span class="lineno">  771</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00772"></a><span class="lineno">  772</span>&#160;                                      <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_stack_descriptor.html">StackDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00773"></a><span class="lineno">  773</span>&#160;                                      <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00774"></a><span class="lineno">  774</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00775"></a><span class="lineno">  775</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a8c9fec997dbb5db4cdb433c36d075782">ClStackWorkloadValidate</a>,</div><div class="line"><a name="l00776"></a><span class="lineno">  776</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00777"></a><span class="lineno">  777</span>&#160;                                   inputs,</div><div class="line"><a name="l00778"></a><span class="lineno">  778</span>&#160;                                   output,</div><div class="line"><a name="l00779"></a><span class="lineno">  779</span>&#160;                                   descriptor);</div><div class="line"><a name="l00780"></a><span class="lineno">  780</span>&#160;}</div><div class="line"><a name="l00781"></a><span class="lineno">  781</span>&#160;</div><div class="line"><a name="l00782"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#ac054cb25099005eac854afb1511340f0">  782</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#aebe3dc6730e1b29aee9c9f33b8f94121">ClLayerSupport::IsStridedSliceSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00783"></a><span class="lineno">  783</span>&#160;                                             <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00784"></a><span class="lineno">  784</span>&#160;                                             <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_strided_slice_descriptor.html">StridedSliceDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00785"></a><span class="lineno">  785</span>&#160;                                             <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00786"></a><span class="lineno">  786</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00787"></a><span class="lineno">  787</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a157e0508f6d6d08e3ca4cf6c661242e6">ClStridedSliceWorkloadValidate</a>,</div><div class="line"><a name="l00788"></a><span class="lineno">  788</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00789"></a><span class="lineno">  789</span>&#160;                                   input,</div><div class="line"><a name="l00790"></a><span class="lineno">  790</span>&#160;                                   output,</div><div class="line"><a name="l00791"></a><span class="lineno">  791</span>&#160;                                   descriptor);</div><div class="line"><a name="l00792"></a><span class="lineno">  792</span>&#160;}</div><div class="line"><a name="l00793"></a><span class="lineno">  793</span>&#160;</div><div class="line"><a name="l00794"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#af6c947e4d4b25bc49d92d18d4ff26736">  794</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#afbf752a51fa513e0a54e343be130d962">ClLayerSupport::IsSubtractionSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input0,</div><div class="line"><a name="l00795"></a><span class="lineno">  795</span>&#160;                                            <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input1,</div><div class="line"><a name="l00796"></a><span class="lineno">  796</span>&#160;                                            <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00797"></a><span class="lineno">  797</span>&#160;                                            <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00798"></a><span class="lineno">  798</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00799"></a><span class="lineno">  799</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a3bbbf958387c788549b0d8481232875f">ClSubtractionValidate</a>,</div><div class="line"><a name="l00800"></a><span class="lineno">  800</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00801"></a><span class="lineno">  801</span>&#160;                                   input0,</div><div class="line"><a name="l00802"></a><span class="lineno">  802</span>&#160;                                   input1,</div><div class="line"><a name="l00803"></a><span class="lineno">  803</span>&#160;                                   output);</div><div class="line"><a name="l00804"></a><span class="lineno">  804</span>&#160;}</div><div class="line"><a name="l00805"></a><span class="lineno">  805</span>&#160;</div><div class="line"><a name="l00806"></a><span class="lineno"><a class="line" href="classarmnn_1_1_cl_layer_support.html#a0c69484f19ed650ad48b716719114e51">  806</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#ac6cc8e0bd35d229486fe6d844d88e0d4">ClLayerSupport::IsTransposeConvolution2dSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; input,</div><div class="line"><a name="l00807"></a><span class="lineno">  807</span>&#160;                                                       <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; output,</div><div class="line"><a name="l00808"></a><span class="lineno">  808</span>&#160;                                                       <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_transpose_convolution2d_descriptor.html">TransposeConvolution2dDescriptor</a>&amp; descriptor,</div><div class="line"><a name="l00809"></a><span class="lineno">  809</span>&#160;                                                       <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; weights,</div><div class="line"><a name="l00810"></a><span class="lineno">  810</span>&#160;                                                       <span class="keyword">const</span> <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;TensorInfo&gt;</a>&amp; biases,</div><div class="line"><a name="l00811"></a><span class="lineno">  811</span>&#160;                                                       <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;std::string&amp;&gt;</a> reasonIfUnsupported)<span class="keyword"> const</span></div><div class="line"><a name="l00812"></a><span class="lineno">  812</span>&#160;<span class="keyword"></span>{</div><div class="line"><a name="l00813"></a><span class="lineno">  813</span>&#160;    <a class="code" href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a>(<a class="code" href="namespacearmnn.html#a719ea81939d6a25f8636b52c59165d66">ClTransposeConvolution2dWorkloadValidate</a>,</div><div class="line"><a name="l00814"></a><span class="lineno">  814</span>&#160;                                   reasonIfUnsupported,</div><div class="line"><a name="l00815"></a><span class="lineno">  815</span>&#160;                                   input,</div><div class="line"><a name="l00816"></a><span class="lineno">  816</span>&#160;                                   output,</div><div class="line"><a name="l00817"></a><span class="lineno">  817</span>&#160;                                   descriptor,</div><div class="line"><a name="l00818"></a><span class="lineno">  818</span>&#160;                                   weights,</div><div class="line"><a name="l00819"></a><span class="lineno">  819</span>&#160;                                   biases);</div><div class="line"><a name="l00820"></a><span class="lineno">  820</span>&#160;}</div><div class="line"><a name="l00821"></a><span class="lineno">  821</span>&#160;</div><div class="line"><a name="l00822"></a><span class="lineno">  822</span>&#160;} <span class="comment">// namespace armnn</span></div><div class="ttc" id="namespacearmnn_html_a42ef3cee193102dc7755193579209cca"><div class="ttname"><a href="namespacearmnn.html#a42ef3cee193102dc7755193579209cca">armnn::ClActivationWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClActivationWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const ActivationDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_activation_workload_8cpp_source.html#l00017">ClActivationWorkload.cpp:17</a></div></div>
<div class="ttc" id="_cl_division_float_workload_8hpp_html"><div class="ttname"><a href="_cl_division_float_workload_8hpp.html">ClDivisionFloatWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_depthwise_convolution_workload_8hpp_html"><div class="ttname"><a href="_cl_depthwise_convolution_workload_8hpp.html">ClDepthwiseConvolutionWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a157e0508f6d6d08e3ca4cf6c661242e6"><div class="ttname"><a href="namespacearmnn.html#a157e0508f6d6d08e3ca4cf6c661242e6">armnn::ClStridedSliceWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClStridedSliceWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const StridedSliceDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_strided_slice_workload_8cpp_source.html#l00026">ClStridedSliceWorkload.cpp:26</a></div></div>
<div class="ttc" id="namespacearmnn_html_ae58d1f4437a779274037bc86efac9e26"><div class="ttname"><a href="namespacearmnn.html#ae58d1f4437a779274037bc86efac9e26">armnn::ClPreluWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClPreluWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;alpha, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_prelu_workload_8cpp_source.html#l00016">ClPreluWorkload.cpp:16</a></div></div>
<div class="ttc" id="structarmnn_1_1_elementwise_unary_descriptor_html_afe768be66897eb3d73284424e3239b23"><div class="ttname"><a href="structarmnn_1_1_elementwise_unary_descriptor.html#afe768be66897eb3d73284424e3239b23">armnn::ElementwiseUnaryDescriptor::m_Operation</a></div><div class="ttdeci">UnaryOperation m_Operation</div><div class="ttdoc">Specifies the elementwiseUnary operation to execute. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00098">Descriptors.hpp:98</a></div></div>
<div class="ttc" id="_cl_transpose_convolution2d_workload_8hpp_html"><div class="ttname"><a href="_cl_transpose_convolution2d_workload_8hpp.html">ClTransposeConvolution2dWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_batch_to_space_nd_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_batch_to_space_nd_descriptor.html">armnn::BatchToSpaceNdDescriptor</a></div><div class="ttdoc">A BatchToSpaceNdDescriptor for the BatchToSpaceNdLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00657">Descriptors.hpp:657</a></div></div>
<div class="ttc" id="namespacearmnn_html_a2399052d9cbb2b88720b07511a2e362f"><div class="ttname"><a href="namespacearmnn.html#a2399052d9cbb2b88720b07511a2e362f">armnn::IsBatchToSpaceNdSupported</a></div><div class="ttdeci">bool IsBatchToSpaceNdSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const BatchToSpaceNdDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00126">LayerSupport.cpp:126</a></div></div>
<div class="ttc" id="_cl_convolution2d_workload_8hpp_html"><div class="ttname"><a href="_cl_convolution2d_workload_8hpp.html">ClConvolution2dWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a67a0db04d321a74b7e7fcfd3f1a3f70b"><div class="ttname"><a href="namespacearmnn.html#a67a0db04d321a74b7e7fcfd3f1a3f70b">armnn::Status</a></div><div class="ttdeci">Status</div><div class="ttdef"><b>Definition:</b> <a href="_types_8hpp_source.html#l00026">Types.hpp:26</a></div></div>
<div class="ttc" id="namespacearmnn_html_a8c04c8e796a4fbec706df42ed9c27e4e"><div class="ttname"><a href="namespacearmnn.html#a8c04c8e796a4fbec706df42ed9c27e4e">armnn::ClMinimumWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClMinimumWorkloadValidate(const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_minimum_workload_8cpp_source.html#l00024">ClMinimumWorkload.cpp:24</a></div></div>
<div class="ttc" id="namespaceboost_html"><div class="ttname"><a href="namespaceboost.html">boost</a></div></div>
<div class="ttc" id="structarmnn_1_1_normalization_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_normalization_descriptor.html">armnn::NormalizationDescriptor</a></div><div class="ttdoc">A NormalizationDescriptor for the NormalizationLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00551">Descriptors.hpp:551</a></div></div>
<div class="ttc" id="namespacearmnn_html_a5fb7fe07abfb2373103d842b47a24726"><div class="ttname"><a href="namespacearmnn.html#a5fb7fe07abfb2373103d842b47a24726">armnn::ClQuantizedLstmWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClQuantizedLstmWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;previousCellStateIn, const TensorInfo &amp;previousOutputIn, const TensorInfo &amp;cellStateOut, const TensorInfo &amp;output, const QuantizedLstmInputParamsInfo &amp;paramsInfo)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_quantized_lstm_workload_8cpp_source.html#l00018">ClQuantizedLstmWorkload.cpp:18</a></div></div>
<div class="ttc" id="namespacearmnn_html_aa2f4e75d4a4f61b24de0dfe150952c80"><div class="ttname"><a href="namespacearmnn.html#aa2f4e75d4a4f61b24de0dfe150952c80">armnn::IsFullyConnectedSupported</a></div><div class="ttdeci">bool IsFullyConnectedSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const TensorInfo &amp;weights, const TensorInfo &amp;biases, const FullyConnectedDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00296">LayerSupport.cpp:296</a></div></div>
<div class="ttc" id="namespacearmnn_html_a67957983877fb2c720a2ad7f88c45a3c"><div class="ttname"><a href="namespacearmnn.html#a67957983877fb2c720a2ad7f88c45a3c">armnn::ClBatchToSpaceNdWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClBatchToSpaceNdWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const BatchToSpaceNdDescriptor &amp;desc)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_batch_to_space_nd_workload_8cpp_source.html#l00045">ClBatchToSpaceNdWorkload.cpp:45</a></div></div>
<div class="ttc" id="_cl_mean_workload_8hpp_html"><div class="ttname"><a href="_cl_mean_workload_8hpp.html">ClMeanWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a8874961260f35da85229554f92e16ca9"><div class="ttname"><a href="namespacearmnn.html#a8874961260f35da85229554f92e16ca9">armnn::ClFloorWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClFloorWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_floor_float_workload_8cpp_source.html#l00014">ClFloorFloatWorkload.cpp:14</a></div></div>
<div class="ttc" id="classarmnn_1_1_optional_html"><div class="ttname"><a href="classarmnn_1_1_optional.html">armnn::Optional</a></div><div class="ttdef"><b>Definition:</b> <a href="_optional_8hpp_source.html#l00270">Optional.hpp:270</a></div></div>
<div class="ttc" id="structarmnn_1_1_resize_descriptor_html_a46c3fa15c46fb0d1dcdc24d0ea5cb5cd"><div class="ttname"><a href="structarmnn_1_1_resize_descriptor.html#a46c3fa15c46fb0d1dcdc24d0ea5cb5cd">armnn::ResizeDescriptor::m_TargetHeight</a></div><div class="ttdeci">uint32_t m_TargetHeight</div><div class="ttdoc">Target height value. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00746">Descriptors.hpp:746</a></div></div>
<div class="ttc" id="namespacearmnn_html_a719ea81939d6a25f8636b52c59165d66"><div class="ttname"><a href="namespacearmnn.html#a719ea81939d6a25f8636b52c59165d66">armnn::ClTransposeConvolution2dWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClTransposeConvolution2dWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const TransposeConvolution2dDescriptor &amp;descriptor, const TensorInfo &amp;weights, const Optional&lt; TensorInfo &gt; &amp;biases)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_transpose_convolution2d_workload_8cpp_source.html#l00026">ClTransposeConvolution2dWorkload.cpp:26</a></div></div>
<div class="ttc" id="_cl_prelu_workload_8hpp_html"><div class="ttname"><a href="_cl_prelu_workload_8hpp.html">ClPreluWorkload.hpp</a></div></div>
<div class="ttc" id="classarmnn_1_1_tensor_info_html"><div class="ttname"><a href="classarmnn_1_1_tensor_info.html">armnn::TensorInfo</a></div><div class="ttdef"><b>Definition:</b> <a href="_tensor_8hpp_source.html#l00053">Tensor.hpp:53</a></div></div>
<div class="ttc" id="namespacearmnn_html_accc42ba9679a474e75b43cdf1efa9422"><div class="ttname"><a href="namespacearmnn.html#accc42ba9679a474e75b43cdf1efa9422">armnn::IsRsqrtSupported</a></div><div class="ttdeci">bool IsRsqrtSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00568">LayerSupport.cpp:568</a></div></div>
<div class="ttc" id="_cl_convert_fp16_to_fp32_workload_8hpp_html"><div class="ttname"><a href="_cl_convert_fp16_to_fp32_workload_8hpp.html">ClConvertFp16ToFp32Workload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a8cbabc875597b3bed0ccdc0adb289fde"><div class="ttname"><a href="namespacearmnn.html#a8cbabc875597b3bed0ccdc0adb289fde">armnn::ComputeSplitAxis</a></div><div class="ttdeci">std::set&lt; unsigned int &gt; ComputeSplitAxis(const armnn::SplitterDescriptor &amp;desc, const TensorShape &amp;input)</div><div class="ttdef"><b>Definition:</b> <a href="_arm_compute_utils_8hpp_source.html#l00154">ArmComputeUtils.hpp:154</a></div></div>
<div class="ttc" id="structarmnn_1_1_resize_descriptor_html_a6089e1ca91914015777ea780a513131a"><div class="ttname"><a href="structarmnn_1_1_resize_descriptor.html#a6089e1ca91914015777ea780a513131a">armnn::ResizeDescriptor::m_DataLayout</a></div><div class="ttdeci">DataLayout m_DataLayout</div><div class="ttdoc">The data layout to be used (NCHW, NHWC). </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00751">Descriptors.hpp:751</a></div></div>
<div class="ttc" id="namespacearmnn_html_a936d3f949a334668f839fb0bdd170b72"><div class="ttname"><a href="namespacearmnn.html#a936d3f949a334668f839fb0bdd170b72">armnn::IsResizeBilinearSupported</a></div><div class="ttdeci">bool IsResizeBilinearSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00552">LayerSupport.cpp:552</a></div></div>
<div class="ttc" id="_cl_abs_workload_8hpp_html"><div class="ttname"><a href="_cl_abs_workload_8hpp.html">ClAbsWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a75045734c29d7d6635342c05adbc151b"><div class="ttname"><a href="namespacearmnn.html#a75045734c29d7d6635342c05adbc151b">armnn::ClDequantizeWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClDequantizeWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_dequantize_workload_8cpp_source.html#l00023">ClDequantizeWorkload.cpp:23</a></div></div>
<div class="ttc" id="_cl_maximum_workload_8hpp_html"><div class="ttname"><a href="_cl_maximum_workload_8hpp.html">ClMaximumWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_pad_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_pad_descriptor.html">armnn::PadDescriptor</a></div><div class="ttdoc">A PadDescriptor for the PadLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00901">Descriptors.hpp:901</a></div></div>
<div class="ttc" id="structarmnn_1_1_activation_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_activation_descriptor.html">armnn::ActivationDescriptor</a></div><div class="ttdoc">An ActivationDescriptor for the ActivationLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00020">Descriptors.hpp:20</a></div></div>
<div class="ttc" id="namespacearmnn_html_a674a280a55c3760374a05ee24e9e3e74"><div class="ttname"><a href="namespacearmnn.html#a674a280a55c3760374a05ee24e9e3e74">armnn::ClMultiplicationWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClMultiplicationWorkloadValidate(const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_multiplication_workload_8cpp_source.html#l00014">ClMultiplicationWorkload.cpp:14</a></div></div>
<div class="ttc" id="_cl_resize_workload_8hpp_html"><div class="ttname"><a href="_cl_resize_workload_8hpp.html">ClResizeWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_backend_id_8hpp_html"><div class="ttname"><a href="_cl_backend_id_8hpp.html">ClBackendId.hpp</a></div></div>
<div class="ttc" id="_cl_layer_support_8cpp_html_af0383f6bb43d6d5df6f3265367b6ebf9"><div class="ttname"><a href="_cl_layer_support_8cpp.html#af0383f6bb43d6d5df6f3265367b6ebf9">FORWARD_WORKLOAD_VALIDATE_FUNC</a></div><div class="ttdeci">#define FORWARD_WORKLOAD_VALIDATE_FUNC(func, reasonIfUnsupported,...)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_layer_support_8cpp_source.html#l00126">ClLayerSupport.cpp:126</a></div></div>
<div class="ttc" id="namespacearmnn_html_ac6cc8e0bd35d229486fe6d844d88e0d4"><div class="ttname"><a href="namespacearmnn.html#ac6cc8e0bd35d229486fe6d844d88e0d4">armnn::IsTransposeConvolution2dSupported</a></div><div class="ttdeci">bool IsTransposeConvolution2dSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const TransposeConvolution2dDescriptor &amp;descriptor, const TensorInfo &amp;weights, const Optional&lt; TensorInfo &gt; &amp;biases, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div></div>
<div class="ttc" id="namespacearmnn_html_acd1146eb56f1473a0bf4561bcc1d1529"><div class="ttname"><a href="namespacearmnn.html#acd1146eb56f1473a0bf4561bcc1d1529">armnn::ClConvolution2dWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClConvolution2dWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const Convolution2dDescriptor &amp;descriptor, const TensorInfo &amp;weights, const Optional&lt; TensorInfo &gt; &amp;biases)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_convolution2d_workload_8cpp_source.html#l00023">ClConvolution2dWorkload.cpp:23</a></div></div>
<div class="ttc" id="structarmnn_1_1_batch_normalization_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_batch_normalization_descriptor.html">armnn::BatchNormalizationDescriptor</a></div><div class="ttdoc">A BatchNormalizationDescriptor for the BatchNormalizationLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00610">Descriptors.hpp:610</a></div></div>
<div class="ttc" id="structarmnn_1_1_resize_descriptor_html_a869254cb56968986a78a79e1d6d4a86b"><div class="ttname"><a href="structarmnn_1_1_resize_descriptor.html#a869254cb56968986a78a79e1d6d4a86b">armnn::ResizeDescriptor::m_Method</a></div><div class="ttdeci">ResizeMethod m_Method</div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00749">Descriptors.hpp:749</a></div></div>
<div class="ttc" id="namespacearmnn_html_a58bfb9626d373249745d78b95543116e"><div class="ttname"><a href="namespacearmnn.html#a58bfb9626d373249745d78b95543116e">armnn::IsActivationSupported</a></div><div class="ttdeci">bool IsActivationSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const ActivationDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00069">LayerSupport.cpp:69</a></div></div>
<div class="ttc" id="namespacearmnn_html_af5014cbc003abcf201d4372b0012734c"><div class="ttname"><a href="namespacearmnn.html#af5014cbc003abcf201d4372b0012734c">armnn::IsReshapeSupported</a></div><div class="ttdeci">bool IsReshapeSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const ReshapeDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div></div>
<div class="ttc" id="_cl_quantize_workload_8hpp_html"><div class="ttname"><a href="_cl_quantize_workload_8hpp.html">ClQuantizeWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_minimum_workload_8hpp_html"><div class="ttname"><a href="_cl_minimum_workload_8hpp.html">ClMinimumWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a7d18d6613bb865b66b05d4d6e0391934"><div class="ttname"><a href="namespacearmnn.html#a7d18d6613bb865b66b05d4d6e0391934">armnn::IsBatchNormalizationSupported</a></div><div class="ttdeci">bool IsBatchNormalizationSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const TensorInfo &amp;mean, const TensorInfo &amp;var, const TensorInfo &amp;beta, const TensorInfo &amp;gamma, const BatchNormalizationDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00104">LayerSupport.cpp:104</a></div></div>
<div class="ttc" id="namespacearmnn_html_a4069381c4737d57fc7fd299a61ad9ca1"><div class="ttname"><a href="namespacearmnn.html#a4069381c4737d57fc7fd299a61ad9ca1">armnn::IsQuantizedLstmSupported</a></div><div class="ttdeci">bool IsQuantizedLstmSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;previousCellStateIn, const TensorInfo &amp;previousOutputIn, const TensorInfo &amp;cellStateOut, const TensorInfo &amp;output, const QuantizedLstmInputParamsInfo &amp;paramsInfo, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00486">LayerSupport.cpp:486</a></div></div>
<div class="ttc" id="namespacearmnn_html_a4b3a41e24d4b9e2b4cb431dc90c48970"><div class="ttname"><a href="namespacearmnn.html#a4b3a41e24d4b9e2b4cb431dc90c48970">armnn::IsSpaceToBatchNdSupported</a></div><div class="ttdeci">bool IsSpaceToBatchNdSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const SpaceToBatchNdDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00591">LayerSupport.cpp:591</a></div></div>
<div class="ttc" id="_cl_quantized_lstm_workload_8hpp_html"><div class="ttname"><a href="_cl_quantized_lstm_workload_8hpp.html">ClQuantizedLstmWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_greater_workload_8hpp_html"><div class="ttname"><a href="_cl_greater_workload_8hpp.html">ClGreaterWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_layer_support_8hpp_html"><div class="ttname"><a href="_cl_layer_support_8hpp.html">ClLayerSupport.hpp</a></div></div>
<div class="ttc" id="_layer_support_common_8hpp_html"><div class="ttname"><a href="_layer_support_common_8hpp.html">LayerSupportCommon.hpp</a></div></div>
<div class="ttc" id="_cl_floor_float_workload_8hpp_html"><div class="ttname"><a href="_cl_floor_float_workload_8hpp.html">ClFloorFloatWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_reshape_workload_8hpp_html"><div class="ttname"><a href="_cl_reshape_workload_8hpp.html">ClReshapeWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_depth_to_space_workload_8hpp_html"><div class="ttname"><a href="_cl_depth_to_space_workload_8hpp.html">ClDepthToSpaceWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_l2_normalization_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_l2_normalization_descriptor.html">armnn::L2NormalizationDescriptor</a></div><div class="ttdoc">A L2NormalizationDescriptor for the L2NormalizationLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00591">Descriptors.hpp:591</a></div></div>
<div class="ttc" id="structarmnn_1_1_views_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_views_descriptor.html">armnn::ViewsDescriptor</a></div><div class="ttdoc">A ViewsDescriptor for the SplitterLayer. Descriptor to configure the splitting process. Number of Views must be equal to the number of outputs, and their order must match - e.g. first view corresponds to the first output, second view to the second output, etc. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00190">Descriptors.hpp:190</a></div></div>
<div class="ttc" id="namespacearmnn_html_addffaddb4bdb6ec506fe08debcce9b75"><div class="ttname"><a href="namespacearmnn.html#addffaddb4bdb6ec506fe08debcce9b75">armnn::IsSpaceToDepthSupported</a></div><div class="ttdeci">bool IsSpaceToDepthSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const SpaceToDepthDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00601">LayerSupport.cpp:601</a></div></div>
<div class="ttc" id="namespacearmnn_html_adffa596b4bdecd54ca460853cd1439e2"><div class="ttname"><a href="namespacearmnn.html#adffa596b4bdecd54ca460853cd1439e2">armnn::IsGreaterSupported</a></div><div class="ttdeci">bool IsGreaterSupported(const BackendId &amp;backend, const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00318">LayerSupport.cpp:318</a></div></div>
<div class="ttc" id="namespacearmnn_html_aebe3dc6730e1b29aee9c9f33b8f94121"><div class="ttname"><a href="namespacearmnn.html#aebe3dc6730e1b29aee9c9f33b8f94121">armnn::IsStridedSliceSupported</a></div><div class="ttdeci">bool IsStridedSliceSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const StridedSliceDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00633">LayerSupport.cpp:633</a></div></div>
<div class="ttc" id="structarmnn_1_1_lstm_input_params_info_html"><div class="ttname"><a href="structarmnn_1_1_lstm_input_params_info.html">armnn::LstmInputParamsInfo</a></div><div class="ttdef"><b>Definition:</b> <a href="_lstm_params_8hpp_source.html#l00063">LstmParams.hpp:63</a></div></div>
<div class="ttc" id="structarmnn_1_1_space_to_depth_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_space_to_depth_descriptor.html">armnn::SpaceToDepthDescriptor</a></div><div class="ttdoc">A SpaceToDepthDescriptor for the SpaceToDepthLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00810">Descriptors.hpp:810</a></div></div>
<div class="ttc" id="namespacearmnn_html_a00ef2c55913f952924a3e23556655285"><div class="ttname"><a href="namespacearmnn.html#a00ef2c55913f952924a3e23556655285">armnn::ClFullyConnectedWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClFullyConnectedWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const TensorInfo &amp;weights, const TensorInfo &amp;biases, const FullyConnectedDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_fully_connected_workload_8cpp_source.html#l00019">ClFullyConnectedWorkload.cpp:19</a></div></div>
<div class="ttc" id="namespacearmnn_html_a02847c99a2acae3b267615479f93ab55"><div class="ttname"><a href="namespacearmnn.html#a02847c99a2acae3b267615479f93ab55">armnn::supported</a></div><div class="ttdeci">ISubgraphViewConverter supported</div><div class="ttdef"><b>Definition:</b> <a href="_i_subgraph_view_converter_8hpp_source.html#l00031">ISubgraphViewConverter.hpp:31</a></div></div>
<div class="ttc" id="_cl_space_to_batch_nd_workload_8hpp_html"><div class="ttname"><a href="_cl_space_to_batch_nd_workload_8hpp.html">ClSpaceToBatchNdWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_reshape_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_reshape_descriptor.html">armnn::ReshapeDescriptor</a></div><div class="ttdoc">A ReshapeDescriptor for the ReshapeLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00758">Descriptors.hpp:758</a></div></div>
<div class="ttc" id="structarmnn_1_1_transpose_convolution2d_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_transpose_convolution2d_descriptor.html">armnn::TransposeConvolution2dDescriptor</a></div><div class="ttdoc">A TransposeConvolution2dDescriptor for the TransposeConvolution2dLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l01079">Descriptors.hpp:1079</a></div></div>
<div class="ttc" id="_cl_permute_workload_8hpp_html"><div class="ttname"><a href="_cl_permute_workload_8hpp.html">ClPermuteWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_elementwise_unary_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_elementwise_unary_descriptor.html">armnn::ElementwiseUnaryDescriptor</a></div><div class="ttdoc">A ElementwiseUnaryDescriptor for the ElementwiseUnaryLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00082">Descriptors.hpp:82</a></div></div>
<div class="ttc" id="namespacearmnn_html_a3b85a270baf98ea6b040bd395c2d700a"><div class="ttname"><a href="namespacearmnn.html#a3b85a270baf98ea6b040bd395c2d700a">armnn::IsMaximumSupported</a></div><div class="ttdeci">bool IsMaximumSupported(const BackendId &amp;backend, const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output, char *reasonIfUnSupported=nullptr, size_t reasonIfUnSupportedMaxLength=0)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00365">LayerSupport.cpp:365</a></div></div>
<div class="ttc" id="namespacearmnn_html_a6a0edac987d58b405636df2eb2ee525d"><div class="ttname"><a href="namespacearmnn.html#a6a0edac987d58b405636df2eb2ee525d">armnn::ClDivisionWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClDivisionWorkloadValidate(const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_division_float_workload_8cpp_source.html#l00015">ClDivisionFloatWorkload.cpp:15</a></div></div>
<div class="ttc" id="namespacearmnn_html_abc6f7e5fe77e5aed3f7842755dd34073"><div class="ttname"><a href="namespacearmnn.html#abc6f7e5fe77e5aed3f7842755dd34073">armnn::ClSoftmaxWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClSoftmaxWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const SoftmaxDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_softmax_base_workload_8cpp_source.html#l00016">ClSoftmaxBaseWorkload.cpp:16</a></div></div>
<div class="ttc" id="namespacearmnn_html_a757df85e956e425c1a082d35a98ca4a9"><div class="ttname"><a href="namespacearmnn.html#a757df85e956e425c1a082d35a98ca4a9">armnn::IsConcatSupported</a></div><div class="ttdeci">bool IsConcatSupported(const BackendId &amp;backend, const std::vector&lt; const TensorInfo *&gt; inputs, const TensorInfo &amp;output, const OriginsDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div></div>
<div class="ttc" id="namespacearmnn_html_a3ac8a60f837b19b20987e4fd238ce0cd"><div class="ttname"><a href="namespacearmnn.html#a3ac8a60f837b19b20987e4fd238ce0cd">armnn::ClSplitterWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClSplitterWorkloadValidate(const TensorInfo &amp;input, const std::vector&lt; std::reference_wrapper&lt; TensorInfo &gt;&gt; &amp;outputs, unsigned int splitAxis)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_splitter_workload_8cpp_source.html#l00031">ClSplitterWorkload.cpp:31</a></div></div>
<div class="ttc" id="namespacearmnn_html_a29b4b6b364a31632597970d0bad3d78f"><div class="ttname"><a href="namespacearmnn.html#a29b4b6b364a31632597970d0bad3d78f">armnn::IsDivisionSupported</a></div><div class="ttdeci">bool IsDivisionSupported(const BackendId &amp;backend, const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00248">LayerSupport.cpp:248</a></div></div>
<div class="ttc" id="namespacearmnn_html_a7782f0809076f14363eacb4a38964b9f"><div class="ttname"><a href="namespacearmnn.html#a7782f0809076f14363eacb4a38964b9f">armnn::ClConcatWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClConcatWorkloadValidate(const std::vector&lt; const TensorInfo *&gt; &amp;inputs, const TensorInfo &amp;output, const OriginsDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_concat_workload_8cpp_source.html#l00029">ClConcatWorkload.cpp:29</a></div></div>
<div class="ttc" id="namespacearmnn_html_a1b01771dc5a057d09f8cd82492154a1f"><div class="ttname"><a href="namespacearmnn.html#a1b01771dc5a057d09f8cd82492154a1f">armnn::IsAdditionSupported</a></div><div class="ttdeci">bool IsAdditionSupported(const BackendId &amp;backend, const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00079">LayerSupport.cpp:79</a></div></div>
<div class="ttc" id="structarmnn_1_1_views_descriptor_html_a78e8266be865fdd92cadd04d6e25ae1f"><div class="ttname"><a href="structarmnn_1_1_views_descriptor.html#a78e8266be865fdd92cadd04d6e25ae1f">armnn::ViewsDescriptor::GetNumDimensions</a></div><div class="ttdeci">uint32_t GetNumDimensions() const</div><div class="ttdoc">Get the number of dimensions. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8cpp_source.html#l00292">Descriptors.cpp:292</a></div></div>
<div class="ttc" id="_arm_compute_tensor_utils_8hpp_html"><div class="ttname"><a href="_arm_compute_tensor_utils_8hpp.html">ArmComputeTensorUtils.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a5634af98b603236c6748adb5ac92e766"><div class="ttname"><a href="namespacearmnn.html#a5634af98b603236c6748adb5ac92e766">armnn::ClDepthToSpaceWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClDepthToSpaceWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const DepthToSpaceDescriptor &amp;desc)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_depth_to_space_workload_8cpp_source.html#l00022">ClDepthToSpaceWorkload.cpp:22</a></div></div>
<div class="ttc" id="_cl_fully_connected_workload_8hpp_html"><div class="ttname"><a href="_cl_fully_connected_workload_8hpp.html">ClFullyConnectedWorkload.hpp</a></div></div>
<div class="ttc" id="classarmnn_1_1_tensor_info_html_a22f377fc4e10dc1773a3f979061e85f1"><div class="ttname"><a href="classarmnn_1_1_tensor_info.html#a22f377fc4e10dc1773a3f979061e85f1">armnn::TensorInfo::IsTypeSpaceMatch</a></div><div class="ttdeci">bool IsTypeSpaceMatch(const TensorInfo &amp;other) const</div><div class="ttdoc">Check that the types are the same and, if quantize, that the quantization parameters are the same...</div><div class="ttdef"><b>Definition:</b> <a href="_tensor_8cpp_source.html#l00218">Tensor.cpp:218</a></div></div>
<div class="ttc" id="namespacearmnn_html_aefc82adf365ff14b0095dafdd2df6afc"><div class="ttname"><a href="namespacearmnn.html#aefc82adf365ff14b0095dafdd2df6afc">armnn::ClAdditionValidate</a></div><div class="ttdeci">arm_compute::Status ClAdditionValidate(const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_addition_workload_8cpp_source.html#l00038">ClAdditionWorkload.cpp:38</a></div></div>
<div class="ttc" id="namespacearmnn_html_a3f6f9f0d3567ae04b49ea88727845900"><div class="ttname"><a href="namespacearmnn.html#a3f6f9f0d3567ae04b49ea88727845900">armnn::ClRsqrtWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClRsqrtWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_rsqrt_workload_8cpp_source.html#l00019">ClRsqrtWorkload.cpp:19</a></div></div>
<div class="ttc" id="namespacearmnn_html_a46efae0191388fd33db4e95c5d79e2be"><div class="ttname"><a href="namespacearmnn.html#a46efae0191388fd33db4e95c5d79e2be">armnn::ClConvertFp16ToFp32WorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClConvertFp16ToFp32WorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_convert_fp16_to_fp32_workload_8cpp_source.html#l00035">ClConvertFp16ToFp32Workload.cpp:35</a></div></div>
<div class="ttc" id="namespacearmnn_html_ab80423b306d8e0436b9a316922911d4d"><div class="ttname"><a href="namespacearmnn.html#ab80423b306d8e0436b9a316922911d4d">armnn::ClArgMinMaxWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClArgMinMaxWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const ArgMinMaxDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_arg_min_max_workload_8cpp_source.html#l00030">ClArgMinMaxWorkload.cpp:30</a></div></div>
<div class="ttc" id="_cl_l2_normalization_float_workload_8hpp_html"><div class="ttname"><a href="_cl_l2_normalization_float_workload_8hpp.html">ClL2NormalizationFloatWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_lstm_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_lstm_descriptor.html">armnn::LstmDescriptor</a></div><div class="ttdoc">An LstmDescriptor for the LstmLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00837">Descriptors.hpp:837</a></div></div>
<div class="ttc" id="structarmnn_1_1_origins_descriptor_html_a78e8266be865fdd92cadd04d6e25ae1f"><div class="ttname"><a href="structarmnn_1_1_origins_descriptor.html#a78e8266be865fdd92cadd04d6e25ae1f">armnn::OriginsDescriptor::GetNumDimensions</a></div><div class="ttdeci">uint32_t GetNumDimensions() const</div><div class="ttdoc">Get the number of dimensions. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8cpp_source.html#l00184">Descriptors.cpp:184</a></div></div>
<div class="ttc" id="structarmnn_1_1_origins_descriptor_html_a379929e3b277f1ef94f3ce645870589d"><div class="ttname"><a href="structarmnn_1_1_origins_descriptor.html#a379929e3b277f1ef94f3ce645870589d">armnn::OriginsDescriptor::GetConcatAxis</a></div><div class="ttdeci">unsigned int GetConcatAxis() const</div><div class="ttdoc">Get the concatenation axis value. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8cpp_source.html#l00154">Descriptors.cpp:154</a></div></div>
<div class="ttc" id="_descriptors_8hpp_html"><div class="ttname"><a href="_descriptors_8hpp.html">Descriptors.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a5a0c1871f7e4822adb8b15e8ae76bca0"><div class="ttname"><a href="namespacearmnn.html#a5a0c1871f7e4822adb8b15e8ae76bca0">armnn::IsPreluSupported</a></div><div class="ttdeci">bool IsPreluSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;alpha, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00521">LayerSupport.cpp:521</a></div></div>
<div class="ttc" id="namespacearmnn_html_a89e9c52419c572f05bf9737a7a60b267"><div class="ttname"><a href="namespacearmnn.html#a89e9c52419c572f05bf9737a7a60b267">armnn::IsFloorSupported</a></div><div class="ttdeci">bool IsFloorSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00282">LayerSupport.cpp:282</a></div></div>
<div class="ttc" id="structarmnn_1_1_instance_normalization_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_instance_normalization_descriptor.html">armnn::InstanceNormalizationDescriptor</a></div><div class="ttdoc">An InstanceNormalizationDescriptor for InstanceNormalizationLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00629">Descriptors.hpp:629</a></div></div>
<div class="ttc" id="_cl_subtraction_workload_8hpp_html"><div class="ttname"><a href="_cl_subtraction_workload_8hpp.html">ClSubtractionWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_multiplication_workload_8hpp_html"><div class="ttname"><a href="_cl_multiplication_workload_8hpp.html">ClMultiplicationWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_normalization_float_workload_8hpp_html"><div class="ttname"><a href="_cl_normalization_float_workload_8hpp.html">ClNormalizationFloatWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_slice_workload_8hpp_html"><div class="ttname"><a href="_cl_slice_workload_8hpp.html">ClSliceWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a7ce5f7168bf0d1e7efe269d59ed564ba"><div class="ttname"><a href="namespacearmnn.html#a7ce5f7168bf0d1e7efe269d59ed564ba">armnn::IsSplitterSupported</a></div><div class="ttdeci">bool IsSplitterSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const ViewsDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00612">LayerSupport.cpp:612</a></div></div>
<div class="ttc" id="structarmnn_1_1_fully_connected_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_fully_connected_descriptor.html">armnn::FullyConnectedDescriptor</a></div><div class="ttdoc">A FullyConnectedDescriptor for the FullyConnectedLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00373">Descriptors.hpp:373</a></div></div>
<div class="ttc" id="_cl_batch_to_space_nd_workload_8hpp_html"><div class="ttname"><a href="_cl_batch_to_space_nd_workload_8hpp.html">ClBatchToSpaceNdWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a477695b3df8c0abd2efcf02051f61065"><div class="ttname"><a href="namespacearmnn.html#a477695b3df8c0abd2efcf02051f61065">armnn::IsSoftmaxSupported</a></div><div class="ttdeci">bool IsSoftmaxSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const SoftmaxDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00581">LayerSupport.cpp:581</a></div></div>
<div class="ttc" id="namespacearmnn_html_a754b0ac19fd6341ce2b5f480c3b35e8e"><div class="ttname"><a href="namespacearmnn.html#a754b0ac19fd6341ce2b5f480c3b35e8e">armnn::IsNormalizationSupported</a></div><div class="ttdeci">bool IsNormalizationSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const NormalizationDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00448">LayerSupport.cpp:448</a></div></div>
<div class="ttc" id="_cl_rsqrt_workload_8hpp_html"><div class="ttname"><a href="_cl_rsqrt_workload_8hpp.html">ClRsqrtWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html"><div class="ttname"><a href="namespacearmnn.html">armnn</a></div><div class="ttdef"><b>Definition:</b> <a href="_backend_helper_8hpp_source.html#l00011">BackendHelper.hpp:11</a></div></div>
<div class="ttc" id="_cl_activation_workload_8hpp_html"><div class="ttname"><a href="_cl_activation_workload_8hpp.html">ClActivationWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_stack_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_stack_descriptor.html">armnn::StackDescriptor</a></div><div class="ttdoc">A StackDescriptor for the StackLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00950">Descriptors.hpp:950</a></div></div>
<div class="ttc" id="_cl_space_to_depth_workload_8hpp_html"><div class="ttname"><a href="_cl_space_to_depth_workload_8hpp.html">ClSpaceToDepthWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_quantized_lstm_input_params_info_html"><div class="ttname"><a href="structarmnn_1_1_quantized_lstm_input_params_info.html">armnn::QuantizedLstmInputParamsInfo</a></div><div class="ttdef"><b>Definition:</b> <a href="_quantized_lstm_params_8hpp_source.html#l00119">QuantizedLstmParams.hpp:119</a></div></div>
<div class="ttc" id="namespacearmnn_html_af6dbe371ec651a8e0063624fdf32afc0"><div class="ttname"><a href="namespacearmnn.html#af6dbe371ec651a8e0063624fdf32afc0">armnn::IsSupportedForDataTypeGeneric</a></div><div class="ttdeci">bool IsSupportedForDataTypeGeneric(Optional&lt; std::string &amp;&gt; reasonIfUnsupported, DataType dataType, Float16Func float16FuncPtr, Float32Func float32FuncPtr, Uint8Func uint8FuncPtr, Int32Func int32FuncPtr, BooleanFunc booleanFuncPtr, Params &amp;&amp;... params)</div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_common_8hpp_source.html#l00028">LayerSupportCommon.hpp:28</a></div></div>
<div class="ttc" id="_cl_softmax_base_workload_8hpp_html"><div class="ttname"><a href="_cl_softmax_base_workload_8hpp.html">ClSoftmaxBaseWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_lstm_float_workload_8hpp_html"><div class="ttname"><a href="_cl_lstm_float_workload_8hpp.html">ClLstmFloatWorkload.hpp</a></div></div>
<div class="ttc" id="_arm_compute_utils_8hpp_html"><div class="ttname"><a href="_arm_compute_utils_8hpp.html">ArmComputeUtils.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a0906736b90464c0eb3ce5a87e05ebeee"><div class="ttname"><a href="namespacearmnn.html#a0906736b90464c0eb3ce5a87e05ebeee">armnn::IsL2NormalizationSupported</a></div><div class="ttdeci">bool IsL2NormalizationSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const L2NormalizationDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00342">LayerSupport.cpp:342</a></div></div>
<div class="ttc" id="structarmnn_1_1_softmax_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_softmax_descriptor.html">armnn::SoftmaxDescriptor</a></div><div class="ttdoc">A SoftmaxDescriptor for the SoftmaxLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00123">Descriptors.hpp:123</a></div></div>
<div class="ttc" id="namespacearmnn_html_a8c9fec997dbb5db4cdb433c36d075782"><div class="ttname"><a href="namespacearmnn.html#a8c9fec997dbb5db4cdb433c36d075782">armnn::ClStackWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClStackWorkloadValidate(const std::vector&lt; const TensorInfo *&gt; &amp;inputs, const TensorInfo &amp;output, const StackDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_stack_workload_8cpp_source.html#l00030">ClStackWorkload.cpp:30</a></div></div>
<div class="ttc" id="structarmnn_1_1_resize_descriptor_html_adcf5037208faac36c0788239a073f75c"><div class="ttname"><a href="structarmnn_1_1_resize_descriptor.html#adcf5037208faac36c0788239a073f75c">armnn::ResizeDescriptor::m_TargetWidth</a></div><div class="ttdeci">uint32_t m_TargetWidth</div><div class="ttdoc">Target width value. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00744">Descriptors.hpp:744</a></div></div>
<div class="ttc" id="namespacearmnn_html_aa1fff3c5bdebee27ad33aacc6d110d32"><div class="ttname"><a href="namespacearmnn.html#aa1fff3c5bdebee27ad33aacc6d110d32">armnn::ClMeanValidate</a></div><div class="ttdeci">arm_compute::Status ClMeanValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const MeanDescriptor &amp;desc)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_mean_workload_8cpp_source.html#l00017">ClMeanWorkload.cpp:17</a></div></div>
<div class="ttc" id="namespacearmnn_html_a197a353aa963497d29a07796268ea5c1"><div class="ttname"><a href="namespacearmnn.html#a197a353aa963497d29a07796268ea5c1">armnn::IsInputSupported</a></div><div class="ttdeci">bool IsInputSupported(const BackendId &amp;backend, const TensorInfo &amp;input, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00333">LayerSupport.cpp:333</a></div></div>
<div class="ttc" id="namespacearmnn_html_a701cecec7714cf8bc9dca804f473610d"><div class="ttname"><a href="namespacearmnn.html#a701cecec7714cf8bc9dca804f473610d">armnn::IsOutputSupported</a></div><div class="ttdeci">bool IsOutputSupported(const BackendId &amp;backend, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00458">LayerSupport.cpp:458</a></div></div>
<div class="ttc" id="_cl_dequantize_workload_8hpp_html"><div class="ttname"><a href="_cl_dequantize_workload_8hpp.html">ClDequantizeWorkload.hpp</a></div></div>
<div class="ttc" id="_backend_registry_8hpp_html"><div class="ttname"><a href="_backend_registry_8hpp.html">BackendRegistry.hpp</a></div></div>
<div class="ttc" id="_cl_instance_normalization_workload_8hpp_html"><div class="ttname"><a href="_cl_instance_normalization_workload_8hpp.html">ClInstanceNormalizationWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a3bbbf958387c788549b0d8481232875f"><div class="ttname"><a href="namespacearmnn.html#a3bbbf958387c788549b0d8481232875f">armnn::ClSubtractionValidate</a></div><div class="ttdeci">arm_compute::Status ClSubtractionValidate(const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_subtraction_workload_8cpp_source.html#l00038">ClSubtractionWorkload.cpp:38</a></div></div>
<div class="ttc" id="structarmnn_1_1_comparison_descriptor_html_a865dc4f43cb0ff01a1dcf78036912fd1"><div class="ttname"><a href="structarmnn_1_1_comparison_descriptor.html#a865dc4f43cb0ff01a1dcf78036912fd1">armnn::ComparisonDescriptor::m_Operation</a></div><div class="ttdeci">ComparisonOperation m_Operation</div><div class="ttdoc">Specifies the comparison operation to execute. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00078">Descriptors.hpp:78</a></div></div>
<div class="ttc" id="namespacearmnn_html_a3e8b3af7771ffb37ede50aa2d9cc3af6"><div class="ttname"><a href="namespacearmnn.html#a3e8b3af7771ffb37ede50aa2d9cc3af6">armnn::IsLstmSupported</a></div><div class="ttdeci">bool IsLstmSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;outputStateIn, const TensorInfo &amp;cellStateIn, const TensorInfo &amp;scratchBuffer, const TensorInfo &amp;outputStateOut, const TensorInfo &amp;cellStateOut, const TensorInfo &amp;output, const LstmDescriptor &amp;descriptor, const LstmInputParamsInfo &amp;paramsInfo, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00352">LayerSupport.cpp:352</a></div></div>
<div class="ttc" id="namespacearmnn_html_aaa152f86599af5189c9d637fe7ade6d0"><div class="ttname"><a href="namespacearmnn.html#aaa152f86599af5189c9d637fe7ade6d0">armnn::IsConvertFp16ToFp32Supported</a></div><div class="ttdeci">bool IsConvertFp16ToFp32Supported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00160">LayerSupport.cpp:160</a></div></div>
<div class="ttc" id="namespacearmnn_html_ad8ed01ff3ff33333d8e19db4d2818bb6"><div class="ttname"><a href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">armnn::DataType</a></div><div class="ttdeci">DataType</div><div class="ttdef"><b>Definition:</b> <a href="_types_8hpp_source.html#l00032">Types.hpp:32</a></div></div>
<div class="ttc" id="classarmnn_1_1_tensor_shape_html"><div class="ttname"><a href="classarmnn_1_1_tensor_shape.html">armnn::TensorShape</a></div><div class="ttdef"><b>Definition:</b> <a href="_tensor_8hpp_source.html#l00020">Tensor.hpp:20</a></div></div>
<div class="ttc" id="namespacearmnn_html_a13c7d751e4d37f65a6d40c3c6e50d2b8"><div class="ttname"><a href="namespacearmnn.html#a13c7d751e4d37f65a6d40c3c6e50d2b8">armnn::SetValueChecked</a></div><div class="ttdeci">void SetValueChecked(Optional&lt; T &amp;&gt; optionalRef, V &amp;&amp;val)</div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_common_8hpp_source.html#l00018">LayerSupportCommon.hpp:18</a></div></div>
<div class="ttc" id="namespacearmnn_html_a79d362f0c6e04d51807e0d81b5b05f3a"><div class="ttname"><a href="namespacearmnn.html#a79d362f0c6e04d51807e0d81b5b05f3a">armnn::ClInstanceNormalizationWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClInstanceNormalizationWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const InstanceNormalizationDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_instance_normalization_workload_8cpp_source.html#l00018">ClInstanceNormalizationWorkload.cpp:18</a></div></div>
<div class="ttc" id="namespacearmnn_html_aea548aa1485adbeeb3e393a13bb6bff8"><div class="ttname"><a href="namespacearmnn.html#aea548aa1485adbeeb3e393a13bb6bff8">armnn::IsPooling2dSupported</a></div><div class="ttdeci">bool IsPooling2dSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const Pooling2dDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00511">LayerSupport.cpp:511</a></div></div>
<div class="ttc" id="namespacearmnn_html_a26c25df9e2271333ab4d4ef71db41dca"><div class="ttname"><a href="namespacearmnn.html#a26c25df9e2271333ab4d4ef71db41dca">armnn::ClPermuteWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClPermuteWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const PermuteDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_permute_workload_8cpp_source.html#l00017">ClPermuteWorkload.cpp:17</a></div></div>
<div class="ttc" id="namespacearmnn_html_a5f81bc4e5533cfe99932865bd102735c"><div class="ttname"><a href="namespacearmnn.html#a5f81bc4e5533cfe99932865bd102735c">armnn::ClSpaceToDepthWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClSpaceToDepthWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const SpaceToDepthDescriptor &amp;desc)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_space_to_depth_workload_8cpp_source.html#l00044">ClSpaceToDepthWorkload.cpp:44</a></div></div>
<div class="ttc" id="namespacearmnn_html_a0cdc60b4988b2193b97590e35f34a07e"><div class="ttname"><a href="namespacearmnn.html#a0cdc60b4988b2193b97590e35f34a07e">armnn::IsMeanSupported</a></div><div class="ttdeci">bool IsMeanSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const MeanDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00375">LayerSupport.cpp:375</a></div></div>
<div class="ttc" id="namespacearmnn_html_a6d85d2806d0a90140832ad8113c1d350"><div class="ttname"><a href="namespacearmnn.html#a6d85d2806d0a90140832ad8113c1d350">armnn::ClSliceWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClSliceWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const SliceDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_slice_workload_8cpp_source.html#l00019">ClSliceWorkload.cpp:19</a></div></div>
<div class="ttc" id="classarmnn_1_1_tensor_info_html_aea909c7327109228ef618d459015def3"><div class="ttname"><a href="classarmnn_1_1_tensor_info.html#aea909c7327109228ef618d459015def3">armnn::TensorInfo::GetDataType</a></div><div class="ttdeci">DataType GetDataType() const</div><div class="ttdef"><b>Definition:</b> <a href="_tensor_8hpp_source.html#l00095">Tensor.hpp:95</a></div></div>
<div class="ttc" id="namespacearmnn_html_acc76cdec78906a3457a9c2293a453869"><div class="ttname"><a href="namespacearmnn.html#acc76cdec78906a3457a9c2293a453869">armnn::IsConstantSupported</a></div><div class="ttdeci">bool IsConstantSupported(const BackendId &amp;backend, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00152">LayerSupport.cpp:152</a></div></div>
<div class="ttc" id="namespacearmnn_html_a10e8442be2b8596afd5770e98b904caa"><div class="ttname"><a href="namespacearmnn.html#a10e8442be2b8596afd5770e98b904caa">armnn::IsStackSupported</a></div><div class="ttdeci">bool IsStackSupported(const BackendId &amp;backend, const std::vector&lt; const TensorInfo *&gt; inputs, const TensorInfo &amp;output, const StackDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div></div>
<div class="ttc" id="namespacearmnn_html_af22d4421773ce95e0f2324fc1a66c0d9"><div class="ttname"><a href="namespacearmnn.html#af22d4421773ce95e0f2324fc1a66c0d9">armnn::IsConvolution2dSupported</a></div><div class="ttdeci">bool IsConvolution2dSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const Convolution2dDescriptor &amp;descriptor, const TensorInfo &amp;weights, const Optional&lt; TensorInfo &gt; &amp;biases, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00178">LayerSupport.cpp:178</a></div></div>
<div class="ttc" id="namespacearmnn_html_a6e2c7ec2b8d47bde2bc9fa04bb2091f6"><div class="ttname"><a href="namespacearmnn.html#a6e2c7ec2b8d47bde2bc9fa04bb2091f6">armnn::IsMergerSupported</a></div><div class="ttdeci">bool IsMergerSupported(const BackendId &amp;backend, const std::vector&lt; const TensorInfo *&gt; inputs, const TensorInfo &amp;output, const OriginsDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div></div>
<div class="ttc" id="structarmnn_1_1_pooling2d_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_pooling2d_descriptor.html">armnn::Pooling2dDescriptor</a></div><div class="ttdoc">A Pooling2dDescriptor for the Pooling2dLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00313">Descriptors.hpp:313</a></div></div>
<div class="ttc" id="namespacearmnn_html_a98994026cec1578ceb7aa74c834b00d9"><div class="ttname"><a href="namespacearmnn.html#a98994026cec1578ceb7aa74c834b00d9">armnn::IsConvertFp32ToFp16Supported</a></div><div class="ttdeci">bool IsConvertFp32ToFp16Supported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00169">LayerSupport.cpp:169</a></div></div>
<div class="ttc" id="namespacearmnn_html_aa3a1bea3b3cd5611f13c06020dababc4"><div class="ttname"><a href="namespacearmnn.html#aa3a1bea3b3cd5611f13c06020dababc4">armnn::IsPermuteSupported</a></div><div class="ttdeci">bool IsPermuteSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const PermuteDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00501">LayerSupport.cpp:501</a></div></div>
<div class="ttc" id="structarmnn_1_1_slice_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_slice_descriptor.html">armnn::SliceDescriptor</a></div><div class="ttdoc">A SliceDescriptor for the SliceLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00927">Descriptors.hpp:927</a></div></div>
<div class="ttc" id="_cl_pad_workload_8hpp_html"><div class="ttname"><a href="_cl_pad_workload_8hpp.html">ClPadWorkload.hpp</a></div></div>
<div class="ttc" id="_cl_stack_workload_8hpp_html"><div class="ttname"><a href="_cl_stack_workload_8hpp.html">ClStackWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a4ec5dfcb3e419ddce1fcb3b799f312e1"><div class="ttname"><a href="namespacearmnn.html#a4ec5dfcb3e419ddce1fcb3b799f312e1">armnn::ClDepthwiseConvolutionWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClDepthwiseConvolutionWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const DepthwiseConvolution2dDescriptor &amp;descriptor, const TensorInfo &amp;weights, const Optional&lt; TensorInfo &gt; &amp;biases)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_depthwise_convolution_workload_8cpp_source.html#l00024">ClDepthwiseConvolutionWorkload.cpp:24</a></div></div>
<div class="ttc" id="namespacearmnn_html_a399d38872500c6ac84ae031673176ef3"><div class="ttname"><a href="namespacearmnn.html#a399d38872500c6ac84ae031673176ef3">armnn::IsDepthwiseConvolutionSupported</a></div><div class="ttdeci">bool IsDepthwiseConvolutionSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const DepthwiseConvolution2dDescriptor &amp;descriptor, const TensorInfo &amp;weights, const Optional&lt; TensorInfo &gt; &amp;biases, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00199">LayerSupport.cpp:199</a></div></div>
<div class="ttc" id="_cl_addition_workload_8hpp_html"><div class="ttname"><a href="_cl_addition_workload_8hpp.html">ClAdditionWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_depthwise_convolution2d_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_depthwise_convolution2d_descriptor.html">armnn::DepthwiseConvolution2dDescriptor</a></div><div class="ttdoc">A DepthwiseConvolution2dDescriptor for the DepthwiseConvolution2dLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00444">Descriptors.hpp:444</a></div></div>
<div class="ttc" id="structarmnn_1_1_permute_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_permute_descriptor.html">armnn::PermuteDescriptor</a></div><div class="ttdoc">A PermuteDescriptor for the PermuteLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00102">Descriptors.hpp:102</a></div></div>
<div class="ttc" id="structarmnn_1_1_convolution2d_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_convolution2d_descriptor.html">armnn::Convolution2dDescriptor</a></div><div class="ttdoc">A Convolution2dDescriptor for the Convolution2dLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00392">Descriptors.hpp:392</a></div></div>
<div class="ttc" id="namespacearmnn_html_a9c1b478e30a1e8a4ecac874cf15f13d4"><div class="ttname"><a href="namespacearmnn.html#a9c1b478e30a1e8a4ecac874cf15f13d4">armnn::ClQuantizeWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClQuantizeWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_quantize_workload_8cpp_source.html#l00022">ClQuantizeWorkload.cpp:22</a></div></div>
<div class="ttc" id="namespacearmnn_html_a1391582cd6e145b67c98f3410667968e"><div class="ttname"><a href="namespacearmnn.html#a1391582cd6e145b67c98f3410667968e">armnn::ClAbsWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClAbsWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_abs_workload_8cpp_source.html#l00019">ClAbsWorkload.cpp:19</a></div></div>
<div class="ttc" id="structarmnn_1_1_mean_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_mean_descriptor.html">armnn::MeanDescriptor</a></div><div class="ttdoc">A MeanDescriptor for the MeanLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00877">Descriptors.hpp:877</a></div></div>
<div class="ttc" id="namespacearmnn_html_a56ff60c2946bf0b7e772007acce0d7ec"><div class="ttname"><a href="namespacearmnn.html#a56ff60c2946bf0b7e772007acce0d7ec">armnn::IsMultiplicationSupported</a></div><div class="ttdeci">bool IsMultiplicationSupported(const BackendId &amp;backend, const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00438">LayerSupport.cpp:438</a></div></div>
<div class="ttc" id="structarmnn_1_1_space_to_batch_nd_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_space_to_batch_nd_descriptor.html">armnn::SpaceToBatchNdDescriptor</a></div><div class="ttdoc">A SpaceToBatchNdDescriptor for the SpaceToBatchNdLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00778">Descriptors.hpp:778</a></div></div>
<div class="ttc" id="namespacearmnn_html_ad6cb42ca5150bb96c151e4a4e6557d70"><div class="ttname"><a href="namespacearmnn.html#ad6cb42ca5150bb96c151e4a4e6557d70">armnn::ClBatchNormalizationValidate</a></div><div class="ttdeci">arm_compute::Status ClBatchNormalizationValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const TensorInfo &amp;mean, const TensorInfo &amp;var, const TensorInfo &amp;beta, const TensorInfo &amp;gamma, const BatchNormalizationDescriptor &amp;desc)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_batch_normalization_float_workload_8cpp_source.html#l00018">ClBatchNormalizationFloatWorkload.cpp:18</a></div></div>
<div class="ttc" id="_cl_pooling2d_workload_8hpp_html"><div class="ttname"><a href="_cl_pooling2d_workload_8hpp.html">ClPooling2dWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a90ab88fe4c7aa9466c4653404a6b2213"><div class="ttname"><a href="namespacearmnn.html#a90ab88fe4c7aa9466c4653404a6b2213">armnn::ClLstmFloatWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClLstmFloatWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;outputStateIn, const TensorInfo &amp;cellStateIn, const TensorInfo &amp;scratchBuffer, const TensorInfo &amp;outputStateOut, const TensorInfo &amp;cellStateOut, const TensorInfo &amp;output, const LstmDescriptor &amp;descriptor, const LstmInputParamsInfo &amp;paramsInfo)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_lstm_float_workload_8cpp_source.html#l00256">ClLstmFloatWorkload.cpp:256</a></div></div>
<div class="ttc" id="namespacearmnn_html_af5bb7a834a74983cbbc249785d0c392b"><div class="ttname"><a href="namespacearmnn.html#af5bb7a834a74983cbbc249785d0c392b">armnn::ClReshapeWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClReshapeWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_reshape_workload_8cpp_source.html#l00015">ClReshapeWorkload.cpp:15</a></div></div>
<div class="ttc" id="_cl_arg_min_max_workload_8hpp_html"><div class="ttname"><a href="_cl_arg_min_max_workload_8hpp.html">ClArgMinMaxWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a90a1aadb53c7537f225252afd681ff22"><div class="ttname"><a href="namespacearmnn.html#a90a1aadb53c7537f225252afd681ff22">armnn::IsResizeSupported</a></div><div class="ttdeci">bool IsResizeSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const ResizeDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00541">LayerSupport.cpp:541</a></div></div>
<div class="ttc" id="_cl_concat_workload_8hpp_html"><div class="ttname"><a href="_cl_concat_workload_8hpp.html">ClConcatWorkload.hpp</a></div></div>
<div class="ttc" id="classarmnn_1_1_tensor_info_html_a8b5d0f8a24e9d9238f412260a552acf8"><div class="ttname"><a href="classarmnn_1_1_tensor_info.html#a8b5d0f8a24e9d9238f412260a552acf8">armnn::TensorInfo::GetShape</a></div><div class="ttdeci">const TensorShape &amp; GetShape() const</div><div class="ttdef"><b>Definition:</b> <a href="_tensor_8hpp_source.html#l00088">Tensor.hpp:88</a></div></div>
<div class="ttc" id="structarmnn_1_1_arg_min_max_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_arg_min_max_descriptor.html">armnn::ArgMinMaxDescriptor</a></div><div class="ttdoc">An ArgMinMaxDescriptor for ArgMinMaxLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00043">Descriptors.hpp:43</a></div></div>
<div class="ttc" id="namespacearmnn_html_a553706c6338ffc52b0d916859f642587"><div class="ttname"><a href="namespacearmnn.html#a553706c6338ffc52b0d916859f642587">armnn::ClMaximumWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClMaximumWorkloadValidate(const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_maximum_workload_8cpp_source.html#l00024">ClMaximumWorkload.cpp:24</a></div></div>
<div class="ttc" id="namespacearmnn_html_afbf752a51fa513e0a54e343be130d962"><div class="ttname"><a href="namespacearmnn.html#afbf752a51fa513e0a54e343be130d962">armnn::IsSubtractionSupported</a></div><div class="ttdeci">bool IsSubtractionSupported(const BackendId &amp;backend, const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00643">LayerSupport.cpp:643</a></div></div>
<div class="ttc" id="namespacearmnn_html_adcf7b7d939bac1cfaeb333c7b3175bb8"><div class="ttname"><a href="namespacearmnn.html#adcf7b7d939bac1cfaeb333c7b3175bb8">armnn::ClPadValidate</a></div><div class="ttdeci">arm_compute::Status ClPadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const PadDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_pad_workload_8cpp_source.html#l00045">ClPadWorkload.cpp:45</a></div></div>
<div class="ttc" id="_cl_splitter_workload_8hpp_html"><div class="ttname"><a href="_cl_splitter_workload_8hpp.html">ClSplitterWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_ac92dceabfbc1e46fe74f699f733886a8"><div class="ttname"><a href="namespacearmnn.html#ac92dceabfbc1e46fe74f699f733886a8">armnn::IsDequantizeSupported</a></div><div class="ttdeci">bool IsDequantizeSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00232">LayerSupport.cpp:232</a></div></div>
<div class="ttc" id="namespacearmnn_html_a37f6946bfb7a9c7d64881b7a2e13945f"><div class="ttname"><a href="namespacearmnn.html#a37f6946bfb7a9c7d64881b7a2e13945f">armnn::ClConvertFp32ToFp16WorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClConvertFp32ToFp16WorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html#l00035">ClConvertFp32ToFp16Workload.cpp:35</a></div></div>
<div class="ttc" id="namespacearmnn_html_acf69869c2242e5e3741c4f9252099393"><div class="ttname"><a href="namespacearmnn.html#acf69869c2242e5e3741c4f9252099393">armnn::ClGreaterWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClGreaterWorkloadValidate(const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_greater_workload_8cpp_source.html#l00024">ClGreaterWorkload.cpp:24</a></div></div>
<div class="ttc" id="namespacearmnn_html_aef334cdb24000c330f4d2e5f1b384784"><div class="ttname"><a href="namespacearmnn.html#aef334cdb24000c330f4d2e5f1b384784">armnn::ClL2NormalizationWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClL2NormalizationWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const L2NormalizationDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_l2_normalization_float_workload_8cpp_source.html#l00017">ClL2NormalizationFloatWorkload.cpp:17</a></div></div>
<div class="ttc" id="_cl_convert_fp32_to_fp16_workload_8hpp_html"><div class="ttname"><a href="_cl_convert_fp32_to_fp16_workload_8hpp.html">ClConvertFp32ToFp16Workload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_resize_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_resize_descriptor.html">armnn::ResizeDescriptor</a></div><div class="ttdoc">A ResizeDescriptor for the ResizeLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00724">Descriptors.hpp:724</a></div></div>
<div class="ttc" id="namespacearmnn_html_a8a21bb33f7f054ce7b48a8c7df9e6d4a"><div class="ttname"><a href="namespacearmnn.html#a8a21bb33f7f054ce7b48a8c7df9e6d4a">armnn::ClPooling2dWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClPooling2dWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const Pooling2dDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_pooling2d_workload_8cpp_source.html#l00018">ClPooling2dWorkload.cpp:18</a></div></div>
<div class="ttc" id="namespacearmnn_html_a95b187d3c6b7b46f4fbdc60be69fc02c"><div class="ttname"><a href="namespacearmnn.html#a95b187d3c6b7b46f4fbdc60be69fc02c">armnn::ClResizeWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClResizeWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const ResizeDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_resize_workload_8cpp_source.html#l00022">ClResizeWorkload.cpp:22</a></div></div>
<div class="ttc" id="namespacearmnn_html_a515e8a98d7ef9ecda64a2e1e5298461a"><div class="ttname"><a href="namespacearmnn.html#a515e8a98d7ef9ecda64a2e1e5298461a">armnn::IsPadSupported</a></div><div class="ttdeci">bool IsPadSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const PadDescriptor &amp;descriptor, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00466">LayerSupport.cpp:466</a></div></div>
<div class="ttc" id="namespacearmnn_html_a534b28fd4b345bbc938d055ff5b8970f"><div class="ttname"><a href="namespacearmnn.html#a534b28fd4b345bbc938d055ff5b8970f">armnn::ClSpaceToBatchNdWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClSpaceToBatchNdWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const SpaceToBatchNdDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_space_to_batch_nd_workload_8cpp_source.html#l00023">ClSpaceToBatchNdWorkload.cpp:23</a></div></div>
<div class="ttc" id="namespacearmnn_html_ab99d3d944b80f47bd1be70f63cc60abb"><div class="ttname"><a href="namespacearmnn.html#ab99d3d944b80f47bd1be70f63cc60abb">armnn::IsMinimumSupported</a></div><div class="ttdeci">bool IsMinimumSupported(const BackendId &amp;backend, const TensorInfo &amp;input0, const TensorInfo &amp;input1, const TensorInfo &amp;output, char *reasonIfUnsupported=nullptr, size_t reasonIfUnsupportedMaxLength=1024)</div><div class="ttdoc">Deprecated in favor of IBackend and ILayerSupport interfaces. </div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00428">LayerSupport.cpp:428</a></div></div>
<div class="ttc" id="structarmnn_1_1_comparison_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_comparison_descriptor.html">armnn::ComparisonDescriptor</a></div><div class="ttdoc">A ComparisonDescriptor for the ComparisonLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00062">Descriptors.hpp:62</a></div></div>
<div class="ttc" id="namespacearmnn_html_aa8d5d17d1edd51d899fe699eb6156b58"><div class="ttname"><a href="namespacearmnn.html#aa8d5d17d1edd51d899fe699eb6156b58">armnn::IsArgMinMaxSupported</a></div><div class="ttdeci">bool IsArgMinMaxSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, const ArgMinMaxDescriptor &amp;descriptor, char *reasonIfUnsupported, size_t reasonIfUnsupportedMaxLength)</div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00094">LayerSupport.cpp:94</a></div></div>
<div class="ttc" id="_cl_strided_slice_workload_8hpp_html"><div class="ttname"><a href="_cl_strided_slice_workload_8hpp.html">ClStridedSliceWorkload.hpp</a></div></div>
<div class="ttc" id="namespacearmnn_html_a599a95f708fa0b6a6230dc6c9e73ea3e"><div class="ttname"><a href="namespacearmnn.html#a599a95f708fa0b6a6230dc6c9e73ea3e">armnn::IsQuantizeSupported</a></div><div class="ttdeci">bool IsQuantizeSupported(const BackendId &amp;backend, const TensorInfo &amp;input, const TensorInfo &amp;output, char *reasonIfUnsupported, size_t reasonIfUnsupportedMaxLength)</div><div class="ttdef"><b>Definition:</b> <a href="_layer_support_8cpp_source.html#l00477">LayerSupport.cpp:477</a></div></div>
<div class="ttc" id="namespacearmnn_html_a144c2e243a255715f309999077ed1792"><div class="ttname"><a href="namespacearmnn.html#a144c2e243a255715f309999077ed1792">armnn::ClNormalizationWorkloadValidate</a></div><div class="ttdeci">arm_compute::Status ClNormalizationWorkloadValidate(const TensorInfo &amp;input, const TensorInfo &amp;output, const NormalizationDescriptor &amp;descriptor)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_normalization_float_workload_8cpp_source.html#l00019">ClNormalizationFloatWorkload.cpp:19</a></div></div>
<div class="ttc" id="structarmnn_1_1_origins_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_origins_descriptor.html">armnn::OriginsDescriptor</a></div><div class="ttdoc">An OriginsDescriptor for the ConcatLayer. Descriptor to configure the concatenation process...</div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l00147">Descriptors.hpp:147</a></div></div>
<div class="ttc" id="_cl_batch_normalization_float_workload_8hpp_html"><div class="ttname"><a href="_cl_batch_normalization_float_workload_8hpp.html">ClBatchNormalizationFloatWorkload.hpp</a></div></div>
<div class="ttc" id="structarmnn_1_1_strided_slice_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_strided_slice_descriptor.html">armnn::StridedSliceDescriptor</a></div><div class="ttdoc">A StridedSliceDescriptor for the StridedSliceLayer. </div><div class="ttdef"><b>Definition:</b> <a href="_descriptors_8hpp_source.html#l01002">Descriptors.hpp:1002</a></div></div>
<div class="ttc" id="_internal_types_8hpp_html"><div class="ttname"><a href="_internal_types_8hpp.html">InternalTypes.hpp</a></div></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  <ul>
    <li class="navelem"><a class="el" href="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="dir_0f3cdec46afbc61a1ded8e1687c9c9a0.html">backends</a></li><li class="navelem"><a class="el" href="dir_1ad86c6d39ab715a831555571b9e98a5.html">cl</a></li><li class="navelem"><a class="el" href="_cl_layer_support_8cpp.html">ClLayerSupport.cpp</a></li>
    <li class="footer">Generated on Fri Mar 13 2020 16:06:57 for ArmNN by
    <a href="http://www.doxygen.org/index.html">
    <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.13 </li>
  </ul>
</div>
</body>
</html>