IVGCVSW-7968 Update Doxygen docu for 24.02
Signed-off-by: Nikhil Raj <nikhil.raj@arm.com>
Change-Id: I8c1e45815c6cf78f80d6f2c0959a5bbba6cd11de
diff --git a/latest/classarmnn_1_1_gpu_fsa_workload_factory.html b/latest/classarmnn_1_1_gpu_fsa_workload_factory.html
new file mode 100644
index 0000000..74d8a0c
--- /dev/null
+++ b/latest/classarmnn_1_1_gpu_fsa_workload_factory.html
@@ -0,0 +1,648 @@
+<!-- HTML header for doxygen 1.8.17-->
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+<head>
+<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
+<meta http-equiv="X-UA-Compatible" content="IE=9"/>
+<meta name="generator" content="Doxygen 1.8.17"/>
+<meta name="viewport" content="width=device-width, initial-scale=1"/>
+<title>Arm NN: GpuFsaWorkloadFactory Class Reference</title>
+<link href="tabs.css" rel="stylesheet" type="text/css"/>
+<script type="text/javascript" src="jquery.js"></script>
+<script type="text/javascript" src="dynsections.js"></script>
+<link href="navtree.css" rel="stylesheet" type="text/css"/>
+<script type="text/javascript" src="resize.js"></script>
+<script type="text/javascript" src="navtreedata.js"></script>
+<script type="text/javascript" src="navtree.js"></script>
+<link href="search/search.css" rel="stylesheet" type="text/css"/>
+<script type="text/javascript" src="search/searchdata.js"></script>
+<script type="text/javascript" src="search/search.js"></script>
+<script type="text/x-mathjax-config">
+ MathJax.Hub.Config({
+ extensions: ["tex2jax.js"],
+ jax: ["input/TeX","output/HTML-CSS"],
+});
+</script>
+<script type="text/javascript" async="async" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js"></script>
+<link href="doxygen.css" rel="stylesheet" type="text/css" />
+<link href="customdoxygen.css" rel="stylesheet" type="text/css"/>
+</head>
+<body>
+<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
+<div id="titlearea">
+<table cellspacing="0" cellpadding="0">
+ <tbody>
+ <tr style="height: 56px;">
+ <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">
+  <span id="projectnumber">24.02</span>
+ </div>
+ </td>
+ </tr>
+ </tbody>
+</table>
+</div>
+<!-- end header part -->
+<!-- Generated by Doxygen 1.8.17 -->
+<script type="text/javascript">
+/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
+var searchBox = new SearchBox("searchBox", "search",false,'Search');
+/* @license-end */
+</script>
+<script type="text/javascript" src="menudata.js"></script>
+<script type="text/javascript" src="menu.js"></script>
+<script type="text/javascript">
+/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
+$(function() {
+ initMenu('',true,false,'search.php','Search');
+ $(document).ready(function() { init_search(); });
+});
+/* @license-end */</script>
+<div id="main-nav"></div>
+</div><!-- top -->
+<div id="side-nav" class="ui-resizable side-nav-resizable">
+ <div id="nav-tree">
+ <div id="nav-tree-contents">
+ <div id="nav-sync" class="sync"></div>
+ </div>
+ </div>
+ <div id="splitbar" style="-moz-user-select:none;"
+ class="ui-resizable-handle">
+ </div>
+</div>
+<script type="text/javascript">
+/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
+$(document).ready(function(){initNavTree('classarmnn_1_1_gpu_fsa_workload_factory.html',''); initResizable(); });
+/* @license-end */
+</script>
+<div id="doc-content">
+<!-- window showing the filter options -->
+<div id="MSearchSelectWindow"
+ onmouseover="return searchBox.OnSearchSelectShow()"
+ onmouseout="return searchBox.OnSearchSelectHide()"
+ onkeydown="return searchBox.OnSearchSelectKey(event)">
+</div>
+
+<!-- iframe showing the search results (closed by default) -->
+<div id="MSearchResultsWindow">
+<iframe src="javascript:void(0)" frameborder="0"
+ name="MSearchResults" id="MSearchResults">
+</iframe>
+</div>
+
+<div class="header">
+ <div class="summary">
+<a href="#pub-methods">Public Member Functions</a> |
+<a href="#pub-static-methods">Static Public Member Functions</a> |
+<a href="classarmnn_1_1_gpu_fsa_workload_factory-members.html">List of all members</a> </div>
+ <div class="headertitle">
+<div class="title">GpuFsaWorkloadFactory Class Reference</div> </div>
+</div><!--header-->
+<div class="contents">
+
+<p><code>#include <<a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a>></code></p>
+<div class="dynheader">
+Inheritance diagram for GpuFsaWorkloadFactory:</div>
+<div class="dyncontent">
+<div class="center"><iframe scrolling="no" frameborder="0" src="classarmnn_1_1_gpu_fsa_workload_factory__inherit__graph.svg" width="190" height="112"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
+</div>
+<center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div>
+<div class="dynheader">
+Collaboration diagram for GpuFsaWorkloadFactory:</div>
+<div class="dyncontent">
+<div class="center"><iframe scrolling="no" frameborder="0" src="classarmnn_1_1_gpu_fsa_workload_factory__coll__graph.svg" width="190" height="112"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
+</div>
+<center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div>
+<table class="memberdecls">
+<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
+Public Member Functions</h2></td></tr>
+<tr class="memitem:a953af2bf56c098c0091e6fcded570181"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a953af2bf56c098c0091e6fcded570181">GpuFsaWorkloadFactory</a> (const std::shared_ptr< <a class="el" href="classarmnn_1_1_gpu_fsa_memory_manager.html">GpuFsaMemoryManager</a> > &memoryManager)</td></tr>
+<tr class="separator:a953af2bf56c098c0091e6fcded570181"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a46a240c3db81b430bf63ba297d29ba16"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a46a240c3db81b430bf63ba297d29ba16">GpuFsaWorkloadFactory</a> ()</td></tr>
+<tr class="separator:a46a240c3db81b430bf63ba297d29ba16"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a722abb456e40c4740305164c44990f6a"><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a722abb456e40c4740305164c44990f6a">~GpuFsaWorkloadFactory</a> ()</td></tr>
+<tr class="separator:a722abb456e40c4740305164c44990f6a"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:ae2cd7e29596b68884bfaade25f8f0dc0"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="classarmnn_1_1_backend_id.html">BackendId</a> & </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#ae2cd7e29596b68884bfaade25f8f0dc0">GetBackendId</a> () const override</td></tr>
+<tr class="separator:ae2cd7e29596b68884bfaade25f8f0dc0"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:aed0a782f32856bde72bc10d9381dc11e"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#aed0a782f32856bde72bc10d9381dc11e">SupportsSubTensors</a> () const override</td></tr>
+<tr class="separator:aed0a782f32856bde72bc10d9381dc11e"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a99251f9711c087d7c1b5a08236ef0201"><td class="memItemLeft" align="right" valign="top">std::unique_ptr< <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a99251f9711c087d7c1b5a08236ef0201">CreateSubTensorHandle</a> (<a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &, <a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a> const &, unsigned int const *) const override</td></tr>
+<tr class="separator:a99251f9711c087d7c1b5a08236ef0201"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a7239477811c44d4398f0c2d291d9ea76"><td class="memItemLeft" align="right" valign="top">std::unique_ptr< <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a7239477811c44d4398f0c2d291d9ea76">CreateTensorHandle</a> (const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &tensorInfo, const bool IsMemoryManaged=true) const override</td></tr>
+<tr class="separator:a7239477811c44d4398f0c2d291d9ea76"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:aaed323bbcbaded57334783e4732ee3ed"><td class="memItemLeft" align="right" valign="top">std::unique_ptr< <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#aaed323bbcbaded57334783e4732ee3ed">CreateTensorHandle</a> (const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &tensorInfo, <a class="el" href="namespacearmnn.html#ad1d5cce2d9e9a5d61c243e5c989112e0">DataLayout</a> dataLayout, const bool IsMemoryManaged=true) const override</td></tr>
+<tr class="separator:aaed323bbcbaded57334783e4732ee3ed"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:ab39a3049bfb85aa489a809d77f3ec1e0"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#ab39a3049bfb85aa489a809d77f3ec1e0">InitializeCLCompileContext</a> ()</td></tr>
+<tr class="separator:ab39a3049bfb85aa489a809d77f3ec1e0"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a739bcc341b89c98a5d38717370ebcaa6"><td class="memItemLeft" align="right" valign="top">std::unique_ptr< <a class="el" href="classarmnn_1_1_i_workload.html">IWorkload</a> > </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6">CreateWorkload</a> (<a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4">LayerType</a> type, const <a class="el" href="structarmnn_1_1_queue_descriptor.html">QueueDescriptor</a> &descriptor, const <a class="el" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a> &info) const override</td></tr>
+<tr class="memdesc:a739bcc341b89c98a5d38717370ebcaa6"><td class="mdescLeft"> </td><td class="mdescRight">Backends should implement their own CreateWorkload function with a switch statement. <a href="classarmnn_1_1_gpu_fsa_workload_factory.html#a739bcc341b89c98a5d38717370ebcaa6">More...</a><br /></td></tr>
+<tr class="separator:a739bcc341b89c98a5d38717370ebcaa6"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="inherit_header pub_methods_classarmnn_1_1_i_workload_factory"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_classarmnn_1_1_i_workload_factory')"><img src="closed.png" alt="-"/> Public Member Functions inherited from <a class="el" href="classarmnn_1_1_i_workload_factory.html">IWorkloadFactory</a></td></tr>
+<tr class="memitem:aab62208f96483015c29ad58549efedd8 inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">virtual </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#aab62208f96483015c29ad58549efedd8">~IWorkloadFactory</a> ()</td></tr>
+<tr class="separator:aab62208f96483015c29ad58549efedd8 inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a54a596adc0162c80f33a6cda4f33a6ef inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#a54a596adc0162c80f33a6cda4f33a6ef">AfterWorkloadsCreated</a> ()</td></tr>
+<tr class="separator:a54a596adc0162c80f33a6cda4f33a6ef inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2"> </td></tr>
+</table><table class="memberdecls">
+<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
+Static Public Member Functions</h2></td></tr>
+<tr class="memitem:a9992ea7c353e8597fbd8ae426f4612ae"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a9992ea7c353e8597fbd8ae426f4612ae">IsLayerSupported</a> (const <a class="el" href="classarmnn_1_1_layer.html">Layer</a> &layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>< <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> > dataType, std::string &outReasonIfUnsupported)</td></tr>
+<tr class="separator:a9992ea7c353e8597fbd8ae426f4612ae"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="inherit_header pub_static_methods_classarmnn_1_1_i_workload_factory"><td colspan="2" onclick="javascript:toggleInherit('pub_static_methods_classarmnn_1_1_i_workload_factory')"><img src="closed.png" alt="-"/> Static Public Member Functions inherited from <a class="el" href="classarmnn_1_1_i_workload_factory.html">IWorkloadFactory</a></td></tr>
+<tr class="memitem:a74dc9ec1a223eab8b072368b2dacee87 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#a74dc9ec1a223eab8b072368b2dacee87">IsLayerSupported</a> (const <a class="el" href="classarmnn_1_1_backend_id.html">BackendId</a> &backendId, const <a class="el" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a> &layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>< <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> > dataType, std::string &outReasonIfUnsupported)</td></tr>
+<tr class="separator:a74dc9ec1a223eab8b072368b2dacee87 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a7d94ea841143b76fe08ccb308839bfd7 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#a7d94ea841143b76fe08ccb308839bfd7">IsLayerSupported</a> (const <a class="el" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a> &layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>< <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> > dataType, std::string &outReasonIfUnsupported)</td></tr>
+<tr class="separator:a7d94ea841143b76fe08ccb308839bfd7 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:aeaff50773427132e1066a7de56a53db1 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#aeaff50773427132e1066a7de56a53db1">IsLayerSupported</a> (const <a class="el" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a> &layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>< <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> > dataType, std::string &outReasonIfUnsupported, const <a class="el" href="namespacearmnn.html#a5b6893cda5b69359a4244c06054da18f">ModelOptions</a> &modelOptions)</td></tr>
+<tr class="separator:aeaff50773427132e1066a7de56a53db1 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2"> </td></tr>
+<tr class="memitem:a52ba8d60c6582a847ef7bc914116d394 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#a52ba8d60c6582a847ef7bc914116d394">IsLayerSupported</a> (const <a class="el" href="classarmnn_1_1_backend_id.html">BackendId</a> &backendId, const <a class="el" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a> &layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>< <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> > dataType, std::string &outReasonIfUnsupported, const <a class="el" href="namespacearmnn.html#a5b6893cda5b69359a4244c06054da18f">ModelOptions</a> &modelOptions)</td></tr>
+<tr class="separator:a52ba8d60c6582a847ef7bc914116d394 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2"> </td></tr>
+</table>
+<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
+<div class="textblock">
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html#l00017">17</a> of file <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a>.</p>
+</div><h2 class="groupheader">Constructor & Destructor Documentation</h2>
+<a id="a953af2bf56c098c0091e6fcded570181"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a953af2bf56c098c0091e6fcded570181">◆ </a></span>GpuFsaWorkloadFactory() <span class="overload">[1/2]</span></h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html">GpuFsaWorkloadFactory</a> </td>
+ <td>(</td>
+ <td class="paramtype">const std::shared_ptr< <a class="el" href="classarmnn_1_1_gpu_fsa_memory_manager.html">GpuFsaMemoryManager</a> > & </td>
+ <td class="paramname"><em>memoryManager</em></td><td>)</td>
+ <td></td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">explicit</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00048">48</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00049"></a><span class="lineno"> 49</span>  : m_MemoryManager(memoryManager)</div>
+<div class="line"><a name="l00050"></a><span class="lineno"> 50</span> {</div>
+<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>  <a class="code" href="classarmnn_1_1_gpu_fsa_workload_factory.html#ab39a3049bfb85aa489a809d77f3ec1e0">InitializeCLCompileContext</a>();</div>
+<div class="line"><a name="l00052"></a><span class="lineno"> 52</span> }</div>
+</div><!-- fragment -->
+<p class="reference">References <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00092">GpuFsaWorkloadFactory::InitializeCLCompileContext()</a>.</p>
+
+</div>
+</div>
+<a id="a46a240c3db81b430bf63ba297d29ba16"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a46a240c3db81b430bf63ba297d29ba16">◆ </a></span>GpuFsaWorkloadFactory() <span class="overload">[2/2]</span></h2>
+
+<div class="memitem">
+<div class="memproto">
+ <table class="memname">
+ <tr>
+ <td class="memname"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html">GpuFsaWorkloadFactory</a> </td>
+ <td>(</td>
+ <td class="paramname"></td><td>)</td>
+ <td></td>
+ </tr>
+ </table>
+</div><div class="memdoc">
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00054">54</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>  : m_MemoryManager(<span class="keyword">new</span> GpuFsaMemoryManager())</div>
+<div class="line"><a name="l00056"></a><span class="lineno"> 56</span> {</div>
+<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>  <a class="code" href="classarmnn_1_1_gpu_fsa_workload_factory.html#ab39a3049bfb85aa489a809d77f3ec1e0">InitializeCLCompileContext</a>();</div>
+<div class="line"><a name="l00058"></a><span class="lineno"> 58</span> }</div>
+</div><!-- fragment -->
+<p class="reference">References <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00092">GpuFsaWorkloadFactory::InitializeCLCompileContext()</a>.</p>
+
+</div>
+</div>
+<a id="a722abb456e40c4740305164c44990f6a"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a722abb456e40c4740305164c44990f6a">◆ </a></span>~GpuFsaWorkloadFactory()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">~<a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html">GpuFsaWorkloadFactory</a> </td>
+ <td>(</td>
+ <td class="paramname"></td><td>)</td>
+ <td></td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">inline</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html#l00023">23</a> of file <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00023"></a><span class="lineno"> 23</span> {}</div>
+</div><!-- fragment -->
+</div>
+</div>
+<h2 class="groupheader">Member Function Documentation</h2>
+<a id="a99251f9711c087d7c1b5a08236ef0201"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a99251f9711c087d7c1b5a08236ef0201">◆ </a></span>CreateSubTensorHandle()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">std::unique_ptr<<a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a>> CreateSubTensorHandle </td>
+ <td>(</td>
+ <td class="paramtype"><a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> & </td>
+ <td class="paramname">, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype"><a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a> const & </td>
+ <td class="paramname">, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype">unsigned int const * </td>
+ <td class="paramname"> </td>
+ </tr>
+ <tr>
+ <td></td>
+ <td>)</td>
+ <td></td><td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#ac043991b839903b2ba9da884e4020848">IWorkloadFactory</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html#l00034">34</a> of file <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>  {</div>
+<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>  <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
+<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>  }</div>
+</div><!-- fragment -->
+</div>
+</div>
+<a id="a7239477811c44d4398f0c2d291d9ea76"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a7239477811c44d4398f0c2d291d9ea76">◆ </a></span>CreateTensorHandle() <span class="overload">[1/2]</span></h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">std::unique_ptr< <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> > CreateTensorHandle </td>
+ <td>(</td>
+ <td class="paramtype">const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> & </td>
+ <td class="paramname"><em>tensorInfo</em>, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype">const bool </td>
+ <td class="paramname"><em>IsMemoryManaged</em> = <code>true</code> </td>
+ </tr>
+ <tr>
+ <td></td>
+ <td>)</td>
+ <td></td><td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a15c140be4ddceffee16436f009d3ed94">IWorkloadFactory</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00072">72</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00074"></a><span class="lineno"> 74</span> {</div>
+<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>  std::unique_ptr<GpuFsaTensorHandle> tensorHandle = std::make_unique<GpuFsaTensorHandle>(tensorInfo);</div>
+<div class="line"><a name="l00076"></a><span class="lineno"> 76</span>  tensorHandle->SetMemoryGroup(m_MemoryManager->GetInterLayerMemoryGroup());</div>
+<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>  </div>
+<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>  <span class="keywordflow">return</span> tensorHandle;</div>
+<div class="line"><a name="l00079"></a><span class="lineno"> 79</span> }</div>
+</div><!-- fragment -->
+</div>
+</div>
+<a id="aaed323bbcbaded57334783e4732ee3ed"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#aaed323bbcbaded57334783e4732ee3ed">◆ </a></span>CreateTensorHandle() <span class="overload">[2/2]</span></h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">std::unique_ptr< <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> > CreateTensorHandle </td>
+ <td>(</td>
+ <td class="paramtype">const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> & </td>
+ <td class="paramname"><em>tensorInfo</em>, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype"><a class="el" href="namespacearmnn.html#ad1d5cce2d9e9a5d61c243e5c989112e0">DataLayout</a> </td>
+ <td class="paramname"><em>dataLayout</em>, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype">const bool </td>
+ <td class="paramname"><em>IsMemoryManaged</em> = <code>true</code> </td>
+ </tr>
+ <tr>
+ <td></td>
+ <td>)</td>
+ <td></td><td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#af0b0226f767fd570877710b84c7caa2a">IWorkloadFactory</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00081">81</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00084"></a><span class="lineno"> 84</span> {</div>
+<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>  std::unique_ptr<GpuFsaTensorHandle> tensorHandle = std::make_unique<GpuFsaTensorHandle>(tensorInfo, dataLayout);</div>
+<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>  tensorHandle->SetMemoryGroup(m_MemoryManager->GetInterLayerMemoryGroup());</div>
+<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>  </div>
+<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>  <span class="keywordflow">return</span> tensorHandle;</div>
+<div class="line"><a name="l00089"></a><span class="lineno"> 89</span> }</div>
+</div><!-- fragment -->
+</div>
+</div>
+<a id="a739bcc341b89c98a5d38717370ebcaa6"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a739bcc341b89c98a5d38717370ebcaa6">◆ </a></span>CreateWorkload()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">std::unique_ptr< <a class="el" href="classarmnn_1_1_i_workload.html">IWorkload</a> > CreateWorkload </td>
+ <td>(</td>
+ <td class="paramtype"><a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4">LayerType</a> </td>
+ <td class="paramname"><em>type</em>, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype">const <a class="el" href="structarmnn_1_1_queue_descriptor.html">QueueDescriptor</a> & </td>
+ <td class="paramname"><em>descriptor</em>, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype">const <a class="el" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a> & </td>
+ <td class="paramname"><em>info</em> </td>
+ </tr>
+ <tr>
+ <td></td>
+ <td>)</td>
+ <td></td><td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Backends should implement their own CreateWorkload function with a switch statement. </p>
+<p>The case for the switch should be the LayerType and based on that they will call their specific workload creation functionality. </p>
+
+<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a694a8411c8c799da95306034d274930b">IWorkloadFactory</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00099">99</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00102"></a><span class="lineno"> 102</span> {</div>
+<div class="line"><a name="l00103"></a><span class="lineno"> 103</span>  <span class="keywordflow">switch</span>(type)</div>
+<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>  {</div>
+<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>  <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acb17869fe51048b5a5c4c6106551a255">LayerType::Constant</a> :</div>
+<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>  {</div>
+<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>  <span class="keyword">auto</span> constQueueDescriptor = PolymorphicDowncast<const ConstantQueueDescriptor*>(&descriptor);</div>
+<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>  <span class="keywordflow">return</span> std::make_unique<GpuFsaConstantWorkload>(*constQueueDescriptor, info, m_CLCompileContext);</div>
+<div class="line"><a name="l00109"></a><span class="lineno"> 109</span>  }</div>
+<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>  <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a324118a6721dd6b8a9b9f4e327df2bf5">LayerType::Input</a> :</div>
+<div class="line"><a name="l00111"></a><span class="lineno"> 111</span>  {</div>
+<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>  <span class="keyword">auto</span> inputQueueDescriptor = PolymorphicDowncast<const InputQueueDescriptor*>(&descriptor);</div>
+<div class="line"><a name="l00113"></a><span class="lineno"> 113</span>  <span class="keywordflow">return</span> std::make_unique<CopyMemGenericWorkload>(*inputQueueDescriptor, info);</div>
+<div class="line"><a name="l00114"></a><span class="lineno"> 114</span>  }</div>
+<div class="line"><a name="l00115"></a><span class="lineno"> 115</span>  <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a29c2c02a361c9d7028472e5d92cd4a54">LayerType::Output</a> :</div>
+<div class="line"><a name="l00116"></a><span class="lineno"> 116</span>  {</div>
+<div class="line"><a name="l00117"></a><span class="lineno"> 117</span>  <span class="keyword">auto</span> outputQueueDescriptor = PolymorphicDowncast<const OutputQueueDescriptor*>(&descriptor);</div>
+<div class="line"><a name="l00118"></a><span class="lineno"> 118</span>  <span class="keywordflow">return</span> std::make_unique<CopyMemGenericWorkload>(*outputQueueDescriptor, info);</div>
+<div class="line"><a name="l00119"></a><span class="lineno"> 119</span>  }</div>
+<div class="line"><a name="l00120"></a><span class="lineno"> 120</span>  <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4dd48794eb3305a0f5aece88b111a97b">LayerType::MemCopy</a> :</div>
+<div class="line"><a name="l00121"></a><span class="lineno"> 121</span>  {</div>
+<div class="line"><a name="l00122"></a><span class="lineno"> 122</span>  <span class="keyword">auto</span> memCopyQueueDescriptor = PolymorphicDowncast<const MemCopyQueueDescriptor*>(&descriptor);</div>
+<div class="line"><a name="l00123"></a><span class="lineno"> 123</span>  <span class="keywordflow">if</span> (memCopyQueueDescriptor->m_Inputs.empty() || !memCopyQueueDescriptor->m_Inputs[0])</div>
+<div class="line"><a name="l00124"></a><span class="lineno"> 124</span>  {</div>
+<div class="line"><a name="l00125"></a><span class="lineno"> 125</span>  <span class="keywordflow">throw</span> InvalidArgumentException(<span class="stringliteral">"GpuFsaWorkloadFactory: Invalid null input for MemCopy workload"</span>);</div>
+<div class="line"><a name="l00126"></a><span class="lineno"> 126</span>  }</div>
+<div class="line"><a name="l00127"></a><span class="lineno"> 127</span>  <span class="keywordflow">return</span> std::make_unique<CopyMemGenericWorkload>(*memCopyQueueDescriptor, info);</div>
+<div class="line"><a name="l00128"></a><span class="lineno"> 128</span>  }</div>
+<div class="line"><a name="l00129"></a><span class="lineno"> 129</span>  <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1ba143ebe524d46181a4b53470693278">LayerType::PreCompiled</a> :</div>
+<div class="line"><a name="l00130"></a><span class="lineno"> 130</span>  {</div>
+<div class="line"><a name="l00131"></a><span class="lineno"> 131</span>  <span class="keyword">auto</span> precompiledQueueDescriptor = PolymorphicDowncast<const PreCompiledQueueDescriptor*>(&descriptor);</div>
+<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>  <span class="keywordflow">return</span> std::make_unique<GpuFsaPreCompiledWorkload>(*precompiledQueueDescriptor, info);</div>
+<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>  }</div>
+<div class="line"><a name="l00134"></a><span class="lineno"> 134</span>  default :</div>
+<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>  <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
+<div class="line"><a name="l00136"></a><span class="lineno"> 136</span>  }</div>
+<div class="line"><a name="l00137"></a><span class="lineno"> 137</span> }</div>
+</div><!-- fragment -->
+<p class="reference">References <a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acb17869fe51048b5a5c4c6106551a255">armnn::Constant</a>, <a class="el" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">armnn::info</a>, <a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a324118a6721dd6b8a9b9f4e327df2bf5">armnn::Input</a>, <a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4dd48794eb3305a0f5aece88b111a97b">armnn::MemCopy</a>, <a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a29c2c02a361c9d7028472e5d92cd4a54">armnn::Output</a>, and <a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1ba143ebe524d46181a4b53470693278">armnn::PreCompiled</a>.</p>
+
+</div>
+</div>
+<a id="ae2cd7e29596b68884bfaade25f8f0dc0"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#ae2cd7e29596b68884bfaade25f8f0dc0">◆ </a></span>GetBackendId()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">const <a class="el" href="classarmnn_1_1_backend_id.html">BackendId</a> & GetBackendId </td>
+ <td>(</td>
+ <td class="paramname"></td><td>)</td>
+ <td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a9f7e4296485d2812e7996089149c96d1">IWorkloadFactory</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00060">60</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00061"></a><span class="lineno"> 61</span> {</div>
+<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>  <span class="keywordflow">return</span> s_Id;</div>
+<div class="line"><a name="l00063"></a><span class="lineno"> 63</span> }</div>
+</div><!-- fragment -->
+</div>
+</div>
+<a id="ab39a3049bfb85aa489a809d77f3ec1e0"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#ab39a3049bfb85aa489a809d77f3ec1e0">◆ </a></span>InitializeCLCompileContext()</h2>
+
+<div class="memitem">
+<div class="memproto">
+ <table class="memname">
+ <tr>
+ <td class="memname">void InitializeCLCompileContext </td>
+ <td>(</td>
+ <td class="paramname"></td><td>)</td>
+ <td></td>
+ </tr>
+ </table>
+</div><div class="memdoc">
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00092">92</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>  {</div>
+<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>  <span class="comment">// Initialize our m_CLCompileContext using default device and context</span></div>
+<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>  <span class="keyword">auto</span> context = arm_compute::CLKernelLibrary::get().context();</div>
+<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>  <span class="keyword">auto</span> device = arm_compute::CLKernelLibrary::get().get_device();</div>
+<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>  m_CLCompileContext = arm_compute::CLCompileContext(context, device);</div>
+<div class="line"><a name="l00097"></a><span class="lineno"> 97</span> }</div>
+</div><!-- fragment -->
+<p class="reference">Referenced by <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00048">GpuFsaWorkloadFactory::GpuFsaWorkloadFactory()</a>.</p>
+
+</div>
+</div>
+<a id="a9992ea7c353e8597fbd8ae426f4612ae"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a9992ea7c353e8597fbd8ae426f4612ae">◆ </a></span>IsLayerSupported()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">bool IsLayerSupported </td>
+ <td>(</td>
+ <td class="paramtype">const <a class="el" href="classarmnn_1_1_layer.html">Layer</a> & </td>
+ <td class="paramname"><em>layer</em>, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype"><a class="el" href="classarmnn_1_1_optional.html">Optional</a>< <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> > </td>
+ <td class="paramname"><em>dataType</em>, </td>
+ </tr>
+ <tr>
+ <td class="paramkey"></td>
+ <td></td>
+ <td class="paramtype">std::string & </td>
+ <td class="paramname"><em>outReasonIfUnsupported</em> </td>
+ </tr>
+ <tr>
+ <td></td>
+ <td>)</td>
+ <td></td><td></td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">static</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00065">65</a> of file <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00068"></a><span class="lineno"> 68</span> {</div>
+<div class="line"><a name="l00069"></a><span class="lineno"> 69</span>  <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="l00070"></a><span class="lineno"> 70</span> }</div>
+</div><!-- fragment -->
+<p class="reference">References <a class="el" href="_workload_factory_8cpp_source.html#l01614">IWorkloadFactory::IsLayerSupported()</a>.</p>
+
+</div>
+</div>
+<a id="aed0a782f32856bde72bc10d9381dc11e"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#aed0a782f32856bde72bc10d9381dc11e">◆ </a></span>SupportsSubTensors()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">bool SupportsSubTensors </td>
+ <td>(</td>
+ <td class="paramname"></td><td>)</td>
+ <td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a37f4eba7877deb34f4d8d64c9bcb9ab5">IWorkloadFactory</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html#l00031">31</a> of file <a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a>.</p>
+<div class="fragment"><div class="line"><a name="l00031"></a><span class="lineno"> 31</span> { <span class="keywordflow">return</span> <span class="keyword">false</span>; }</div>
+</div><!-- fragment -->
+</div>
+</div>
+<hr/>The documentation for this class was generated from the following files:<ul>
+<li>src/backends/gpuFsa/<a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a></li>
+<li>src/backends/gpuFsa/<a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a></li>
+</ul>
+</div><!-- contents -->
+</div><!-- doc-content -->
+<div class="ttc" id="aclassarmnn_1_1_gpu_fsa_workload_factory_html_ab39a3049bfb85aa489a809d77f3ec1e0"><div class="ttname"><a href="classarmnn_1_1_gpu_fsa_workload_factory.html#ab39a3049bfb85aa489a809d77f3ec1e0">armnn::GpuFsaWorkloadFactory::InitializeCLCompileContext</a></div><div class="ttdeci">void InitializeCLCompileContext()</div><div class="ttdef"><b>Definition:</b> <a href="_gpu_fsa_workload_factory_8cpp_source.html#l00092">GpuFsaWorkloadFactory.cpp:92</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 &backendId, const IConnectableLayer &layer, Optional< DataType > dataType, std::string &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="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a1ba143ebe524d46181a4b53470693278"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1ba143ebe524d46181a4b53470693278">armnn::LayerType::PreCompiled</a></div><div class="ttdeci">@ PreCompiled</div></div>
+<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4a4dd48794eb3305a0f5aece88b111a97b"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4dd48794eb3305a0f5aece88b111a97b">armnn::LayerType::MemCopy</a></div><div class="ttdeci">@ MemCopy</div></div>
+<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_a56943a0946e5f15e5e58054b8e7a04a4a29c2c02a361c9d7028472e5d92cd4a54"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a29c2c02a361c9d7028472e5d92cd4a54">armnn::LayerType::Output</a></div><div class="ttdeci">@ Output</div></div>
+<div class="ttc" id="anamespacearmnn_html_a56943a0946e5f15e5e58054b8e7a04a4acb17869fe51048b5a5c4c6106551a255"><div class="ttname"><a href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acb17869fe51048b5a5c4c6106551a255">armnn::LayerType::Constant</a></div><div class="ttdeci">@ Constant</div></div>
+<!-- start footer part -->
+<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
+ <ul>
+ <li class="navelem"><a class="el" href="namespacearmnn.html">armnn</a></li><li class="navelem"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html">GpuFsaWorkloadFactory</a></li>
+ <li class="footer">Generated on Wed Feb 14 2024 16:36:22 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>
+</div>
+</body>
+</html>