blob: 66d47ed92ffc765f5ac1433d2212d375187df39e [file] [log] [blame]
<!-- 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: NeonTensorHandle 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">
&#160;<span id="projectnumber">24.05</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&amp;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&amp;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&amp;dn=gpl-2.0.txt GPL-v2 */
$(document).ready(function(){initNavTree('classarmnn_1_1_neon_tensor_handle.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> &#124;
<a href="classarmnn_1_1_neon_tensor_handle-members.html">List of all members</a> </div>
<div class="headertitle">
<div class="title">NeonTensorHandle Class Reference</div> </div>
</div><!--header-->
<div class="contents">
<p><code>#include &lt;<a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>&gt;</code></p>
<div class="dynheader">
Inheritance diagram for NeonTensorHandle:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classarmnn_1_1_neon_tensor_handle__inherit__graph.svg" width="155" height="187"><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 NeonTensorHandle:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classarmnn_1_1_neon_tensor_handle__coll__graph.svg" width="155" height="187"><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:aec1964e898a1dfc9c6be2f5589c0ee33"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#aec1964e898a1dfc9c6be2f5589c0ee33">NeonTensorHandle</a> (const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &amp;tensorInfo)</td></tr>
<tr class="separator:aec1964e898a1dfc9c6be2f5589c0ee33"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8be757c370ed96fdb90168e2ff0216d6"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a8be757c370ed96fdb90168e2ff0216d6">NeonTensorHandle</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, <a class="el" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a> importFlags=static_cast&lt; <a class="el" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a> &gt;(<a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">MemorySource::Malloc</a>))</td></tr>
<tr class="separator:a8be757c370ed96fdb90168e2ff0216d6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab18b27bb871248e2ba3120eb557dcfe4"><td class="memItemLeft" align="right" valign="top">arm_compute::ITensor &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#ab18b27bb871248e2ba3120eb557dcfe4">GetTensor</a> () override</td></tr>
<tr class="separator:ab18b27bb871248e2ba3120eb557dcfe4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6fde23d85d96f26ac7c33b69a945a922"><td class="memItemLeft" align="right" valign="top">arm_compute::ITensor const &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a6fde23d85d96f26ac7c33b69a945a922">GetTensor</a> () const override</td></tr>
<tr class="separator:a6fde23d85d96f26ac7c33b69a945a922"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac4c894e28b763523748ba2bb718d569d"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#ac4c894e28b763523748ba2bb718d569d">Allocate</a> () override</td></tr>
<tr class="memdesc:ac4c894e28b763523748ba2bb718d569d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Indicate to the memory manager that this resource is no longer active. <a href="classarmnn_1_1_neon_tensor_handle.html#ac4c894e28b763523748ba2bb718d569d">More...</a><br /></td></tr>
<tr class="separator:ac4c894e28b763523748ba2bb718d569d"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a19aa18d78d5ac31e3a3c8f782f0e8606"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a19aa18d78d5ac31e3a3c8f782f0e8606">Manage</a> () override</td></tr>
<tr class="memdesc:a19aa18d78d5ac31e3a3c8f782f0e8606"><td class="mdescLeft">&#160;</td><td class="mdescRight">Indicate to the memory manager that this resource is active. <a href="classarmnn_1_1_neon_tensor_handle.html#a19aa18d78d5ac31e3a3c8f782f0e8606">More...</a><br /></td></tr>
<tr class="separator:a19aa18d78d5ac31e3a3c8f782f0e8606"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab6c52b35388890f2c563afbebfb456a6"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#ab6c52b35388890f2c563afbebfb456a6">GetParent</a> () const override</td></tr>
<tr class="memdesc:ab6c52b35388890f2c563afbebfb456a6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the parent tensor if this is a subtensor. <a href="classarmnn_1_1_neon_tensor_handle.html#ab6c52b35388890f2c563afbebfb456a6">More...</a><br /></td></tr>
<tr class="separator:ab6c52b35388890f2c563afbebfb456a6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad3e63bb560123889f1ec98e40c5f8279"><td class="memItemLeft" align="right" valign="top">virtual arm_compute::DataType&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#ad3e63bb560123889f1ec98e40c5f8279">GetDataType</a> () const override</td></tr>
<tr class="separator:ad3e63bb560123889f1ec98e40c5f8279"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:af9c82a4633347a36ad10c8bfab384396"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#af9c82a4633347a36ad10c8bfab384396">SetMemoryGroup</a> (const std::shared_ptr&lt; arm_compute::IMemoryGroup &gt; &amp;memoryGroup) override</td></tr>
<tr class="separator:af9c82a4633347a36ad10c8bfab384396"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acc3fcce7a100cc3b64247519f22e37fc"><td class="memItemLeft" align="right" valign="top">virtual const void *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#acc3fcce7a100cc3b64247519f22e37fc">Map</a> (bool) const override</td></tr>
<tr class="memdesc:acc3fcce7a100cc3b64247519f22e37fc"><td class="mdescLeft">&#160;</td><td class="mdescRight">Map the tensor data for access. <a href="classarmnn_1_1_neon_tensor_handle.html#acc3fcce7a100cc3b64247519f22e37fc">More...</a><br /></td></tr>
<tr class="separator:acc3fcce7a100cc3b64247519f22e37fc"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a88ab6decf78c152e746b7d8dc2dd931f"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a88ab6decf78c152e746b7d8dc2dd931f">Unmap</a> () const override</td></tr>
<tr class="memdesc:a88ab6decf78c152e746b7d8dc2dd931f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unmap the tensor data. <a href="classarmnn_1_1_neon_tensor_handle.html#a88ab6decf78c152e746b7d8dc2dd931f">More...</a><br /></td></tr>
<tr class="separator:a88ab6decf78c152e746b7d8dc2dd931f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a967f220393d291f71dabce0c06bf9b6c"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a967f220393d291f71dabce0c06bf9b6c">GetStrides</a> () const override</td></tr>
<tr class="memdesc:a967f220393d291f71dabce0c06bf9b6c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the strides for each dimension ordered from largest to smallest where the smallest value is the same as the size of a single element in the tensor. <a href="classarmnn_1_1_neon_tensor_handle.html#a967f220393d291f71dabce0c06bf9b6c">More...</a><br /></td></tr>
<tr class="separator:a967f220393d291f71dabce0c06bf9b6c"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a8e8d2fbabcac19f9e12779080ddff54e"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a8e8d2fbabcac19f9e12779080ddff54e">GetShape</a> () const override</td></tr>
<tr class="memdesc:a8e8d2fbabcac19f9e12779080ddff54e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the number of elements for each dimension ordered from slowest iterating dimension to fastest iterating dimension. <a href="classarmnn_1_1_neon_tensor_handle.html#a8e8d2fbabcac19f9e12779080ddff54e">More...</a><br /></td></tr>
<tr class="separator:a8e8d2fbabcac19f9e12779080ddff54e"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acd3ddbebcda4124217925ae36d551441"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#acd3ddbebcda4124217925ae36d551441">SetImportFlags</a> (<a class="el" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a> importFlags)</td></tr>
<tr class="separator:acd3ddbebcda4124217925ae36d551441"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa1d3334a17a9f136fe65ed833fbf68b4"><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#aa1d3334a17a9f136fe65ed833fbf68b4">GetImportFlags</a> () const override</td></tr>
<tr class="memdesc:aa1d3334a17a9f136fe65ed833fbf68b4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get flags describing supported import sources. <a href="classarmnn_1_1_neon_tensor_handle.html#aa1d3334a17a9f136fe65ed833fbf68b4">More...</a><br /></td></tr>
<tr class="separator:aa1d3334a17a9f136fe65ed833fbf68b4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9b8adcb578eb6f9ad63c21b1fa43bb14"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a9b8adcb578eb6f9ad63c21b1fa43bb14">SetImportEnabledFlag</a> (bool importEnabledFlag)</td></tr>
<tr class="separator:a9b8adcb578eb6f9ad63c21b1fa43bb14"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae69aed5d7a4cc5deb4488dc6841b2096"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#ae69aed5d7a4cc5deb4488dc6841b2096">CanBeImported</a> (void *memory, <a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277">MemorySource</a> source) override</td></tr>
<tr class="memdesc:ae69aed5d7a4cc5deb4488dc6841b2096"><td class="mdescLeft">&#160;</td><td class="mdescRight">Implementations must determine if this memory block can be imported. <a href="classarmnn_1_1_neon_tensor_handle.html#ae69aed5d7a4cc5deb4488dc6841b2096">More...</a><br /></td></tr>
<tr class="separator:ae69aed5d7a4cc5deb4488dc6841b2096"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a468bf13728df2ac9ec772733047ff136"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html#a468bf13728df2ac9ec772733047ff136">Import</a> (void *memory, <a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277">MemorySource</a> source) override</td></tr>
<tr class="memdesc:a468bf13728df2ac9ec772733047ff136"><td class="mdescLeft">&#160;</td><td class="mdescRight">Import externally allocated memory. <a href="classarmnn_1_1_neon_tensor_handle.html#a468bf13728df2ac9ec772733047ff136">More...</a><br /></td></tr>
<tr class="separator:a468bf13728df2ac9ec772733047ff136"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a937b32594cf8f2ea8df5cbb653e3d769"><td class="memItemLeft" align="right" valign="top">virtual std::shared_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_neon_tensor_handle.html#a937b32594cf8f2ea8df5cbb653e3d769">DecorateTensorHandle</a> (const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &amp;tensorInfo) override</td></tr>
<tr class="memdesc:a937b32594cf8f2ea8df5cbb653e3d769"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a decorated version of this <a class="el" href="classarmnn_1_1_tensor_handle.html">TensorHandle</a> allowing us to override the <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> for it. <a href="classarmnn_1_1_neon_tensor_handle.html#a937b32594cf8f2ea8df5cbb653e3d769">More...</a><br /></td></tr>
<tr class="separator:a937b32594cf8f2ea8df5cbb653e3d769"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="inherit_header pub_methods_classarmnn_1_1_i_tensor_handle"><td colspan="2" onclick="javascript:toggleInherit('pub_methods_classarmnn_1_1_i_tensor_handle')"><img src="closed.png" alt="-"/>&#160;Public Member Functions inherited from <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a></td></tr>
<tr class="memitem:aff95f063e2b8041b3d0e4b4dc0e3821d inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.html#aff95f063e2b8041b3d0e4b4dc0e3821d">~ITensorHandle</a> ()</td></tr>
<tr class="separator:aff95f063e2b8041b3d0e4b4dc0e3821d inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a270c8f844df649b9b0599c1e4db44cd3 inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memItemLeft" align="right" valign="top">void *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.html#a270c8f844df649b9b0599c1e4db44cd3">Map</a> (bool blocking=true)</td></tr>
<tr class="memdesc:a270c8f844df649b9b0599c1e4db44cd3 inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="mdescLeft">&#160;</td><td class="mdescRight">Map the tensor data for access. <a href="classarmnn_1_1_i_tensor_handle.html#a270c8f844df649b9b0599c1e4db44cd3">More...</a><br /></td></tr>
<tr class="separator:a270c8f844df649b9b0599c1e4db44cd3 inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab2be1412c91842a072ad94759f52033e inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.html#ab2be1412c91842a072ad94759f52033e">Unmap</a> ()</td></tr>
<tr class="memdesc:ab2be1412c91842a072ad94759f52033e inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unmap the tensor data that was previously mapped with call to <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a9afbc055a017adf1bc38ee137bca6e90" title="Map the tensor data for access.">Map()</a>. <a href="classarmnn_1_1_i_tensor_handle.html#ab2be1412c91842a072ad94759f52033e">More...</a><br /></td></tr>
<tr class="separator:ab2be1412c91842a072ad94759f52033e inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9eee7f9d4e230d684a7307ac4d75d8a9 inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memItemLeft" align="right" valign="top">virtual void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.html#a9eee7f9d4e230d684a7307ac4d75d8a9">Unimport</a> ()</td></tr>
<tr class="memdesc:a9eee7f9d4e230d684a7307ac4d75d8a9 inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unimport externally allocated memory. <a href="classarmnn_1_1_i_tensor_handle.html#a9eee7f9d4e230d684a7307ac4d75d8a9">More...</a><br /></td></tr>
<tr class="separator:a9eee7f9d4e230d684a7307ac4d75d8a9 inherit pub_methods_classarmnn_1_1_i_tensor_handle"><td class="memSeparator" colspan="2">&#160;</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="_neon_tensor_handle_8hpp_source.html#l00028">28</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
</div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
<a id="aec1964e898a1dfc9c6be2f5589c0ee33"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aec1964e898a1dfc9c6be2f5589c0ee33">&#9670;&nbsp;</a></span>NeonTensorHandle() <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_neon_tensor_handle.html">NeonTensorHandle</a> </td>
<td>(</td>
<td class="paramtype">const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &amp;&#160;</td>
<td class="paramname"><em>tensorInfo</em></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="_neon_tensor_handle_8hpp_source.html#l00031">31</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00032"></a><span class="lineno"> 32</span>&#160; : m_ImportFlags(<span class="keyword">static_cast&lt;</span><a class="code" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a><span class="keyword">&gt;</span>(<a class="code" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">MemorySource::Malloc</a>)),</div>
<div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160; m_Imported(<span class="keyword">false</span>),</div>
<div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160; m_IsImportEnabled(<span class="keyword">false</span>),</div>
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160; m_TypeAlignment(<a class="code" href="namespacearmnn.html#aa02b9e06fb20fa3c13da0427e6ee5ab2">GetDataTypeSize</a>(tensorInfo.GetDataType()))</div>
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160; {</div>
<div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160; armnn::armcomputetensorutils::BuildArmComputeTensor(m_Tensor, tensorInfo);</div>
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160; }</div>
</div><!-- fragment -->
<p class="reference">References <a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">armnn::Malloc</a>.</p>
</div>
</div>
<a id="a8be757c370ed96fdb90168e2ff0216d6"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8be757c370ed96fdb90168e2ff0216d6">&#9670;&nbsp;</a></span>NeonTensorHandle() <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"><a class="el" href="classarmnn_1_1_neon_tensor_handle.html">NeonTensorHandle</a> </td>
<td>(</td>
<td class="paramtype">const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &amp;&#160;</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>&#160;</td>
<td class="paramname"><em>dataLayout</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a>&#160;</td>
<td class="paramname"><em>importFlags</em> = <code>static_cast&lt;<a class="el" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a>&gt;(<a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">MemorySource::Malloc</a>)</code>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</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="_neon_tensor_handle_8hpp_source.html#l00040">40</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160; : m_ImportFlags(importFlags),</div>
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160; m_Imported(<span class="keyword">false</span>),</div>
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160; m_IsImportEnabled(<span class="keyword">false</span>),</div>
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160; m_TypeAlignment(<a class="code" href="namespacearmnn.html#aa02b9e06fb20fa3c13da0427e6ee5ab2">GetDataTypeSize</a>(tensorInfo.GetDataType()))</div>
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160; </div>
<div class="line"><a name="l00048"></a><span class="lineno"> 48</span>&#160; </div>
<div class="line"><a name="l00049"></a><span class="lineno"> 49</span>&#160; {</div>
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160; armnn::armcomputetensorutils::BuildArmComputeTensor(m_Tensor, tensorInfo, dataLayout);</div>
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<h2 class="groupheader">Member Function Documentation</h2>
<a id="ac4c894e28b763523748ba2bb718d569d"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ac4c894e28b763523748ba2bb718d569d">&#9670;&nbsp;</a></span>Allocate()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual void Allocate </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 class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Indicate to the memory manager that this resource is no longer active. </p>
<p>This is used to compute overlapping lifetimes of resources. </p>
<p>Implements <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a5cceed8b707a09bf27eb61f17acf8a88">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00056">56</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160; {</div>
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160; <span class="comment">// If we have enabled Importing, don&#39;t Allocate the tensor</span></div>
<div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160; <span class="keywordflow">if</span> (!m_IsImportEnabled)</div>
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160; {</div>
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160; armnn::armcomputetensorutils::InitialiseArmComputeTensorEmpty(m_Tensor);</div>
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160; }</div>
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160; };</div>
</div><!-- fragment -->
</div>
</div>
<a id="ae69aed5d7a4cc5deb4488dc6841b2096"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ae69aed5d7a4cc5deb4488dc6841b2096">&#9670;&nbsp;</a></span>CanBeImported()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">bool CanBeImported </td>
<td>(</td>
<td class="paramtype">void *&#160;</td>
<td class="paramname"><em>memory</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277">MemorySource</a>&#160;</td>
<td class="paramname"><em>source</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></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>Implementations must determine if this memory block can be imported. </p>
<p>This might be based on alignment or memory source type. </p><dl class="section return"><dt>Returns</dt><dd>true if this memory can be imported. </dd>
<dd>
false by default, cannot be imported. </dd></dl>
<p>Reimplemented from <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a6caeedd55f4d685fd04b8fcb352dae4e">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00119">119</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160; {</div>
<div class="line"><a name="l00121"></a><span class="lineno"> 121</span>&#160; <span class="keywordflow">if</span> (source != <a class="code" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">MemorySource::Malloc</a> || <span class="keyword">reinterpret_cast&lt;</span>uintptr_t<span class="keyword">&gt;</span>(memory) % m_TypeAlignment)</div>
<div class="line"><a name="l00122"></a><span class="lineno"> 122</span>&#160; {</div>
<div class="line"><a name="l00123"></a><span class="lineno"> 123</span>&#160; <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
<div class="line"><a name="l00124"></a><span class="lineno"> 124</span>&#160; }</div>
<div class="line"><a name="l00125"></a><span class="lineno"> 125</span>&#160; <span class="keywordflow">return</span> <span class="keyword">true</span>;</div>
<div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; }</div>
</div><!-- fragment -->
<p class="reference">References <a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">armnn::Malloc</a>.</p>
<p class="reference">Referenced by <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00128">NeonTensorHandle::Import()</a>.</p>
</div>
</div>
<a id="a937b32594cf8f2ea8df5cbb653e3d769"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a937b32594cf8f2ea8df5cbb653e3d769">&#9670;&nbsp;</a></span>DecorateTensorHandle()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::shared_ptr&lt; <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a> &gt; DecorateTensorHandle </td>
<td>(</td>
<td class="paramtype">const <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> &amp;&#160;</td>
<td class="paramname"><em>tensorInfo</em></td><td>)</td>
<td></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>Returns a decorated version of this <a class="el" href="classarmnn_1_1_tensor_handle.html">TensorHandle</a> allowing us to override the <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a> for it. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramname">tensorInfo</td><td>the overidden <a class="el" href="classarmnn_1_1_tensor_info.html">TensorInfo</a>. </td></tr>
</table>
</dd>
</dl>
<p>Reimplemented from <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a82d949cbbc7667d9f13e3f2a474cad36">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8cpp_source.html#l00012">12</a> of file <a class="el" href="_neon_tensor_handle_8cpp_source.html">NeonTensorHandle.cpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00013"></a><span class="lineno"> 13</span>&#160;{</div>
<div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160; <span class="keyword">auto</span>* parent = <span class="keyword">const_cast&lt;</span><a class="code" href="classarmnn_1_1_neon_tensor_handle.html#aec1964e898a1dfc9c6be2f5589c0ee33">NeonTensorHandle</a>*<span class="keyword">&gt;</span>(<span class="keyword">this</span>);</div>
<div class="line"><a name="l00015"></a><span class="lineno"> 15</span>&#160; <span class="keyword">auto</span> decorated = std::make_shared&lt;NeonTensorHandleDecorator&gt;(parent, tensorInfo);</div>
<div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160; m_Decorated.emplace_back(decorated);</div>
<div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160; <span class="keywordflow">return</span> decorated;</div>
<div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160;}</div>
</div><!-- fragment -->
</div>
</div>
<a id="ad3e63bb560123889f1ec98e40c5f8279"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ad3e63bb560123889f1ec98e40c5f8279">&#9670;&nbsp;</a></span>GetDataType()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual arm_compute::DataType GetDataType </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_acl_tensor_handle.html#a3767f569fc55323ddf7b2ee57987d9c5">IAclTensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00077">77</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; {</div>
<div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; <span class="keywordflow">return</span> m_Tensor.info()-&gt;data_type();</div>
<div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="aa1d3334a17a9f136fe65ed833fbf68b4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#aa1d3334a17a9f136fe65ed833fbf68b4">&#9670;&nbsp;</a></span>GetImportFlags()</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="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a> GetImportFlags </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>Get flags describing supported import sources. </p>
<p>Reimplemented from <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a55cddc2dbb32d680cd85b635ba370e48">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00109">109</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; {</div>
<div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; <span class="keywordflow">return</span> m_ImportFlags;</div>
<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="ab6c52b35388890f2c563afbebfb456a6"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab6c52b35388890f2c563afbebfb456a6">&#9670;&nbsp;</a></span>GetParent()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual <a class="el" href="classarmnn_1_1_i_tensor_handle.html">ITensorHandle</a>* GetParent </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>Get the parent tensor if this is a subtensor. </p>
<dl class="section return"><dt>Returns</dt><dd>a pointer to the parent tensor. Otherwise nullptr if not a subtensor. </dd></dl>
<p>Implements <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a437893b8dcf58a0b68b70e1ad7933be6">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00075">75</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160;{ <span class="keywordflow">return</span> <span class="keyword">nullptr</span>; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a8e8d2fbabcac19f9e12779080ddff54e"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a8e8d2fbabcac19f9e12779080ddff54e">&#9670;&nbsp;</a></span>GetShape()</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_tensor_shape.html">TensorShape</a> GetShape </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>Get the number of elements for each dimension ordered from slowest iterating dimension to fastest iterating dimension. </p>
<dl class="section return"><dt>Returns</dt><dd>a <a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a> filled with the number of elements for each dimension. </dd></dl>
<p>Implements <a class="el" href="classarmnn_1_1_i_tensor_handle.html#affd5aae75cad90f472f96cfd25a13f29">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00099">99</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; {</div>
<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160; <span class="keywordflow">return</span> armcomputetensorutils::GetShape(m_Tensor.info()-&gt;tensor_shape());</div>
<div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; }</div>
</div><!-- fragment -->
<p class="reference">Referenced by <a class="el" href="_neon_rank_workload_8hpp_source.html#l00020">NeonRankWorkload::Execute()</a>.</p>
</div>
</div>
<a id="a967f220393d291f71dabce0c06bf9b6c"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a967f220393d291f71dabce0c06bf9b6c">&#9670;&nbsp;</a></span>GetStrides()</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_tensor_shape.html">TensorShape</a> GetStrides </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>Get the strides for each dimension ordered from largest to smallest where the smallest value is the same as the size of a single element in the tensor. </p>
<dl class="section return"><dt>Returns</dt><dd>a <a class="el" href="classarmnn_1_1_tensor_shape.html">TensorShape</a> filled with the strides for each dimension </dd></dl>
<p>Implements <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a30c3e09ce55369b66469443a4ca5ef03">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00094">94</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160; {</div>
<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160; <span class="keywordflow">return</span> armcomputetensorutils::GetStrides(m_Tensor.info()-&gt;strides_in_bytes());</div>
<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a6fde23d85d96f26ac7c33b69a945a922"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a6fde23d85d96f26ac7c33b69a945a922">&#9670;&nbsp;</a></span>GetTensor() <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">arm_compute::ITensor const&amp; GetTensor </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_acl_tensor_handle.html#adb0fcd17dec048e91459a89fe4433ae9">IAclTensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00054">54</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160;{ <span class="keywordflow">return</span> m_Tensor; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="ab18b27bb871248e2ba3120eb557dcfe4"></a>
<h2 class="memtitle"><span class="permalink"><a href="#ab18b27bb871248e2ba3120eb557dcfe4">&#9670;&nbsp;</a></span>GetTensor() <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">arm_compute::ITensor&amp; GetTensor </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 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_acl_tensor_handle.html#a326e78519af5570a5921c6aa39968a20">IAclTensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00053">53</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160;{ <span class="keywordflow">return</span> m_Tensor; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a468bf13728df2ac9ec772733047ff136"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a468bf13728df2ac9ec772733047ff136">&#9670;&nbsp;</a></span>Import()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual bool Import </td>
<td>(</td>
<td class="paramtype">void *&#160;</td>
<td class="paramname"><em>memory</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype"><a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277">MemorySource</a>&#160;</td>
<td class="paramname"><em>source</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></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>Import externally allocated memory. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramname">memory</td><td>base address of the memory being imported. </td></tr>
<tr><td class="paramname">source</td><td>source of the allocation for the memory being imported. </td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>true on success or false on failure </dd></dl>
<p>Reimplemented from <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a4f81a9eff30c9b9fe76f5b83af470ba7">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00128">128</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; {</div>
<div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160; <span class="keywordflow">if</span> (m_ImportFlags&amp; <span class="keyword">static_cast&lt;</span><a class="code" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a><span class="keyword">&gt;</span>(source))</div>
<div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; {</div>
<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; <span class="keywordflow">if</span> (source == <a class="code" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">MemorySource::Malloc</a> &amp;&amp; m_IsImportEnabled)</div>
<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; {</div>
<div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; <span class="keywordflow">if</span> (!<a class="code" href="classarmnn_1_1_neon_tensor_handle.html#ae69aed5d7a4cc5deb4488dc6841b2096">CanBeImported</a>(memory, source))</div>
<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; {</div>
<div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; <span class="keywordflow">throw</span> MemoryImportException(<span class="stringliteral">&quot;NeonTensorHandle::Import Attempting to import unaligned memory&quot;</span>);</div>
<div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; }</div>
<div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; </div>
<div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160; <span class="comment">// m_Tensor not yet Allocated</span></div>
<div class="line"><a name="l00140"></a><span class="lineno"> 140</span>&#160; <span class="keywordflow">if</span> (!m_Imported &amp;&amp; !m_Tensor.buffer())</div>
<div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; {</div>
<div class="line"><a name="l00142"></a><span class="lineno"> 142</span>&#160; <a class="code" href="namespacearmnn.html#a67a0db04d321a74b7e7fcfd3f1a3f70b">arm_compute::Status</a> status = m_Tensor.allocator()-&gt;import_memory(memory);</div>
<div class="line"><a name="l00143"></a><span class="lineno"> 143</span>&#160; <span class="comment">// Use the overloaded bool operator of Status to check if it worked, if not throw an exception</span></div>
<div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160; <span class="comment">// with the Status error message</span></div>
<div class="line"><a name="l00145"></a><span class="lineno"> 145</span>&#160; m_Imported = bool(status);</div>
<div class="line"><a name="l00146"></a><span class="lineno"> 146</span>&#160; <span class="keywordflow">if</span> (!m_Imported)</div>
<div class="line"><a name="l00147"></a><span class="lineno"> 147</span>&#160; {</div>
<div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160; <span class="keywordflow">throw</span> MemoryImportException(status.error_description());</div>
<div class="line"><a name="l00149"></a><span class="lineno"> 149</span>&#160; }</div>
<div class="line"><a name="l00150"></a><span class="lineno"> 150</span>&#160; <span class="keywordflow">return</span> m_Imported;</div>
<div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160; }</div>
<div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160; </div>
<div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160; <span class="comment">// m_Tensor.buffer() initially allocated with Allocate().</span></div>
<div class="line"><a name="l00154"></a><span class="lineno"> 154</span>&#160; <span class="keywordflow">if</span> (!m_Imported &amp;&amp; m_Tensor.buffer())</div>
<div class="line"><a name="l00155"></a><span class="lineno"> 155</span>&#160; {</div>
<div class="line"><a name="l00156"></a><span class="lineno"> 156</span>&#160; <span class="keywordflow">throw</span> MemoryImportException(</div>
<div class="line"><a name="l00157"></a><span class="lineno"> 157</span>&#160; <span class="stringliteral">&quot;NeonTensorHandle::Import Attempting to import on an already allocated tensor&quot;</span>);</div>
<div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160; }</div>
<div class="line"><a name="l00159"></a><span class="lineno"> 159</span>&#160; </div>
<div class="line"><a name="l00160"></a><span class="lineno"> 160</span>&#160; <span class="comment">// m_Tensor.buffer() previously imported.</span></div>
<div class="line"><a name="l00161"></a><span class="lineno"> 161</span>&#160; <span class="keywordflow">if</span> (m_Imported)</div>
<div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160; {</div>
<div class="line"><a name="l00163"></a><span class="lineno"> 163</span>&#160; <a class="code" href="namespacearmnn.html#a67a0db04d321a74b7e7fcfd3f1a3f70b">arm_compute::Status</a> status = m_Tensor.allocator()-&gt;import_memory(memory);</div>
<div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160; <span class="comment">// Use the overloaded bool operator of Status to check if it worked, if not throw an exception</span></div>
<div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160; <span class="comment">// with the Status error message</span></div>
<div class="line"><a name="l00166"></a><span class="lineno"> 166</span>&#160; m_Imported = bool(status);</div>
<div class="line"><a name="l00167"></a><span class="lineno"> 167</span>&#160; <span class="keywordflow">if</span> (!m_Imported)</div>
<div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160; {</div>
<div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160; <span class="keywordflow">throw</span> MemoryImportException(status.error_description());</div>
<div class="line"><a name="l00170"></a><span class="lineno"> 170</span>&#160; }</div>
<div class="line"><a name="l00171"></a><span class="lineno"> 171</span>&#160; <span class="keywordflow">return</span> m_Imported;</div>
<div class="line"><a name="l00172"></a><span class="lineno"> 172</span>&#160; }</div>
<div class="line"><a name="l00173"></a><span class="lineno"> 173</span>&#160; }</div>
<div class="line"><a name="l00174"></a><span class="lineno"> 174</span>&#160; <span class="keywordflow">else</span></div>
<div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160; {</div>
<div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160; <span class="keywordflow">throw</span> MemoryImportException(<span class="stringliteral">&quot;NeonTensorHandle::Import is disabled&quot;</span>);</div>
<div class="line"><a name="l00177"></a><span class="lineno"> 177</span>&#160; }</div>
<div class="line"><a name="l00178"></a><span class="lineno"> 178</span>&#160; }</div>
<div class="line"><a name="l00179"></a><span class="lineno"> 179</span>&#160; <span class="keywordflow">else</span></div>
<div class="line"><a name="l00180"></a><span class="lineno"> 180</span>&#160; {</div>
<div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160; <span class="keywordflow">throw</span> MemoryImportException(<span class="stringliteral">&quot;NeonTensorHandle::Incorrect import flag&quot;</span>);</div>
<div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; }</div>
<div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160; <span class="keywordflow">return</span> <span class="keyword">false</span>;</div>
<div class="line"><a name="l00184"></a><span class="lineno"> 184</span>&#160; }</div>
</div><!-- fragment -->
<p class="reference">References <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00119">NeonTensorHandle::CanBeImported()</a>, and <a class="el" href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">armnn::Malloc</a>.</p>
</div>
</div>
<a id="a19aa18d78d5ac31e3a3c8f782f0e8606"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a19aa18d78d5ac31e3a3c8f782f0e8606">&#9670;&nbsp;</a></span>Manage()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual void Manage </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 class="mlabel">override</span><span class="mlabel">virtual</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Indicate to the memory manager that this resource is active. </p>
<p>This is used to compute overlapping lifetimes of resources. </p>
<p>Implements <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a04149d0f9b9c54c05e95693111490daf">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00065">65</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00066"></a><span class="lineno"> 66</span>&#160; {</div>
<div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160; <span class="comment">// If we have enabled Importing, don&#39;t manage the tensor</span></div>
<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>&#160; <span class="keywordflow">if</span> (!m_IsImportEnabled)</div>
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160; {</div>
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160; <a class="code" href="_exceptions_8hpp.html#a5b0cd1f24b12298894d6367f186ea6dc">ARMNN_THROW_INVALIDARG_MSG_IF_FALSE</a>(m_MemoryGroup, <span class="stringliteral">&quot;arm_compute::MemoryGroup is null.&quot;</span>);</div>
<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; m_MemoryGroup-&gt;manage(&amp;m_Tensor);</div>
<div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; }</div>
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; }</div>
</div><!-- fragment -->
<p class="reference">References <a class="el" href="_exceptions_8hpp_source.html#l00210">ARMNN_THROW_INVALIDARG_MSG_IF_FALSE</a>.</p>
</div>
</div>
<a id="acc3fcce7a100cc3b64247519f22e37fc"></a>
<h2 class="memtitle"><span class="permalink"><a href="#acc3fcce7a100cc3b64247519f22e37fc">&#9670;&nbsp;</a></span>Map()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual const void* Map </td>
<td>(</td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>blocking</em></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>Map the tensor data for access. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramname">blocking</td><td>hint to block the calling thread until all other accesses are complete. (backend dependent) </td></tr>
</table>
</dd>
</dl>
<dl class="section return"><dt>Returns</dt><dd>pointer to the first element of the mapped data. </dd></dl>
<p>Implements <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a9afbc055a017adf1bc38ee137bca6e90">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00087">87</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; {</div>
<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160; <span class="keywordflow">return</span> <span class="keyword">static_cast&lt;</span><span class="keyword">const </span><span class="keywordtype">void</span>*<span class="keyword">&gt;</span>(m_Tensor.buffer() + m_Tensor.info()-&gt;offset_first_element_in_bytes());</div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a9b8adcb578eb6f9ad63c21b1fa43bb14"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a9b8adcb578eb6f9ad63c21b1fa43bb14">&#9670;&nbsp;</a></span>SetImportEnabledFlag()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void SetImportEnabledFlag </td>
<td>(</td>
<td class="paramtype">bool&#160;</td>
<td class="paramname"><em>importEnabledFlag</em></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="_neon_tensor_handle_8hpp_source.html#l00114">114</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00115"></a><span class="lineno"> 115</span>&#160; {</div>
<div class="line"><a name="l00116"></a><span class="lineno"> 116</span>&#160; m_IsImportEnabled = importEnabledFlag;</div>
<div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="acd3ddbebcda4124217925ae36d551441"></a>
<h2 class="memtitle"><span class="permalink"><a href="#acd3ddbebcda4124217925ae36d551441">&#9670;&nbsp;</a></span>SetImportFlags()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void SetImportFlags </td>
<td>(</td>
<td class="paramtype"><a class="el" href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">MemorySourceFlags</a>&#160;</td>
<td class="paramname"><em>importFlags</em></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="_neon_tensor_handle_8hpp_source.html#l00104">104</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; {</div>
<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; m_ImportFlags = importFlags;</div>
<div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="af9c82a4633347a36ad10c8bfab384396"></a>
<h2 class="memtitle"><span class="permalink"><a href="#af9c82a4633347a36ad10c8bfab384396">&#9670;&nbsp;</a></span>SetMemoryGroup()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual void SetMemoryGroup </td>
<td>(</td>
<td class="paramtype">const std::shared_ptr&lt; arm_compute::IMemoryGroup &gt; &amp;&#160;</td>
<td class="paramname"><em>memoryGroup</em></td><td>)</td>
<td></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_acl_tensor_handle.html#a658c8c0848fa9d1fb2fc6c1422bfe3e8">IAclTensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00082">82</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160; {</div>
<div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; m_MemoryGroup = PolymorphicPointerDowncast&lt;arm_compute::MemoryGroup&gt;(memoryGroup);</div>
<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; }</div>
</div><!-- fragment -->
</div>
</div>
<a id="a88ab6decf78c152e746b7d8dc2dd931f"></a>
<h2 class="memtitle"><span class="permalink"><a href="#a88ab6decf78c152e746b7d8dc2dd931f">&#9670;&nbsp;</a></span>Unmap()</h2>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual void Unmap </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>Unmap the tensor data. </p>
<p>Implements <a class="el" href="classarmnn_1_1_i_tensor_handle.html#a563609828050f1b3a7868c23f3365923">ITensorHandle</a>.</p>
<p class="definition">Definition at line <a class="el" href="_neon_tensor_handle_8hpp_source.html#l00092">92</a> of file <a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a>.</p>
<div class="fragment"><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160;{}</div>
</div><!-- fragment -->
</div>
</div>
<hr/>The documentation for this class was generated from the following files:<ul>
<li>src/backends/neon/<a class="el" href="_neon_tensor_handle_8hpp_source.html">NeonTensorHandle.hpp</a></li>
<li>src/backends/neon/<a class="el" href="_neon_tensor_handle_8cpp_source.html">NeonTensorHandle.cpp</a></li>
</ul>
</div><!-- contents -->
</div><!-- doc-content -->
<div class="ttc" id="anamespacearmnn_html_a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523"><div class="ttname"><a href="namespacearmnn.html#a14fcd7f88d11cea0a018269dca5f9277a1131a914388fac73e5f07b0ba0aad523">armnn::MemorySource::Malloc</a></div><div class="ttdeci">@ Malloc</div></div>
<div class="ttc" id="aclassarmnn_1_1_neon_tensor_handle_html_aec1964e898a1dfc9c6be2f5589c0ee33"><div class="ttname"><a href="classarmnn_1_1_neon_tensor_handle.html#aec1964e898a1dfc9c6be2f5589c0ee33">armnn::NeonTensorHandle::NeonTensorHandle</a></div><div class="ttdeci">NeonTensorHandle(const TensorInfo &amp;tensorInfo)</div><div class="ttdef"><b>Definition:</b> <a href="_neon_tensor_handle_8hpp_source.html#l00031">NeonTensorHandle.hpp:31</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a5b05f3b7208ec7cea3338e30057c0bac"><div class="ttname"><a href="namespacearmnn.html#a5b05f3b7208ec7cea3338e30057c0bac">armnn::MemorySourceFlags</a></div><div class="ttdeci">unsigned int MemorySourceFlags</div><div class="ttdef"><b>Definition:</b> <a href="_memory_sources_8hpp_source.html#l00015">MemorySources.hpp:15</a></div></div>
<div class="ttc" id="aclassarmnn_1_1_neon_tensor_handle_html_ae69aed5d7a4cc5deb4488dc6841b2096"><div class="ttname"><a href="classarmnn_1_1_neon_tensor_handle.html#ae69aed5d7a4cc5deb4488dc6841b2096">armnn::NeonTensorHandle::CanBeImported</a></div><div class="ttdeci">bool CanBeImported(void *memory, MemorySource source) override</div><div class="ttdoc">Implementations must determine if this memory block can be imported.</div><div class="ttdef"><b>Definition:</b> <a href="_neon_tensor_handle_8hpp_source.html#l00119">NeonTensorHandle.hpp:119</a></div></div>
<div class="ttc" id="anamespacearmnn_html_aa02b9e06fb20fa3c13da0427e6ee5ab2"><div class="ttname"><a href="namespacearmnn.html#aa02b9e06fb20fa3c13da0427e6ee5ab2">armnn::GetDataTypeSize</a></div><div class="ttdeci">constexpr unsigned int GetDataTypeSize(DataType dataType)</div><div class="ttdef"><b>Definition:</b> <a href="_types_utils_8hpp_source.html#l00182">TypesUtils.hpp:182</a></div></div>
<div class="ttc" id="anamespacearmnn_html_a67a0db04d321a74b7e7fcfd3f1a3f70b"><div class="ttname"><a href="namespacearmnn.html#a67a0db04d321a74b7e7fcfd3f1a3f70b">armnn::Status</a></div><div class="ttdeci">Status</div><div class="ttdef"><b>Definition:</b> <a href="_types_8hpp_source.html#l00042">Types.hpp:42</a></div></div>
<div class="ttc" id="a_exceptions_8hpp_html_a5b0cd1f24b12298894d6367f186ea6dc"><div class="ttname"><a href="_exceptions_8hpp.html#a5b0cd1f24b12298894d6367f186ea6dc">ARMNN_THROW_INVALIDARG_MSG_IF_FALSE</a></div><div class="ttdeci">#define ARMNN_THROW_INVALIDARG_MSG_IF_FALSE(_cond, _str)</div><div class="ttdef"><b>Definition:</b> <a href="_exceptions_8hpp_source.html#l00210">Exceptions.hpp:210</a></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_neon_tensor_handle.html">NeonTensorHandle</a></li>
<li class="footer">Generated on Thu May 16 2024 09:31:57 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>