blob: 7ad71e37935a5125a455a50abea651418400d801 [file] [log] [blame]
Nikhil Raj1dc83fe2024-05-16 09:47:51 +01001<!-- 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: ClConvertFp32ToFp16Workload 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">
39 &#160;<span id="projectnumber">24.05</span>
40 </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_cl_convert_fp32_to_fp16_workload.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="classarmnn_1_1_cl_convert_fp32_to_fp16_workload-members.html">List of all members</a> </div>
98 <div class="headertitle">
99<div class="title">ClConvertFp32ToFp16Workload Class Reference</div> </div>
100</div><!--header-->
101<div class="contents">
102
103<p><code>#include &lt;<a class="el" href="_cl_convert_fp32_to_fp16_workload_8hpp_source.html">ClConvertFp32ToFp16Workload.hpp</a>&gt;</code></p>
104<div class="dynheader">
105Inheritance diagram for ClConvertFp32ToFp16Workload:</div>
106<div class="dyncontent">
107<div class="center"><iframe scrolling="no" frameborder="0" src="classarmnn_1_1_cl_convert_fp32_to_fp16_workload__inherit__graph.svg" width="302" height="276"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
108</div>
109<center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div>
110<div class="dynheader">
111Collaboration diagram for ClConvertFp32ToFp16Workload:</div>
112<div class="dyncontent">
113<div class="center"><iframe scrolling="no" frameborder="0" src="classarmnn_1_1_cl_convert_fp32_to_fp16_workload__coll__graph.svg" width="302" height="294"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
114</div>
115<center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div>
116<table class="memberdecls">
117<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
118Public Member Functions</h2></td></tr>
119<tr class="memitem:a339943596f4ef5bb9bd0d0228d049c2c"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_cl_convert_fp32_to_fp16_workload.html#a339943596f4ef5bb9bd0d0228d049c2c">ClConvertFp32ToFp16Workload</a> (const <a class="el" href="structarmnn_1_1_convert_fp32_to_fp16_queue_descriptor.html">ConvertFp32ToFp16QueueDescriptor</a> &amp;descriptor, const <a class="el" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a> &amp;info, const arm_compute::CLCompileContext &amp;clCompileContext)</td></tr>
120<tr class="separator:a339943596f4ef5bb9bd0d0228d049c2c"><td class="memSeparator" colspan="2">&#160;</td></tr>
121<tr class="memitem:ae071e8822437c78baea75c3aef3a263a"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_cl_convert_fp32_to_fp16_workload.html#ae071e8822437c78baea75c3aef3a263a">Execute</a> () const override</td></tr>
122<tr class="separator:ae071e8822437c78baea75c3aef3a263a"><td class="memSeparator" colspan="2">&#160;</td></tr>
123<tr class="memitem:ac145e7f83bc14257d8d4f9941245163f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_cl_convert_fp32_to_fp16_workload.html#ac145e7f83bc14257d8d4f9941245163f">SupportsTensorHandleReplacement</a> () const override</td></tr>
124<tr class="separator:ac145e7f83bc14257d8d4f9941245163f"><td class="memSeparator" colspan="2">&#160;</td></tr>
125<tr class="memitem:ab0a67f8179ddb997dda0070a6661f837"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_cl_convert_fp32_to_fp16_workload.html#ab0a67f8179ddb997dda0070a6661f837">ReplaceInputTensorHandle</a> (<a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> *tensorHandle, unsigned int slot) override</td></tr>
126<tr class="separator:ab0a67f8179ddb997dda0070a6661f837"><td class="memSeparator" colspan="2">&#160;</td></tr>
127<tr class="memitem:acc08590544f05c641d21c724aedf26dd"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_cl_convert_fp32_to_fp16_workload.html#acc08590544f05c641d21c724aedf26dd">ReplaceOutputTensorHandle</a> (<a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> *tensorHandle, unsigned int slot) override</td></tr>
128<tr class="separator:acc08590544f05c641d21c724aedf26dd"><td class="memSeparator" colspan="2">&#160;</td></tr>
129<tr class="inherit_header pub_methods_classarmnn_1_1_multi_typed_workload"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_classarmnn_1_1_multi_typed_workload')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="classarmnn_1_1_multi_typed_workload.html">MultiTypedWorkload&lt; QueueDescriptor, InputDataType, OutputDataType &gt;</a></td></tr>
130<tr class="memitem:ab020f6e4ccf7b3e8b3c0a88dccf89d50 inherit pub_methods_classarmnn_1_1_multi_typed_workload"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_multi_typed_workload.html#ab020f6e4ccf7b3e8b3c0a88dccf89d50">MultiTypedWorkload</a> (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)</td></tr>
131<tr class="separator:ab020f6e4ccf7b3e8b3c0a88dccf89d50 inherit pub_methods_classarmnn_1_1_multi_typed_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
132<tr class="inherit_header pub_methods_classarmnn_1_1_base_workload"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_classarmnn_1_1_base_workload')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="classarmnn_1_1_base_workload.html">BaseWorkload&lt; QueueDescriptor &gt;</a></td></tr>
133<tr class="memitem:af2ef420610280dc5a661cd3d4836d5a2 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#af2ef420610280dc5a661cd3d4836d5a2">BaseWorkload</a> (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)</td></tr>
134<tr class="separator:af2ef420610280dc5a661cd3d4836d5a2 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
135<tr class="memitem:a163c04b26f9804eafc598a047128f887 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">virtual const std::string &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#a163c04b26f9804eafc598a047128f887">GetName</a> () const override</td></tr>
136<tr class="separator:a163c04b26f9804eafc598a047128f887 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
137<tr class="memitem:ae1c43d025fc90382d7aff7a500937e2c inherit pub_methods_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#ae1c43d025fc90382d7aff7a500937e2c">ExecuteAsync</a> (<a class="el" href="structarmnn_1_1experimental_1_1_execution_data.html">ExecutionData</a> &amp;executionData) override</td></tr>
138<tr class="separator:ae1c43d025fc90382d7aff7a500937e2c inherit pub_methods_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
139<tr class="memitem:a81627f96ba06d76e147f7d392a8117ed inherit pub_methods_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#a81627f96ba06d76e147f7d392a8117ed">PostAllocationConfigure</a> () override</td></tr>
140<tr class="separator:a81627f96ba06d76e147f7d392a8117ed inherit pub_methods_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
141<tr class="memitem:a965cf380c7adf547d0f14b3f6d1da249 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">const <a class="el" href="structarmnn_1_1_queue_descriptor.html">QueueDescriptor</a> &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#a965cf380c7adf547d0f14b3f6d1da249">GetData</a> () const</td></tr>
142<tr class="separator:a965cf380c7adf547d0f14b3f6d1da249 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
143<tr class="memitem:aaff95a48875d8fb4a616352906660ca9 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">arm::pipe::ProfilingGuid&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#aaff95a48875d8fb4a616352906660ca9">GetGuid</a> () const final</td></tr>
144<tr class="separator:aaff95a48875d8fb4a616352906660ca9 inherit pub_methods_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
145<tr class="inherit_header pub_methods_classarmnn_1_1_i_workload"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_classarmnn_1_1_i_workload')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="classarmnn_1_1_i_workload.html">IWorkload</a></td></tr>
146<tr class="memitem:a69c83c02ae8de866bc7a46c49e69c1ba inherit pub_methods_classarmnn_1_1_i_workload"><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload.html#a69c83c02ae8de866bc7a46c49e69c1ba">~IWorkload</a> ()</td></tr>
147<tr class="separator:a69c83c02ae8de866bc7a46c49e69c1ba inherit pub_methods_classarmnn_1_1_i_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
148<tr class="memitem:ab81312bd5e64cbae2803de9f243bdb32 inherit pub_methods_classarmnn_1_1_i_workload"><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.html#ab81312bd5e64cbae2803de9f243bdb32">RegisterDebugCallback</a> (const <a class="el" href="namespacearmnn.html#a15f3ad9b5e4e3d46b0a6dda246a7bc28">DebugCallbackFunction</a> &amp;)</td></tr>
149<tr class="separator:ab81312bd5e64cbae2803de9f243bdb32 inherit pub_methods_classarmnn_1_1_i_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
150<tr class="memitem:a2d2834d1029217934f504e3e59579081 inherit pub_methods_classarmnn_1_1_i_workload"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="classarmnn_1_1_optional.html">armnn::Optional</a>&lt; <a class="el" href="structarmnn_1_1_memory_requirements.html">armnn::MemoryRequirements</a> &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_workload.html#a2d2834d1029217934f504e3e59579081">GetMemoryRequirements</a> ()</td></tr>
151<tr class="separator:a2d2834d1029217934f504e3e59579081 inherit pub_methods_classarmnn_1_1_i_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
152</table><table class="memberdecls">
153<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="inherited"></a>
154Additional Inherited Members</h2></td></tr>
155<tr class="inherit_header pro_attribs_classarmnn_1_1_base_workload"><td colspan="2" onclick="javascript:toggleInherit('pro_attribs_classarmnn_1_1_base_workload')"><img src="closed.png" alt="-"/>&#160;Protected Attributes inherited from <a class="el" href="classarmnn_1_1_base_workload.html">BaseWorkload&lt; QueueDescriptor &gt;</a></td></tr>
156<tr class="memitem:afb8d2c8817c75de9d01a4c0e0d5c160b inherit pro_attribs_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top"><a class="el" href="structarmnn_1_1_queue_descriptor.html">QueueDescriptor</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a></td></tr>
157<tr class="separator:afb8d2c8817c75de9d01a4c0e0d5c160b inherit pro_attribs_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
158<tr class="memitem:a4c2b3ca86eec6c199364671af267cd2c inherit pro_attribs_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">const arm::pipe::ProfilingGuid&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#a4c2b3ca86eec6c199364671af267cd2c">m_Guid</a></td></tr>
159<tr class="separator:a4c2b3ca86eec6c199364671af267cd2c inherit pro_attribs_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
160<tr class="memitem:a77806f89d6edb879d3f6c6b6b18168a7 inherit pro_attribs_classarmnn_1_1_base_workload"><td class="memItemLeft" align="right" valign="top">const std::string&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_base_workload.html#a77806f89d6edb879d3f6c6b6b18168a7">m_Name</a></td></tr>
161<tr class="separator:a77806f89d6edb879d3f6c6b6b18168a7 inherit pro_attribs_classarmnn_1_1_base_workload"><td class="memSeparator" colspan="2">&#160;</td></tr>
162</table>
163<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
164<div class="textblock">
165<p class="definition">Definition at line <a class="el" href="_cl_convert_fp32_to_fp16_workload_8hpp_source.html#l00017">17</a> of file <a class="el" href="_cl_convert_fp32_to_fp16_workload_8hpp_source.html">ClConvertFp32ToFp16Workload.hpp</a>.</p>
166</div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
167<a id="a339943596f4ef5bb9bd0d0228d049c2c"></a>
168<h2 class="memtitle"><span class="permalink"><a href="#a339943596f4ef5bb9bd0d0228d049c2c">&#9670;&nbsp;</a></span>ClConvertFp32ToFp16Workload()</h2>
169
170<div class="memitem">
171<div class="memproto">
172 <table class="memname">
173 <tr>
174 <td class="memname"><a class="el" href="classarmnn_1_1_cl_convert_fp32_to_fp16_workload.html">ClConvertFp32ToFp16Workload</a> </td>
175 <td>(</td>
176 <td class="paramtype">const <a class="el" href="structarmnn_1_1_convert_fp32_to_fp16_queue_descriptor.html">ConvertFp32ToFp16QueueDescriptor</a> &amp;&#160;</td>
177 <td class="paramname"><em>descriptor</em>, </td>
178 </tr>
179 <tr>
180 <td class="paramkey"></td>
181 <td></td>
182 <td class="paramtype">const <a class="el" href="structarmnn_1_1_workload_info.html">WorkloadInfo</a> &amp;&#160;</td>
183 <td class="paramname"><em>info</em>, </td>
184 </tr>
185 <tr>
186 <td class="paramkey"></td>
187 <td></td>
188 <td class="paramtype">const arm_compute::CLCompileContext &amp;&#160;</td>
189 <td class="paramname"><em>clCompileContext</em>&#160;</td>
190 </tr>
191 <tr>
192 <td></td>
193 <td>)</td>
194 <td></td><td></td>
195 </tr>
196 </table>
197</div><div class="memdoc">
198
199<p class="definition">Definition at line <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html#l00017">17</a> of file <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html">ClConvertFp32ToFp16Workload.cpp</a>.</p>
200<div class="fragment"><div class="line"><a name="l00020"></a><span class="lineno"> 20</span>&#160; :</div>
201<div class="line"><a name="l00021"></a><span class="lineno"> 21</span>&#160; Float32ToFloat16Workload&lt;ConvertFp32ToFp16QueueDescriptor&gt;(descriptor, info)</div>
202<div class="line"><a name="l00022"></a><span class="lineno"> 22</span>&#160;{</div>
203<div class="line"><a name="l00023"></a><span class="lineno"> 23</span>&#160; this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a765d2cee4ccce5b9467e0c2b6d25b84a">ValidateInputsOutputs</a>(<span class="stringliteral">&quot;ClConvertFp32ToFp16Workload&quot;</span>, 1, 1);</div>
204<div class="line"><a name="l00024"></a><span class="lineno"> 24</span>&#160; </div>
205<div class="line"><a name="l00025"></a><span class="lineno"> 25</span>&#160; arm_compute::ICLTensor&amp; input = <span class="keyword">static_cast&lt;</span>IClTensorHandle*<span class="keyword">&gt;</span>(this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>[0])-&gt;GetTensor();</div>
206<div class="line"><a name="l00026"></a><span class="lineno"> 26</span>&#160; arm_compute::ICLTensor&amp; output = <span class="keyword">static_cast&lt;</span>IClTensorHandle*<span class="keyword">&gt;</span>(this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a6abd491bb99ffe88bd472c1ae5a1ed1a">m_Outputs</a>[0])-&gt;GetTensor();</div>
207<div class="line"><a name="l00027"></a><span class="lineno"> 27</span>&#160; </div>
208<div class="line"><a name="l00028"></a><span class="lineno"> 28</span>&#160; <span class="comment">// Create Proxy tensor and set the initial tensor handle to it</span></div>
209<div class="line"><a name="l00029"></a><span class="lineno"> 29</span>&#160; m_InputProxy = std::make_unique&lt;ICLTensorProxy&gt;(&amp;input);</div>
210<div class="line"><a name="l00030"></a><span class="lineno"> 30</span>&#160; m_OutputProxy = std::make_unique&lt;ICLTensorProxy&gt;(&amp;output);</div>
211<div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160; </div>
212<div class="line"><a name="l00032"></a><span class="lineno"> 32</span>&#160; {</div>
213<div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160; <a class="code" href="_cl_workload_utils_8hpp.html#a2d57ef1645138f5f8a6dbd2ce92dc072">ARMNN_SCOPED_PROFILING_EVENT_CL_NAME_GUID</a>(<span class="stringliteral">&quot;ClConvertFp32ToFp16Workload_configure&quot;</span>);</div>
214<div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160; <a class="code" href="_subgraph_view_selector_8cpp.html#ac0f60caa770d0eda339103aa4098ad15">m_Layer</a>.configure(clCompileContext, m_InputProxy.get(), m_OutputProxy.get(), g_AclConvertPolicy, 0);</div>
215<div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160; }</div>
216<div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160;}</div>
217</div><!-- fragment -->
218<p class="reference">References <a class="el" href="_cl_workload_utils_8hpp_source.html#l00036">ARMNN_SCOPED_PROFILING_EVENT_CL_NAME_GUID</a>, <a class="el" href="namespacearmnn.html#a4dc0adc6737b5944e7671bee71788407acaf9b6b99962bf5c2264824231d7a40c">armnn::info</a>, <a class="el" href="_workload_8hpp_source.html#l00089">BaseWorkload&lt; QueueDescriptor &gt;::m_Data</a>, <a class="el" href="_workload_data_8hpp_source.html#l00026">QueueDescriptor::m_Inputs</a>, <a class="el" href="_workload_data_8hpp_source.html#l00027">QueueDescriptor::m_Outputs</a>, and <a class="el" href="_workload_data_8cpp_source.html#l00447">QueueDescriptor::ValidateInputsOutputs()</a>.</p>
219
220</div>
221</div>
222<h2 class="groupheader">Member Function Documentation</h2>
223<a id="ae071e8822437c78baea75c3aef3a263a"></a>
224<h2 class="memtitle"><span class="permalink"><a href="#ae071e8822437c78baea75c3aef3a263a">&#9670;&nbsp;</a></span>Execute()</h2>
225
226<div class="memitem">
227<div class="memproto">
228<table class="mlabels">
229 <tr>
230 <td class="mlabels-left">
231 <table class="memname">
232 <tr>
233 <td class="memname">void Execute </td>
234 <td>(</td>
235 <td class="paramname"></td><td>)</td>
236 <td> const</td>
237 </tr>
238 </table>
239 </td>
240 <td class="mlabels-right">
241<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
242 </tr>
243</table>
244</div><div class="memdoc">
245
246<p>Implements <a class="el" href="classarmnn_1_1_i_workload.html#a72ae00e6604850c8798c5e0d825ee7e4">IWorkload</a>.</p>
247
248<p class="definition">Definition at line <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html#l00038">38</a> of file <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html">ClConvertFp32ToFp16Workload.cpp</a>.</p>
249<div class="fragment"><div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160;{</div>
250<div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160; <a class="code" href="_cl_workload_utils_8hpp.html#a2d57ef1645138f5f8a6dbd2ce92dc072">ARMNN_SCOPED_PROFILING_EVENT_CL_NAME_GUID</a>(<span class="stringliteral">&quot;ClConvertFp32ToFp16Workload_Execute&quot;</span>);</div>
251<div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160; <a class="code" href="namespacearmnn.html#a52c299ca6a3884c609583a5a0663db80">RunClFunction</a>(<a class="code" href="_subgraph_view_selector_8cpp.html#ac0f60caa770d0eda339103aa4098ad15">m_Layer</a>, <a class="code" href="_exceptions_8hpp.html#aa3be76aec4ce713822a5ea1ecbb7bc61">CHECK_LOCATION</a>());</div>
252<div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160;}</div>
253</div><!-- fragment -->
254<p class="reference">References <a class="el" href="_cl_workload_utils_8hpp_source.html#l00036">ARMNN_SCOPED_PROFILING_EVENT_CL_NAME_GUID</a>, <a class="el" href="_exceptions_8hpp_source.html#l00203">CHECK_LOCATION</a>, and <a class="el" href="_cl_workload_utils_8hpp_source.html#l00167">armnn::RunClFunction()</a>.</p>
255
256</div>
257</div>
258<a id="ab0a67f8179ddb997dda0070a6661f837"></a>
259<h2 class="memtitle"><span class="permalink"><a href="#ab0a67f8179ddb997dda0070a6661f837">&#9670;&nbsp;</a></span>ReplaceInputTensorHandle()</h2>
260
261<div class="memitem">
262<div class="memproto">
263<table class="mlabels">
264 <tr>
265 <td class="mlabels-left">
266 <table class="memname">
267 <tr>
268 <td class="memname">void ReplaceInputTensorHandle </td>
269 <td>(</td>
270 <td class="paramtype"><a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> *&#160;</td>
271 <td class="paramname"><em>tensorHandle</em>, </td>
272 </tr>
273 <tr>
274 <td class="paramkey"></td>
275 <td></td>
276 <td class="paramtype">unsigned int&#160;</td>
277 <td class="paramname"><em>slot</em>&#160;</td>
278 </tr>
279 <tr>
280 <td></td>
281 <td>)</td>
282 <td></td><td></td>
283 </tr>
284 </table>
285 </td>
286 <td class="mlabels-right">
287<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
288 </tr>
289</table>
290</div><div class="memdoc">
291
292<p>Reimplemented from <a class="el" href="classarmnn_1_1_base_workload.html#ab0a67f8179ddb997dda0070a6661f837">BaseWorkload&lt; QueueDescriptor &gt;</a>.</p>
293
294<p class="definition">Definition at line <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html#l00064">64</a> of file <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html">ClConvertFp32ToFp16Workload.cpp</a>.</p>
295<div class="fragment"><div class="line"><a name="l00065"></a><span class="lineno"> 65</span>&#160;{</div>
296<div class="line"><a name="l00066"></a><span class="lineno"> 66</span>&#160; ITensorHandle* backupHandle = this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>[slot];</div>
297<div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160; this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>[slot] = tensorHandle;</div>
298<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>&#160; <span class="keywordflow">try</span></div>
299<div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160; {</div>
300<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160; Reconfigure();</div>
301<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; }</div>
302<div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; <span class="keywordflow">catch</span>(<a class="code" href="classarmnn_1_1_unimplemented_exception.html">armnn::UnimplementedException</a>&amp; e)</div>
303<div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; {</div>
304<div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160; <span class="comment">// Cannot reconfigure, revert the slot back and throw the exception.</span></div>
305<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">m_Inputs</a>[slot] = backupHandle;</div>
306<div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; <span class="keywordflow">throw</span> e;</div>
307<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; }</div>
308<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160;}</div>
309</div><!-- fragment -->
310<p class="reference">References <a class="el" href="_workload_8hpp_source.html#l00089">BaseWorkload&lt; QueueDescriptor &gt;::m_Data</a>, and <a class="el" href="_workload_data_8hpp_source.html#l00026">QueueDescriptor::m_Inputs</a>.</p>
311
312</div>
313</div>
314<a id="acc08590544f05c641d21c724aedf26dd"></a>
315<h2 class="memtitle"><span class="permalink"><a href="#acc08590544f05c641d21c724aedf26dd">&#9670;&nbsp;</a></span>ReplaceOutputTensorHandle()</h2>
316
317<div class="memitem">
318<div class="memproto">
319<table class="mlabels">
320 <tr>
321 <td class="mlabels-left">
322 <table class="memname">
323 <tr>
324 <td class="memname">void ReplaceOutputTensorHandle </td>
325 <td>(</td>
326 <td class="paramtype"><a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> *&#160;</td>
327 <td class="paramname"><em>tensorHandle</em>, </td>
328 </tr>
329 <tr>
330 <td class="paramkey"></td>
331 <td></td>
332 <td class="paramtype">unsigned int&#160;</td>
333 <td class="paramname"><em>slot</em>&#160;</td>
334 </tr>
335 <tr>
336 <td></td>
337 <td>)</td>
338 <td></td><td></td>
339 </tr>
340 </table>
341 </td>
342 <td class="mlabels-right">
343<span class="mlabels"><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
344 </tr>
345</table>
346</div><div class="memdoc">
347
348<p>Reimplemented from <a class="el" href="classarmnn_1_1_base_workload.html#acc08590544f05c641d21c724aedf26dd">BaseWorkload&lt; QueueDescriptor &gt;</a>.</p>
349
350<p class="definition">Definition at line <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html#l00081">81</a> of file <a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html">ClConvertFp32ToFp16Workload.cpp</a>.</p>
351<div class="fragment"><div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160;{</div>
352<div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160; ITensorHandle* backupHandle = this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a6abd491bb99ffe88bd472c1ae5a1ed1a">m_Outputs</a>[slot];</div>
353<div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a6abd491bb99ffe88bd472c1ae5a1ed1a">m_Outputs</a>[slot] = tensorHandle;</div>
354<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; <span class="keywordflow">try</span></div>
355<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; {</div>
356<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160; Reconfigure();</div>
357<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; }</div>
358<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160; <span class="keywordflow">catch</span>(<a class="code" href="classarmnn_1_1_unimplemented_exception.html">armnn::UnimplementedException</a>&amp; e)</div>
359<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; {</div>
360<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; <span class="comment">// Cannot reconfigure, revert the slot back and throw the exception.</span></div>
361<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; this-&gt;<a class="code" href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">m_Data</a>.<a class="code" href="structarmnn_1_1_queue_descriptor.html#a6abd491bb99ffe88bd472c1ae5a1ed1a">m_Outputs</a>[slot] = backupHandle;</div>
362<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <span class="keywordflow">throw</span> e;</div>
363<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160; }</div>
364<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160;}</div>
365</div><!-- fragment -->
366<p class="reference">References <a class="el" href="_workload_8hpp_source.html#l00089">BaseWorkload&lt; QueueDescriptor &gt;::m_Data</a>, and <a class="el" href="_workload_data_8hpp_source.html#l00027">QueueDescriptor::m_Outputs</a>.</p>
367
368</div>
369</div>
370<a id="ac145e7f83bc14257d8d4f9941245163f"></a>
371<h2 class="memtitle"><span class="permalink"><a href="#ac145e7f83bc14257d8d4f9941245163f">&#9670;&nbsp;</a></span>SupportsTensorHandleReplacement()</h2>
372
373<div class="memitem">
374<div class="memproto">
375<table class="mlabels">
376 <tr>
377 <td class="mlabels-left">
378 <table class="memname">
379 <tr>
380 <td class="memname">bool SupportsTensorHandleReplacement </td>
381 <td>(</td>
382 <td class="paramname"></td><td>)</td>
383 <td> const</td>
384 </tr>
385 </table>
386 </td>
387 <td class="mlabels-right">
388<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
389 </tr>
390</table>
391</div><div class="memdoc">
392
393<p>Reimplemented from <a class="el" href="classarmnn_1_1_base_workload.html#a0c326c344355d8423217e9431781f2ee">BaseWorkload&lt; QueueDescriptor &gt;</a>.</p>
394
395<p class="definition">Definition at line <a class="el" href="_cl_convert_fp32_to_fp16_workload_8hpp_source.html#l00026">26</a> of file <a class="el" href="_cl_convert_fp32_to_fp16_workload_8hpp_source.html">ClConvertFp32ToFp16Workload.hpp</a>.</p>
396<div class="fragment"><div class="line"><a name="l00026"></a><span class="lineno"> 26</span>&#160;{ <span class="keywordflow">return</span> <span class="keyword">true</span>;};</div>
397</div><!-- fragment -->
398</div>
399</div>
400<hr/>The documentation for this class was generated from the following files:<ul>
401<li>src/backends/cl/workloads/<a class="el" href="_cl_convert_fp32_to_fp16_workload_8hpp_source.html">ClConvertFp32ToFp16Workload.hpp</a></li>
402<li>src/backends/cl/workloads/<a class="el" href="_cl_convert_fp32_to_fp16_workload_8cpp_source.html">ClConvertFp32ToFp16Workload.cpp</a></li>
403</ul>
404</div><!-- contents -->
405</div><!-- doc-content -->
406<div class="ttc" id="astructarmnn_1_1_queue_descriptor_html_a765d2cee4ccce5b9467e0c2b6d25b84a"><div class="ttname"><a href="structarmnn_1_1_queue_descriptor.html#a765d2cee4ccce5b9467e0c2b6d25b84a">armnn::QueueDescriptor::ValidateInputsOutputs</a></div><div class="ttdeci">void ValidateInputsOutputs(const std::string &amp;descName, unsigned int numExpectedIn, unsigned int numExpectedOut) const</div><div class="ttdef"><b>Definition:</b> <a href="_workload_data_8cpp_source.html#l00447">WorkloadData.cpp:447</a></div></div>
407<div class="ttc" id="a_subgraph_view_selector_8cpp_html_ac0f60caa770d0eda339103aa4098ad15"><div class="ttname"><a href="_subgraph_view_selector_8cpp.html#ac0f60caa770d0eda339103aa4098ad15">m_Layer</a></div><div class="ttdeci">IConnectableLayer * m_Layer</div><div class="ttdef"><b>Definition:</b> <a href="_subgraph_view_selector_8cpp_source.html#l00257">SubgraphViewSelector.cpp:257</a></div></div>
408<div class="ttc" id="a_exceptions_8hpp_html_aa3be76aec4ce713822a5ea1ecbb7bc61"><div class="ttname"><a href="_exceptions_8hpp.html#aa3be76aec4ce713822a5ea1ecbb7bc61">CHECK_LOCATION</a></div><div class="ttdeci">#define CHECK_LOCATION()</div><div class="ttdef"><b>Definition:</b> <a href="_exceptions_8hpp_source.html#l00203">Exceptions.hpp:203</a></div></div>
409<div class="ttc" id="a_cl_workload_utils_8hpp_html_a2d57ef1645138f5f8a6dbd2ce92dc072"><div class="ttname"><a href="_cl_workload_utils_8hpp.html#a2d57ef1645138f5f8a6dbd2ce92dc072">ARMNN_SCOPED_PROFILING_EVENT_CL_NAME_GUID</a></div><div class="ttdeci">#define ARMNN_SCOPED_PROFILING_EVENT_CL_NAME_GUID(label)</div><div class="ttdoc">Creates a profiling event that uses GetGuid() and GetName() from the calling class.</div><div class="ttdef"><b>Definition:</b> <a href="_cl_workload_utils_8hpp_source.html#l00036">ClWorkloadUtils.hpp:36</a></div></div>
410<div class="ttc" id="astructarmnn_1_1_queue_descriptor_html_a6abd491bb99ffe88bd472c1ae5a1ed1a"><div class="ttname"><a href="structarmnn_1_1_queue_descriptor.html#a6abd491bb99ffe88bd472c1ae5a1ed1a">armnn::QueueDescriptor::m_Outputs</a></div><div class="ttdeci">std::vector&lt; ITensorHandle * &gt; m_Outputs</div><div class="ttdef"><b>Definition:</b> <a href="_workload_data_8hpp_source.html#l00027">WorkloadData.hpp:27</a></div></div>
411<div class="ttc" id="aclassarmnn_1_1_base_workload_html_afb8d2c8817c75de9d01a4c0e0d5c160b"><div class="ttname"><a href="classarmnn_1_1_base_workload.html#afb8d2c8817c75de9d01a4c0e0d5c160b">armnn::BaseWorkload::m_Data</a></div><div class="ttdeci">QueueDescriptor m_Data</div><div class="ttdef"><b>Definition:</b> <a href="_workload_8hpp_source.html#l00089">Workload.hpp:89</a></div></div>
412<div class="ttc" id="anamespacearmnn_html_a52c299ca6a3884c609583a5a0663db80"><div class="ttname"><a href="namespacearmnn.html#a52c299ca6a3884c609583a5a0663db80">armnn::RunClFunction</a></div><div class="ttdeci">void RunClFunction(arm_compute::IFunction &amp;function, const CheckLocation &amp;location)</div><div class="ttdef"><b>Definition:</b> <a href="_cl_workload_utils_8hpp_source.html#l00167">ClWorkloadUtils.hpp:167</a></div></div>
413<div class="ttc" id="aclassarmnn_1_1_unimplemented_exception_html"><div class="ttname"><a href="classarmnn_1_1_unimplemented_exception.html">armnn::UnimplementedException</a></div><div class="ttdef"><b>Definition:</b> <a href="_exceptions_8hpp_source.html#l00098">Exceptions.hpp:98</a></div></div>
414<div class="ttc" id="astructarmnn_1_1_queue_descriptor_html_a4b50e46a6810018f3edecfb68b2a76b3"><div class="ttname"><a href="structarmnn_1_1_queue_descriptor.html#a4b50e46a6810018f3edecfb68b2a76b3">armnn::QueueDescriptor::m_Inputs</a></div><div class="ttdeci">std::vector&lt; ITensorHandle * &gt; m_Inputs</div><div class="ttdef"><b>Definition:</b> <a href="_workload_data_8hpp_source.html#l00026">WorkloadData.hpp:26</a></div></div>
415<!-- start footer part -->
416<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
417 <ul>
418 <li class="navelem"><a class="el" href="namespacearmnn.html">armnn</a></li><li class="navelem"><a class="el" href="classarmnn_1_1_cl_convert_fp32_to_fp16_workload.html">ClConvertFp32ToFp16Workload</a></li>
419 <li class="footer">Generated on Thu May 16 2024 09:31:55 for Arm NN by
420 <a href="http://www.doxygen.org/index.html">
421 <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.17 </li>
422 </ul>
423</div>
424</body>
425</html>