blob: a21476d8654d9a45f53fa05c5a58b18eb7634d21 [file] [log] [blame]
Nikhil Raj38b600d2024-02-15 15:02:19 +00001<!-- HTML header for doxygen 1.8.17-->
2<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3<html xmlns="http://www.w3.org/1999/xhtml">
4<head>
5<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
6<meta http-equiv="X-UA-Compatible" content="IE=9"/>
7<meta name="generator" content="Doxygen 1.8.17"/>
8<meta name="viewport" content="width=device-width, initial-scale=1"/>
9<title>Arm NN: GpuFsaWorkloadFactory Class Reference</title>
10<link href="tabs.css" rel="stylesheet" type="text/css"/>
11<script type="text/javascript" src="jquery.js"></script>
12<script type="text/javascript" src="dynsections.js"></script>
13<link href="navtree.css" rel="stylesheet" type="text/css"/>
14<script type="text/javascript" src="resize.js"></script>
15<script type="text/javascript" src="navtreedata.js"></script>
16<script type="text/javascript" src="navtree.js"></script>
17<link href="search/search.css" rel="stylesheet" type="text/css"/>
18<script type="text/javascript" src="search/searchdata.js"></script>
19<script type="text/javascript" src="search/search.js"></script>
20<script type="text/x-mathjax-config">
21 MathJax.Hub.Config({
22 extensions: ["tex2jax.js"],
23 jax: ["input/TeX","output/HTML-CSS"],
24});
25</script>
26<script type="text/javascript" async="async" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js"></script>
27<link href="doxygen.css" rel="stylesheet" type="text/css" />
28<link href="customdoxygen.css" rel="stylesheet" type="text/css"/>
29</head>
30<body>
31<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
32<div id="titlearea">
33<table cellspacing="0" cellpadding="0">
34 <tbody>
35 <tr style="height: 56px;">
36 <img alt="ArmNN" src="Arm_NN_horizontal_blue.png" style="max-width: 15rem; margin-top: .5rem; margin-left 13px"/>
37 <td id="projectalign" style="padding-left: 0.9em;">
38 <div id="projectname">
Nikhil Raj1dc83fe2024-05-16 09:47:51 +010039 &#160;<span id="projectnumber">24.05</span>
Nikhil Raj38b600d2024-02-15 15:02:19 +000040 </div>
41 </td>
42 </tr>
43 </tbody>
44</table>
45</div>
46<!-- end header part -->
47<!-- Generated by Doxygen 1.8.17 -->
48<script type="text/javascript">
49/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
50var searchBox = new SearchBox("searchBox", "search",false,'Search');
51/* @license-end */
52</script>
53<script type="text/javascript" src="menudata.js"></script>
54<script type="text/javascript" src="menu.js"></script>
55<script type="text/javascript">
56/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
57$(function() {
58 initMenu('',true,false,'search.php','Search');
59 $(document).ready(function() { init_search(); });
60});
61/* @license-end */</script>
62<div id="main-nav"></div>
63</div><!-- top -->
64<div id="side-nav" class="ui-resizable side-nav-resizable">
65 <div id="nav-tree">
66 <div id="nav-tree-contents">
67 <div id="nav-sync" class="sync"></div>
68 </div>
69 </div>
70 <div id="splitbar" style="-moz-user-select:none;"
71 class="ui-resizable-handle">
72 </div>
73</div>
74<script type="text/javascript">
75/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
76$(document).ready(function(){initNavTree('classarmnn_1_1_gpu_fsa_workload_factory.html',''); initResizable(); });
77/* @license-end */
78</script>
79<div id="doc-content">
80<!-- window showing the filter options -->
81<div id="MSearchSelectWindow"
82 onmouseover="return searchBox.OnSearchSelectShow()"
83 onmouseout="return searchBox.OnSearchSelectHide()"
84 onkeydown="return searchBox.OnSearchSelectKey(event)">
85</div>
86
87<!-- iframe showing the search results (closed by default) -->
88<div id="MSearchResultsWindow">
89<iframe src="javascript:void(0)" frameborder="0"
90 name="MSearchResults" id="MSearchResults">
91</iframe>
92</div>
93
94<div class="header">
95 <div class="summary">
96<a href="#pub-methods">Public Member Functions</a> &#124;
97<a href="#pub-static-methods">Static Public Member Functions</a> &#124;
98<a href="classarmnn_1_1_gpu_fsa_workload_factory-members.html">List of all members</a> </div>
99 <div class="headertitle">
100<div class="title">GpuFsaWorkloadFactory Class Reference</div> </div>
101</div><!--header-->
102<div class="contents">
103
104<p><code>#include &lt;<a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a>&gt;</code></p>
105<div class="dynheader">
106Inheritance diagram for GpuFsaWorkloadFactory:</div>
107<div class="dyncontent">
108<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>
109</div>
110<center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div>
111<div class="dynheader">
112Collaboration diagram for GpuFsaWorkloadFactory:</div>
113<div class="dyncontent">
114<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>
115</div>
116<center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div>
117<table class="memberdecls">
118<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
119Public Member Functions</h2></td></tr>
120<tr class="memitem:a953af2bf56c098c0091e6fcded570181"><td class="memItemLeft" align="right" valign="top">&#160;</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&lt; <a class="el" href="classarmnn_1_1_gpu_fsa_memory_manager.html">GpuFsaMemoryManager</a> &gt; &amp;memoryManager)</td></tr>
121<tr class="separator:a953af2bf56c098c0091e6fcded570181"><td class="memSeparator" colspan="2">&#160;</td></tr>
122<tr class="memitem:a46a240c3db81b430bf63ba297d29ba16"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a46a240c3db81b430bf63ba297d29ba16">GpuFsaWorkloadFactory</a> ()</td></tr>
123<tr class="separator:a46a240c3db81b430bf63ba297d29ba16"><td class="memSeparator" colspan="2">&#160;</td></tr>
124<tr class="memitem:a722abb456e40c4740305164c44990f6a"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#a722abb456e40c4740305164c44990f6a">~GpuFsaWorkloadFactory</a> ()</td></tr>
125<tr class="separator:a722abb456e40c4740305164c44990f6a"><td class="memSeparator" colspan="2">&#160;</td></tr>
126<tr class="memitem:ae2cd7e29596b68884bfaade25f8f0dc0"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="classarmnn_1_1_backend_id.html">BackendId</a> &amp;&#160;</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>
127<tr class="separator:ae2cd7e29596b68884bfaade25f8f0dc0"><td class="memSeparator" colspan="2">&#160;</td></tr>
128<tr class="memitem:aed0a782f32856bde72bc10d9381dc11e"><td class="memItemLeft" align="right" valign="top">bool&#160;</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>
129<tr class="separator:aed0a782f32856bde72bc10d9381dc11e"><td class="memSeparator" colspan="2">&#160;</td></tr>
130<tr class="memitem:a99251f9711c087d7c1b5a08236ef0201"><td class="memItemLeft" align="right" valign="top">std::unique_ptr&lt; <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &gt;&#160;</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> &amp;, <a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a> const &amp;, unsigned int const *) const override</td></tr>
131<tr class="separator:a99251f9711c087d7c1b5a08236ef0201"><td class="memSeparator" colspan="2">&#160;</td></tr>
132<tr class="memitem:a7239477811c44d4398f0c2d291d9ea76"><td class="memItemLeft" align="right" valign="top">std::unique_ptr&lt; <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &gt;&#160;</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> &amp;tensorInfo, const bool IsMemoryManaged=true) const override</td></tr>
133<tr class="separator:a7239477811c44d4398f0c2d291d9ea76"><td class="memSeparator" colspan="2">&#160;</td></tr>
134<tr class="memitem:aaed323bbcbaded57334783e4732ee3ed"><td class="memItemLeft" align="right" valign="top">std::unique_ptr&lt; <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &gt;&#160;</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> &amp;tensorInfo, <a class="el" href="namespacearmnn.html#ad1d5cce2d9e9a5d61c243e5c989112e0">DataLayout</a> dataLayout, const bool IsMemoryManaged=true) const override</td></tr>
135<tr class="separator:aaed323bbcbaded57334783e4732ee3ed"><td class="memSeparator" colspan="2">&#160;</td></tr>
136<tr class="memitem:ab39a3049bfb85aa489a809d77f3ec1e0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html#ab39a3049bfb85aa489a809d77f3ec1e0">InitializeCLCompileContext</a> ()</td></tr>
137<tr class="separator:ab39a3049bfb85aa489a809d77f3ec1e0"><td class="memSeparator" colspan="2">&#160;</td></tr>
138<tr class="memitem:a739bcc341b89c98a5d38717370ebcaa6"><td class="memItemLeft" align="right" valign="top">std::unique_ptr&lt; <a class="el" href="classarmnn_1_1_i_workload.html">IWorkload</a> &gt;&#160;</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> &amp;descriptor, const <a class="el" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a> &amp;info) const override</td></tr>
139<tr class="memdesc:a739bcc341b89c98a5d38717370ebcaa6"><td class="mdescLeft">&#160;</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>
140<tr class="separator:a739bcc341b89c98a5d38717370ebcaa6"><td class="memSeparator" colspan="2">&#160;</td></tr>
141<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="-"/>&#160;Public Member Functions inherited from <a class="el" href="classarmnn_1_1_i_workload_factory.html">IWorkloadFactory</a></td></tr>
142<tr class="memitem:aab62208f96483015c29ad58549efedd8 inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#aab62208f96483015c29ad58549efedd8">~IWorkloadFactory</a> ()</td></tr>
143<tr class="separator:aab62208f96483015c29ad58549efedd8 inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2">&#160;</td></tr>
144<tr class="memitem:a54a596adc0162c80f33a6cda4f33a6ef inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload_factory.html#a54a596adc0162c80f33a6cda4f33a6ef">AfterWorkloadsCreated</a> ()</td></tr>
145<tr class="separator:a54a596adc0162c80f33a6cda4f33a6ef inherit pub_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2">&#160;</td></tr>
146</table><table class="memberdecls">
147<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
148Static Public Member Functions</h2></td></tr>
149<tr class="memitem:a9992ea7c353e8597fbd8ae426f4612ae"><td class="memItemLeft" align="right" valign="top">static bool&#160;</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> &amp;layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>&lt; <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> &gt; dataType, std::string &amp;outReasonIfUnsupported)</td></tr>
150<tr class="separator:a9992ea7c353e8597fbd8ae426f4612ae"><td class="memSeparator" colspan="2">&#160;</td></tr>
151<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="-"/>&#160;Static Public Member Functions inherited from <a class="el" href="classarmnn_1_1_i_workload_factory.html">IWorkloadFactory</a></td></tr>
152<tr class="memitem:a74dc9ec1a223eab8b072368b2dacee87 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool&#160;</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> &amp;backendId, const <a class="el" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a> &amp;layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>&lt; <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> &gt; dataType, std::string &amp;outReasonIfUnsupported)</td></tr>
153<tr class="separator:a74dc9ec1a223eab8b072368b2dacee87 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2">&#160;</td></tr>
154<tr class="memitem:a7d94ea841143b76fe08ccb308839bfd7 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool&#160;</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> &amp;layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>&lt; <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> &gt; dataType, std::string &amp;outReasonIfUnsupported)</td></tr>
155<tr class="separator:a7d94ea841143b76fe08ccb308839bfd7 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2">&#160;</td></tr>
156<tr class="memitem:aeaff50773427132e1066a7de56a53db1 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool&#160;</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> &amp;layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>&lt; <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> &gt; dataType, std::string &amp;outReasonIfUnsupported, const <a class="el" href="namespacearmnn.html#a5b6893cda5b69359a4244c06054da18f">ModelOptions</a> &amp;modelOptions)</td></tr>
157<tr class="separator:aeaff50773427132e1066a7de56a53db1 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2">&#160;</td></tr>
158<tr class="memitem:a52ba8d60c6582a847ef7bc914116d394 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memItemLeft" align="right" valign="top">static bool&#160;</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> &amp;backendId, const <a class="el" href="classarmnn_1_1_i_connectable_layer.html">IConnectableLayer</a> &amp;layer, <a class="el" href="classarmnn_1_1_optional.html">Optional</a>&lt; <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> &gt; dataType, std::string &amp;outReasonIfUnsupported, const <a class="el" href="namespacearmnn.html#a5b6893cda5b69359a4244c06054da18f">ModelOptions</a> &amp;modelOptions)</td></tr>
159<tr class="separator:a52ba8d60c6582a847ef7bc914116d394 inherit pub_static_methods_classarmnn_1_1_i_workload_factory"><td class="memSeparator" colspan="2">&#160;</td></tr>
160</table>
161<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
162<div class="textblock">
163<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>
164</div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
165<a id="a953af2bf56c098c0091e6fcded570181"></a>
166<h2 class="memtitle"><span class="permalink"><a href="#a953af2bf56c098c0091e6fcded570181">&#9670;&nbsp;</a></span>GpuFsaWorkloadFactory() <span class="overload">[1/2]</span></h2>
167
168<div class="memitem">
169<div class="memproto">
170<table class="mlabels">
171 <tr>
172 <td class="mlabels-left">
173 <table class="memname">
174 <tr>
175 <td class="memname"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html">GpuFsaWorkloadFactory</a> </td>
176 <td>(</td>
177 <td class="paramtype">const std::shared_ptr&lt; <a class="el" href="classarmnn_1_1_gpu_fsa_memory_manager.html">GpuFsaMemoryManager</a> &gt; &amp;&#160;</td>
178 <td class="paramname"><em>memoryManager</em></td><td>)</td>
179 <td></td>
180 </tr>
181 </table>
182 </td>
183 <td class="mlabels-right">
184<span class="mlabels"><span class="mlabel">explicit</span></span> </td>
185 </tr>
186</table>
187</div><div class="memdoc">
188
189<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>
190<div class="fragment"><div class="line"><a name="l00049"></a><span class="lineno"> 49</span>&#160; : m_MemoryManager(memoryManager)</div>
191<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160;{</div>
192<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; <a class="code" href="classarmnn_1_1_gpu_fsa_workload_factory.html#ab39a3049bfb85aa489a809d77f3ec1e0">InitializeCLCompileContext</a>();</div>
193<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160;}</div>
194</div><!-- fragment -->
195<p class="reference">References <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00092">GpuFsaWorkloadFactory::InitializeCLCompileContext()</a>.</p>
196
197</div>
198</div>
199<a id="a46a240c3db81b430bf63ba297d29ba16"></a>
200<h2 class="memtitle"><span class="permalink"><a href="#a46a240c3db81b430bf63ba297d29ba16">&#9670;&nbsp;</a></span>GpuFsaWorkloadFactory() <span class="overload">[2/2]</span></h2>
201
202<div class="memitem">
203<div class="memproto">
204 <table class="memname">
205 <tr>
206 <td class="memname"><a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html">GpuFsaWorkloadFactory</a> </td>
207 <td>(</td>
208 <td class="paramname"></td><td>)</td>
209 <td></td>
210 </tr>
211 </table>
212</div><div class="memdoc">
213
214<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>
215<div class="fragment"><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160; : m_MemoryManager(<span class="keyword">new</span> GpuFsaMemoryManager())</div>
216<div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160;{</div>
217<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160; <a class="code" href="classarmnn_1_1_gpu_fsa_workload_factory.html#ab39a3049bfb85aa489a809d77f3ec1e0">InitializeCLCompileContext</a>();</div>
218<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160;}</div>
219</div><!-- fragment -->
220<p class="reference">References <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00092">GpuFsaWorkloadFactory::InitializeCLCompileContext()</a>.</p>
221
222</div>
223</div>
224<a id="a722abb456e40c4740305164c44990f6a"></a>
225<h2 class="memtitle"><span class="permalink"><a href="#a722abb456e40c4740305164c44990f6a">&#9670;&nbsp;</a></span>~GpuFsaWorkloadFactory()</h2>
226
227<div class="memitem">
228<div class="memproto">
229<table class="mlabels">
230 <tr>
231 <td class="mlabels-left">
232 <table class="memname">
233 <tr>
234 <td class="memname">~<a class="el" href="classarmnn_1_1_gpu_fsa_workload_factory.html">GpuFsaWorkloadFactory</a> </td>
235 <td>(</td>
236 <td class="paramname"></td><td>)</td>
237 <td></td>
238 </tr>
239 </table>
240 </td>
241 <td class="mlabels-right">
242<span class="mlabels"><span class="mlabel">inline</span></span> </td>
243 </tr>
244</table>
245</div><div class="memdoc">
246
247<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>
248<div class="fragment"><div class="line"><a name="l00023"></a><span class="lineno"> 23</span>&#160;{}</div>
249</div><!-- fragment -->
250</div>
251</div>
252<h2 class="groupheader">Member Function Documentation</h2>
253<a id="a99251f9711c087d7c1b5a08236ef0201"></a>
254<h2 class="memtitle"><span class="permalink"><a href="#a99251f9711c087d7c1b5a08236ef0201">&#9670;&nbsp;</a></span>CreateSubTensorHandle()</h2>
255
256<div class="memitem">
257<div class="memproto">
258<table class="mlabels">
259 <tr>
260 <td class="mlabels-left">
261 <table class="memname">
262 <tr>
263 <td class="memname">std::unique_ptr&lt;<a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a>&gt; CreateSubTensorHandle </td>
264 <td>(</td>
265 <td class="paramtype"><a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &amp;&#160;</td>
266 <td class="paramname">, </td>
267 </tr>
268 <tr>
269 <td class="paramkey"></td>
270 <td></td>
271 <td class="paramtype"><a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a> const &amp;&#160;</td>
272 <td class="paramname">, </td>
273 </tr>
274 <tr>
275 <td class="paramkey"></td>
276 <td></td>
277 <td class="paramtype">unsigned int const *&#160;</td>
278 <td class="paramname">&#160;</td>
279 </tr>
280 <tr>
281 <td></td>
282 <td>)</td>
283 <td></td><td> const</td>
284 </tr>
285 </table>
286 </td>
287 <td class="mlabels-right">
288<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
289 </tr>
290</table>
291</div><div class="memdoc">
292
293<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#ac043991b839903b2ba9da884e4020848">IWorkloadFactory</a>.</p>
294
295<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>
296<div class="fragment"><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160; {</div>
297<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
298<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160; }</div>
299</div><!-- fragment -->
300</div>
301</div>
302<a id="a7239477811c44d4398f0c2d291d9ea76"></a>
303<h2 class="memtitle"><span class="permalink"><a href="#a7239477811c44d4398f0c2d291d9ea76">&#9670;&nbsp;</a></span>CreateTensorHandle() <span class="overload">[1/2]</span></h2>
304
305<div class="memitem">
306<div class="memproto">
307<table class="mlabels">
308 <tr>
309 <td class="mlabels-left">
310 <table class="memname">
311 <tr>
312 <td class="memname">std::unique_ptr&lt; <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &gt; CreateTensorHandle </td>
313 <td>(</td>
314 <td class="paramtype">const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &amp;&#160;</td>
315 <td class="paramname"><em>tensorInfo</em>, </td>
316 </tr>
317 <tr>
318 <td class="paramkey"></td>
319 <td></td>
320 <td class="paramtype">const bool&#160;</td>
321 <td class="paramname"><em>IsMemoryManaged</em> = <code>true</code>&#160;</td>
322 </tr>
323 <tr>
324 <td></td>
325 <td>)</td>
326 <td></td><td> const</td>
327 </tr>
328 </table>
329 </td>
330 <td class="mlabels-right">
331<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
332 </tr>
333</table>
334</div><div class="memdoc">
335
336<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a15c140be4ddceffee16436f009d3ed94">IWorkloadFactory</a>.</p>
337
338<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>
339<div class="fragment"><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160;{</div>
340<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; std::unique_ptr&lt;GpuFsaTensorHandle&gt; tensorHandle = std::make_unique&lt;GpuFsaTensorHandle&gt;(tensorInfo);</div>
341<div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; tensorHandle-&gt;SetMemoryGroup(m_MemoryManager-&gt;GetInterLayerMemoryGroup());</div>
342<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; </div>
343<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; <span class="keywordflow">return</span> tensorHandle;</div>
344<div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160;}</div>
345</div><!-- fragment -->
346</div>
347</div>
348<a id="aaed323bbcbaded57334783e4732ee3ed"></a>
349<h2 class="memtitle"><span class="permalink"><a href="#aaed323bbcbaded57334783e4732ee3ed">&#9670;&nbsp;</a></span>CreateTensorHandle() <span class="overload">[2/2]</span></h2>
350
351<div class="memitem">
352<div class="memproto">
353<table class="mlabels">
354 <tr>
355 <td class="mlabels-left">
356 <table class="memname">
357 <tr>
358 <td class="memname">std::unique_ptr&lt; <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &gt; CreateTensorHandle </td>
359 <td>(</td>
360 <td class="paramtype">const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &amp;&#160;</td>
361 <td class="paramname"><em>tensorInfo</em>, </td>
362 </tr>
363 <tr>
364 <td class="paramkey"></td>
365 <td></td>
366 <td class="paramtype"><a class="el" href="namespacearmnn.html#ad1d5cce2d9e9a5d61c243e5c989112e0">DataLayout</a>&#160;</td>
367 <td class="paramname"><em>dataLayout</em>, </td>
368 </tr>
369 <tr>
370 <td class="paramkey"></td>
371 <td></td>
372 <td class="paramtype">const bool&#160;</td>
373 <td class="paramname"><em>IsMemoryManaged</em> = <code>true</code>&#160;</td>
374 </tr>
375 <tr>
376 <td></td>
377 <td>)</td>
378 <td></td><td> const</td>
379 </tr>
380 </table>
381 </td>
382 <td class="mlabels-right">
383<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
384 </tr>
385</table>
386</div><div class="memdoc">
387
388<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#af0b0226f767fd570877710b84c7caa2a">IWorkloadFactory</a>.</p>
389
390<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>
391<div class="fragment"><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160;{</div>
392<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; std::unique_ptr&lt;GpuFsaTensorHandle&gt; tensorHandle = std::make_unique&lt;GpuFsaTensorHandle&gt;(tensorInfo, dataLayout);</div>
393<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; tensorHandle-&gt;SetMemoryGroup(m_MemoryManager-&gt;GetInterLayerMemoryGroup());</div>
394<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160; </div>
395<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; <span class="keywordflow">return</span> tensorHandle;</div>
396<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160;}</div>
397</div><!-- fragment -->
398</div>
399</div>
400<a id="a739bcc341b89c98a5d38717370ebcaa6"></a>
401<h2 class="memtitle"><span class="permalink"><a href="#a739bcc341b89c98a5d38717370ebcaa6">&#9670;&nbsp;</a></span>CreateWorkload()</h2>
402
403<div class="memitem">
404<div class="memproto">
405<table class="mlabels">
406 <tr>
407 <td class="mlabels-left">
408 <table class="memname">
409 <tr>
410 <td class="memname">std::unique_ptr&lt; <a class="el" href="classarmnn_1_1_i_workload.html">IWorkload</a> &gt; CreateWorkload </td>
411 <td>(</td>
412 <td class="paramtype"><a class="el" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4">LayerType</a>&#160;</td>
413 <td class="paramname"><em>type</em>, </td>
414 </tr>
415 <tr>
416 <td class="paramkey"></td>
417 <td></td>
418 <td class="paramtype">const <a class="el" href="structarmnn_1_1_queue_descriptor.html">QueueDescriptor</a> &amp;&#160;</td>
419 <td class="paramname"><em>descriptor</em>, </td>
420 </tr>
421 <tr>
422 <td class="paramkey"></td>
423 <td></td>
424 <td class="paramtype">const <a class="el" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a> &amp;&#160;</td>
425 <td class="paramname"><em>info</em>&#160;</td>
426 </tr>
427 <tr>
428 <td></td>
429 <td>)</td>
430 <td></td><td> const</td>
431 </tr>
432 </table>
433 </td>
434 <td class="mlabels-right">
435<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
436 </tr>
437</table>
438</div><div class="memdoc">
439
440<p>Backends should implement their own CreateWorkload function with a switch statement. </p>
441<p>The case for the switch should be the LayerType and based on that they will call their specific workload creation functionality. </p>
442
443<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a694a8411c8c799da95306034d274930b">IWorkloadFactory</a>.</p>
444
445<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>
446<div class="fragment"><div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160;{</div>
447<div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160; <span class="keywordflow">switch</span>(type)</div>
448<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160; {</div>
449<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4acb17869fe51048b5a5c4c6106551a255">LayerType::Constant</a> :</div>
450<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; {</div>
451<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160; <span class="keyword">auto</span> constQueueDescriptor = PolymorphicDowncast&lt;const ConstantQueueDescriptor*&gt;(&amp;descriptor);</div>
452<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;GpuFsaConstantWorkload&gt;(*constQueueDescriptor, info, m_CLCompileContext);</div>
453<div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160; }</div>
454<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a324118a6721dd6b8a9b9f4e327df2bf5">LayerType::Input</a> :</div>
455<div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; {</div>
456<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160; <span class="keyword">auto</span> inputQueueDescriptor = PolymorphicDowncast&lt;const InputQueueDescriptor*&gt;(&amp;descriptor);</div>
457<div class="line"><a name="l00113"></a><span class="lineno"> 113</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*inputQueueDescriptor, info);</div>
458<div class="line"><a name="l00114"></a><span class="lineno"> 114</span>&#160; }</div>
459<div class="line"><a name="l00115"></a><span class="lineno"> 115</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a29c2c02a361c9d7028472e5d92cd4a54">LayerType::Output</a> :</div>
460<div class="line"><a name="l00116"></a><span class="lineno"> 116</span>&#160; {</div>
461<div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; <span class="keyword">auto</span> outputQueueDescriptor = PolymorphicDowncast&lt;const OutputQueueDescriptor*&gt;(&amp;descriptor);</div>
462<div class="line"><a name="l00118"></a><span class="lineno"> 118</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*outputQueueDescriptor, info);</div>
463<div class="line"><a name="l00119"></a><span class="lineno"> 119</span>&#160; }</div>
464<div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a4dd48794eb3305a0f5aece88b111a97b">LayerType::MemCopy</a> :</div>
465<div class="line"><a name="l00121"></a><span class="lineno"> 121</span>&#160; {</div>
466<div class="line"><a name="l00122"></a><span class="lineno"> 122</span>&#160; <span class="keyword">auto</span> memCopyQueueDescriptor = PolymorphicDowncast&lt;const MemCopyQueueDescriptor*&gt;(&amp;descriptor);</div>
467<div class="line"><a name="l00123"></a><span class="lineno"> 123</span>&#160; <span class="keywordflow">if</span> (memCopyQueueDescriptor-&gt;m_Inputs.empty() || !memCopyQueueDescriptor-&gt;m_Inputs[0])</div>
468<div class="line"><a name="l00124"></a><span class="lineno"> 124</span>&#160; {</div>
469<div class="line"><a name="l00125"></a><span class="lineno"> 125</span>&#160; <span class="keywordflow">throw</span> InvalidArgumentException(<span class="stringliteral">&quot;GpuFsaWorkloadFactory: Invalid null input for MemCopy workload&quot;</span>);</div>
470<div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; }</div>
471<div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;CopyMemGenericWorkload&gt;(*memCopyQueueDescriptor, info);</div>
472<div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160; }</div>
473<div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; <span class="keywordflow">case</span> <a class="code" href="namespacearmnn.html#a56943a0946e5f15e5e58054b8e7a04a4a1ba143ebe524d46181a4b53470693278">LayerType::PreCompiled</a> :</div>
474<div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160; {</div>
475<div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; <span class="keyword">auto</span> precompiledQueueDescriptor = PolymorphicDowncast&lt;const PreCompiledQueueDescriptor*&gt;(&amp;descriptor);</div>
476<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; <span class="keywordflow">return</span> std::make_unique&lt;GpuFsaPreCompiledWorkload&gt;(*precompiledQueueDescriptor, info);</div>
477<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; }</div>
478<div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; default :</div>
479<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; <span class="keywordflow">return</span> <span class="keyword">nullptr</span>;</div>
480<div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; }</div>
481<div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160;}</div>
482</div><!-- fragment -->
483<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>
484
485</div>
486</div>
487<a id="ae2cd7e29596b68884bfaade25f8f0dc0"></a>
488<h2 class="memtitle"><span class="permalink"><a href="#ae2cd7e29596b68884bfaade25f8f0dc0">&#9670;&nbsp;</a></span>GetBackendId()</h2>
489
490<div class="memitem">
491<div class="memproto">
492<table class="mlabels">
493 <tr>
494 <td class="mlabels-left">
495 <table class="memname">
496 <tr>
497 <td class="memname">const <a class="el" href="classarmnn_1_1_backend_id.html">BackendId</a> &amp; GetBackendId </td>
498 <td>(</td>
499 <td class="paramname"></td><td>)</td>
500 <td> const</td>
501 </tr>
502 </table>
503 </td>
504 <td class="mlabels-right">
505<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
506 </tr>
507</table>
508</div><div class="memdoc">
509
510<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a9f7e4296485d2812e7996089149c96d1">IWorkloadFactory</a>.</p>
511
512<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>
513<div class="fragment"><div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160;{</div>
514<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160; <span class="keywordflow">return</span> s_Id;</div>
515<div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160;}</div>
516</div><!-- fragment -->
517</div>
518</div>
519<a id="ab39a3049bfb85aa489a809d77f3ec1e0"></a>
520<h2 class="memtitle"><span class="permalink"><a href="#ab39a3049bfb85aa489a809d77f3ec1e0">&#9670;&nbsp;</a></span>InitializeCLCompileContext()</h2>
521
522<div class="memitem">
523<div class="memproto">
524 <table class="memname">
525 <tr>
526 <td class="memname">void InitializeCLCompileContext </td>
527 <td>(</td>
528 <td class="paramname"></td><td>)</td>
529 <td></td>
530 </tr>
531 </table>
532</div><div class="memdoc">
533
534<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>
535<div class="fragment"><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; {</div>
536<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <span class="comment">// Initialize our m_CLCompileContext using default device and context</span></div>
537<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160; <span class="keyword">auto</span> context = arm_compute::CLKernelLibrary::get().context();</div>
538<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160; <span class="keyword">auto</span> device = arm_compute::CLKernelLibrary::get().get_device();</div>
539<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160; m_CLCompileContext = arm_compute::CLCompileContext(context, device);</div>
540<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160;}</div>
541</div><!-- fragment -->
542<p class="reference">Referenced by <a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html#l00048">GpuFsaWorkloadFactory::GpuFsaWorkloadFactory()</a>.</p>
543
544</div>
545</div>
546<a id="a9992ea7c353e8597fbd8ae426f4612ae"></a>
547<h2 class="memtitle"><span class="permalink"><a href="#a9992ea7c353e8597fbd8ae426f4612ae">&#9670;&nbsp;</a></span>IsLayerSupported()</h2>
548
549<div class="memitem">
550<div class="memproto">
551<table class="mlabels">
552 <tr>
553 <td class="mlabels-left">
554 <table class="memname">
555 <tr>
556 <td class="memname">bool IsLayerSupported </td>
557 <td>(</td>
558 <td class="paramtype">const <a class="el" href="classarmnn_1_1_layer.html">Layer</a> &amp;&#160;</td>
559 <td class="paramname"><em>layer</em>, </td>
560 </tr>
561 <tr>
562 <td class="paramkey"></td>
563 <td></td>
564 <td class="paramtype"><a class="el" href="classarmnn_1_1_optional.html">Optional</a>&lt; <a class="el" href="namespacearmnn.html#ad8ed01ff3ff33333d8e19db4d2818bb6">DataType</a> &gt;&#160;</td>
565 <td class="paramname"><em>dataType</em>, </td>
566 </tr>
567 <tr>
568 <td class="paramkey"></td>
569 <td></td>
570 <td class="paramtype">std::string &amp;&#160;</td>
571 <td class="paramname"><em>outReasonIfUnsupported</em>&#160;</td>
572 </tr>
573 <tr>
574 <td></td>
575 <td>)</td>
576 <td></td><td></td>
577 </tr>
578 </table>
579 </td>
580 <td class="mlabels-right">
581<span class="mlabels"><span class="mlabel">static</span></span> </td>
582 </tr>
583</table>
584</div><div class="memdoc">
585
586<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>
587<div class="fragment"><div class="line"><a name="l00068"></a><span class="lineno"> 68</span>&#160;{</div>
588<div class="line"><a name="l00069"></a><span class="lineno"> 69</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>
589<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160;}</div>
590</div><!-- fragment -->
Nikhil Raj1dc83fe2024-05-16 09:47:51 +0100591<p class="reference">References <a class="el" href="_workload_factory_8cpp_source.html#l01629">IWorkloadFactory::IsLayerSupported()</a>.</p>
Nikhil Raj38b600d2024-02-15 15:02:19 +0000592
593</div>
594</div>
595<a id="aed0a782f32856bde72bc10d9381dc11e"></a>
596<h2 class="memtitle"><span class="permalink"><a href="#aed0a782f32856bde72bc10d9381dc11e">&#9670;&nbsp;</a></span>SupportsSubTensors()</h2>
597
598<div class="memitem">
599<div class="memproto">
600<table class="mlabels">
601 <tr>
602 <td class="mlabels-left">
603 <table class="memname">
604 <tr>
605 <td class="memname">bool SupportsSubTensors </td>
606 <td>(</td>
607 <td class="paramname"></td><td>)</td>
608 <td> const</td>
609 </tr>
610 </table>
611 </td>
612 <td class="mlabels-right">
613<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
614 </tr>
615</table>
616</div><div class="memdoc">
617
618<p>Implements <a class="el" href="classarmnn_1_1_i_workload_factory.html#a37f4eba7877deb34f4d8d64c9bcb9ab5">IWorkloadFactory</a>.</p>
619
620<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>
621<div class="fragment"><div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160;{ <span class="keywordflow">return</span> <span class="keyword">false</span>; }</div>
622</div><!-- fragment -->
623</div>
624</div>
625<hr/>The documentation for this class was generated from the following files:<ul>
626<li>src/backends/gpuFsa/<a class="el" href="_gpu_fsa_workload_factory_8hpp_source.html">GpuFsaWorkloadFactory.hpp</a></li>
627<li>src/backends/gpuFsa/<a class="el" href="_gpu_fsa_workload_factory_8cpp_source.html">GpuFsaWorkloadFactory.cpp</a></li>
628</ul>
629</div><!-- contents -->
630</div><!-- doc-content -->
631<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>
Nikhil Raj1dc83fe2024-05-16 09:47:51 +0100632<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>
Nikhil Raj38b600d2024-02-15 15:02:19 +0000633<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>
634<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>
635<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>
636<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>
637<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>
638<!-- start footer part -->
639<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
640 <ul>
641 <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>
Nikhil Raj1dc83fe2024-05-16 09:47:51 +0100642 <li class="footer">Generated on Thu May 16 2024 09:31:56 for Arm NN by
Nikhil Raj38b600d2024-02-15 15:02:19 +0000643 <a href="http://www.doxygen.org/index.html">
644 <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.17 </li>
645 </ul>
646</div>
647</body>
648</html>