aboutsummaryrefslogtreecommitdiff
path: root/latest/_ref_workload_factory_8cpp_source.html
diff options
context:
space:
mode:
authorNikhil Raj <nikhil.raj@arm.com>2024-05-16 09:47:51 +0100
committerNikhil Raj <nikhil.raj@arm.com>2024-05-16 09:47:51 +0100
commit1dc83febfb76d6a770bdf3ba16c4034a970c2320 (patch)
tree66d27e5587e9010f3db26a23a348df844c88f8e6 /latest/_ref_workload_factory_8cpp_source.html
parent38b600d8abb2c5f7a44511b5deddf441f975d51d (diff)
downloadarmnn-gh-pages.tar.gz
IVGCVSW-8260 Update Doxgen Docu for 24.05gh-pages
Signed-off-by: Nikhil Raj <nikhil.raj@arm.com> Change-Id: If4bc983bf2793a27ded8e26ac2b29523fc1e4711
Diffstat (limited to 'latest/_ref_workload_factory_8cpp_source.html')
-rw-r--r--latest/_ref_workload_factory_8cpp_source.html1151
1 files changed, 583 insertions, 568 deletions
diff --git a/latest/_ref_workload_factory_8cpp_source.html b/latest/_ref_workload_factory_8cpp_source.html
index 1493857994..bddceb45f1 100644
--- a/latest/_ref_workload_factory_8cpp_source.html
+++ b/latest/_ref_workload_factory_8cpp_source.html
@@ -36,7 +36,7 @@
<img alt="ArmNN" src="Arm_NN_horizontal_blue.png" style="max-width: 15rem; margin-top: .5rem; margin-left 13px"/>
<td id="projectalign" style="padding-left: 0.9em;">
<div id="projectname">
- &#160;<span id="projectnumber">24.02</span>
+ &#160;<span id="projectnumber">24.05</span>
</div>
</td>
</tr>
@@ -97,7 +97,7 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
</div><!--header-->
<div class="contents">
<a href="_ref_workload_factory_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-2023 Arm Ltd and Contributors. All rights reserved.</span></div>
+<div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment">// Copyright © 2017-2024 Arm Ltd and Contributors. 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;<span class="preprocessor">#include &lt;<a class="code" href="_layer_8hpp.html">Layer.hpp</a>&gt;</span></div>
@@ -175,592 +175,605 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160;{</div>
<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; <span class="keywordflow">return</span> IsDataType&lt;DataType::QAsymmU8&gt;(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; </div>
-<div class="line"><a name="l00081"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a5be2bdecd6346eba07c6807fd15a5d74"> 81</a></span>&#160;<a class="code" href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4">RefWorkloadFactory::RefWorkloadFactory</a>(<span class="keyword">const</span> std::shared_ptr&lt;RefMemoryManager&gt;&amp; memoryManager)</div>
-<div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160; : m_MemoryManager(memoryManager)</div>
-<div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160;{</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"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4"> 86</a></span>&#160;<a class="code" href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4">RefWorkloadFactory::RefWorkloadFactory</a>()</div>
-<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160; : m_MemoryManager(new <a class="code" href="classarmnn_1_1_ref_memory_manager.html">RefMemoryManager</a>())</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;}</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"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#ae2cd7e29596b68884bfaade25f8f0dc0"> 91</a></span>&#160;<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_backend_id.html">BackendId</a>&amp; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#ae2cd7e29596b68884bfaade25f8f0dc0">RefWorkloadFactory::GetBackendId</a>()<span class="keyword"> const</span></div>
-<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160;<span class="keyword"></span>{</div>
-<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <span class="keywordflow">return</span> s_Id;</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; </div>
-<div class="line"><a name="l00096"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae"> 96</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae">RefWorkloadFactory::IsLayerSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_layer.html">Layer</a>&amp; layer,</div>
-<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160; <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;DataType&gt;</a> dataType,</div>
-<div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160; std::string&amp; outReasonIfUnsupported)</div>
-<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160;{</div>
-<div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classarmnn_1_1_i_workload_factory.html#a74dc9ec1a223eab8b072368b2dacee87">IWorkloadFactory::IsLayerSupported</a>(s_Id, layer, dataType, outReasonIfUnsupported);</div>
-<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160;}</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"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#aeaff50773427132e1066a7de56a53db1"> 103</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae">RefWorkloadFactory::IsLayerSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a>&amp; layer,</div>
-<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160; <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;DataType&gt;</a> dataType,</div>
-<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; std::string&amp; outReasonIfUnsupported,</div>
-<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; <span class="keyword">const</span> <a class="code" href="namespacearmnn.html#a5b6893cda5b69359a4244c06054da18f">ModelOptions</a>&amp; modelOptions)</div>
-<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160;{</div>
-<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classarmnn_1_1_i_workload_factory.html#a74dc9ec1a223eab8b072368b2dacee87">IWorkloadFactory::IsLayerSupported</a>(s_Id, layer, dataType, outReasonIfUnsupported, modelOptions);</div>
-<div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160;}</div>
-<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; </div>
-<div class="line"><a name="l00111"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76"> 111</a></span>&#160;std::unique_ptr&lt;ITensorHandle&gt; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76">RefWorkloadFactory::CreateTensorHandle</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; tensorInfo,</div>
-<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160; <span class="keyword">const</span> <span class="keywordtype">bool</span> isMemoryManaged)<span class="keyword"> const</span></div>
-<div class="line"><a name="l00113"></a><span class="lineno"> 113</span>&#160;<span class="keyword"></span>{</div>
-<div class="line"><a name="l00114"></a><span class="lineno"> 114</span>&#160; <span class="keywordflow">if</span> (isMemoryManaged)</div>
-<div class="line"><a name="l00115"></a><span class="lineno"> 115</span>&#160; {</div>
-<div class="line"><a name="l00116"></a><span class="lineno"> 116</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo, m_MemoryManager);</div>
-<div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; }</div>
-<div class="line"><a name="l00118"></a><span class="lineno"> 118</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00080"></a><span class="lineno"><a class="line" href="namespacearmnn.html#abe95e2847292413f6dc71c21dabce181"> 80</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="namespacearmnn.html#abe95e2847292413f6dc71c21dabce181">IsBoolean</a>(<span class="keyword">const</span> <a class="code" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a>&amp; info)</div>
+<div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160;{</div>
+<div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160; <span class="keywordflow">return</span> IsDataType&lt;DataType::Boolean&gt;(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160;}</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"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a5be2bdecd6346eba07c6807fd15a5d74"> 85</a></span>&#160;<a class="code" href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4">RefWorkloadFactory::RefWorkloadFactory</a>(<span class="keyword">const</span> std::shared_ptr&lt;RefMemoryManager&gt;&amp; memoryManager)</div>
+<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; : m_MemoryManager(memoryManager)</div>
+<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160;{</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; </div>
+<div class="line"><a name="l00090"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4"> 90</a></span>&#160;<a class="code" href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4">RefWorkloadFactory::RefWorkloadFactory</a>()</div>
+<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; : m_MemoryManager(new <a class="code" href="classarmnn_1_1_ref_memory_manager.html">RefMemoryManager</a>())</div>
+<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160;{</div>
+<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160;}</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"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#ae2cd7e29596b68884bfaade25f8f0dc0"> 95</a></span>&#160;<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_backend_id.html">BackendId</a>&amp; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#ae2cd7e29596b68884bfaade25f8f0dc0">RefWorkloadFactory::GetBackendId</a>()<span class="keyword"> const</span></div>
+<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160;<span class="keyword"></span>{</div>
+<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160; <span class="keywordflow">return</span> s_Id;</div>
+<div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160;}</div>
+<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; </div>
+<div class="line"><a name="l00100"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae"> 100</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae">RefWorkloadFactory::IsLayerSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_layer.html">Layer</a>&amp; layer,</div>
+<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160; <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;DataType&gt;</a> dataType,</div>
+<div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; std::string&amp; outReasonIfUnsupported)</div>
+<div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160;{</div>
+<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classarmnn_1_1_i_workload_factory.html#a74dc9ec1a223eab8b072368b2dacee87">IWorkloadFactory::IsLayerSupported</a>(s_Id, layer, dataType, outReasonIfUnsupported);</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"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#aeaff50773427132e1066a7de56a53db1"> 107</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae">RefWorkloadFactory::IsLayerSupported</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a>&amp; layer,</div>
+<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160; <a class="code" href="classarmnn_1_1_optional.html">Optional&lt;DataType&gt;</a> dataType,</div>
+<div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160; std::string&amp; outReasonIfUnsupported,</div>
+<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; <span class="keyword">const</span> <a class="code" href="namespacearmnn.html#a5b6893cda5b69359a4244c06054da18f">ModelOptions</a>&amp; modelOptions)</div>
+<div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160;{</div>
+<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classarmnn_1_1_i_workload_factory.html#a74dc9ec1a223eab8b072368b2dacee87">IWorkloadFactory::IsLayerSupported</a>(s_Id, layer, dataType, outReasonIfUnsupported, modelOptions);</div>
+<div class="line"><a name="l00113"></a><span class="lineno"> 113</span>&#160;}</div>
+<div class="line"><a name="l00114"></a><span class="lineno"> 114</span>&#160; </div>
+<div class="line"><a name="l00115"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76"> 115</a></span>&#160;std::unique_ptr&lt;ITensorHandle&gt; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76">RefWorkloadFactory::CreateTensorHandle</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; tensorInfo,</div>
+<div class="line"><a name="l00116"></a><span class="lineno"> 116</span>&#160; <span class="keyword">const</span> <span class="keywordtype">bool</span> isMemoryManaged)<span class="keyword"> const</span></div>
+<div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160;<span class="keyword"></span>{</div>
+<div class="line"><a name="l00118"></a><span class="lineno"> 118</span>&#160; <span class="keywordflow">if</span> (isMemoryManaged)</div>
<div class="line"><a name="l00119"></a><span class="lineno"> 119</span>&#160; {</div>
-<div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo);</div>
+<div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo, m_MemoryManager);</div>
<div class="line"><a name="l00121"></a><span class="lineno"> 121</span>&#160; }</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; </div>
-<div class="line"><a name="l00124"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#aaed323bbcbaded57334783e4732ee3ed"> 124</a></span>&#160;std::unique_ptr&lt;ITensorHandle&gt; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76">RefWorkloadFactory::CreateTensorHandle</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; tensorInfo,</div>
-<div class="line"><a name="l00125"></a><span class="lineno"> 125</span>&#160; <a class="code" href="namespacearmnn.html#ad1d5cce2d9e9a5d61c243e5c989112e0">DataLayout</a> dataLayout,</div>
-<div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; <span class="keyword">const</span> <span class="keywordtype">bool</span> isMemoryManaged)<span class="keyword"> const</span></div>
-<div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160;<span class="keyword"></span>{</div>
-<div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160; <span class="comment">// For Ref it is okay to make the TensorHandle memory managed as it can also store a pointer</span></div>
-<div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; <span class="comment">// to unmanaged memory. This also ensures memory alignment.</span></div>
-<div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160; <a class="code" href="namespacearmnn.html#a44affeeb090c3c6a3062830562672e84">IgnoreUnused</a>(isMemoryManaged, dataLayout);</div>
-<div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; </div>
-<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; <span class="keywordflow">if</span> (isMemoryManaged)</div>
-<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; {</div>
-<div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo, m_MemoryManager);</div>
-<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; }</div>
-<div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00122"></a><span class="lineno"> 122</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00123"></a><span class="lineno"> 123</span>&#160; {</div>
+<div class="line"><a name="l00124"></a><span class="lineno"> 124</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo);</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"> 126</span>&#160;}</div>
+<div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160; </div>
+<div class="line"><a name="l00128"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#aaed323bbcbaded57334783e4732ee3ed"> 128</a></span>&#160;std::unique_ptr&lt;ITensorHandle&gt; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76">RefWorkloadFactory::CreateTensorHandle</a>(<span class="keyword">const</span> <a class="code" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>&amp; tensorInfo,</div>
+<div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; <a class="code" href="namespacearmnn.html#ad1d5cce2d9e9a5d61c243e5c989112e0">DataLayout</a> dataLayout,</div>
+<div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160; <span class="keyword">const</span> <span class="keywordtype">bool</span> isMemoryManaged)<span class="keyword"> const</span></div>
+<div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160;<span class="keyword"></span>{</div>
+<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; <span class="comment">// For Ref it is okay to make the TensorHandle memory managed as it can also store a pointer</span></div>
+<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; <span class="comment">// to unmanaged memory. This also ensures memory alignment.</span></div>
+<div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; <a class="code" href="namespacearmnn.html#a44affeeb090c3c6a3062830562672e84">IgnoreUnused</a>(isMemoryManaged, dataLayout);</div>
+<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; </div>
+<div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; <span class="keywordflow">if</span> (isMemoryManaged)</div>
<div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; {</div>
-<div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo);</div>
+<div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo, m_MemoryManager);</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;}</div>
-<div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; </div>
-<div class="line"><a name="l00142"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6"> 142</a></span>&#160;std::unique_ptr&lt;IWorkload&gt; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6">RefWorkloadFactory::CreateWorkload</a>(<a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4">LayerType</a> type,</div>
-<div class="line"><a name="l00143"></a><span class="lineno"> 143</span>&#160; <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_queue_descriptor.html">QueueDescriptor</a>&amp; descriptor,</div>
-<div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160; <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a>&amp; info)<span class="keyword"> const</span></div>
-<div class="line"><a name="l00145"></a><span class="lineno"> 145</span>&#160;<span class="keyword"></span>{</div>
-<div class="line"><a name="l00146"></a><span class="lineno"> 146</span>&#160; <span class="keywordflow">switch</span>(type)</div>
-<div class="line"><a name="l00147"></a><span class="lineno"> 147</span>&#160; {</div>
-<div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa9a62e70841c4d06dd16306a85700d36">LayerType::Activation</a> :</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="keyword">auto</span> activationQueueDescriptor = PolymorphicDowncast&lt;const ActivationQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefActivationWorkload&gt;(*activationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160; }</div>
-<div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a7c5531bbefed0945814f874baf9e0e0f">LayerType::Addition</a> :</div>
-<div class="line"><a name="l00154"></a><span class="lineno"> 154</span>&#160; {</div>
-<div class="line"><a name="l00155"></a><span class="lineno"> 155</span>&#160; <span class="keyword">auto</span> additionQueueDescriptor = PolymorphicDowncast&lt;const AdditionQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00156"></a><span class="lineno"> 156</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
-<div class="line"><a name="l00157"></a><span class="lineno"> 157</span>&#160; {</div>
-<div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefAdditionWorkload&lt;int32_t&gt;&gt;(*additionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 160</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00140"></a><span class="lineno"> 140</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; {</div>
+<div class="line"><a name="l00142"></a><span class="lineno"> 142</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTensorHandle&gt;(tensorInfo);</div>
+<div class="line"><a name="l00143"></a><span class="lineno"> 143</span>&#160; }</div>
+<div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160;}</div>
+<div class="line"><a name="l00145"></a><span class="lineno"> 145</span>&#160; </div>
+<div class="line"><a name="l00146"></a><span class="lineno"><a class="line" href="classarmnn_1_1_ref_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6"> 146</a></span>&#160;std::unique_ptr&lt;IWorkload&gt; <a class="code" href="classarmnn_1_1_ref_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6">RefWorkloadFactory::CreateWorkload</a>(<a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4">LayerType</a> type,</div>
+<div class="line"><a name="l00147"></a><span class="lineno"> 147</span>&#160; <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_queue_descriptor.html">QueueDescriptor</a>&amp; descriptor,</div>
+<div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160; <span class="keyword">const</span> <a class="code" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a>&amp; info)<span class="keyword"> const</span></div>
+<div class="line"><a name="l00149"></a><span class="lineno"> 149</span>&#160;<span class="keyword"></span>{</div>
+<div class="line"><a name="l00150"></a><span class="lineno"> 150</span>&#160; <span class="keywordflow">switch</span>(type)</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"> 152</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa9a62e70841c4d06dd16306a85700d36">LayerType::Activation</a> :</div>
+<div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160; {</div>
+<div class="line"><a name="l00154"></a><span class="lineno"> 154</span>&#160; <span class="keyword">auto</span> activationQueueDescriptor = PolymorphicDowncast&lt;const ActivationQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00155"></a><span class="lineno"> 155</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefActivationWorkload&gt;(*activationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00156"></a><span class="lineno"> 156</span>&#160; }</div>
+<div class="line"><a name="l00157"></a><span class="lineno"> 157</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a7c5531bbefed0945814f874baf9e0e0f">LayerType::Addition</a> :</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; <span class="keyword">auto</span> additionQueueDescriptor = PolymorphicDowncast&lt;const AdditionQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00160"></a><span class="lineno"> 160</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
<div class="line"><a name="l00161"></a><span class="lineno"> 161</span>&#160; {</div>
-<div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefAdditionWorkload&lt;float&gt;&gt;(*additionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefAdditionWorkload&lt;int32_t&gt;&gt;(*additionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00163"></a><span class="lineno"> 163</span>&#160; }</div>
-<div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160; }</div>
-<div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2139684546b147c106b329f41547640c">LayerType::ArgMinMax</a> :</div>
-<div class="line"><a name="l00166"></a><span class="lineno"> 166</span>&#160; {</div>
-<div class="line"><a name="l00167"></a><span class="lineno"> 167</span>&#160; <span class="keyword">auto</span> argMinMaxQueueDescriptor = PolymorphicDowncast&lt;const ArgMinMaxQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefArgMinMaxWorkload&gt;(*argMinMaxQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160; }</div>
-<div class="line"><a name="l00170"></a><span class="lineno"> 170</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9882ff3cfed27d6161c20a305e7a3484">LayerType::BatchMatMul</a>:</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"> 172</span>&#160; <span class="keyword">auto</span> batchMatMulQueueDescriptor = PolymorphicDowncast&lt;const BatchMatMulQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00173"></a><span class="lineno"> 173</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBatchMatMulWorkload&gt;(*batchMatMulQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00174"></a><span class="lineno"> 174</span>&#160; }</div>
-<div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ae4743c3ec15d1d84169b17264634692e">LayerType::BatchNormalization</a> :</div>
-<div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160; {</div>
-<div class="line"><a name="l00177"></a><span class="lineno"> 177</span>&#160; <span class="keyword">auto</span> batchNormQueueDescriptor = PolymorphicDowncast&lt;const BatchNormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00178"></a><span class="lineno"> 178</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBatchNormalizationWorkload&gt;(*batchNormQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00179"></a><span class="lineno"> 179</span>&#160; }</div>
-<div class="line"><a name="l00180"></a><span class="lineno"> 180</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a6ee06c6045d0c5b6565a247955ef0fc2">LayerType::BatchToSpaceNd</a> :</div>
-<div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160; {</div>
-<div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; <span class="keyword">auto</span> batchToSpaceNdQueueDescriptor</div>
-<div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160; = PolymorphicDowncast&lt;const BatchToSpaceNdQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00184"></a><span class="lineno"> 184</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBatchToSpaceNdWorkload&gt;(*batchToSpaceNdQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00185"></a><span class="lineno"> 185</span>&#160; }</div>
-<div class="line"><a name="l00186"></a><span class="lineno"> 186</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af6f7ce1d0822dea293ac2edc111e54ed">LayerType::BroadcastTo</a>:</div>
-<div class="line"><a name="l00187"></a><span class="lineno"> 187</span>&#160; {</div>
-<div class="line"><a name="l00188"></a><span class="lineno"> 188</span>&#160; <span class="keyword">auto</span> broadcastToQueueDescriptor = PolymorphicDowncast&lt;const BroadcastToQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00189"></a><span class="lineno"> 189</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBroadcastToWorkload&gt;(*broadcastToQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00190"></a><span class="lineno"> 190</span>&#160; }</div>
-<div class="line"><a name="l00191"></a><span class="lineno"> 191</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4cd9f3996d60790cd11c04f842ebc43c">LayerType::Cast</a> :</div>
-<div class="line"><a name="l00192"></a><span class="lineno"> 192</span>&#160; {</div>
-<div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160; <span class="keyword">auto</span> castQueueDescriptor = PolymorphicDowncast&lt;const CastQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00194"></a><span class="lineno"> 194</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefCastWorkload&gt;(*castQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a0ca5f33c1d35fd4105d3a26a2823f9dd">LayerType::ChannelShuffle</a> :</div>
-<div class="line"><a name="l00197"></a><span class="lineno"> 197</span>&#160; {</div>
-<div class="line"><a name="l00198"></a><span class="lineno"> 198</span>&#160; <span class="keyword">auto</span> channelShuffleQueueDescriptor</div>
-<div class="line"><a name="l00199"></a><span class="lineno"> 199</span>&#160; = PolymorphicDowncast&lt;const ChannelShuffleQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefChannelShuffleWorkload&gt;(*channelShuffleQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00201"></a><span class="lineno"> 201</span>&#160; }</div>
-<div class="line"><a name="l00202"></a><span class="lineno"> 202</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af6c0e3a1c3cfabd32ae8d3ae741fcf0a">LayerType::Comparison</a> :</div>
-<div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160; {</div>
-<div class="line"><a name="l00204"></a><span class="lineno"> 204</span>&#160; <span class="keyword">auto</span> comparisonQueueDescriptor = PolymorphicDowncast&lt;const ComparisonQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00205"></a><span class="lineno"> 205</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefComparisonWorkload&gt;(*comparisonQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160; }</div>
-<div class="line"><a name="l00207"></a><span class="lineno"> 207</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ae20f0f2826a6549809f050b86274567f">LayerType::Concat</a> :</div>
-<div class="line"><a name="l00208"></a><span class="lineno"> 208</span>&#160; {</div>
-<div class="line"><a name="l00209"></a><span class="lineno"> 209</span>&#160; <span class="keyword">auto</span> concatQueueDescriptor = PolymorphicDowncast&lt;const ConcatQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConcatWorkload&gt;(*concatQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160; }</div>
-<div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acb17869fe51048b5a5c4c6106551a255">LayerType::Constant</a> :</div>
-<div class="line"><a name="l00213"></a><span class="lineno"> 213</span>&#160; {</div>
-<div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160; <span class="keyword">auto</span> constantQueueDescriptor = PolymorphicDowncast&lt;const ConstantQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00215"></a><span class="lineno"> 215</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConstantWorkload&gt;(*constantQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 217</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a912a4b4d73726c282e3f79aa2c390d6c">LayerType::ConvertFp16ToFp32</a>:</div>
-<div class="line"><a name="l00218"></a><span class="lineno"> 218</span>&#160; {</div>
-<div class="line"><a name="l00219"></a><span class="lineno"> 219</span>&#160; <span class="keyword">auto</span> convertFp16ToFp32QueueDescriptor</div>
-<div class="line"><a name="l00220"></a><span class="lineno"> 220</span>&#160; = PolymorphicDowncast&lt;const ConvertFp16ToFp32QueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00221"></a><span class="lineno"> 221</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvertFp16ToFp32Workload&gt;(*convertFp16ToFp32QueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00222"></a><span class="lineno"> 222</span>&#160; }</div>
-<div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4addf4f83b056acd5549949fc0350e9aad">LayerType::ConvertFp32ToFp16</a>:</div>
-<div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160; {</div>
-<div class="line"><a name="l00225"></a><span class="lineno"> 225</span>&#160; <span class="keyword">auto</span> convertFp32ToFp16QueueDescriptor</div>
-<div class="line"><a name="l00226"></a><span class="lineno"> 226</span>&#160; = PolymorphicDowncast&lt;const ConvertFp32ToFp16QueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvertFp32ToFp16Workload&gt;(*convertFp32ToFp16QueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 229</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4adb033d2f81b68f9a17e8f62de69fed4a">LayerType::Convolution2d</a>:</div>
-<div class="line"><a name="l00230"></a><span class="lineno"> 230</span>&#160; {</div>
-<div class="line"><a name="l00231"></a><span class="lineno"> 231</span>&#160; <span class="keyword">auto</span> convolution2dQueueDescriptor = PolymorphicDowncast&lt;const Convolution2dQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00232"></a><span class="lineno"> 232</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvolution2dWorkload&gt;(*convolution2dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00233"></a><span class="lineno"> 233</span>&#160; }</div>
-<div class="line"><a name="l00234"></a><span class="lineno"> 234</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a583550d0f265fd3756f7de0e42c51953">LayerType::Convolution3d</a>:</div>
-<div class="line"><a name="l00235"></a><span class="lineno"> 235</span>&#160; {</div>
-<div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160; <span class="keyword">auto</span> convolution3dQueueDescriptor = PolymorphicDowncast&lt;const Convolution3dQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvolution3dWorkload&gt;(*convolution3dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160; }</div>
-<div class="line"><a name="l00239"></a><span class="lineno"> 239</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa603905470e2a5b8c13e96b579ef0dba">LayerType::Debug</a>:</div>
-<div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160; {</div>
-<div class="line"><a name="l00241"></a><span class="lineno"> 241</span>&#160; <span class="keyword">auto</span> debugQueueDescriptor = PolymorphicDowncast&lt;const DebugQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00242"></a><span class="lineno"> 242</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a3d504240723912bf9c76ff3afeaa25c5">IsBFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</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> std::make_unique&lt;RefDebugBFloat16Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#ad78d822be14a8d585cd038cf0e73cd7e">IsFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160; {</div>
+<div class="line"><a name="l00166"></a><span class="lineno"> 166</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefAdditionWorkload&lt;float&gt;&gt;(*additionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00167"></a><span class="lineno"> 167</span>&#160; }</div>
+<div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160; }</div>
+<div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2139684546b147c106b329f41547640c">LayerType::ArgMinMax</a> :</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; <span class="keyword">auto</span> argMinMaxQueueDescriptor = PolymorphicDowncast&lt;const ArgMinMaxQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00172"></a><span class="lineno"> 172</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefArgMinMaxWorkload&gt;(*argMinMaxQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00173"></a><span class="lineno"> 173</span>&#160; }</div>
+<div class="line"><a name="l00174"></a><span class="lineno"> 174</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9882ff3cfed27d6161c20a305e7a3484">LayerType::BatchMatMul</a>:</div>
+<div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160; {</div>
+<div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160; <span class="keyword">auto</span> batchMatMulQueueDescriptor = PolymorphicDowncast&lt;const BatchMatMulQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00177"></a><span class="lineno"> 177</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBatchMatMulWorkload&gt;(*batchMatMulQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00178"></a><span class="lineno"> 178</span>&#160; }</div>
+<div class="line"><a name="l00179"></a><span class="lineno"> 179</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ae4743c3ec15d1d84169b17264634692e">LayerType::BatchNormalization</a> :</div>
+<div class="line"><a name="l00180"></a><span class="lineno"> 180</span>&#160; {</div>
+<div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160; <span class="keyword">auto</span> batchNormQueueDescriptor = PolymorphicDowncast&lt;const BatchNormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBatchNormalizationWorkload&gt;(*batchNormQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 184</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a6ee06c6045d0c5b6565a247955ef0fc2">LayerType::BatchToSpaceNd</a> :</div>
+<div class="line"><a name="l00185"></a><span class="lineno"> 185</span>&#160; {</div>
+<div class="line"><a name="l00186"></a><span class="lineno"> 186</span>&#160; <span class="keyword">auto</span> batchToSpaceNdQueueDescriptor</div>
+<div class="line"><a name="l00187"></a><span class="lineno"> 187</span>&#160; = PolymorphicDowncast&lt;const BatchToSpaceNdQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00188"></a><span class="lineno"> 188</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBatchToSpaceNdWorkload&gt;(*batchToSpaceNdQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af6f7ce1d0822dea293ac2edc111e54ed">LayerType::BroadcastTo</a>:</div>
+<div class="line"><a name="l00191"></a><span class="lineno"> 191</span>&#160; {</div>
+<div class="line"><a name="l00192"></a><span class="lineno"> 192</span>&#160; <span class="keyword">auto</span> broadcastToQueueDescriptor = PolymorphicDowncast&lt;const BroadcastToQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefBroadcastToWorkload&gt;(*broadcastToQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00194"></a><span class="lineno"> 194</span>&#160; }</div>
+<div class="line"><a name="l00195"></a><span class="lineno"> 195</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4cd9f3996d60790cd11c04f842ebc43c">LayerType::Cast</a> :</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"> 197</span>&#160; <span class="keyword">auto</span> castQueueDescriptor = PolymorphicDowncast&lt;const CastQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00198"></a><span class="lineno"> 198</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefCastWorkload&gt;(*castQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00199"></a><span class="lineno"> 199</span>&#160; }</div>
+<div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a0ca5f33c1d35fd4105d3a26a2823f9dd">LayerType::ChannelShuffle</a> :</div>
+<div class="line"><a name="l00201"></a><span class="lineno"> 201</span>&#160; {</div>
+<div class="line"><a name="l00202"></a><span class="lineno"> 202</span>&#160; <span class="keyword">auto</span> channelShuffleQueueDescriptor</div>
+<div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160; = PolymorphicDowncast&lt;const ChannelShuffleQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00204"></a><span class="lineno"> 204</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefChannelShuffleWorkload&gt;(*channelShuffleQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00205"></a><span class="lineno"> 205</span>&#160; }</div>
+<div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af6c0e3a1c3cfabd32ae8d3ae741fcf0a">LayerType::Comparison</a> :</div>
+<div class="line"><a name="l00207"></a><span class="lineno"> 207</span>&#160; {</div>
+<div class="line"><a name="l00208"></a><span class="lineno"> 208</span>&#160; <span class="keyword">auto</span> comparisonQueueDescriptor = PolymorphicDowncast&lt;const ComparisonQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00209"></a><span class="lineno"> 209</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefComparisonWorkload&gt;(*comparisonQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160; }</div>
+<div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ae20f0f2826a6549809f050b86274567f">LayerType::Concat</a> :</div>
+<div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160; {</div>
+<div class="line"><a name="l00213"></a><span class="lineno"> 213</span>&#160; <span class="keyword">auto</span> concatQueueDescriptor = PolymorphicDowncast&lt;const ConcatQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConcatWorkload&gt;(*concatQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acb17869fe51048b5a5c4c6106551a255">LayerType::Constant</a> :</div>
+<div class="line"><a name="l00217"></a><span class="lineno"> 217</span>&#160; {</div>
+<div class="line"><a name="l00218"></a><span class="lineno"> 218</span>&#160; <span class="keyword">auto</span> constantQueueDescriptor = PolymorphicDowncast&lt;const ConstantQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00219"></a><span class="lineno"> 219</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConstantWorkload&gt;(*constantQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00220"></a><span class="lineno"> 220</span>&#160; }</div>
+<div class="line"><a name="l00221"></a><span class="lineno"> 221</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a912a4b4d73726c282e3f79aa2c390d6c">LayerType::ConvertFp16ToFp32</a>:</div>
+<div class="line"><a name="l00222"></a><span class="lineno"> 222</span>&#160; {</div>
+<div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160; <span class="keyword">auto</span> convertFp16ToFp32QueueDescriptor</div>
+<div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160; = PolymorphicDowncast&lt;const ConvertFp16ToFp32QueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00225"></a><span class="lineno"> 225</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvertFp16ToFp32Workload&gt;(*convertFp16ToFp32QueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00226"></a><span class="lineno"> 226</span>&#160; }</div>
+<div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4addf4f83b056acd5549949fc0350e9aad">LayerType::ConvertFp32ToFp16</a>:</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"> 229</span>&#160; <span class="keyword">auto</span> convertFp32ToFp16QueueDescriptor</div>
+<div class="line"><a name="l00230"></a><span class="lineno"> 230</span>&#160; = PolymorphicDowncast&lt;const ConvertFp32ToFp16QueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00231"></a><span class="lineno"> 231</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvertFp32ToFp16Workload&gt;(*convertFp32ToFp16QueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00232"></a><span class="lineno"> 232</span>&#160; }</div>
+<div class="line"><a name="l00233"></a><span class="lineno"> 233</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4adb033d2f81b68f9a17e8f62de69fed4a">LayerType::Convolution2d</a>:</div>
+<div class="line"><a name="l00234"></a><span class="lineno"> 234</span>&#160; {</div>
+<div class="line"><a name="l00235"></a><span class="lineno"> 235</span>&#160; <span class="keyword">auto</span> convolution2dQueueDescriptor = PolymorphicDowncast&lt;const Convolution2dQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvolution2dWorkload&gt;(*convolution2dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160; }</div>
+<div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a583550d0f265fd3756f7de0e42c51953">LayerType::Convolution3d</a>:</div>
+<div class="line"><a name="l00239"></a><span class="lineno"> 239</span>&#160; {</div>
+<div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160; <span class="keyword">auto</span> convolution3dQueueDescriptor = PolymorphicDowncast&lt;const Convolution3dQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00241"></a><span class="lineno"> 241</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefConvolution3dWorkload&gt;(*convolution3dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa603905470e2a5b8c13e96b579ef0dba">LayerType::Debug</a>:</div>
+<div class="line"><a name="l00244"></a><span class="lineno"> 244</span>&#160; {</div>
+<div class="line"><a name="l00245"></a><span class="lineno"> 245</span>&#160; <span class="keyword">auto</span> debugQueueDescriptor = PolymorphicDowncast&lt;const DebugQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00246"></a><span class="lineno"> 246</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a3d504240723912bf9c76ff3afeaa25c5">IsBFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
<div class="line"><a name="l00247"></a><span class="lineno"> 247</span>&#160; {</div>
-<div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugFloat16Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugBFloat16Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00249"></a><span class="lineno"> 249</span>&#160; }</div>
-<div class="line"><a name="l00250"></a><span class="lineno"> 250</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#abcd0d843d5736b78740ae73249b6b977">IsQSymmS16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00250"></a><span class="lineno"> 250</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#ad78d822be14a8d585cd038cf0e73cd7e">IsFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
<div class="line"><a name="l00251"></a><span class="lineno"> 251</span>&#160; {</div>
-<div class="line"><a name="l00252"></a><span class="lineno"> 252</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQSymmS16Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00252"></a><span class="lineno"> 252</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugFloat16Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</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; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a09a7cd515c3b495e61b2a5116bf6a335">IsQSymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00254"></a><span class="lineno"> 254</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#abcd0d843d5736b78740ae73249b6b977">IsQSymmS16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
<div class="line"><a name="l00255"></a><span class="lineno"> 255</span>&#160; {</div>
-<div class="line"><a name="l00256"></a><span class="lineno"> 256</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQSymmS8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00256"></a><span class="lineno"> 256</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQSymmS16Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a37c36bbf668cd8a0d7dcd731c9b591d7">IsQAsymmU8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00258"></a><span class="lineno"> 258</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a09a7cd515c3b495e61b2a5116bf6a335">IsQSymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
<div class="line"><a name="l00259"></a><span class="lineno"> 259</span>&#160; {</div>
-<div class="line"><a name="l00260"></a><span class="lineno"> 260</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQAsymmU8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00260"></a><span class="lineno"> 260</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQSymmS8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00261"></a><span class="lineno"> 261</span>&#160; }</div>
-<div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a47d136a5519331dee24f5e01b206ae7c">IsQAsymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a37c36bbf668cd8a0d7dcd731c9b591d7">IsQAsymmU8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
<div class="line"><a name="l00263"></a><span class="lineno"> 263</span>&#160; {</div>
-<div class="line"><a name="l00264"></a><span class="lineno"> 264</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQAsymmS8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00264"></a><span class="lineno"> 264</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQAsymmU8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00265"></a><span class="lineno"> 265</span>&#160; }</div>
-<div class="line"><a name="l00266"></a><span class="lineno"> 266</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a87b99791ccf8793961db67ea19eb6fa4">IsSigned32</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00266"></a><span class="lineno"> 266</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a47d136a5519331dee24f5e01b206ae7c">IsQAsymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
<div class="line"><a name="l00267"></a><span class="lineno"> 267</span>&#160; {</div>
-<div class="line"><a name="l00268"></a><span class="lineno"> 268</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugSigned32Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00268"></a><span class="lineno"> 268</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugQAsymmS8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00269"></a><span class="lineno"> 269</span>&#160; }</div>
-<div class="line"><a name="l00270"></a><span class="lineno"> 270</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#aa21ff5349b2240a92b847e670659357f">IsSigned64</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00270"></a><span class="lineno"> 270</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a87b99791ccf8793961db67ea19eb6fa4">IsSigned32</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
<div class="line"><a name="l00271"></a><span class="lineno"> 271</span>&#160; {</div>
-<div class="line"><a name="l00272"></a><span class="lineno"> 272</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugSigned64Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00272"></a><span class="lineno"> 272</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugSigned32Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00273"></a><span class="lineno"> 273</span>&#160; }</div>
-<div class="line"><a name="l00274"></a><span class="lineno"> 274</span>&#160; <span class="keywordflow">return</span> MakeWorkload&lt;RefDebugFloat32Workload, RefDebugQAsymmU8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00275"></a><span class="lineno"> 275</span>&#160; }</div>
-<div class="line"><a name="l00276"></a><span class="lineno"> 276</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a731729ad1b2c0eb9399b62c770b3482d">LayerType::DepthToSpace</a>:</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; <span class="keyword">auto</span> depthToSpaceQueueDescriptor = PolymorphicDowncast&lt;const DepthToSpaceQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00279"></a><span class="lineno"> 279</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDepthToSpaceWorkload&gt;(*depthToSpaceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af97adbfc88b7012a0243215b1076e7e7">LayerType::DepthwiseConvolution2d</a>:</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; <span class="keyword">auto</span> depthwiseConvolution2DQueueDescriptor</div>
-<div class="line"><a name="l00284"></a><span class="lineno"> 284</span>&#160; = PolymorphicDowncast&lt;const DepthwiseConvolution2dQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00285"></a><span class="lineno"> 285</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDepthwiseConvolution2dWorkload&gt;(*depthwiseConvolution2DQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9bc35e069257a508e14ed82965a8661d">LayerType::Dequantize</a>:</div>
-<div class="line"><a name="l00288"></a><span class="lineno"> 288</span>&#160; {</div>
-<div class="line"><a name="l00289"></a><span class="lineno"> 289</span>&#160; <span class="keyword">auto</span> dequantizeQueueDescriptor = PolymorphicDowncast&lt;const DequantizeQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00290"></a><span class="lineno"> 290</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDequantizeWorkload&gt;(*dequantizeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00291"></a><span class="lineno"> 291</span>&#160; }</div>
-<div class="line"><a name="l00292"></a><span class="lineno"> 292</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1db19222ac424bd7162142ddf929fd2a">LayerType::DetectionPostProcess</a>:</div>
-<div class="line"><a name="l00293"></a><span class="lineno"> 293</span>&#160; {</div>
-<div class="line"><a name="l00294"></a><span class="lineno"> 294</span>&#160; <span class="keyword">auto</span> detectionPostProcessQueueDescriptor</div>
-<div class="line"><a name="l00295"></a><span class="lineno"> 295</span>&#160; = PolymorphicDowncast&lt;const DetectionPostProcessQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00296"></a><span class="lineno"> 296</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDetectionPostProcessWorkload&gt;(*detectionPostProcessQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00297"></a><span class="lineno"> 297</span>&#160; }</div>
-<div class="line"><a name="l00298"></a><span class="lineno"> 298</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3025cdaab2deb0bb2cd642449e570833">LayerType::Division</a>:</div>
-<div class="line"><a name="l00299"></a><span class="lineno"> 299</span>&#160; {</div>
-<div class="line"><a name="l00300"></a><span class="lineno"> 300</span>&#160; <span class="keyword">auto</span> divisionQueueDescriptor = PolymorphicDowncast&lt;const DivisionQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00301"></a><span class="lineno"> 301</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
-<div class="line"><a name="l00302"></a><span class="lineno"> 302</span>&#160; {</div>
-<div class="line"><a name="l00303"></a><span class="lineno"> 303</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDivisionWorkload&lt;int32_t&gt;&gt;(*divisionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00304"></a><span class="lineno"> 304</span>&#160; }</div>
-<div class="line"><a name="l00305"></a><span class="lineno"> 305</span>&#160; <span class="keywordflow">else</span></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"> 307</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDivisionWorkload&lt;float&gt;&gt;(*divisionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00308"></a><span class="lineno"> 308</span>&#160; }</div>
-<div class="line"><a name="l00309"></a><span class="lineno"> 309</span>&#160; }</div>
-<div class="line"><a name="l00310"></a><span class="lineno"> 310</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a699bcffd93aff3022014b9efc9eaefd1">LayerType::ElementwiseBinary</a>:</div>
-<div class="line"><a name="l00311"></a><span class="lineno"> 311</span>&#160; {</div>
-<div class="line"><a name="l00312"></a><span class="lineno"> 312</span>&#160; <span class="keyword">auto</span> elementwiseBinaryQueueDescriptor</div>
-<div class="line"><a name="l00313"></a><span class="lineno"> 313</span>&#160; = PolymorphicDowncast&lt;const ElementwiseBinaryQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00314"></a><span class="lineno"> 314</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefElementwiseBinaryWorkload&gt;(*elementwiseBinaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4abcd30d7ea97ad20c2cddc0f47e6b70c7">LayerType::ElementwiseUnary</a>:</div>
-<div class="line"><a name="l00317"></a><span class="lineno"> 317</span>&#160; {</div>
-<div class="line"><a name="l00318"></a><span class="lineno"> 318</span>&#160; <span class="keyword">auto</span> elementwiseUnaryQueueDescriptor</div>
-<div class="line"><a name="l00319"></a><span class="lineno"> 319</span>&#160; = PolymorphicDowncast&lt;const ElementwiseUnaryQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00320"></a><span class="lineno"> 320</span>&#160; <span class="keywordflow">if</span> ((*elementwiseUnaryQueueDescriptor).m_Parameters.m_Operation == <a class="code" href="namespacearmnn.html#a1cfaa710db2a54673b21d2ea2da757c8a2a25ebd8c909241e3f7818389b804ecc">UnaryOperation::LogicalNot</a>)</div>
-<div class="line"><a name="l00321"></a><span class="lineno"> 321</span>&#160; {</div>
-<div class="line"><a name="l00322"></a><span class="lineno"> 322</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLogicalUnaryWorkload&gt;(*elementwiseUnaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00323"></a><span class="lineno"> 323</span>&#160; }</div>
-<div class="line"><a name="l00324"></a><span class="lineno"> 324</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefElementwiseUnaryWorkload&gt;(*elementwiseUnaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00325"></a><span class="lineno"> 325</span>&#160; }</div>
-<div class="line"><a name="l00326"></a><span class="lineno"> 326</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3489c7b05e180496cb2ce8ac73887f48">LayerType::FakeQuantization</a>:</div>
-<div class="line"><a name="l00327"></a><span class="lineno"> 327</span>&#160; {</div>
-<div class="line"><a name="l00328"></a><span class="lineno"> 328</span>&#160; <span class="keyword">auto</span> fakeQuantizationQueueDescriptor</div>
-<div class="line"><a name="l00329"></a><span class="lineno"> 329</span>&#160; = PolymorphicDowncast&lt;const FakeQuantizationQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00330"></a><span class="lineno"> 330</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefFakeQuantizationFloat32Workload&gt;(*fakeQuantizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4adb3e3f51c9107e26c9bccf9a188ce2ed">LayerType::Fill</a>:</div>
-<div class="line"><a name="l00333"></a><span class="lineno"> 333</span>&#160; {</div>
-<div class="line"><a name="l00334"></a><span class="lineno"> 334</span>&#160; <span class="keyword">auto</span> fillQueueDescriptor = PolymorphicDowncast&lt;const FillQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00335"></a><span class="lineno"> 335</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefFillWorkload&gt;(*fillQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00336"></a><span class="lineno"> 336</span>&#160; }</div>
-<div class="line"><a name="l00337"></a><span class="lineno"> 337</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af3f6d0343d56ce88ce7958170ed05cb3">LayerType::Floor</a>:</div>
-<div class="line"><a name="l00338"></a><span class="lineno"> 338</span>&#160; {</div>
-<div class="line"><a name="l00339"></a><span class="lineno"> 339</span>&#160; <span class="keyword">auto</span> floorQueueDescriptor = PolymorphicDowncast&lt;const FloorQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00340"></a><span class="lineno"> 340</span>&#160; <span class="keywordflow">if</span>(<a class="code" href="namespacearmnn.html#ad44c007f21af2d0375e3ef9400a1b275">IsQuantizedType</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType()))</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; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
-<div class="line"><a name="l00343"></a><span class="lineno"> 343</span>&#160; }</div>
-<div class="line"><a name="l00344"></a><span class="lineno"> 344</span>&#160; <span class="keywordflow">else</span></div>
-<div class="line"><a name="l00345"></a><span class="lineno"> 345</span>&#160; {</div>
-<div class="line"><a name="l00346"></a><span class="lineno"> 346</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefFloorWorkload&gt;(*floorQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00347"></a><span class="lineno"> 347</span>&#160; }</div>
-<div class="line"><a name="l00348"></a><span class="lineno"> 348</span>&#160; }</div>
-<div class="line"><a name="l00349"></a><span class="lineno"> 349</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acab78faff25393e9defd1911cb58133e">LayerType::FullyConnected</a>:</div>
-<div class="line"><a name="l00350"></a><span class="lineno"> 350</span>&#160; {</div>
-<div class="line"><a name="l00351"></a><span class="lineno"> 351</span>&#160; <span class="keyword">auto</span> fullyConnectedQueueDescriptor</div>
-<div class="line"><a name="l00352"></a><span class="lineno"> 352</span>&#160; = PolymorphicDowncast&lt;const FullyConnectedQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00353"></a><span class="lineno"> 353</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefFullyConnectedWorkload&gt;(*fullyConnectedQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 355</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aad22c799930d644e8468fe44c0312d53">LayerType::Gather</a>:</div>
-<div class="line"><a name="l00356"></a><span class="lineno"> 356</span>&#160; {</div>
-<div class="line"><a name="l00357"></a><span class="lineno"> 357</span>&#160; <span class="keyword">auto</span> gatherQueueDescriptor = PolymorphicDowncast&lt;const GatherQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00358"></a><span class="lineno"> 358</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefGatherWorkload&gt;(*gatherQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00359"></a><span class="lineno"> 359</span>&#160; }</div>
-<div class="line"><a name="l00360"></a><span class="lineno"> 360</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3028cc42e40f9a1f4f8b35556d9715a4">LayerType::GatherNd</a>:</div>
-<div class="line"><a name="l00361"></a><span class="lineno"> 361</span>&#160; {</div>
-<div class="line"><a name="l00362"></a><span class="lineno"> 362</span>&#160; <span class="keyword">auto</span> gatherNdQueueDescriptor = PolymorphicDowncast&lt;const GatherNdQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00363"></a><span class="lineno"> 363</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefGatherNdWorkload&gt;(*gatherNdQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00364"></a><span class="lineno"> 364</span>&#160; }</div>
-<div class="line"><a name="l00365"></a><span class="lineno"> 365</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a324118a6721dd6b8a9b9f4e327df2bf5">LayerType::Input</a>:</div>
-<div class="line"><a name="l00366"></a><span class="lineno"> 366</span>&#160; {</div>
-<div class="line"><a name="l00367"></a><span class="lineno"> 367</span>&#160; <span class="keyword">auto</span> inputQueueDescriptor = PolymorphicDowncast&lt;const InputQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00368"></a><span class="lineno"> 368</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos.empty() )</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; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateInput: Input cannot be zero length&quot;</span>);</div>
-<div class="line"><a name="l00371"></a><span class="lineno"> 371</span>&#160; }</div>
-<div class="line"><a name="l00372"></a><span class="lineno"> 372</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos.empty())</div>
-<div class="line"><a name="l00373"></a><span class="lineno"> 373</span>&#160; {</div>
-<div class="line"><a name="l00374"></a><span class="lineno"> 374</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateInput: Output cannot be zero length&quot;</span>);</div>
-<div class="line"><a name="l00375"></a><span class="lineno"> 375</span>&#160; }</div>
-<div class="line"><a name="l00376"></a><span class="lineno"> 376</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetNumBytes() != <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos[0].GetNumBytes())</div>
+<div class="line"><a name="l00274"></a><span class="lineno"> 274</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#aa21ff5349b2240a92b847e670659357f">IsSigned64</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00275"></a><span class="lineno"> 275</span>&#160; {</div>
+<div class="line"><a name="l00276"></a><span class="lineno"> 276</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugSigned64Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#abe95e2847292413f6dc71c21dabce181">IsBoolean</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00279"></a><span class="lineno"> 279</span>&#160; {</div>
+<div class="line"><a name="l00280"></a><span class="lineno"> 280</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDebugBooleanWorkload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00281"></a><span class="lineno"> 281</span>&#160; }</div>
+<div class="line"><a name="l00282"></a><span class="lineno"> 282</span>&#160; <span class="keywordflow">return</span> MakeWorkload&lt;RefDebugFloat32Workload, RefDebugQAsymmU8Workload&gt;(*debugQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00283"></a><span class="lineno"> 283</span>&#160; }</div>
+<div class="line"><a name="l00284"></a><span class="lineno"> 284</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a731729ad1b2c0eb9399b62c770b3482d">LayerType::DepthToSpace</a>:</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; <span class="keyword">auto</span> depthToSpaceQueueDescriptor = PolymorphicDowncast&lt;const DepthToSpaceQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00287"></a><span class="lineno"> 287</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDepthToSpaceWorkload&gt;(*depthToSpaceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00288"></a><span class="lineno"> 288</span>&#160; }</div>
+<div class="line"><a name="l00289"></a><span class="lineno"> 289</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af97adbfc88b7012a0243215b1076e7e7">LayerType::DepthwiseConvolution2d</a>:</div>
+<div class="line"><a name="l00290"></a><span class="lineno"> 290</span>&#160; {</div>
+<div class="line"><a name="l00291"></a><span class="lineno"> 291</span>&#160; <span class="keyword">auto</span> depthwiseConvolution2DQueueDescriptor</div>
+<div class="line"><a name="l00292"></a><span class="lineno"> 292</span>&#160; = PolymorphicDowncast&lt;const DepthwiseConvolution2dQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00293"></a><span class="lineno"> 293</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDepthwiseConvolution2dWorkload&gt;(*depthwiseConvolution2DQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00294"></a><span class="lineno"> 294</span>&#160; }</div>
+<div class="line"><a name="l00295"></a><span class="lineno"> 295</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9bc35e069257a508e14ed82965a8661d">LayerType::Dequantize</a>:</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"> 297</span>&#160; <span class="keyword">auto</span> dequantizeQueueDescriptor = PolymorphicDowncast&lt;const DequantizeQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00298"></a><span class="lineno"> 298</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDequantizeWorkload&gt;(*dequantizeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00299"></a><span class="lineno"> 299</span>&#160; }</div>
+<div class="line"><a name="l00300"></a><span class="lineno"> 300</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1db19222ac424bd7162142ddf929fd2a">LayerType::DetectionPostProcess</a>:</div>
+<div class="line"><a name="l00301"></a><span class="lineno"> 301</span>&#160; {</div>
+<div class="line"><a name="l00302"></a><span class="lineno"> 302</span>&#160; <span class="keyword">auto</span> detectionPostProcessQueueDescriptor</div>
+<div class="line"><a name="l00303"></a><span class="lineno"> 303</span>&#160; = PolymorphicDowncast&lt;const DetectionPostProcessQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00304"></a><span class="lineno"> 304</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDetectionPostProcessWorkload&gt;(*detectionPostProcessQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3025cdaab2deb0bb2cd642449e570833">LayerType::Division</a>:</div>
+<div class="line"><a name="l00307"></a><span class="lineno"> 307</span>&#160; {</div>
+<div class="line"><a name="l00308"></a><span class="lineno"> 308</span>&#160; <span class="keyword">auto</span> divisionQueueDescriptor = PolymorphicDowncast&lt;const DivisionQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00309"></a><span class="lineno"> 309</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
+<div class="line"><a name="l00310"></a><span class="lineno"> 310</span>&#160; {</div>
+<div class="line"><a name="l00311"></a><span class="lineno"> 311</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDivisionWorkload&lt;int32_t&gt;&gt;(*divisionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00312"></a><span class="lineno"> 312</span>&#160; }</div>
+<div class="line"><a name="l00313"></a><span class="lineno"> 313</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00314"></a><span class="lineno"> 314</span>&#160; {</div>
+<div class="line"><a name="l00315"></a><span class="lineno"> 315</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefDivisionWorkload&lt;float&gt;&gt;(*divisionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 317</span>&#160; }</div>
+<div class="line"><a name="l00318"></a><span class="lineno"> 318</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a699bcffd93aff3022014b9efc9eaefd1">LayerType::ElementwiseBinary</a>:</div>
+<div class="line"><a name="l00319"></a><span class="lineno"> 319</span>&#160; {</div>
+<div class="line"><a name="l00320"></a><span class="lineno"> 320</span>&#160; <span class="keyword">auto</span> elementwiseBinaryQueueDescriptor</div>
+<div class="line"><a name="l00321"></a><span class="lineno"> 321</span>&#160; = PolymorphicDowncast&lt;const ElementwiseBinaryQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00322"></a><span class="lineno"> 322</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefElementwiseBinaryWorkload&gt;(*elementwiseBinaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00323"></a><span class="lineno"> 323</span>&#160; }</div>
+<div class="line"><a name="l00324"></a><span class="lineno"> 324</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4abcd30d7ea97ad20c2cddc0f47e6b70c7">LayerType::ElementwiseUnary</a>:</div>
+<div class="line"><a name="l00325"></a><span class="lineno"> 325</span>&#160; {</div>
+<div class="line"><a name="l00326"></a><span class="lineno"> 326</span>&#160; <span class="keyword">auto</span> elementwiseUnaryQueueDescriptor</div>
+<div class="line"><a name="l00327"></a><span class="lineno"> 327</span>&#160; = PolymorphicDowncast&lt;const ElementwiseUnaryQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00328"></a><span class="lineno"> 328</span>&#160; <span class="keywordflow">if</span> ((*elementwiseUnaryQueueDescriptor).m_Parameters.m_Operation == <a class="code" href="namespacearmnn.html#a1cfaa710db2a54673b21d2ea2da757c8a2a25ebd8c909241e3f7818389b804ecc">UnaryOperation::LogicalNot</a>)</div>
+<div class="line"><a name="l00329"></a><span class="lineno"> 329</span>&#160; {</div>
+<div class="line"><a name="l00330"></a><span class="lineno"> 330</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLogicalUnaryWorkload&gt;(*elementwiseUnaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">return</span> std::make_unique&lt;RefElementwiseUnaryWorkload&gt;(*elementwiseUnaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00333"></a><span class="lineno"> 333</span>&#160; }</div>
+<div class="line"><a name="l00334"></a><span class="lineno"> 334</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3489c7b05e180496cb2ce8ac73887f48">LayerType::FakeQuantization</a>:</div>
+<div class="line"><a name="l00335"></a><span class="lineno"> 335</span>&#160; {</div>
+<div class="line"><a name="l00336"></a><span class="lineno"> 336</span>&#160; <span class="keyword">auto</span> fakeQuantizationQueueDescriptor</div>
+<div class="line"><a name="l00337"></a><span class="lineno"> 337</span>&#160; = PolymorphicDowncast&lt;const FakeQuantizationQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00338"></a><span class="lineno"> 338</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefFakeQuantizationFloat32Workload&gt;(*fakeQuantizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00339"></a><span class="lineno"> 339</span>&#160; }</div>
+<div class="line"><a name="l00340"></a><span class="lineno"> 340</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4adb3e3f51c9107e26c9bccf9a188ce2ed">LayerType::Fill</a>:</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; <span class="keyword">auto</span> fillQueueDescriptor = PolymorphicDowncast&lt;const FillQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00343"></a><span class="lineno"> 343</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefFillWorkload&gt;(*fillQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00344"></a><span class="lineno"> 344</span>&#160; }</div>
+<div class="line"><a name="l00345"></a><span class="lineno"> 345</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af3f6d0343d56ce88ce7958170ed05cb3">LayerType::Floor</a>:</div>
+<div class="line"><a name="l00346"></a><span class="lineno"> 346</span>&#160; {</div>
+<div class="line"><a name="l00347"></a><span class="lineno"> 347</span>&#160; <span class="keyword">auto</span> floorQueueDescriptor = PolymorphicDowncast&lt;const FloorQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00348"></a><span class="lineno"> 348</span>&#160; <span class="keywordflow">if</span>(<a class="code" href="namespacearmnn.html#ad44c007f21af2d0375e3ef9400a1b275">IsQuantizedType</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType()))</div>
+<div class="line"><a name="l00349"></a><span class="lineno"> 349</span>&#160; {</div>
+<div class="line"><a name="l00350"></a><span class="lineno"> 350</span>&#160; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
+<div class="line"><a name="l00351"></a><span class="lineno"> 351</span>&#160; }</div>
+<div class="line"><a name="l00352"></a><span class="lineno"> 352</span>&#160; <span class="keywordflow">else</span></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; <span class="keywordflow">return</span> std::make_unique&lt;RefFloorWorkload&gt;(*floorQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00355"></a><span class="lineno"> 355</span>&#160; }</div>
+<div class="line"><a name="l00356"></a><span class="lineno"> 356</span>&#160; }</div>
+<div class="line"><a name="l00357"></a><span class="lineno"> 357</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acab78faff25393e9defd1911cb58133e">LayerType::FullyConnected</a>:</div>
+<div class="line"><a name="l00358"></a><span class="lineno"> 358</span>&#160; {</div>
+<div class="line"><a name="l00359"></a><span class="lineno"> 359</span>&#160; <span class="keyword">auto</span> fullyConnectedQueueDescriptor</div>
+<div class="line"><a name="l00360"></a><span class="lineno"> 360</span>&#160; = PolymorphicDowncast&lt;const FullyConnectedQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00361"></a><span class="lineno"> 361</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefFullyConnectedWorkload&gt;(*fullyConnectedQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00362"></a><span class="lineno"> 362</span>&#160; }</div>
+<div class="line"><a name="l00363"></a><span class="lineno"> 363</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aad22c799930d644e8468fe44c0312d53">LayerType::Gather</a>:</div>
+<div class="line"><a name="l00364"></a><span class="lineno"> 364</span>&#160; {</div>
+<div class="line"><a name="l00365"></a><span class="lineno"> 365</span>&#160; <span class="keyword">auto</span> gatherQueueDescriptor = PolymorphicDowncast&lt;const GatherQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00366"></a><span class="lineno"> 366</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefGatherWorkload&gt;(*gatherQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00367"></a><span class="lineno"> 367</span>&#160; }</div>
+<div class="line"><a name="l00368"></a><span class="lineno"> 368</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3028cc42e40f9a1f4f8b35556d9715a4">LayerType::GatherNd</a>:</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; <span class="keyword">auto</span> gatherNdQueueDescriptor = PolymorphicDowncast&lt;const GatherNdQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00371"></a><span class="lineno"> 371</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefGatherNdWorkload&gt;(*gatherNdQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00372"></a><span class="lineno"> 372</span>&#160; }</div>
+<div class="line"><a name="l00373"></a><span class="lineno"> 373</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a324118a6721dd6b8a9b9f4e327df2bf5">LayerType::Input</a>:</div>
+<div class="line"><a name="l00374"></a><span class="lineno"> 374</span>&#160; {</div>
+<div class="line"><a name="l00375"></a><span class="lineno"> 375</span>&#160; <span class="keyword">auto</span> inputQueueDescriptor = PolymorphicDowncast&lt;const InputQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00376"></a><span class="lineno"> 376</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos.empty() )</div>
<div class="line"><a name="l00377"></a><span class="lineno"> 377</span>&#160; {</div>
-<div class="line"><a name="l00378"></a><span class="lineno"> 378</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateInput: &quot;</span></div>
-<div class="line"><a name="l00379"></a><span class="lineno"> 379</span>&#160; <span class="stringliteral">&quot;data input and output differ in byte count.&quot;</span>);</div>
-<div class="line"><a name="l00380"></a><span class="lineno"> 380</span>&#160; }</div>
-<div class="line"><a name="l00381"></a><span class="lineno"> 381</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*inputQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00382"></a><span class="lineno"> 382</span>&#160; }</div>
-<div class="line"><a name="l00383"></a><span class="lineno"> 383</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a21baa4498161d195f5bb2e3627344ba4">LayerType::InstanceNormalization</a>:</div>
-<div class="line"><a name="l00384"></a><span class="lineno"> 384</span>&#160; {</div>
-<div class="line"><a name="l00385"></a><span class="lineno"> 385</span>&#160; <span class="keyword">auto</span> instanceNormalizationQueueDescriptor</div>
-<div class="line"><a name="l00386"></a><span class="lineno"> 386</span>&#160; = PolymorphicDowncast&lt;const InstanceNormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00387"></a><span class="lineno"> 387</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefInstanceNormalizationWorkload&gt;(*instanceNormalizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00388"></a><span class="lineno"> 388</span>&#160; }</div>
-<div class="line"><a name="l00389"></a><span class="lineno"> 389</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1189467870bc421ae59277e750263eb2">LayerType::L2Normalization</a>:</div>
-<div class="line"><a name="l00390"></a><span class="lineno"> 390</span>&#160; {</div>
-<div class="line"><a name="l00391"></a><span class="lineno"> 391</span>&#160; <span class="keyword">auto</span> l2NormalizationQueueDescriptor</div>
-<div class="line"><a name="l00392"></a><span class="lineno"> 392</span>&#160; = PolymorphicDowncast&lt;const L2NormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00393"></a><span class="lineno"> 393</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefL2NormalizationWorkload&gt;(*l2NormalizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00394"></a><span class="lineno"> 394</span>&#160; }</div>
-<div class="line"><a name="l00395"></a><span class="lineno"> 395</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af4f53c8297dc1cb53d4e6f8151070a30">LayerType::LogicalBinary</a>:</div>
-<div class="line"><a name="l00396"></a><span class="lineno"> 396</span>&#160; {</div>
-<div class="line"><a name="l00397"></a><span class="lineno"> 397</span>&#160; <span class="keyword">auto</span> logicalBinaryQueueDescriptor = PolymorphicDowncast&lt;const LogicalBinaryQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00398"></a><span class="lineno"> 398</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLogicalBinaryWorkload&gt;(*logicalBinaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 400</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ac21dbda57d88c21ec9857f5d1522c488">LayerType::LogSoftmax</a>:</div>
-<div class="line"><a name="l00401"></a><span class="lineno"> 401</span>&#160; {</div>
-<div class="line"><a name="l00402"></a><span class="lineno"> 402</span>&#160; <span class="keyword">auto</span> logSoftmaxQueueDescriptor = PolymorphicDowncast&lt;const LogSoftmaxQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00403"></a><span class="lineno"> 403</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLogSoftmaxWorkload&gt;(*logSoftmaxQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00404"></a><span class="lineno"> 404</span>&#160; }</div>
-<div class="line"><a name="l00405"></a><span class="lineno"> 405</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a06b091bc9aea697ba473c71f0bb55925">LayerType::Lstm</a>:</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; <span class="keyword">auto</span> lstmQueueDescriptor = PolymorphicDowncast&lt;const LstmQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00408"></a><span class="lineno"> 408</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLstmWorkload&gt;(*lstmQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00409"></a><span class="lineno"> 409</span>&#160; }</div>
-<div class="line"><a name="l00410"></a><span class="lineno"> 410</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a8321e79c278ec510f63675c040594892">LayerType::Maximum</a>:</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="keyword">auto</span> maximumQueueDescriptor = PolymorphicDowncast&lt;const MaximumQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00413"></a><span class="lineno"> 413</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
-<div class="line"><a name="l00414"></a><span class="lineno"> 414</span>&#160; {</div>
-<div class="line"><a name="l00415"></a><span class="lineno"> 415</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMaximumWorkload&lt;int32_t&gt;&gt;(*maximumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00416"></a><span class="lineno"> 416</span>&#160; }</div>
-<div class="line"><a name="l00417"></a><span class="lineno"> 417</span>&#160; <span class="keywordflow">else</span></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; <span class="keywordflow">return</span> std::make_unique&lt;RefMaximumWorkload&lt;float&gt;&gt;(*maximumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00420"></a><span class="lineno"> 420</span>&#160; }</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3d6c9ac08ada31c184094bbc67afe00d">LayerType::Mean</a>:</div>
-<div class="line"><a name="l00423"></a><span class="lineno"> 423</span>&#160; {</div>
-<div class="line"><a name="l00424"></a><span class="lineno"> 424</span>&#160; <span class="keyword">auto</span> meanQueueDescriptor = PolymorphicDowncast&lt;const MeanQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00425"></a><span class="lineno"> 425</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMeanWorkload&gt;(*meanQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00426"></a><span class="lineno"> 426</span>&#160; }</div>
-<div class="line"><a name="l00427"></a><span class="lineno"> 427</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4dd48794eb3305a0f5aece88b111a97b">LayerType::MemCopy</a>:</div>
-<div class="line"><a name="l00428"></a><span class="lineno"> 428</span>&#160; {</div>
-<div class="line"><a name="l00429"></a><span class="lineno"> 429</span>&#160; <span class="keyword">auto</span> memCopyQueueDescriptor = PolymorphicDowncast&lt;const MemCopyQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00430"></a><span class="lineno"> 430</span>&#160; <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>.empty())</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; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory: CreateMemCopy() expected an input tensor.&quot;</span>);</div>
-<div class="line"><a name="l00433"></a><span class="lineno"> 433</span>&#160; }</div>
-<div class="line"><a name="l00434"></a><span class="lineno"> 434</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*memCopyQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00435"></a><span class="lineno"> 435</span>&#160; }</div>
-<div class="line"><a name="l00436"></a><span class="lineno"> 436</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a115bfc5d633eae55c67f9588acdd2bf9">LayerType::MemImport</a>:</div>
-<div class="line"><a name="l00437"></a><span class="lineno"> 437</span>&#160; {</div>
-<div class="line"><a name="l00438"></a><span class="lineno"> 438</span>&#160; <span class="keyword">auto</span> memImportQueueDescriptor = PolymorphicDowncast&lt;const MemImportQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00439"></a><span class="lineno"> 439</span>&#160; <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>.empty())</div>
-<div class="line"><a name="l00440"></a><span class="lineno"> 440</span>&#160; {</div>
-<div class="line"><a name="l00441"></a><span class="lineno"> 441</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory: CreateMemImport() expected an input tensor.&quot;</span>);</div>
-<div class="line"><a name="l00442"></a><span class="lineno"> 442</span>&#160; }</div>
-<div class="line"><a name="l00443"></a><span class="lineno"> 443</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;ImportMemGenericWorkload&gt;(*memImportQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00444"></a><span class="lineno"> 444</span>&#160; }</div>
-<div class="line"><a name="l00445"></a><span class="lineno"> 445</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa1d0ec6d56f8833a078b5a7ac4caf2d4">LayerType::Minimum</a>:</div>
-<div class="line"><a name="l00446"></a><span class="lineno"> 446</span>&#160; {</div>
-<div class="line"><a name="l00447"></a><span class="lineno"> 447</span>&#160; <span class="keyword">auto</span> minimumQueueDescriptor = PolymorphicDowncast&lt;const MinimumQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00448"></a><span class="lineno"> 448</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
-<div class="line"><a name="l00449"></a><span class="lineno"> 449</span>&#160; {</div>
-<div class="line"><a name="l00450"></a><span class="lineno"> 450</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMinimumWorkload&lt;int32_t&gt;&gt;(*minimumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00451"></a><span class="lineno"> 451</span>&#160; }</div>
-<div class="line"><a name="l00452"></a><span class="lineno"> 452</span>&#160; <span class="keywordflow">else</span></div>
-<div class="line"><a name="l00453"></a><span class="lineno"> 453</span>&#160; {</div>
-<div class="line"><a name="l00454"></a><span class="lineno"> 454</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMinimumWorkload&lt;float&gt;&gt;(*minimumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00455"></a><span class="lineno"> 455</span>&#160; }</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a27d1a1f7b7c2180e5b20ce9e3d00e2dd">LayerType::Multiplication</a>:</div>
-<div class="line"><a name="l00458"></a><span class="lineno"> 458</span>&#160; {</div>
-<div class="line"><a name="l00459"></a><span class="lineno"> 459</span>&#160; <span class="keyword">auto</span> multiplicationQueueDescriptor</div>
-<div class="line"><a name="l00460"></a><span class="lineno"> 460</span>&#160; = PolymorphicDowncast&lt;const MultiplicationQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00461"></a><span class="lineno"> 461</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</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; <span class="keywordflow">return</span> std::make_unique&lt;RefMultiplicationWorkload&lt;int32_t&gt;&gt;(*multiplicationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00464"></a><span class="lineno"> 464</span>&#160; }</div>
-<div class="line"><a name="l00465"></a><span class="lineno"> 465</span>&#160; <span class="keywordflow">else</span></div>
-<div class="line"><a name="l00466"></a><span class="lineno"> 466</span>&#160; {</div>
-<div class="line"><a name="l00467"></a><span class="lineno"> 467</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMultiplicationWorkload&lt;float&gt;&gt;(*multiplicationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00468"></a><span class="lineno"> 468</span>&#160; }</div>
-<div class="line"><a name="l00469"></a><span class="lineno"> 469</span>&#160; }</div>
-<div class="line"><a name="l00470"></a><span class="lineno"> 470</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aac61f2e17250a818dee4d12b112aa88f">LayerType::Normalization</a>:</div>
-<div class="line"><a name="l00471"></a><span class="lineno"> 471</span>&#160; {</div>
-<div class="line"><a name="l00472"></a><span class="lineno"> 472</span>&#160; <span class="keyword">auto</span> normalizationQueueDescriptor = PolymorphicDowncast&lt;const NormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00473"></a><span class="lineno"> 473</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefNormalizationWorkload&gt;(*normalizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a29c2c02a361c9d7028472e5d92cd4a54">LayerType::Output</a>:</div>
-<div class="line"><a name="l00476"></a><span class="lineno"> 476</span>&#160; {</div>
-<div class="line"><a name="l00477"></a><span class="lineno"> 477</span>&#160; <span class="keyword">auto</span> outputQueueDescriptor = PolymorphicDowncast&lt;const OutputQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00478"></a><span class="lineno"> 478</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos.empty() )</div>
-<div class="line"><a name="l00479"></a><span class="lineno"> 479</span>&#160; {</div>
-<div class="line"><a name="l00480"></a><span class="lineno"> 480</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateOutput: Input cannot be zero length&quot;</span>);</div>
-<div class="line"><a name="l00481"></a><span class="lineno"> 481</span>&#160; }</div>
-<div class="line"><a name="l00482"></a><span class="lineno"> 482</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos.empty())</div>
-<div class="line"><a name="l00483"></a><span class="lineno"> 483</span>&#160; {</div>
-<div class="line"><a name="l00484"></a><span class="lineno"> 484</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateOutput: Output cannot be zero length&quot;</span>);</div>
-<div class="line"><a name="l00485"></a><span class="lineno"> 485</span>&#160; }</div>
-<div class="line"><a name="l00486"></a><span class="lineno"> 486</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetNumBytes() != <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos[0].GetNumBytes())</div>
+<div class="line"><a name="l00378"></a><span class="lineno"> 378</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateInput: Input cannot be zero length&quot;</span>);</div>
+<div class="line"><a name="l00379"></a><span class="lineno"> 379</span>&#160; }</div>
+<div class="line"><a name="l00380"></a><span class="lineno"> 380</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos.empty())</div>
+<div class="line"><a name="l00381"></a><span class="lineno"> 381</span>&#160; {</div>
+<div class="line"><a name="l00382"></a><span class="lineno"> 382</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateInput: Output cannot be zero length&quot;</span>);</div>
+<div class="line"><a name="l00383"></a><span class="lineno"> 383</span>&#160; }</div>
+<div class="line"><a name="l00384"></a><span class="lineno"> 384</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetNumBytes() != <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos[0].GetNumBytes())</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; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateInput: &quot;</span></div>
+<div class="line"><a name="l00387"></a><span class="lineno"> 387</span>&#160; <span class="stringliteral">&quot;data input and output differ in byte count.&quot;</span>);</div>
+<div class="line"><a name="l00388"></a><span class="lineno"> 388</span>&#160; }</div>
+<div class="line"><a name="l00389"></a><span class="lineno"> 389</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*inputQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00390"></a><span class="lineno"> 390</span>&#160; }</div>
+<div class="line"><a name="l00391"></a><span class="lineno"> 391</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a21baa4498161d195f5bb2e3627344ba4">LayerType::InstanceNormalization</a>:</div>
+<div class="line"><a name="l00392"></a><span class="lineno"> 392</span>&#160; {</div>
+<div class="line"><a name="l00393"></a><span class="lineno"> 393</span>&#160; <span class="keyword">auto</span> instanceNormalizationQueueDescriptor</div>
+<div class="line"><a name="l00394"></a><span class="lineno"> 394</span>&#160; = PolymorphicDowncast&lt;const InstanceNormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00395"></a><span class="lineno"> 395</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefInstanceNormalizationWorkload&gt;(*instanceNormalizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00396"></a><span class="lineno"> 396</span>&#160; }</div>
+<div class="line"><a name="l00397"></a><span class="lineno"> 397</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1189467870bc421ae59277e750263eb2">LayerType::L2Normalization</a>:</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; <span class="keyword">auto</span> l2NormalizationQueueDescriptor</div>
+<div class="line"><a name="l00400"></a><span class="lineno"> 400</span>&#160; = PolymorphicDowncast&lt;const L2NormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00401"></a><span class="lineno"> 401</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefL2NormalizationWorkload&gt;(*l2NormalizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00402"></a><span class="lineno"> 402</span>&#160; }</div>
+<div class="line"><a name="l00403"></a><span class="lineno"> 403</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af4f53c8297dc1cb53d4e6f8151070a30">LayerType::LogicalBinary</a>:</div>
+<div class="line"><a name="l00404"></a><span class="lineno"> 404</span>&#160; {</div>
+<div class="line"><a name="l00405"></a><span class="lineno"> 405</span>&#160; <span class="keyword">auto</span> logicalBinaryQueueDescriptor = PolymorphicDowncast&lt;const LogicalBinaryQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00406"></a><span class="lineno"> 406</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLogicalBinaryWorkload&gt;(*logicalBinaryQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00407"></a><span class="lineno"> 407</span>&#160; }</div>
+<div class="line"><a name="l00408"></a><span class="lineno"> 408</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ac21dbda57d88c21ec9857f5d1522c488">LayerType::LogSoftmax</a>:</div>
+<div class="line"><a name="l00409"></a><span class="lineno"> 409</span>&#160; {</div>
+<div class="line"><a name="l00410"></a><span class="lineno"> 410</span>&#160; <span class="keyword">auto</span> logSoftmaxQueueDescriptor = PolymorphicDowncast&lt;const LogSoftmaxQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00411"></a><span class="lineno"> 411</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLogSoftmaxWorkload&gt;(*logSoftmaxQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00412"></a><span class="lineno"> 412</span>&#160; }</div>
+<div class="line"><a name="l00413"></a><span class="lineno"> 413</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a06b091bc9aea697ba473c71f0bb55925">LayerType::Lstm</a>:</div>
+<div class="line"><a name="l00414"></a><span class="lineno"> 414</span>&#160; {</div>
+<div class="line"><a name="l00415"></a><span class="lineno"> 415</span>&#160; <span class="keyword">auto</span> lstmQueueDescriptor = PolymorphicDowncast&lt;const LstmQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00416"></a><span class="lineno"> 416</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefLstmWorkload&gt;(*lstmQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00417"></a><span class="lineno"> 417</span>&#160; }</div>
+<div class="line"><a name="l00418"></a><span class="lineno"> 418</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a8321e79c278ec510f63675c040594892">LayerType::Maximum</a>:</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="keyword">auto</span> maximumQueueDescriptor = PolymorphicDowncast&lt;const MaximumQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00421"></a><span class="lineno"> 421</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</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"> 423</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMaximumWorkload&lt;int32_t&gt;&gt;(*maximumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00424"></a><span class="lineno"> 424</span>&#160; }</div>
+<div class="line"><a name="l00425"></a><span class="lineno"> 425</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00426"></a><span class="lineno"> 426</span>&#160; {</div>
+<div class="line"><a name="l00427"></a><span class="lineno"> 427</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMaximumWorkload&lt;float&gt;&gt;(*maximumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00428"></a><span class="lineno"> 428</span>&#160; }</div>
+<div class="line"><a name="l00429"></a><span class="lineno"> 429</span>&#160; }</div>
+<div class="line"><a name="l00430"></a><span class="lineno"> 430</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3d6c9ac08ada31c184094bbc67afe00d">LayerType::Mean</a>:</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; <span class="keyword">auto</span> meanQueueDescriptor = PolymorphicDowncast&lt;const MeanQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00433"></a><span class="lineno"> 433</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMeanWorkload&gt;(*meanQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00434"></a><span class="lineno"> 434</span>&#160; }</div>
+<div class="line"><a name="l00435"></a><span class="lineno"> 435</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4dd48794eb3305a0f5aece88b111a97b">LayerType::MemCopy</a>:</div>
+<div class="line"><a name="l00436"></a><span class="lineno"> 436</span>&#160; {</div>
+<div class="line"><a name="l00437"></a><span class="lineno"> 437</span>&#160; <span class="keyword">auto</span> memCopyQueueDescriptor = PolymorphicDowncast&lt;const MemCopyQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00438"></a><span class="lineno"> 438</span>&#160; <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>.empty())</div>
+<div class="line"><a name="l00439"></a><span class="lineno"> 439</span>&#160; {</div>
+<div class="line"><a name="l00440"></a><span class="lineno"> 440</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory: CreateMemCopy() expected an input tensor.&quot;</span>);</div>
+<div class="line"><a name="l00441"></a><span class="lineno"> 441</span>&#160; }</div>
+<div class="line"><a name="l00442"></a><span class="lineno"> 442</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*memCopyQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00443"></a><span class="lineno"> 443</span>&#160; }</div>
+<div class="line"><a name="l00444"></a><span class="lineno"> 444</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a115bfc5d633eae55c67f9588acdd2bf9">LayerType::MemImport</a>:</div>
+<div class="line"><a name="l00445"></a><span class="lineno"> 445</span>&#160; {</div>
+<div class="line"><a name="l00446"></a><span class="lineno"> 446</span>&#160; <span class="keyword">auto</span> memImportQueueDescriptor = PolymorphicDowncast&lt;const MemImportQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00447"></a><span class="lineno"> 447</span>&#160; <span class="keywordflow">if</span> (descriptor.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>.empty())</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"> 449</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory: CreateMemImport() expected an input tensor.&quot;</span>);</div>
+<div class="line"><a name="l00450"></a><span class="lineno"> 450</span>&#160; }</div>
+<div class="line"><a name="l00451"></a><span class="lineno"> 451</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;ImportMemGenericWorkload&gt;(*memImportQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00452"></a><span class="lineno"> 452</span>&#160; }</div>
+<div class="line"><a name="l00453"></a><span class="lineno"> 453</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa1d0ec6d56f8833a078b5a7ac4caf2d4">LayerType::Minimum</a>:</div>
+<div class="line"><a name="l00454"></a><span class="lineno"> 454</span>&#160; {</div>
+<div class="line"><a name="l00455"></a><span class="lineno"> 455</span>&#160; <span class="keyword">auto</span> minimumQueueDescriptor = PolymorphicDowncast&lt;const MinimumQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00456"></a><span class="lineno"> 456</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</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"> 458</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMinimumWorkload&lt;int32_t&gt;&gt;(*minimumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00459"></a><span class="lineno"> 459</span>&#160; }</div>
+<div class="line"><a name="l00460"></a><span class="lineno"> 460</span>&#160; <span class="keywordflow">else</span></div>
+<div class="line"><a name="l00461"></a><span class="lineno"> 461</span>&#160; {</div>
+<div class="line"><a name="l00462"></a><span class="lineno"> 462</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMinimumWorkload&lt;float&gt;&gt;(*minimumQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 464</span>&#160; }</div>
+<div class="line"><a name="l00465"></a><span class="lineno"> 465</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a27d1a1f7b7c2180e5b20ce9e3d00e2dd">LayerType::Multiplication</a>:</div>
+<div class="line"><a name="l00466"></a><span class="lineno"> 466</span>&#160; {</div>
+<div class="line"><a name="l00467"></a><span class="lineno"> 467</span>&#160; <span class="keyword">auto</span> multiplicationQueueDescriptor</div>
+<div class="line"><a name="l00468"></a><span class="lineno"> 468</span>&#160; = PolymorphicDowncast&lt;const MultiplicationQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00469"></a><span class="lineno"> 469</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
+<div class="line"><a name="l00470"></a><span class="lineno"> 470</span>&#160; {</div>
+<div class="line"><a name="l00471"></a><span class="lineno"> 471</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefMultiplicationWorkload&lt;int32_t&gt;&gt;(*multiplicationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00472"></a><span class="lineno"> 472</span>&#160; }</div>
+<div class="line"><a name="l00473"></a><span class="lineno"> 473</span>&#160; <span class="keywordflow">else</span></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; <span class="keywordflow">return</span> std::make_unique&lt;RefMultiplicationWorkload&lt;float&gt;&gt;(*multiplicationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00476"></a><span class="lineno"> 476</span>&#160; }</div>
+<div class="line"><a name="l00477"></a><span class="lineno"> 477</span>&#160; }</div>
+<div class="line"><a name="l00478"></a><span class="lineno"> 478</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aac61f2e17250a818dee4d12b112aa88f">LayerType::Normalization</a>:</div>
+<div class="line"><a name="l00479"></a><span class="lineno"> 479</span>&#160; {</div>
+<div class="line"><a name="l00480"></a><span class="lineno"> 480</span>&#160; <span class="keyword">auto</span> normalizationQueueDescriptor = PolymorphicDowncast&lt;const NormalizationQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00481"></a><span class="lineno"> 481</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefNormalizationWorkload&gt;(*normalizationQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00482"></a><span class="lineno"> 482</span>&#160; }</div>
+<div class="line"><a name="l00483"></a><span class="lineno"> 483</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a29c2c02a361c9d7028472e5d92cd4a54">LayerType::Output</a>:</div>
+<div class="line"><a name="l00484"></a><span class="lineno"> 484</span>&#160; {</div>
+<div class="line"><a name="l00485"></a><span class="lineno"> 485</span>&#160; <span class="keyword">auto</span> outputQueueDescriptor = PolymorphicDowncast&lt;const OutputQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00486"></a><span class="lineno"> 486</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos.empty() )</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"> 488</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateOutput: data input and output &quot;</span></div>
-<div class="line"><a name="l00489"></a><span class="lineno"> 489</span>&#160; <span class="stringliteral">&quot;differ in byte count.&quot;</span>);</div>
-<div class="line"><a name="l00490"></a><span class="lineno"> 490</span>&#160; }</div>
-<div class="line"><a name="l00491"></a><span class="lineno"> 491</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*outputQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00492"></a><span class="lineno"> 492</span>&#160; }</div>
-<div class="line"><a name="l00493"></a><span class="lineno"> 493</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ade43468adaf6acb2c38ebc0c1176f82f">LayerType::Pad</a>:</div>
-<div class="line"><a name="l00494"></a><span class="lineno"> 494</span>&#160; {</div>
-<div class="line"><a name="l00495"></a><span class="lineno"> 495</span>&#160; <span class="keyword">auto</span> padQueueDescriptor = PolymorphicDowncast&lt;const PadQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00496"></a><span class="lineno"> 496</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPadWorkload&gt;(*padQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00497"></a><span class="lineno"> 497</span>&#160; }</div>
-<div class="line"><a name="l00498"></a><span class="lineno"> 498</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4afa662c6eb71caef475b2b981ce8eccd7">LayerType::Permute</a>:</div>
-<div class="line"><a name="l00499"></a><span class="lineno"> 499</span>&#160; {</div>
-<div class="line"><a name="l00500"></a><span class="lineno"> 500</span>&#160; <span class="keyword">auto</span> permuteQueueDescriptor = PolymorphicDowncast&lt;const PermuteQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00501"></a><span class="lineno"> 501</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#abcd0d843d5736b78740ae73249b6b977">IsQSymmS16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
-<div class="line"><a name="l00502"></a><span class="lineno"> 502</span>&#160; {</div>
-<div class="line"><a name="l00503"></a><span class="lineno"> 503</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPermuteQSymm16Workload&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00504"></a><span class="lineno"> 504</span>&#160; }</div>
-<div class="line"><a name="l00505"></a><span class="lineno"> 505</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a3d504240723912bf9c76ff3afeaa25c5">IsBFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
-<div class="line"><a name="l00506"></a><span class="lineno"> 506</span>&#160; {</div>
-<div class="line"><a name="l00507"></a><span class="lineno"> 507</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPermuteBFloat16Workload&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00508"></a><span class="lineno"> 508</span>&#160; }</div>
-<div class="line"><a name="l00509"></a><span class="lineno"> 509</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a47d136a5519331dee24f5e01b206ae7c">IsQAsymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00488"></a><span class="lineno"> 488</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateOutput: Input cannot be zero length&quot;</span>);</div>
+<div class="line"><a name="l00489"></a><span class="lineno"> 489</span>&#160; }</div>
+<div class="line"><a name="l00490"></a><span class="lineno"> 490</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos.empty())</div>
+<div class="line"><a name="l00491"></a><span class="lineno"> 491</span>&#160; {</div>
+<div class="line"><a name="l00492"></a><span class="lineno"> 492</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateOutput: Output cannot be zero length&quot;</span>);</div>
+<div class="line"><a name="l00493"></a><span class="lineno"> 493</span>&#160; }</div>
+<div class="line"><a name="l00494"></a><span class="lineno"> 494</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetNumBytes() != <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_OutputTensorInfos[0].GetNumBytes())</div>
+<div class="line"><a name="l00495"></a><span class="lineno"> 495</span>&#160; {</div>
+<div class="line"><a name="l00496"></a><span class="lineno"> 496</span>&#160; <span class="keywordflow">throw</span> <a class="code" href="classarmnn_1_1_invalid_argument_exception.html">InvalidArgumentException</a>(<span class="stringliteral">&quot;RefWorkloadFactory::CreateOutput: data input and output &quot;</span></div>
+<div class="line"><a name="l00497"></a><span class="lineno"> 497</span>&#160; <span class="stringliteral">&quot;differ in byte count.&quot;</span>);</div>
+<div class="line"><a name="l00498"></a><span class="lineno"> 498</span>&#160; }</div>
+<div class="line"><a name="l00499"></a><span class="lineno"> 499</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*outputQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00500"></a><span class="lineno"> 500</span>&#160; }</div>
+<div class="line"><a name="l00501"></a><span class="lineno"> 501</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ade43468adaf6acb2c38ebc0c1176f82f">LayerType::Pad</a>:</div>
+<div class="line"><a name="l00502"></a><span class="lineno"> 502</span>&#160; {</div>
+<div class="line"><a name="l00503"></a><span class="lineno"> 503</span>&#160; <span class="keyword">auto</span> padQueueDescriptor = PolymorphicDowncast&lt;const PadQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00504"></a><span class="lineno"> 504</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPadWorkload&gt;(*padQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00505"></a><span class="lineno"> 505</span>&#160; }</div>
+<div class="line"><a name="l00506"></a><span class="lineno"> 506</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4afa662c6eb71caef475b2b981ce8eccd7">LayerType::Permute</a>:</div>
+<div class="line"><a name="l00507"></a><span class="lineno"> 507</span>&#160; {</div>
+<div class="line"><a name="l00508"></a><span class="lineno"> 508</span>&#160; <span class="keyword">auto</span> permuteQueueDescriptor = PolymorphicDowncast&lt;const PermuteQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00509"></a><span class="lineno"> 509</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#abcd0d843d5736b78740ae73249b6b977">IsQSymmS16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</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; <span class="keywordflow">return</span> std::make_unique&lt;RefPermuteQAsymmS8Workload&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00511"></a><span class="lineno"> 511</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPermuteQSymm16Workload&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00512"></a><span class="lineno"> 512</span>&#160; }</div>
-<div class="line"><a name="l00513"></a><span class="lineno"> 513</span>&#160; <span class="keywordflow">return</span> MakeWorkloadHelper&lt;<a class="code" href="namespacearmnn.html#ad1c0fb6bfa580b04574ab56971b6cbc6">RefPermuteFloat16Workload</a>, <a class="code" href="namespacearmnn.html#a54c3f7c7b9909e828a084f68dc78a031">RefPermuteFloat32Workload</a>, <a class="code" href="namespacearmnn.html#a50ffe5068ecb2fbf7f73b30ef0d753f8">RefPermuteQAsymm8Workload</a>,</div>
-<div class="line"><a name="l00514"></a><span class="lineno"> 514</span>&#160; <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00515"></a><span class="lineno"> 515</span>&#160; }</div>
-<div class="line"><a name="l00516"></a><span class="lineno"> 516</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ad662867a41bfb30b9f75dda2b5849001">LayerType::Pooling2d</a>:</div>
-<div class="line"><a name="l00517"></a><span class="lineno"> 517</span>&#160; {</div>
-<div class="line"><a name="l00518"></a><span class="lineno"> 518</span>&#160; <span class="keyword">auto</span> pooling2dQueueDescriptor = PolymorphicDowncast&lt;const Pooling2dQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00519"></a><span class="lineno"> 519</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPooling2dWorkload&gt;(*pooling2dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00520"></a><span class="lineno"> 520</span>&#160; }</div>
-<div class="line"><a name="l00521"></a><span class="lineno"> 521</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2b3140dc366b9fcd25ed786a79d1817c">LayerType::Pooling3d</a>:</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; <span class="keyword">auto</span> pooling3dQueueDescriptor = PolymorphicDowncast&lt;const Pooling3dQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00524"></a><span class="lineno"> 524</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPooling3dWorkload&gt;(*pooling3dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00525"></a><span class="lineno"> 525</span>&#160; }</div>
-<div class="line"><a name="l00526"></a><span class="lineno"> 526</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1ba143ebe524d46181a4b53470693278">LayerType::PreCompiled</a>:</div>
-<div class="line"><a name="l00527"></a><span class="lineno"> 527</span>&#160; {</div>
-<div class="line"><a name="l00528"></a><span class="lineno"> 528</span>&#160; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
-<div class="line"><a name="l00529"></a><span class="lineno"> 529</span>&#160; }</div>
-<div class="line"><a name="l00530"></a><span class="lineno"> 530</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a0c5967f09e0669c840ebb1ed0da85e32">LayerType::Prelu</a>:</div>
-<div class="line"><a name="l00531"></a><span class="lineno"> 531</span>&#160; {</div>
-<div class="line"><a name="l00532"></a><span class="lineno"> 532</span>&#160; <span class="keyword">auto</span> preluQueueDescriptor = PolymorphicDowncast&lt;const PreluQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00533"></a><span class="lineno"> 533</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPreluWorkload&gt;(*preluQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a91880b71ea6d007439b7bc7c320b5c25">LayerType::QLstm</a>:</div>
-<div class="line"><a name="l00536"></a><span class="lineno"> 536</span>&#160; {</div>
-<div class="line"><a name="l00537"></a><span class="lineno"> 537</span>&#160; <span class="keyword">auto</span> qlstmQueueDescriptor = PolymorphicDowncast&lt;const QLstmQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00538"></a><span class="lineno"> 538</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefQLstmWorkload&gt;(*qlstmQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00539"></a><span class="lineno"> 539</span>&#160; }</div>
-<div class="line"><a name="l00540"></a><span class="lineno"> 540</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aca39930e22f40d10155a57dba32240bb">LayerType::Quantize</a>:</div>
-<div class="line"><a name="l00541"></a><span class="lineno"> 541</span>&#160; {</div>
-<div class="line"><a name="l00542"></a><span class="lineno"> 542</span>&#160; <span class="keyword">auto</span> quantizeQueueDescriptor = PolymorphicDowncast&lt;const QuantizeQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00543"></a><span class="lineno"> 543</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefQuantizeWorkload&gt;(*quantizeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00544"></a><span class="lineno"> 544</span>&#160; }</div>
-<div class="line"><a name="l00545"></a><span class="lineno"> 545</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a021da1b20f73dc252361a54d80497ef3">LayerType::Rank</a>:</div>
-<div class="line"><a name="l00546"></a><span class="lineno"> 546</span>&#160; {</div>
-<div class="line"><a name="l00547"></a><span class="lineno"> 547</span>&#160; <span class="keyword">auto</span> rankQueueDescriptor = PolymorphicDowncast&lt;const RankQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00548"></a><span class="lineno"> 548</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefRankWorkload&gt;(*rankQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00549"></a><span class="lineno"> 549</span>&#160; }</div>
-<div class="line"><a name="l00550"></a><span class="lineno"> 550</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aec4875f03ff0bb0b26cf76ac7f41e3c8">LayerType::Reduce</a>:</div>
-<div class="line"><a name="l00551"></a><span class="lineno"> 551</span>&#160; {</div>
-<div class="line"><a name="l00552"></a><span class="lineno"> 552</span>&#160; <span class="keyword">auto</span> reduceQueueDescriptor = PolymorphicDowncast&lt;const ReduceQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00553"></a><span class="lineno"> 553</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefReduceWorkload&gt;(*reduceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa7c59ccedc6a3bd90c17f3b990afefad">LayerType::Reshape</a>:</div>
-<div class="line"><a name="l00556"></a><span class="lineno"> 556</span>&#160; {</div>
-<div class="line"><a name="l00557"></a><span class="lineno"> 557</span>&#160; <span class="keyword">auto</span> reshapeQueueDescriptor = PolymorphicDowncast&lt;const ReshapeQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00558"></a><span class="lineno"> 558</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefReshapeWorkload&gt;(*reshapeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00559"></a><span class="lineno"> 559</span>&#160; }</div>
-<div class="line"><a name="l00560"></a><span class="lineno"> 560</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9d723d04c40bfd81835c0766a698cf63">LayerType::Resize</a>:</div>
-<div class="line"><a name="l00561"></a><span class="lineno"> 561</span>&#160; {</div>
-<div class="line"><a name="l00562"></a><span class="lineno"> 562</span>&#160; <span class="keyword">auto</span> resizeQueueDescriptor = PolymorphicDowncast&lt;const ResizeQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00563"></a><span class="lineno"> 563</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefResizeWorkload&gt;(*resizeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00564"></a><span class="lineno"> 564</span>&#160; }</div>
-<div class="line"><a name="l00565"></a><span class="lineno"> 565</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af9a0b6ef62dc10097826358e28b19295">LayerType::ReverseV2</a>:</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; <span class="keyword">auto</span> reverseV2QueueDescriptor = PolymorphicDowncast&lt;const ReverseV2QueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00568"></a><span class="lineno"> 568</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefReverseV2Workload&gt;(*reverseV2QueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00569"></a><span class="lineno"> 569</span>&#160; }</div>
-<div class="line"><a name="l00570"></a><span class="lineno"> 570</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a880c1273b27d27cfc82004c3a4b205c9">LayerType::Shape</a>:</div>
-<div class="line"><a name="l00571"></a><span class="lineno"> 571</span>&#160; {</div>
-<div class="line"><a name="l00572"></a><span class="lineno"> 572</span>&#160; <span class="keyword">auto</span> shapeQueueDescriptor = PolymorphicDowncast&lt;const ShapeQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00573"></a><span class="lineno"> 573</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefShapeWorkload&gt;(*shapeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ad140d37ad98c12ccd8e1c432f548bcdb">LayerType::Slice</a>:</div>
-<div class="line"><a name="l00576"></a><span class="lineno"> 576</span>&#160; {</div>
-<div class="line"><a name="l00577"></a><span class="lineno"> 577</span>&#160; <span class="keyword">auto</span> sliceQueueDescriptor = PolymorphicDowncast&lt;const SliceQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00578"></a><span class="lineno"> 578</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSliceWorkload&gt;(*sliceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00579"></a><span class="lineno"> 579</span>&#160; }</div>
-<div class="line"><a name="l00580"></a><span class="lineno"> 580</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a31d953b9d49a6b4378f45097047976d0">LayerType::Softmax</a>:</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"> 582</span>&#160; <span class="keyword">auto</span> softmaxQueueDescriptor = PolymorphicDowncast&lt;const SoftmaxQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00583"></a><span class="lineno"> 583</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSoftmaxWorkload&gt;(*softmaxQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00584"></a><span class="lineno"> 584</span>&#160; }</div>
-<div class="line"><a name="l00585"></a><span class="lineno"> 585</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a337c392144dca0d18290c6b4711a2279">LayerType::SpaceToBatchNd</a>:</div>
-<div class="line"><a name="l00586"></a><span class="lineno"> 586</span>&#160; {</div>
-<div class="line"><a name="l00587"></a><span class="lineno"> 587</span>&#160; <span class="keyword">auto</span> spaceToBatchNdQueueDescriptor</div>
-<div class="line"><a name="l00588"></a><span class="lineno"> 588</span>&#160; = PolymorphicDowncast&lt;const SpaceToBatchNdQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00589"></a><span class="lineno"> 589</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSpaceToBatchNdWorkload&gt;(*spaceToBatchNdQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00590"></a><span class="lineno"> 590</span>&#160; }</div>
-<div class="line"><a name="l00591"></a><span class="lineno"> 591</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a5e7ff12da912dc79e7e547281823fa4a">LayerType::SpaceToDepth</a>:</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; <span class="keyword">auto</span> spaceToDepthQueueDescriptor = PolymorphicDowncast&lt;const SpaceToDepthQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00594"></a><span class="lineno"> 594</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSpaceToDepthWorkload&gt;(*spaceToDepthQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00595"></a><span class="lineno"> 595</span>&#160; }</div>
-<div class="line"><a name="l00596"></a><span class="lineno"> 596</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a41cb9b797ebc6f6f6314e3ded935f4cf">LayerType::Splitter</a>:</div>
-<div class="line"><a name="l00597"></a><span class="lineno"> 597</span>&#160; {</div>
-<div class="line"><a name="l00598"></a><span class="lineno"> 598</span>&#160; <span class="keyword">auto</span> splitterQueueDescriptor = PolymorphicDowncast&lt;const SplitterQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00599"></a><span class="lineno"> 599</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSplitterWorkload&gt;(*splitterQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2187e1021a911b3807cc1bea2eb1a9ca">LayerType::Stack</a>:</div>
-<div class="line"><a name="l00602"></a><span class="lineno"> 602</span>&#160; {</div>
-<div class="line"><a name="l00603"></a><span class="lineno"> 603</span>&#160; <span class="keyword">auto</span> stackQueueDescriptor = PolymorphicDowncast&lt;const StackQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00604"></a><span class="lineno"> 604</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefStackWorkload&gt;(*stackQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00605"></a><span class="lineno"> 605</span>&#160; }</div>
-<div class="line"><a name="l00606"></a><span class="lineno"> 606</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa31904f2b3479b5a00137fd985974b4d">LayerType::StridedSlice</a>:</div>
-<div class="line"><a name="l00607"></a><span class="lineno"> 607</span>&#160; {</div>
-<div class="line"><a name="l00608"></a><span class="lineno"> 608</span>&#160; <span class="keyword">auto</span> stridedSliceQueueDescriptor = PolymorphicDowncast&lt;const StridedSliceQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00609"></a><span class="lineno"> 609</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefStridedSliceWorkload&gt;(*stridedSliceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00610"></a><span class="lineno"> 610</span>&#160; }</div>
-<div class="line"><a name="l00611"></a><span class="lineno"> 611</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a6eb8b8b560161603402c0238b3a7d8b0">LayerType::Subtraction</a>:</div>
-<div class="line"><a name="l00612"></a><span class="lineno"> 612</span>&#160; {</div>
-<div class="line"><a name="l00613"></a><span class="lineno"> 613</span>&#160; <span class="keyword">auto</span> subtractionQueueDescriptor = PolymorphicDowncast&lt;const SubtractionQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00614"></a><span class="lineno"> 614</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
-<div class="line"><a name="l00615"></a><span class="lineno"> 615</span>&#160; {</div>
-<div class="line"><a name="l00616"></a><span class="lineno"> 616</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSubtractionWorkload&lt;int32_t&gt;&gt;(*subtractionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 618</span>&#160; <span class="keywordflow">else</span></div>
-<div class="line"><a name="l00619"></a><span class="lineno"> 619</span>&#160; {</div>
-<div class="line"><a name="l00620"></a><span class="lineno"> 620</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSubtractionWorkload&lt;float&gt;&gt;(*subtractionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00621"></a><span class="lineno"> 621</span>&#160; }</div>
-<div class="line"><a name="l00622"></a><span class="lineno"> 622</span>&#160; }</div>
-<div class="line"><a name="l00623"></a><span class="lineno"> 623</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ac5457c5f3cfb4da8638ce7190f8e5152">LayerType::Tile</a>:</div>
-<div class="line"><a name="l00624"></a><span class="lineno"> 624</span>&#160; {</div>
-<div class="line"><a name="l00625"></a><span class="lineno"> 625</span>&#160; <span class="keyword">auto</span> tileQueueDescriptor = PolymorphicDowncast&lt;const TileQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00626"></a><span class="lineno"> 626</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTileWorkload&gt;(*tileQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00627"></a><span class="lineno"> 627</span>&#160; }</div>
-<div class="line"><a name="l00628"></a><span class="lineno"> 628</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aaf70b1ac863830a4e1ce6268c8399f54">LayerType::Transpose</a>:</div>
-<div class="line"><a name="l00629"></a><span class="lineno"> 629</span>&#160; {</div>
-<div class="line"><a name="l00630"></a><span class="lineno"> 630</span>&#160; <span class="keyword">auto</span> transposeQueueDescriptor = PolymorphicDowncast&lt;const TransposeQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00631"></a><span class="lineno"> 631</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#abcd0d843d5736b78740ae73249b6b977">IsQSymmS16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00513"></a><span class="lineno"> 513</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a3d504240723912bf9c76ff3afeaa25c5">IsBFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00514"></a><span class="lineno"> 514</span>&#160; {</div>
+<div class="line"><a name="l00515"></a><span class="lineno"> 515</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPermuteBFloat16Workload&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00516"></a><span class="lineno"> 516</span>&#160; }</div>
+<div class="line"><a name="l00517"></a><span class="lineno"> 517</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a47d136a5519331dee24f5e01b206ae7c">IsQAsymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00518"></a><span class="lineno"> 518</span>&#160; {</div>
+<div class="line"><a name="l00519"></a><span class="lineno"> 519</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPermuteQAsymmS8Workload&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00520"></a><span class="lineno"> 520</span>&#160; }</div>
+<div class="line"><a name="l00521"></a><span class="lineno"> 521</span>&#160; <span class="keywordflow">return</span> MakeWorkloadHelper&lt;<a class="code" href="namespacearmnn.html#ad1c0fb6bfa580b04574ab56971b6cbc6">RefPermuteFloat16Workload</a>, <a class="code" href="namespacearmnn.html#a54c3f7c7b9909e828a084f68dc78a031">RefPermuteFloat32Workload</a>, <a class="code" href="namespacearmnn.html#a50ffe5068ecb2fbf7f73b30ef0d753f8">RefPermuteQAsymm8Workload</a>,</div>
+<div class="line"><a name="l00522"></a><span class="lineno"> 522</span>&#160; <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>&gt;(*permuteQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 524</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ad662867a41bfb30b9f75dda2b5849001">LayerType::Pooling2d</a>:</div>
+<div class="line"><a name="l00525"></a><span class="lineno"> 525</span>&#160; {</div>
+<div class="line"><a name="l00526"></a><span class="lineno"> 526</span>&#160; <span class="keyword">auto</span> pooling2dQueueDescriptor = PolymorphicDowncast&lt;const Pooling2dQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00527"></a><span class="lineno"> 527</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPooling2dWorkload&gt;(*pooling2dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00528"></a><span class="lineno"> 528</span>&#160; }</div>
+<div class="line"><a name="l00529"></a><span class="lineno"> 529</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2b3140dc366b9fcd25ed786a79d1817c">LayerType::Pooling3d</a>:</div>
+<div class="line"><a name="l00530"></a><span class="lineno"> 530</span>&#160; {</div>
+<div class="line"><a name="l00531"></a><span class="lineno"> 531</span>&#160; <span class="keyword">auto</span> pooling3dQueueDescriptor = PolymorphicDowncast&lt;const Pooling3dQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00532"></a><span class="lineno"> 532</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPooling3dWorkload&gt;(*pooling3dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00533"></a><span class="lineno"> 533</span>&#160; }</div>
+<div class="line"><a name="l00534"></a><span class="lineno"> 534</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1ba143ebe524d46181a4b53470693278">LayerType::PreCompiled</a>:</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"> 536</span>&#160; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
+<div class="line"><a name="l00537"></a><span class="lineno"> 537</span>&#160; }</div>
+<div class="line"><a name="l00538"></a><span class="lineno"> 538</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a0c5967f09e0669c840ebb1ed0da85e32">LayerType::Prelu</a>:</div>
+<div class="line"><a name="l00539"></a><span class="lineno"> 539</span>&#160; {</div>
+<div class="line"><a name="l00540"></a><span class="lineno"> 540</span>&#160; <span class="keyword">auto</span> preluQueueDescriptor = PolymorphicDowncast&lt;const PreluQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00541"></a><span class="lineno"> 541</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefPreluWorkload&gt;(*preluQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a91880b71ea6d007439b7bc7c320b5c25">LayerType::QLstm</a>:</div>
+<div class="line"><a name="l00544"></a><span class="lineno"> 544</span>&#160; {</div>
+<div class="line"><a name="l00545"></a><span class="lineno"> 545</span>&#160; <span class="keyword">auto</span> qlstmQueueDescriptor = PolymorphicDowncast&lt;const QLstmQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00546"></a><span class="lineno"> 546</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefQLstmWorkload&gt;(*qlstmQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00547"></a><span class="lineno"> 547</span>&#160; }</div>
+<div class="line"><a name="l00548"></a><span class="lineno"> 548</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aca39930e22f40d10155a57dba32240bb">LayerType::Quantize</a>:</div>
+<div class="line"><a name="l00549"></a><span class="lineno"> 549</span>&#160; {</div>
+<div class="line"><a name="l00550"></a><span class="lineno"> 550</span>&#160; <span class="keyword">auto</span> quantizeQueueDescriptor = PolymorphicDowncast&lt;const QuantizeQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00551"></a><span class="lineno"> 551</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefQuantizeWorkload&gt;(*quantizeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00552"></a><span class="lineno"> 552</span>&#160; }</div>
+<div class="line"><a name="l00553"></a><span class="lineno"> 553</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a021da1b20f73dc252361a54d80497ef3">LayerType::Rank</a>:</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; <span class="keyword">auto</span> rankQueueDescriptor = PolymorphicDowncast&lt;const RankQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00556"></a><span class="lineno"> 556</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefRankWorkload&gt;(*rankQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00557"></a><span class="lineno"> 557</span>&#160; }</div>
+<div class="line"><a name="l00558"></a><span class="lineno"> 558</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aec4875f03ff0bb0b26cf76ac7f41e3c8">LayerType::Reduce</a>:</div>
+<div class="line"><a name="l00559"></a><span class="lineno"> 559</span>&#160; {</div>
+<div class="line"><a name="l00560"></a><span class="lineno"> 560</span>&#160; <span class="keyword">auto</span> reduceQueueDescriptor = PolymorphicDowncast&lt;const ReduceQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00561"></a><span class="lineno"> 561</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefReduceWorkload&gt;(*reduceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00562"></a><span class="lineno"> 562</span>&#160; }</div>
+<div class="line"><a name="l00563"></a><span class="lineno"> 563</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa7c59ccedc6a3bd90c17f3b990afefad">LayerType::Reshape</a>:</div>
+<div class="line"><a name="l00564"></a><span class="lineno"> 564</span>&#160; {</div>
+<div class="line"><a name="l00565"></a><span class="lineno"> 565</span>&#160; <span class="keyword">auto</span> reshapeQueueDescriptor = PolymorphicDowncast&lt;const ReshapeQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00566"></a><span class="lineno"> 566</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefReshapeWorkload&gt;(*reshapeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 568</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9d723d04c40bfd81835c0766a698cf63">LayerType::Resize</a>:</div>
+<div class="line"><a name="l00569"></a><span class="lineno"> 569</span>&#160; {</div>
+<div class="line"><a name="l00570"></a><span class="lineno"> 570</span>&#160; <span class="keyword">auto</span> resizeQueueDescriptor = PolymorphicDowncast&lt;const ResizeQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00571"></a><span class="lineno"> 571</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefResizeWorkload&gt;(*resizeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00572"></a><span class="lineno"> 572</span>&#160; }</div>
+<div class="line"><a name="l00573"></a><span class="lineno"> 573</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af9a0b6ef62dc10097826358e28b19295">LayerType::ReverseV2</a>:</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; <span class="keyword">auto</span> reverseV2QueueDescriptor = PolymorphicDowncast&lt;const ReverseV2QueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00576"></a><span class="lineno"> 576</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefReverseV2Workload&gt;(*reverseV2QueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00577"></a><span class="lineno"> 577</span>&#160; }</div>
+<div class="line"><a name="l00578"></a><span class="lineno"> 578</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a7401e8c502f3f7c3544e3f16bf3f488b">LayerType::ScatterNd</a>:</div>
+<div class="line"><a name="l00579"></a><span class="lineno"> 579</span>&#160; {</div>
+<div class="line"><a name="l00580"></a><span class="lineno"> 580</span>&#160; <span class="keyword">auto</span> scatterQueueDescriptor = PolymorphicDowncast&lt;const ScatterNdQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00581"></a><span class="lineno"> 581</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefScatterNdWorkload&gt;(*scatterQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00582"></a><span class="lineno"> 582</span>&#160; }</div>
+<div class="line"><a name="l00583"></a><span class="lineno"> 583</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a880c1273b27d27cfc82004c3a4b205c9">LayerType::Shape</a>:</div>
+<div class="line"><a name="l00584"></a><span class="lineno"> 584</span>&#160; {</div>
+<div class="line"><a name="l00585"></a><span class="lineno"> 585</span>&#160; <span class="keyword">auto</span> shapeQueueDescriptor = PolymorphicDowncast&lt;const ShapeQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00586"></a><span class="lineno"> 586</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefShapeWorkload&gt;(*shapeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00587"></a><span class="lineno"> 587</span>&#160; }</div>
+<div class="line"><a name="l00588"></a><span class="lineno"> 588</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ad140d37ad98c12ccd8e1c432f548bcdb">LayerType::Slice</a>:</div>
+<div class="line"><a name="l00589"></a><span class="lineno"> 589</span>&#160; {</div>
+<div class="line"><a name="l00590"></a><span class="lineno"> 590</span>&#160; <span class="keyword">auto</span> sliceQueueDescriptor = PolymorphicDowncast&lt;const SliceQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00591"></a><span class="lineno"> 591</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSliceWorkload&gt;(*sliceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a31d953b9d49a6b4378f45097047976d0">LayerType::Softmax</a>:</div>
+<div class="line"><a name="l00594"></a><span class="lineno"> 594</span>&#160; {</div>
+<div class="line"><a name="l00595"></a><span class="lineno"> 595</span>&#160; <span class="keyword">auto</span> softmaxQueueDescriptor = PolymorphicDowncast&lt;const SoftmaxQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00596"></a><span class="lineno"> 596</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSoftmaxWorkload&gt;(*softmaxQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00597"></a><span class="lineno"> 597</span>&#160; }</div>
+<div class="line"><a name="l00598"></a><span class="lineno"> 598</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a337c392144dca0d18290c6b4711a2279">LayerType::SpaceToBatchNd</a>:</div>
+<div class="line"><a name="l00599"></a><span class="lineno"> 599</span>&#160; {</div>
+<div class="line"><a name="l00600"></a><span class="lineno"> 600</span>&#160; <span class="keyword">auto</span> spaceToBatchNdQueueDescriptor</div>
+<div class="line"><a name="l00601"></a><span class="lineno"> 601</span>&#160; = PolymorphicDowncast&lt;const SpaceToBatchNdQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00602"></a><span class="lineno"> 602</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSpaceToBatchNdWorkload&gt;(*spaceToBatchNdQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00603"></a><span class="lineno"> 603</span>&#160; }</div>
+<div class="line"><a name="l00604"></a><span class="lineno"> 604</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a5e7ff12da912dc79e7e547281823fa4a">LayerType::SpaceToDepth</a>:</div>
+<div class="line"><a name="l00605"></a><span class="lineno"> 605</span>&#160; {</div>
+<div class="line"><a name="l00606"></a><span class="lineno"> 606</span>&#160; <span class="keyword">auto</span> spaceToDepthQueueDescriptor = PolymorphicDowncast&lt;const SpaceToDepthQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00607"></a><span class="lineno"> 607</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSpaceToDepthWorkload&gt;(*spaceToDepthQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a41cb9b797ebc6f6f6314e3ded935f4cf">LayerType::Splitter</a>:</div>
+<div class="line"><a name="l00610"></a><span class="lineno"> 610</span>&#160; {</div>
+<div class="line"><a name="l00611"></a><span class="lineno"> 611</span>&#160; <span class="keyword">auto</span> splitterQueueDescriptor = PolymorphicDowncast&lt;const SplitterQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00612"></a><span class="lineno"> 612</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSplitterWorkload&gt;(*splitterQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00613"></a><span class="lineno"> 613</span>&#160; }</div>
+<div class="line"><a name="l00614"></a><span class="lineno"> 614</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2187e1021a911b3807cc1bea2eb1a9ca">LayerType::Stack</a>:</div>
+<div class="line"><a name="l00615"></a><span class="lineno"> 615</span>&#160; {</div>
+<div class="line"><a name="l00616"></a><span class="lineno"> 616</span>&#160; <span class="keyword">auto</span> stackQueueDescriptor = PolymorphicDowncast&lt;const StackQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00617"></a><span class="lineno"> 617</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefStackWorkload&gt;(*stackQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00618"></a><span class="lineno"> 618</span>&#160; }</div>
+<div class="line"><a name="l00619"></a><span class="lineno"> 619</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa31904f2b3479b5a00137fd985974b4d">LayerType::StridedSlice</a>:</div>
+<div class="line"><a name="l00620"></a><span class="lineno"> 620</span>&#160; {</div>
+<div class="line"><a name="l00621"></a><span class="lineno"> 621</span>&#160; <span class="keyword">auto</span> stridedSliceQueueDescriptor = PolymorphicDowncast&lt;const StridedSliceQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00622"></a><span class="lineno"> 622</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefStridedSliceWorkload&gt;(*stridedSliceQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00623"></a><span class="lineno"> 623</span>&#160; }</div>
+<div class="line"><a name="l00624"></a><span class="lineno"> 624</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a6eb8b8b560161603402c0238b3a7d8b0">LayerType::Subtraction</a>:</div>
+<div class="line"><a name="l00625"></a><span class="lineno"> 625</span>&#160; {</div>
+<div class="line"><a name="l00626"></a><span class="lineno"> 626</span>&#160; <span class="keyword">auto</span> subtractionQueueDescriptor = PolymorphicDowncast&lt;const SubtractionQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00627"></a><span class="lineno"> 627</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>.m_InputTensorInfos[0].GetDataType() == <a class="code" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a>)</div>
+<div class="line"><a name="l00628"></a><span class="lineno"> 628</span>&#160; {</div>
+<div class="line"><a name="l00629"></a><span class="lineno"> 629</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSubtractionWorkload&lt;int32_t&gt;&gt;(*subtractionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00630"></a><span class="lineno"> 630</span>&#160; }</div>
+<div class="line"><a name="l00631"></a><span class="lineno"> 631</span>&#160; <span class="keywordflow">else</span></div>
<div class="line"><a name="l00632"></a><span class="lineno"> 632</span>&#160; {</div>
-<div class="line"><a name="l00633"></a><span class="lineno"> 633</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeQSymm16Workload&gt;(*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00633"></a><span class="lineno"> 633</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefSubtractionWorkload&lt;float&gt;&gt;(*subtractionQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a3d504240723912bf9c76ff3afeaa25c5">IsBFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
-<div class="line"><a name="l00636"></a><span class="lineno"> 636</span>&#160; {</div>
-<div class="line"><a name="l00637"></a><span class="lineno"> 637</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeBFloat16Workload&gt;(*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00638"></a><span class="lineno"> 638</span>&#160; }</div>
-<div class="line"><a name="l00639"></a><span class="lineno"> 639</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a47d136a5519331dee24f5e01b206ae7c">IsQAsymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
-<div class="line"><a name="l00640"></a><span class="lineno"> 640</span>&#160; {</div>
-<div class="line"><a name="l00641"></a><span class="lineno"> 641</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeQAsymmS8Workload&gt;(*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00642"></a><span class="lineno"> 642</span>&#160; }</div>
-<div class="line"><a name="l00643"></a><span class="lineno"> 643</span>&#160; <span class="keywordflow">return</span> MakeWorkloadHelper&lt;<a class="code" href="namespacearmnn.html#aefcfe4efab61267262d1e02cb8af739d">RefTransposeFloat16Workload</a>, <a class="code" href="namespacearmnn.html#ad67165b4639bd5e50e5bc4538d226b35">RefTransposeFloat32Workload</a>,</div>
-<div class="line"><a name="l00644"></a><span class="lineno"> 644</span>&#160; <a class="code" href="namespacearmnn.html#a1d13693cba12d3e406454b852527fb37">RefTransposeQAsymm8Workload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>&gt;</div>
-<div class="line"><a name="l00645"></a><span class="lineno"> 645</span>&#160; (*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00646"></a><span class="lineno"> 646</span>&#160; }</div>
-<div class="line"><a name="l00647"></a><span class="lineno"> 647</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a71b23d26c0f5d20416d6c77754f9806a">LayerType::TransposeConvolution2d</a>:</div>
-<div class="line"><a name="l00648"></a><span class="lineno"> 648</span>&#160; {</div>
-<div class="line"><a name="l00649"></a><span class="lineno"> 649</span>&#160; <span class="keyword">auto</span> transposeConvolution2dQueueDescriptor</div>
-<div class="line"><a name="l00650"></a><span class="lineno"> 650</span>&#160; = PolymorphicDowncast&lt;const TransposeConvolution2dQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00651"></a><span class="lineno"> 651</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeConvolution2dWorkload&gt;(*transposeConvolution2dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
-<div class="line"><a name="l00652"></a><span class="lineno"> 652</span>&#160; }</div>
-<div class="line"><a name="l00653"></a><span class="lineno"> 653</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a300124b2433e0376ec4b19251ac3a9e5">LayerType::UnidirectionalSequenceLstm</a>:</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"> 655</span>&#160; <span class="keyword">auto</span> unidirectionalSequenceLstmQueueDescriptor</div>
-<div class="line"><a name="l00656"></a><span class="lineno"> 656</span>&#160; = PolymorphicDowncast&lt;const UnidirectionalSequenceLstmQueueDescriptor*&gt;(&amp;descriptor);</div>
-<div class="line"><a name="l00657"></a><span class="lineno"> 657</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefUnidirectionalSequenceLstmWorkload&gt;(*unidirectionalSequenceLstmQueueDescriptor,</div>
-<div class="line"><a name="l00658"></a><span class="lineno"> 658</span>&#160; <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</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"> 636</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ac5457c5f3cfb4da8638ce7190f8e5152">LayerType::Tile</a>:</div>
+<div class="line"><a name="l00637"></a><span class="lineno"> 637</span>&#160; {</div>
+<div class="line"><a name="l00638"></a><span class="lineno"> 638</span>&#160; <span class="keyword">auto</span> tileQueueDescriptor = PolymorphicDowncast&lt;const TileQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00639"></a><span class="lineno"> 639</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTileWorkload&gt;(*tileQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00640"></a><span class="lineno"> 640</span>&#160; }</div>
+<div class="line"><a name="l00641"></a><span class="lineno"> 641</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aaf70b1ac863830a4e1ce6268c8399f54">LayerType::Transpose</a>:</div>
+<div class="line"><a name="l00642"></a><span class="lineno"> 642</span>&#160; {</div>
+<div class="line"><a name="l00643"></a><span class="lineno"> 643</span>&#160; <span class="keyword">auto</span> transposeQueueDescriptor = PolymorphicDowncast&lt;const TransposeQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00644"></a><span class="lineno"> 644</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#abcd0d843d5736b78740ae73249b6b977">IsQSymmS16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</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"> 646</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeQSymm16Workload&gt;(*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00647"></a><span class="lineno"> 647</span>&#160; }</div>
+<div class="line"><a name="l00648"></a><span class="lineno"> 648</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a3d504240723912bf9c76ff3afeaa25c5">IsBFloat16</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</div>
+<div class="line"><a name="l00649"></a><span class="lineno"> 649</span>&#160; {</div>
+<div class="line"><a name="l00650"></a><span class="lineno"> 650</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeBFloat16Workload&gt;(*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00651"></a><span class="lineno"> 651</span>&#160; }</div>
+<div class="line"><a name="l00652"></a><span class="lineno"> 652</span>&#160; <span class="keywordflow">else</span> <span class="keywordflow">if</span> (<a class="code" href="namespacearmnn.html#a47d136a5519331dee24f5e01b206ae7c">IsQAsymmS8</a>(<a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>))</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; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeQAsymmS8Workload&gt;(*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00655"></a><span class="lineno"> 655</span>&#160; }</div>
+<div class="line"><a name="l00656"></a><span class="lineno"> 656</span>&#160; <span class="keywordflow">return</span> MakeWorkloadHelper&lt;<a class="code" href="namespacearmnn.html#aefcfe4efab61267262d1e02cb8af739d">RefTransposeFloat16Workload</a>, <a class="code" href="namespacearmnn.html#ad67165b4639bd5e50e5bc4538d226b35">RefTransposeFloat32Workload</a>,</div>
+<div class="line"><a name="l00657"></a><span class="lineno"> 657</span>&#160; <a class="code" href="namespacearmnn.html#a1d13693cba12d3e406454b852527fb37">RefTransposeQAsymm8Workload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>, <a class="code" href="classarmnn_1_1_null_workload.html">NullWorkload</a>&gt;</div>
+<div class="line"><a name="l00658"></a><span class="lineno"> 658</span>&#160; (*transposeQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
<div class="line"><a name="l00659"></a><span class="lineno"> 659</span>&#160; }</div>
-<div class="line"><a name="l00660"></a><span class="lineno"> 660</span>&#160; <span class="keywordflow">default</span>:</div>
-<div class="line"><a name="l00661"></a><span class="lineno"> 661</span>&#160; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</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"> 663</span>&#160;}</div>
-<div class="line"><a name="l00664"></a><span class="lineno"> 664</span>&#160; </div>
-<div class="line"><a name="l00665"></a><span class="lineno"> 665</span>&#160;} <span class="comment">// namespace armnn</span></div>
+<div class="line"><a name="l00660"></a><span class="lineno"> 660</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a71b23d26c0f5d20416d6c77754f9806a">LayerType::TransposeConvolution2d</a>:</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; <span class="keyword">auto</span> transposeConvolution2dQueueDescriptor</div>
+<div class="line"><a name="l00663"></a><span class="lineno"> 663</span>&#160; = PolymorphicDowncast&lt;const TransposeConvolution2dQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00664"></a><span class="lineno"> 664</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefTransposeConvolution2dWorkload&gt;(*transposeConvolution2dQueueDescriptor, <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00665"></a><span class="lineno"> 665</span>&#160; }</div>
+<div class="line"><a name="l00666"></a><span class="lineno"> 666</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a300124b2433e0376ec4b19251ac3a9e5">LayerType::UnidirectionalSequenceLstm</a>:</div>
+<div class="line"><a name="l00667"></a><span class="lineno"> 667</span>&#160; {</div>
+<div class="line"><a name="l00668"></a><span class="lineno"> 668</span>&#160; <span class="keyword">auto</span> unidirectionalSequenceLstmQueueDescriptor</div>
+<div class="line"><a name="l00669"></a><span class="lineno"> 669</span>&#160; = PolymorphicDowncast&lt;const UnidirectionalSequenceLstmQueueDescriptor*&gt;(&amp;descriptor);</div>
+<div class="line"><a name="l00670"></a><span class="lineno"> 670</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;RefUnidirectionalSequenceLstmWorkload&gt;(*unidirectionalSequenceLstmQueueDescriptor,</div>
+<div class="line"><a name="l00671"></a><span class="lineno"> 671</span>&#160; <a class="code" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">info</a>);</div>
+<div class="line"><a name="l00672"></a><span class="lineno"> 672</span>&#160; }</div>
+<div class="line"><a name="l00673"></a><span class="lineno"> 673</span>&#160; <span class="keywordflow">default</span>:</div>
+<div class="line"><a name="l00674"></a><span class="lineno"> 674</span>&#160; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
+<div class="line"><a name="l00675"></a><span class="lineno"> 675</span>&#160; }</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"> 678</span>&#160;} <span class="comment">// namespace armnn</span></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a5e7ff12da912dc79e7e547281823fa4a"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a5e7ff12da912dc79e7e547281823fa4a">armnn::LayerType::SpaceToDepth</a></div><div class="ttdeci">@ SpaceToDepth</div></div>
@@ -782,7 +795,7 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4aaf70b1ac863830a4e1ce6268c8399f54"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aaf70b1ac863830a4e1ce6268c8399f54">armnn::LayerType::Transpose</a></div><div class="ttdeci">@ Transpose</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4af6c0e3a1c3cfabd32ae8d3ae741fcf0a"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af6c0e3a1c3cfabd32ae8d3ae741fcf0a">armnn::LayerType::Comparison</a></div><div class="ttdeci">@ Comparison</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4aa31904f2b3479b5a00137fd985974b4d"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa31904f2b3479b5a00137fd985974b4d">armnn::LayerType::StridedSlice</a></div><div class="ttdeci">@ StridedSlice</div></div>
-<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_ae2cd7e29596b68884bfaade25f8f0dc0"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#ae2cd7e29596b68884bfaade25f8f0dc0">armnn::RefWorkloadFactory::GetBackendId</a></div><div class="ttdeci">const BackendId &amp; GetBackendId() const override</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00091">RefWorkloadFactory.cpp:91</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_ae2cd7e29596b68884bfaade25f8f0dc0"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#ae2cd7e29596b68884bfaade25f8f0dc0">armnn::RefWorkloadFactory::GetBackendId</a></div><div class="ttdeci">const BackendId &amp; GetBackendId() const override</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00095">RefWorkloadFactory.cpp:95</a></div></div>
<div class="ttc" id="anamespacearmnn_html_ae7d50846b2769f81521af24d063bc093"><div class="ttname"><a href="namespacearmnn.html#ae7d50846b2769f81521af24d063bc093">armnn::RefBackendId</a></div><div class="ttdeci">constexpr const char * RefBackendId()</div><div class="ttdef"><b>Definition:</b> <a href="_ref_backend_id_8hpp_source.html#l00010">RefBackendId.hpp:10</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4ac5457c5f3cfb4da8638ce7190f8e5152"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ac5457c5f3cfb4da8638ce7190f8e5152">armnn::LayerType::Tile</a></div><div class="ttdeci">@ Tile</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a2187e1021a911b3807cc1bea2eb1a9ca"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2187e1021a911b3807cc1bea2eb1a9ca">armnn::LayerType::Stack</a></div><div class="ttdeci">@ Stack</div></div>
@@ -803,6 +816,7 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
<div class="ttc" id="anamespacearmnn_html_a1cfaa710db2a54673b21d2ea2da757c8a2a25ebd8c909241e3f7818389b804ecc"><div class="ttname"><a href="namespacearmnn.html#a1cfaa710db2a54673b21d2ea2da757c8a2a25ebd8c909241e3f7818389b804ecc">armnn::UnaryOperation::LogicalNot</a></div><div class="ttdeci">@ LogicalNot</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a6eb8b8b560161603402c0238b3a7d8b0"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a6eb8b8b560161603402c0238b3a7d8b0">armnn::LayerType::Subtraction</a></div><div class="ttdeci">@ Subtraction</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a0c5967f09e0669c840ebb1ed0da85e32"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a0c5967f09e0669c840ebb1ed0da85e32">armnn::LayerType::Prelu</a></div><div class="ttdeci">@ Prelu</div></div>
+<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a7401e8c502f3f7c3544e3f16bf3f488b"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a7401e8c502f3f7c3544e3f16bf3f488b">armnn::LayerType::ScatterNd</a></div><div class="ttdeci">@ ScatterNd</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4af4f53c8297dc1cb53d4e6f8151070a30"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af4f53c8297dc1cb53d4e6f8151070a30">armnn::LayerType::LogicalBinary</a></div><div class="ttdeci">@ LogicalBinary</div></div>
<div class="ttc" id="anamespacearmnn_html_a37c36bbf668cd8a0d7dcd731c9b591d7"><div class="ttname"><a href="namespacearmnn.html#a37c36bbf668cd8a0d7dcd731c9b591d7">armnn::IsQAsymmU8</a></div><div class="ttdeci">bool IsQAsymmU8(const WorkloadInfo &amp;info)</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00076">RefWorkloadFactory.cpp:76</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4ae20f0f2826a6549809f050b86274567f"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ae20f0f2826a6549809f050b86274567f">armnn::LayerType::Concat</a></div><div class="ttdeci">@ Concat</div></div>
@@ -813,7 +827,7 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
<div class="ttc" id="aclassarmnn_1_1_invalid_argument_exception_html"><div class="ttname"><a href="classarmnn_1_1_invalid_argument_exception.html">armnn::InvalidArgumentException</a></div><div class="ttdef"><b>Definition:</b> <a href="_exceptions_8hpp_source.html#l00080">Exceptions.hpp:80</a></div></div>
<div class="ttc" id="anamespacearmnn_html_aefcfe4efab61267262d1e02cb8af739d"><div class="ttname"><a href="namespacearmnn.html#aefcfe4efab61267262d1e02cb8af739d">armnn::RefTransposeFloat16Workload</a></div><div class="ttdeci">RefTransposeWorkload&lt; DataType::Float16 &gt; RefTransposeFloat16Workload</div><div class="ttdef"><b>Definition:</b> <a href="_ref_transpose_workload_8hpp_source.html#l00028">RefTransposeWorkload.hpp:28</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4aca39930e22f40d10155a57dba32240bb"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aca39930e22f40d10155a57dba32240bb">armnn::LayerType::Quantize</a></div><div class="ttdeci">@ Quantize</div></div>
-<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a26b27b4f789cfda06b8843e5dea361b4"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4">armnn::RefWorkloadFactory::RefWorkloadFactory</a></div><div class="ttdeci">RefWorkloadFactory()</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00086">RefWorkloadFactory.cpp:86</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a26b27b4f789cfda06b8843e5dea361b4"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a26b27b4f789cfda06b8843e5dea361b4">armnn::RefWorkloadFactory::RefWorkloadFactory</a></div><div class="ttdeci">RefWorkloadFactory()</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00090">RefWorkloadFactory.cpp:90</a></div></div>
<div class="ttc" id="astructarmnn_1_1_queue_descriptor_html"><div class="ttname"><a href="structarmnn_1_1_queue_descriptor.html">armnn::QueueDescriptor</a></div><div class="ttdef"><b>Definition:</b> <a href="_workload_data_8hpp_source.html#l00024">WorkloadData.hpp:24</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a27d1a1f7b7c2180e5b20ce9e3d00e2dd"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a27d1a1f7b7c2180e5b20ce9e3d00e2dd">armnn::LayerType::Multiplication</a></div><div class="ttdeci">@ Multiplication</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a7c5531bbefed0945814f874baf9e0e0f"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a7c5531bbefed0945814f874baf9e0e0f">armnn::LayerType::Addition</a></div><div class="ttdeci">@ Addition</div></div>
@@ -824,24 +838,25 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a1db19222ac424bd7162142ddf929fd2a"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1db19222ac424bd7162142ddf929fd2a">armnn::LayerType::DetectionPostProcess</a></div><div class="ttdeci">@ DetectionPostProcess</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a115bfc5d633eae55c67f9588acdd2bf9"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a115bfc5d633eae55c67f9588acdd2bf9">armnn::LayerType::MemImport</a></div><div class="ttdeci">@ MemImport</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4ad662867a41bfb30b9f75dda2b5849001"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ad662867a41bfb30b9f75dda2b5849001">armnn::LayerType::Pooling2d</a></div><div class="ttdeci">@ Pooling2d</div></div>
-<div class="ttc" id="aclassarmnn_1_1_i_workload_factory_html_a74dc9ec1a223eab8b072368b2dacee87"><div class="ttname"><a href="classarmnn_1_1_i_workload_factory.html#a74dc9ec1a223eab8b072368b2dacee87">armnn::IWorkloadFactory::IsLayerSupported</a></div><div class="ttdeci">static bool IsLayerSupported(const BackendId &amp;backendId, const IConnectableLayer &amp;layer, Optional&lt; DataType &gt; dataType, std::string &amp;outReasonIfUnsupported)</div><div class="ttdef"><b>Definition:</b> <a href="_workload_factory_8cpp_source.html#l01614">WorkloadFactory.cpp:1614</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_i_workload_factory_html_a74dc9ec1a223eab8b072368b2dacee87"><div class="ttname"><a href="classarmnn_1_1_i_workload_factory.html#a74dc9ec1a223eab8b072368b2dacee87">armnn::IWorkloadFactory::IsLayerSupported</a></div><div class="ttdeci">static bool IsLayerSupported(const BackendId &amp;backendId, const IConnectableLayer &amp;layer, Optional&lt; DataType &gt; dataType, std::string &amp;outReasonIfUnsupported)</div><div class="ttdef"><b>Definition:</b> <a href="_workload_factory_8cpp_source.html#l01629">WorkloadFactory.cpp:1629</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a3025cdaab2deb0bb2cd642449e570833"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3025cdaab2deb0bb2cd642449e570833">armnn::LayerType::Division</a></div><div class="ttdeci">@ Division</div></div>
<div class="ttc" id="anamespacearmnn_html_ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7"><div class="ttname"><a href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6accedffbc6e5308e33d3843e8bdc0dad7">armnn::DataType::Signed32</a></div><div class="ttdeci">@ Signed32</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a880c1273b27d27cfc82004c3a4b205c9"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a880c1273b27d27cfc82004c3a4b205c9">armnn::LayerType::Shape</a></div><div class="ttdeci">@ Shape</div></div>
<div class="ttc" id="a_mem_import_workload_8hpp_html"><div class="ttname"><a href="_mem_import_workload_8hpp.html">MemImportWorkload.hpp</a></div></div>
-<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a739bcc341b89c98a5d38717370ebcaa6"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6">armnn::RefWorkloadFactory::CreateWorkload</a></div><div class="ttdeci">std::unique_ptr&lt; IWorkload &gt; CreateWorkload(LayerType type, const QueueDescriptor &amp;descriptor, const WorkloadInfo &amp;info) const override</div><div class="ttdoc">Backends should implement their own CreateWorkload function with a switch statement.</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00142">RefWorkloadFactory.cpp:142</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a739bcc341b89c98a5d38717370ebcaa6"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6">armnn::RefWorkloadFactory::CreateWorkload</a></div><div class="ttdeci">std::unique_ptr&lt; IWorkload &gt; CreateWorkload(LayerType type, const QueueDescriptor &amp;descriptor, const WorkloadInfo &amp;info) const override</div><div class="ttdoc">Backends should implement their own CreateWorkload function with a switch statement.</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00146">RefWorkloadFactory.cpp:146</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4acab78faff25393e9defd1911cb58133e"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acab78faff25393e9defd1911cb58133e">armnn::LayerType::FullyConnected</a></div><div class="ttdeci">@ FullyConnected</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4aad22c799930d644e8468fe44c0312d53"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aad22c799930d644e8468fe44c0312d53">armnn::LayerType::Gather</a></div><div class="ttdeci">@ Gather</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a2b3140dc366b9fcd25ed786a79d1817c"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a2b3140dc366b9fcd25ed786a79d1817c">armnn::LayerType::Pooling3d</a></div><div class="ttdeci">@ Pooling3d</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4ac21dbda57d88c21ec9857f5d1522c488"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4ac21dbda57d88c21ec9857f5d1522c488">armnn::LayerType::LogSoftmax</a></div><div class="ttdeci">@ LogSoftmax</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a9882ff3cfed27d6161c20a305e7a3484"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9882ff3cfed27d6161c20a305e7a3484">armnn::LayerType::BatchMatMul</a></div><div class="ttdeci">@ BatchMatMul</div></div>
<div class="ttc" id="a_ref_workload_factory_8hpp_html"><div class="ttname"><a href="_ref_workload_factory_8hpp.html">RefWorkloadFactory.hpp</a></div></div>
+<div class="ttc" id="anamespacearmnn_html_abe95e2847292413f6dc71c21dabce181"><div class="ttname"><a href="namespacearmnn.html#abe95e2847292413f6dc71c21dabce181">armnn::IsBoolean</a></div><div class="ttdeci">bool IsBoolean(const WorkloadInfo &amp;info)</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00080">RefWorkloadFactory.cpp:80</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4af97adbfc88b7012a0243215b1076e7e7"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4af97adbfc88b7012a0243215b1076e7e7">armnn::LayerType::DepthwiseConvolution2d</a></div><div class="ttdeci">@ DepthwiseConvolution2d</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a4cd9f3996d60790cd11c04f842ebc43c"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4cd9f3996d60790cd11c04f842ebc43c">armnn::LayerType::Cast</a></div><div class="ttdeci">@ Cast</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a6ee06c6045d0c5b6565a247955ef0fc2"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a6ee06c6045d0c5b6565a247955ef0fc2">armnn::LayerType::BatchToSpaceNd</a></div><div class="ttdeci">@ BatchToSpaceNd</div></div>
<div class="ttc" id="anamespacearmnn_html_a50ffe5068ecb2fbf7f73b30ef0d753f8"><div class="ttname"><a href="namespacearmnn.html#a50ffe5068ecb2fbf7f73b30ef0d753f8">armnn::RefPermuteQAsymm8Workload</a></div><div class="ttdeci">RefPermuteWorkload&lt; DataType::QAsymmU8 &gt; RefPermuteQAsymm8Workload</div><div class="ttdef"><b>Definition:</b> <a href="_ref_permute_workload_8hpp_source.html#l00031">RefPermuteWorkload.hpp:31</a></div></div>
<div class="ttc" id="a_tensor_handle_8hpp_html"><div class="ttname"><a href="_tensor_handle_8hpp.html">TensorHandle.hpp</a></div></div>
-<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a7239477811c44d4398f0c2d291d9ea76"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76">armnn::RefWorkloadFactory::CreateTensorHandle</a></div><div class="ttdeci">std::unique_ptr&lt; ITensorHandle &gt; CreateTensorHandle(const TensorInfo &amp;tensorInfo, const bool IsMemoryManaged=true) const override</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00111">RefWorkloadFactory.cpp:111</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a7239477811c44d4398f0c2d291d9ea76"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76">armnn::RefWorkloadFactory::CreateTensorHandle</a></div><div class="ttdeci">std::unique_ptr&lt; ITensorHandle &gt; CreateTensorHandle(const TensorInfo &amp;tensorInfo, const bool IsMemoryManaged=true) const override</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00115">RefWorkloadFactory.cpp:115</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4aa7c59ccedc6a3bd90c17f3b990afefad"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4aa7c59ccedc6a3bd90c17f3b990afefad">armnn::LayerType::Reshape</a></div><div class="ttdeci">@ Reshape</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a337c392144dca0d18290c6b4711a2279"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a337c392144dca0d18290c6b4711a2279">armnn::LayerType::SpaceToBatchNd</a></div><div class="ttdeci">@ SpaceToBatchNd</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4adb3e3f51c9107e26c9bccf9a188ce2ed"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4adb3e3f51c9107e26c9bccf9a188ce2ed">armnn::LayerType::Fill</a></div><div class="ttdeci">@ Fill</div></div>
@@ -868,7 +883,7 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a324118a6721dd6b8a9b9f4e327df2bf5"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a324118a6721dd6b8a9b9f4e327df2bf5">armnn::LayerType::Input</a></div><div class="ttdeci">@ Input</div></div>
<div class="ttc" id="anamespacearmnn_html_a5b6893cda5b69359a4244c06054da18f"><div class="ttname"><a href="namespacearmnn.html#a5b6893cda5b69359a4244c06054da18f">armnn::ModelOptions</a></div><div class="ttdeci">std::vector&lt; BackendOptions &gt; ModelOptions</div><div class="ttdef"><b>Definition:</b> <a href="_backend_options_8hpp_source.html#l00018">BackendOptions.hpp:18</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a9d723d04c40bfd81835c0766a698cf63"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a9d723d04c40bfd81835c0766a698cf63">armnn::LayerType::Resize</a></div><div class="ttdeci">@ Resize</div></div>
-<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a9992ea7c353e8597fbd8ae426f4612ae"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae">armnn::RefWorkloadFactory::IsLayerSupported</a></div><div class="ttdeci">static bool IsLayerSupported(const Layer &amp;layer, Optional&lt; DataType &gt; dataType, std::string &amp;outReasonIfUnsupported)</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00096">RefWorkloadFactory.cpp:96</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_ref_workload_factory_html_a9992ea7c353e8597fbd8ae426f4612ae"><div class="ttname"><a href="classarmnn_1_1_ref_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae">armnn::RefWorkloadFactory::IsLayerSupported</a></div><div class="ttdeci">static bool IsLayerSupported(const Layer &amp;layer, Optional&lt; DataType &gt; dataType, std::string &amp;outReasonIfUnsupported)</div><div class="ttdef"><b>Definition:</b> <a href="_ref_workload_factory_8cpp_source.html#l00100">RefWorkloadFactory.cpp:100</a></div></div>
<div class="ttc" id="a_ref_tensor_handle_8hpp_html"><div class="ttname"><a href="_ref_tensor_handle_8hpp.html">RefTensorHandle.hpp</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4adb033d2f81b68f9a17e8f62de69fed4a"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4adb033d2f81b68f9a17e8f62de69fed4a">armnn::LayerType::Convolution2d</a></div><div class="ttdeci">@ Convolution2d</div></div>
<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a3489c7b05e180496cb2ce8ac73887f48"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a3489c7b05e180496cb2ce8ac73887f48">armnn::LayerType::FakeQuantization</a></div><div class="ttdeci">@ FakeQuantization</div></div>
@@ -888,7 +903,7 @@ $(document).ready(function(){initNavTree('_ref_workload_factory_8cpp_source.html
<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_efae4012d0e357ebeaba7d02491d70e5.html">reference</a></li><li class="navelem"><a class="el" href="_ref_workload_factory_8cpp.html">RefWorkloadFactory.cpp</a></li>
- <li class="footer">Generated on Wed Feb 14 2024 16:36:16 for Arm NN by
+ <li class="footer">Generated on Thu May 16 2024 09:31:48 for Arm NN by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.17 </li>
</ul>