aboutsummaryrefslogtreecommitdiff
path: root/20.02/classarmnn_1_1_i_tensor_handle.xhtml
diff options
context:
space:
mode:
Diffstat (limited to '20.02/classarmnn_1_1_i_tensor_handle.xhtml')
-rw-r--r--20.02/classarmnn_1_1_i_tensor_handle.xhtml668
1 files changed, 668 insertions, 0 deletions
diff --git a/20.02/classarmnn_1_1_i_tensor_handle.xhtml b/20.02/classarmnn_1_1_i_tensor_handle.xhtml
new file mode 100644
index 0000000000..bf544631d3
--- /dev/null
+++ b/20.02/classarmnn_1_1_i_tensor_handle.xhtml
@@ -0,0 +1,668 @@
+<!-- Copyright (c) 2020 ARM Limited. -->
+<!-- -->
+<!-- SPDX-License-Identifier: MIT -->
+<!-- -->
+<!-- HTML header for doxygen 1.8.13-->
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://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.13"/>
+<meta name="robots" content="NOINDEX, NOFOLLOW" />
+<meta name="viewport" content="width=device-width, initial-scale=1"/>
+<title>ArmNN: ITensorHandle 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>
+<script type="text/javascript">
+ $(document).ready(initResizable);
+</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" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js"></script>
+<link href="doxygen.css" rel="stylesheet" type="text/css" />
+<link href="stylesheet.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: 10rem; margin-top: .5rem; margin-left 10px"/>
+ <td style="padding-left: 0.5em;">
+ <div id="projectname">
+ &#160;<span id="projectnumber">20.02</span>
+ </div>
+ </td>
+ </tr>
+ </tbody>
+</table>
+</div>
+<!-- end header part -->
+<!-- Generated by Doxygen 1.8.13 -->
+<script type="text/javascript">
+var searchBox = new SearchBox("searchBox", "search",false,'Search');
+</script>
+<script type="text/javascript" src="menudata.js"></script>
+<script type="text/javascript" src="menu.js"></script>
+<script type="text/javascript">
+$(function() {
+ initMenu('',true,false,'search.php','Search');
+ $(document).ready(function() { init_search(); });
+});
+</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">
+$(document).ready(function(){initNavTree('classarmnn_1_1_i_tensor_handle.xhtml','');});
+</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_i_tensor_handle-members.xhtml">List of all members</a> </div>
+ <div class="headertitle">
+<div class="title">ITensorHandle Class Reference<span class="mlabels"><span class="mlabel">abstract</span></span></div> </div>
+</div><!--header-->
+<div class="contents">
+
+<p><code>#include &lt;<a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a>&gt;</code></p>
+<div class="dynheader">
+Inheritance diagram for ITensorHandle:</div>
+<div class="dyncontent">
+ <div class="center">
+ <img src="classarmnn_1_1_i_tensor_handle.png" usemap="#ITensorHandle_map" alt=""/>
+ <map id="ITensorHandle_map" name="ITensorHandle_map">
+<area href="classarmnn_1_1_const_cpu_tensor_handle.xhtml" alt="ConstCpuTensorHandle" shape="rect" coords="113,56,329,80"/>
+<area href="classarmnn_1_1_i_acl_tensor_handle.xhtml" alt="IAclTensorHandle" shape="rect" coords="904,56,1120,80"/>
+<area href="classarmnn_1_1_ref_tensor_handle.xhtml" alt="RefTensorHandle" shape="rect" coords="1130,56,1346,80"/>
+<area href="classarmnn_1_1_sample_tensor_handle.xhtml" alt="SampleTensorHandle" shape="rect" coords="1356,56,1572,80"/>
+<area href="classarmnn_1_1_const_passthrough_cpu_tensor_handle.xhtml" alt="ConstPassthroughCpuTensorHandle" shape="rect" coords="0,112,216,136"/>
+<area href="classarmnn_1_1_cpu_tensor_handle.xhtml" alt="CpuTensorHandle" shape="rect" coords="226,112,442,136"/>
+<area href="classarmnn_1_1_i_cl_tensor_handle.xhtml" alt="IClTensorHandle" shape="rect" coords="678,112,894,136"/>
+<area href="classarmnn_1_1_neon_sub_tensor_handle.xhtml" alt="NeonSubTensorHandle" shape="rect" coords="904,112,1120,136"/>
+<area href="classarmnn_1_1_neon_tensor_handle.xhtml" alt="NeonTensorHandle" shape="rect" coords="1130,112,1346,136"/>
+<area href="classarmnn_1_1_passthrough_cpu_tensor_handle.xhtml" alt="PassthroughCpuTensorHandle" shape="rect" coords="113,168,329,192"/>
+<area href="classarmnn_1_1_scoped_cpu_tensor_handle.xhtml" alt="ScopedCpuTensorHandle" shape="rect" coords="339,168,555,192"/>
+<area href="classarmnn_1_1_cl_sub_tensor_handle.xhtml" alt="ClSubTensorHandle" shape="rect" coords="565,168,781,192"/>
+<area href="classarmnn_1_1_cl_tensor_handle.xhtml" alt="ClTensorHandle" shape="rect" coords="791,168,1007,192"/>
+</map>
+ </div></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:aff95f063e2b8041b3d0e4b4dc0e3821d"><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.xhtml#aff95f063e2b8041b3d0e4b4dc0e3821d">~ITensorHandle</a> ()</td></tr>
+<tr class="separator:aff95f063e2b8041b3d0e4b4dc0e3821d"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a04149d0f9b9c54c05e95693111490daf"><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.xhtml#a04149d0f9b9c54c05e95693111490daf">Manage</a> ()=0</td></tr>
+<tr class="memdesc:a04149d0f9b9c54c05e95693111490daf"><td class="mdescLeft">&#160;</td><td class="mdescRight">Indicate to the memory manager that this resource is active. <a href="#a04149d0f9b9c54c05e95693111490daf">More...</a><br /></td></tr>
+<tr class="separator:a04149d0f9b9c54c05e95693111490daf"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a5cceed8b707a09bf27eb61f17acf8a88"><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.xhtml#a5cceed8b707a09bf27eb61f17acf8a88">Allocate</a> ()=0</td></tr>
+<tr class="memdesc:a5cceed8b707a09bf27eb61f17acf8a88"><td class="mdescLeft">&#160;</td><td class="mdescRight">Indicate to the memory manager that this resource is no longer active. <a href="#a5cceed8b707a09bf27eb61f17acf8a88">More...</a><br /></td></tr>
+<tr class="separator:a5cceed8b707a09bf27eb61f17acf8a88"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a437893b8dcf58a0b68b70e1ad7933be6"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml">ITensorHandle</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a437893b8dcf58a0b68b70e1ad7933be6">GetParent</a> () const =0</td></tr>
+<tr class="memdesc:a437893b8dcf58a0b68b70e1ad7933be6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the parent tensor if this is a subtensor. <a href="#a437893b8dcf58a0b68b70e1ad7933be6">More...</a><br /></td></tr>
+<tr class="separator:a437893b8dcf58a0b68b70e1ad7933be6"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a9afbc055a017adf1bc38ee137bca6e90"><td class="memItemLeft" align="right" valign="top">virtual const void *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a9afbc055a017adf1bc38ee137bca6e90">Map</a> (bool blocking=<a class="el" href="_ref_layer_tests_8cpp.xhtml#a37f1c3ccc9fc906be85185350dd83d48">true</a>) const =0</td></tr>
+<tr class="memdesc:a9afbc055a017adf1bc38ee137bca6e90"><td class="mdescLeft">&#160;</td><td class="mdescRight">Map the tensor data for access. <a href="#a9afbc055a017adf1bc38ee137bca6e90">More...</a><br /></td></tr>
+<tr class="separator:a9afbc055a017adf1bc38ee137bca6e90"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a563609828050f1b3a7868c23f3365923"><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.xhtml#a563609828050f1b3a7868c23f3365923">Unmap</a> () const =0</td></tr>
+<tr class="memdesc:a563609828050f1b3a7868c23f3365923"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unmap the tensor data. <a href="#a563609828050f1b3a7868c23f3365923">More...</a><br /></td></tr>
+<tr class="separator:a563609828050f1b3a7868c23f3365923"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a270c8f844df649b9b0599c1e4db44cd3"><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.xhtml#a270c8f844df649b9b0599c1e4db44cd3">Map</a> (bool blocking=<a class="el" href="_ref_layer_tests_8cpp.xhtml#a37f1c3ccc9fc906be85185350dd83d48">true</a>)</td></tr>
+<tr class="memdesc:a270c8f844df649b9b0599c1e4db44cd3"><td class="mdescLeft">&#160;</td><td class="mdescRight">Map the tensor data for access. <a href="#a270c8f844df649b9b0599c1e4db44cd3">More...</a><br /></td></tr>
+<tr class="separator:a270c8f844df649b9b0599c1e4db44cd3"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:ab2be1412c91842a072ad94759f52033e"><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.xhtml#ab2be1412c91842a072ad94759f52033e">Unmap</a> ()</td></tr>
+<tr class="memdesc:ab2be1412c91842a072ad94759f52033e"><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.xhtml#a9afbc055a017adf1bc38ee137bca6e90" title="Map the tensor data for access. ">Map()</a>. <a href="#ab2be1412c91842a072ad94759f52033e">More...</a><br /></td></tr>
+<tr class="separator:ab2be1412c91842a072ad94759f52033e"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a30c3e09ce55369b66469443a4ca5ef03"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="classarmnn_1_1_tensor_shape.xhtml">TensorShape</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a30c3e09ce55369b66469443a4ca5ef03">GetStrides</a> () const =0</td></tr>
+<tr class="memdesc:a30c3e09ce55369b66469443a4ca5ef03"><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="#a30c3e09ce55369b66469443a4ca5ef03">More...</a><br /></td></tr>
+<tr class="separator:a30c3e09ce55369b66469443a4ca5ef03"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:affd5aae75cad90f472f96cfd25a13f29"><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="classarmnn_1_1_tensor_shape.xhtml">TensorShape</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#affd5aae75cad90f472f96cfd25a13f29">GetShape</a> () const =0</td></tr>
+<tr class="memdesc:affd5aae75cad90f472f96cfd25a13f29"><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="#affd5aae75cad90f472f96cfd25a13f29">More...</a><br /></td></tr>
+<tr class="separator:affd5aae75cad90f472f96cfd25a13f29"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a4ec32790513ea4af4c5746f1ee48fbfe"><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.xhtml#a4ec32790513ea4af4c5746f1ee48fbfe">CopyOutTo</a> (void *memory) const =0</td></tr>
+<tr class="memdesc:a4ec32790513ea4af4c5746f1ee48fbfe"><td class="mdescLeft">&#160;</td><td class="mdescRight">Testing support to be able to verify and set tensor data content. <a href="#a4ec32790513ea4af4c5746f1ee48fbfe">More...</a><br /></td></tr>
+<tr class="separator:a4ec32790513ea4af4c5746f1ee48fbfe"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:ad495ac6d9fd9e1ba5bb7a02c731a2d83"><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.xhtml#ad495ac6d9fd9e1ba5bb7a02c731a2d83">CopyInFrom</a> (const void *memory)=0</td></tr>
+<tr class="separator:ad495ac6d9fd9e1ba5bb7a02c731a2d83"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a55cddc2dbb32d680cd85b635ba370e48"><td class="memItemLeft" align="right" valign="top">virtual unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a55cddc2dbb32d680cd85b635ba370e48">GetImportFlags</a> () const</td></tr>
+<tr class="memdesc:a55cddc2dbb32d680cd85b635ba370e48"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get flags describing supported import sources. <a href="#a55cddc2dbb32d680cd85b635ba370e48">More...</a><br /></td></tr>
+<tr class="separator:a55cddc2dbb32d680cd85b635ba370e48"><td class="memSeparator" colspan="2">&#160;</td></tr>
+<tr class="memitem:a4f81a9eff30c9b9fe76f5b83af470ba7"><td class="memItemLeft" align="right" valign="top">virtual bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a4f81a9eff30c9b9fe76f5b83af470ba7">Import</a> (void *memory, <a class="el" href="namespacearmnn.xhtml#a0fc99721e27eb20ecd0ea85a3cc8b488">MemorySource</a> source)</td></tr>
+<tr class="memdesc:a4f81a9eff30c9b9fe76f5b83af470ba7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Import externally allocated memory. <a href="#a4f81a9eff30c9b9fe76f5b83af470ba7">More...</a><br /></td></tr>
+<tr class="separator:a4f81a9eff30c9b9fe76f5b83af470ba7"><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="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00015">15</a> of file <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a>.</p>
+</div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
+<a id="aff95f063e2b8041b3d0e4b4dc0e3821d"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#aff95f063e2b8041b3d0e4b4dc0e3821d">&#9670;&nbsp;</a></span>~ITensorHandle()</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.xhtml">ITensorHandle</a> </td>
+ <td>(</td>
+ <td class="paramname"></td><td>)</td>
+ <td></td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p class="definition">Definition at line <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00018">18</a> of file <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a>.</p>
+
+<p class="reference">References <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a5cceed8b707a09bf27eb61f17acf8a88">ITensorHandle::Allocate()</a>, <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a437893b8dcf58a0b68b70e1ad7933be6">ITensorHandle::GetParent()</a>, <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a04149d0f9b9c54c05e95693111490daf">ITensorHandle::Manage()</a>, <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a9afbc055a017adf1bc38ee137bca6e90">ITensorHandle::Map()</a>, and <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a563609828050f1b3a7868c23f3365923">ITensorHandle::Unmap()</a>.</p>
+<div class="fragment"><div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160;{}</div></div><!-- fragment -->
+</div>
+</div>
+<h2 class="groupheader">Member Function Documentation</h2>
+<a id="a5cceed8b707a09bf27eb61f17acf8a88"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a5cceed8b707a09bf27eb61f17acf8a88">&#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">pure 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>Implemented in <a class="el" href="classarmnn_1_1_neon_sub_tensor_handle.xhtml#ac4c894e28b763523748ba2bb718d569d">NeonSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_sub_tensor_handle.xhtml#ac4c894e28b763523748ba2bb718d569d">ClSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_const_passthrough_cpu_tensor_handle.xhtml#a8518772c5d692e334a76617582b10b92">ConstPassthroughCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_passthrough_cpu_tensor_handle.xhtml#a8518772c5d692e334a76617582b10b92">PassthroughCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_scoped_cpu_tensor_handle.xhtml#a8518772c5d692e334a76617582b10b92">ScopedCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_tensor_handle.xhtml#ac4c894e28b763523748ba2bb718d569d">ClTensorHandle</a>, <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#ac4c894e28b763523748ba2bb718d569d">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#a8518772c5d692e334a76617582b10b92">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#a8518772c5d692e334a76617582b10b92">RefTensorHandle</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_tensor_copy_utils_8cpp_source.xhtml#l00019">AllocateAndCopyDataToITensorHandle()</a>, <a class="el" href="_graph_8cpp_source.xhtml#l00142">Graph::AllocateDynamicBuffers()</a>, <a class="el" href="_cpu_tensor_handle_8hpp_source.xhtml#l00160">ConstPassthroughCpuTensorHandle::ConstPassthroughCpuTensorHandle()</a>, <a class="el" href="_cpu_tensor_handle_8hpp_source.xhtml#l00141">PassthroughCpuTensorHandle::PassthroughCpuTensorHandle()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00018">ITensorHandle::~ITensorHandle()</a>.</p>
+
+</div>
+</div>
+<a id="ad495ac6d9fd9e1ba5bb7a02c731a2d83"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#ad495ac6d9fd9e1ba5bb7a02c731a2d83">&#9670;&nbsp;</a></span>CopyInFrom()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">virtual void CopyInFrom </td>
+ <td>(</td>
+ <td class="paramtype">const void *&#160;</td>
+ <td class="paramname"><em>memory</em></td><td>)</td>
+ <td></td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">pure virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p class="reference">Referenced by <a class="el" href="_tensor_copy_utils_8cpp_source.xhtml#l00009">CopyDataToITensorHandle()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00049">ITensorHandle::Unmap()</a>.</p>
+
+</div>
+</div>
+<a id="a4ec32790513ea4af4c5746f1ee48fbfe"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a4ec32790513ea4af4c5746f1ee48fbfe">&#9670;&nbsp;</a></span>CopyOutTo()</h2>
+
+<div class="memitem">
+<div class="memproto">
+<table class="mlabels">
+ <tr>
+ <td class="mlabels-left">
+ <table class="memname">
+ <tr>
+ <td class="memname">virtual void CopyOutTo </td>
+ <td>(</td>
+ <td class="paramtype">void *&#160;</td>
+ <td class="paramname"><em>memory</em></td><td>)</td>
+ <td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">pure virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Testing support to be able to verify and set tensor data content. </p>
+
+<p class="reference">Referenced by <a class="el" href="_tensor_copy_utils_8cpp_source.xhtml#l00014">CopyDataFromITensorHandle()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00049">ITensorHandle::Unmap()</a>.</p>
+
+</div>
+</div>
+<a id="a55cddc2dbb32d680cd85b635ba370e48"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a55cddc2dbb32d680cd85b635ba370e48">&#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">virtual unsigned int 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">virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Get flags describing supported import sources. </p>
+
+<p>Reimplemented in <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#aa1d3334a17a9f136fe65ed833fbf68b4">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#ada8abaac0e81a715dedadf76aaadcbac">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#ada8abaac0e81a715dedadf76aaadcbac">RefTensorHandle</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00069">69</a> of file <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_loaded_network_8cpp_source.xhtml#l00412">LoadedNetwork::EnqueueWorkload()</a>.</p>
+<div class="fragment"><div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160;{ <span class="keywordflow">return</span> 0; }</div></div><!-- fragment -->
+</div>
+</div>
+<a id="a437893b8dcf58a0b68b70e1ad7933be6"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a437893b8dcf58a0b68b70e1ad7933be6">&#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.xhtml">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">pure 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>Implemented in <a class="el" href="classarmnn_1_1_neon_sub_tensor_handle.xhtml#ab6c52b35388890f2c563afbebfb456a6">NeonSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_sub_tensor_handle.xhtml#ab6c52b35388890f2c563afbebfb456a6">ClSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#ab6c52b35388890f2c563afbebfb456a6">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_tensor_handle.xhtml#ab6c52b35388890f2c563afbebfb456a6">ClTensorHandle</a>, <a class="el" href="classarmnn_1_1_const_cpu_tensor_handle.xhtml#ab6c52b35388890f2c563afbebfb456a6">ConstCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#ab6c52b35388890f2c563afbebfb456a6">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#ab6c52b35388890f2c563afbebfb456a6">RefTensorHandle</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_graph_8cpp_source.xhtml#l00142">Graph::AllocateDynamicBuffers()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00018">ITensorHandle::~ITensorHandle()</a>.</p>
+
+</div>
+</div>
+<a id="affd5aae75cad90f472f96cfd25a13f29"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#affd5aae75cad90f472f96cfd25a13f29">&#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">virtual <a class="el" href="classarmnn_1_1_tensor_shape.xhtml">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">pure 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.xhtml">TensorShape</a> filled with the number of elements for each dimension. </dd></dl>
+
+<p>Implemented in <a class="el" href="classarmnn_1_1_neon_sub_tensor_handle.xhtml#a8e8d2fbabcac19f9e12779080ddff54e">NeonSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_sub_tensor_handle.xhtml#a8e8d2fbabcac19f9e12779080ddff54e">ClSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#a8e8d2fbabcac19f9e12779080ddff54e">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_tensor_handle.xhtml#a8e8d2fbabcac19f9e12779080ddff54e">ClTensorHandle</a>, <a class="el" href="classarmnn_1_1_const_cpu_tensor_handle.xhtml#a8e8d2fbabcac19f9e12779080ddff54e">ConstCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#a8e8d2fbabcac19f9e12779080ddff54e">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#a8e8d2fbabcac19f9e12779080ddff54e">RefTensorHandle</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_workload_utils_8hpp_source.xhtml#l00049">armnn::CopyTensorContentsGeneric()</a>, <a class="el" href="_tensor_utils_8cpp_source.xhtml#l00058">armnnUtils::FindMinMax()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00049">ITensorHandle::Unmap()</a>.</p>
+
+</div>
+</div>
+<a id="a30c3e09ce55369b66469443a4ca5ef03"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a30c3e09ce55369b66469443a4ca5ef03">&#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">virtual <a class="el" href="classarmnn_1_1_tensor_shape.xhtml">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">pure 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.xhtml">TensorShape</a> filled with the strides for each dimension </dd></dl>
+
+<p>Implemented in <a class="el" href="classarmnn_1_1_neon_sub_tensor_handle.xhtml#a967f220393d291f71dabce0c06bf9b6c">NeonSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_sub_tensor_handle.xhtml#a967f220393d291f71dabce0c06bf9b6c">ClSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#a967f220393d291f71dabce0c06bf9b6c">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_tensor_handle.xhtml#a967f220393d291f71dabce0c06bf9b6c">ClTensorHandle</a>, <a class="el" href="classarmnn_1_1_const_cpu_tensor_handle.xhtml#a967f220393d291f71dabce0c06bf9b6c">ConstCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#a967f220393d291f71dabce0c06bf9b6c">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#a967f220393d291f71dabce0c06bf9b6c">RefTensorHandle</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_workload_utils_8hpp_source.xhtml#l00049">armnn::CopyTensorContentsGeneric()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00049">ITensorHandle::Unmap()</a>.</p>
+
+</div>
+</div>
+<a id="a4f81a9eff30c9b9fe76f5b83af470ba7"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a4f81a9eff30c9b9fe76f5b83af470ba7">&#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.xhtml#a0fc99721e27eb20ecd0ea85a3cc8b488">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">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 in <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#a468bf13728df2ac9ec772733047ff136">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#ab1766bd9f6a7902c5806178f3fd68f0b">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#ab1766bd9f6a7902c5806178f3fd68f0b">RefTensorHandle</a>.</p>
+
+<p class="definition">Definition at line <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00075">75</a> of file <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a>.</p>
+
+<p class="reference">References <a class="el" href="_ignore_unused_8hpp_source.xhtml#l00014">armnn::IgnoreUnused()</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_loaded_network_8cpp_source.xhtml#l00412">LoadedNetwork::EnqueueWorkload()</a>.</p>
+<div class="fragment"><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; {</div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; <a class="code" href="namespacearmnn.xhtml#a44affeeb090c3c6a3062830562672e84">IgnoreUnused</a>(memory, source);</div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; <span class="keywordflow">return</span> <span class="keyword">false</span>;</div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; };</div><div class="ttc" id="namespacearmnn_xhtml_a44affeeb090c3c6a3062830562672e84"><div class="ttname"><a href="namespacearmnn.xhtml#a44affeeb090c3c6a3062830562672e84">armnn::IgnoreUnused</a></div><div class="ttdeci">void IgnoreUnused(Ts &amp;&amp;...)</div><div class="ttdef"><b>Definition:</b> <a href="_ignore_unused_8hpp_source.xhtml#l00014">IgnoreUnused.hpp:14</a></div></div>
+</div><!-- fragment -->
+</div>
+</div>
+<a id="a04149d0f9b9c54c05e95693111490daf"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a04149d0f9b9c54c05e95693111490daf">&#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">pure 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>Implemented in <a class="el" href="classarmnn_1_1_neon_sub_tensor_handle.xhtml#a19aa18d78d5ac31e3a3c8f782f0e8606">NeonSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_sub_tensor_handle.xhtml#a19aa18d78d5ac31e3a3c8f782f0e8606">ClSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#a19aa18d78d5ac31e3a3c8f782f0e8606">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_tensor_handle.xhtml#a19aa18d78d5ac31e3a3c8f782f0e8606">ClTensorHandle</a>, <a class="el" href="classarmnn_1_1_const_cpu_tensor_handle.xhtml#a19aa18d78d5ac31e3a3c8f782f0e8606">ConstCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#aca21728cdaa75f9d656d25ae7200ade5">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#aca21728cdaa75f9d656d25ae7200ade5">RefTensorHandle</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_graph_8cpp_source.xhtml#l00142">Graph::AllocateDynamicBuffers()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00018">ITensorHandle::~ITensorHandle()</a>.</p>
+
+</div>
+</div>
+<a id="a9afbc055a017adf1bc38ee137bca6e90"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a9afbc055a017adf1bc38ee137bca6e90">&#9670;&nbsp;</a></span>Map() <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">virtual const void* Map </td>
+ <td>(</td>
+ <td class="paramtype">bool&#160;</td>
+ <td class="paramname"><em>blocking</em> = <code><a class="el" href="_ref_layer_tests_8cpp.xhtml#a37f1c3ccc9fc906be85185350dd83d48">true</a></code></td><td>)</td>
+ <td> const</td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">pure 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>Implemented in <a class="el" href="classarmnn_1_1_neon_sub_tensor_handle.xhtml#acc3fcce7a100cc3b64247519f22e37fc">NeonSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_sub_tensor_handle.xhtml#abe9956a614f816b4181a47a046e42db9">ClSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#acc3fcce7a100cc3b64247519f22e37fc">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_tensor_handle.xhtml#abe9956a614f816b4181a47a046e42db9">ClTensorHandle</a>, <a class="el" href="classarmnn_1_1_const_cpu_tensor_handle.xhtml#acc3fcce7a100cc3b64247519f22e37fc">ConstCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#adc70d69d2748d1432e4999d4af361f3b">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#adc70d69d2748d1432e4999d4af361f3b">RefTensorHandle</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_workload_utils_8hpp_source.xhtml#l00049">armnn::CopyTensorContentsGeneric()</a>, <a class="el" href="_loaded_network_8cpp_source.xhtml#l00412">LoadedNetwork::EnqueueWorkload()</a>, <a class="el" href="_mem_sync_workload_8cpp_source.xhtml#l00025">SyncMemGenericWorkload::Execute()</a>, <a class="el" href="_tensor_utils_8cpp_source.xhtml#l00058">armnnUtils::FindMinMax()</a>, <a class="el" href="_ref_workload_utils_8hpp_source.xhtml#l00034">armnn::GetInputTensorData()</a>, <a class="el" href="_ref_workload_utils_8hpp_source.xhtml#l00041">armnn::GetOutputTensorData()</a>, <a class="el" href="_ref_tensor_handle_8hpp_source.xhtml#l00029">RefTensorHandle::GetParent()</a>, <a class="el" href="_sample_tensor_handle_8hpp_source.xhtml#l00030">SampleTensorHandle::GetParent()</a>, <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00043">ITensorHandle::Map()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00018">ITensorHandle::~ITensorHandle()</a>.</p>
+
+</div>
+</div>
+<a id="a270c8f844df649b9b0599c1e4db44cd3"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a270c8f844df649b9b0599c1e4db44cd3">&#9670;&nbsp;</a></span>Map() <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">void* Map </td>
+ <td>(</td>
+ <td class="paramtype">bool&#160;</td>
+ <td class="paramname"><em>blocking</em> = <code><a class="el" href="_ref_layer_tests_8cpp.xhtml#a37f1c3ccc9fc906be85185350dd83d48">true</a></code></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>Map the tensor data for access. </p>
+<p>Must be paired with call to <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#ab2be1412c91842a072ad94759f52033e" title="Unmap the tensor data that was previously mapped with call to Map(). ">Unmap()</a>. </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 class="definition">Definition at line <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00043">43</a> of file <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a>.</p>
+
+<p class="reference">References <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a9afbc055a017adf1bc38ee137bca6e90">ITensorHandle::Map()</a>.</p>
+<div class="fragment"><div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160; {</div><div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160; <span class="keywordflow">return</span> <span class="keyword">const_cast&lt;</span><span class="keywordtype">void</span>*<span class="keyword">&gt;</span>(<span class="keyword">static_cast&lt;</span><span class="keyword">const </span>ITensorHandle*<span class="keyword">&gt;</span>(<span class="keyword">this</span>)-&gt;<a class="code" href="classarmnn_1_1_i_tensor_handle.xhtml#a9afbc055a017adf1bc38ee137bca6e90">Map</a>(blocking));</div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160; }</div><div class="ttc" id="classarmnn_1_1_i_tensor_handle_xhtml_a9afbc055a017adf1bc38ee137bca6e90"><div class="ttname"><a href="classarmnn_1_1_i_tensor_handle.xhtml#a9afbc055a017adf1bc38ee137bca6e90">armnn::ITensorHandle::Map</a></div><div class="ttdeci">virtual const void * Map(bool blocking=true) const =0</div><div class="ttdoc">Map the tensor data for access. </div></div>
+</div><!-- fragment -->
+</div>
+</div>
+<a id="a563609828050f1b3a7868c23f3365923"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#a563609828050f1b3a7868c23f3365923">&#9670;&nbsp;</a></span>Unmap() <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">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">pure virtual</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Unmap the tensor data. </p>
+
+<p>Implemented in <a class="el" href="classarmnn_1_1_neon_sub_tensor_handle.xhtml#a88ab6decf78c152e746b7d8dc2dd931f">NeonSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_sub_tensor_handle.xhtml#a88ab6decf78c152e746b7d8dc2dd931f">ClSubTensorHandle</a>, <a class="el" href="classarmnn_1_1_neon_tensor_handle.xhtml#a88ab6decf78c152e746b7d8dc2dd931f">NeonTensorHandle</a>, <a class="el" href="classarmnn_1_1_cl_tensor_handle.xhtml#a88ab6decf78c152e746b7d8dc2dd931f">ClTensorHandle</a>, <a class="el" href="classarmnn_1_1_const_cpu_tensor_handle.xhtml#a88ab6decf78c152e746b7d8dc2dd931f">ConstCpuTensorHandle</a>, <a class="el" href="classarmnn_1_1_sample_tensor_handle.xhtml#a88ab6decf78c152e746b7d8dc2dd931f">SampleTensorHandle</a>, and <a class="el" href="classarmnn_1_1_ref_tensor_handle.xhtml#a88ab6decf78c152e746b7d8dc2dd931f">RefTensorHandle</a>.</p>
+
+<p class="reference">Referenced by <a class="el" href="_workload_utils_8hpp_source.xhtml#l00049">armnn::CopyTensorContentsGeneric()</a>, <a class="el" href="_loaded_network_8cpp_source.xhtml#l00412">LoadedNetwork::EnqueueWorkload()</a>, <a class="el" href="_mem_sync_workload_8cpp_source.xhtml#l00025">SyncMemGenericWorkload::Execute()</a>, <a class="el" href="_tensor_utils_8cpp_source.xhtml#l00058">armnnUtils::FindMinMax()</a>, <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00049">ITensorHandle::Unmap()</a>, and <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00018">ITensorHandle::~ITensorHandle()</a>.</p>
+
+</div>
+</div>
+<a id="ab2be1412c91842a072ad94759f52033e"></a>
+<h2 class="memtitle"><span class="permalink"><a href="#ab2be1412c91842a072ad94759f52033e">&#9670;&nbsp;</a></span>Unmap() <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">void Unmap </td>
+ <td>(</td>
+ <td class="paramname"></td><td>)</td>
+ <td></td>
+ </tr>
+ </table>
+ </td>
+ <td class="mlabels-right">
+<span class="mlabels"><span class="mlabel">inline</span></span> </td>
+ </tr>
+</table>
+</div><div class="memdoc">
+
+<p>Unmap the tensor data that was previously mapped with call to <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a9afbc055a017adf1bc38ee137bca6e90" title="Map the tensor data for access. ">Map()</a>. </p>
+
+<p class="definition">Definition at line <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml#l00049">49</a> of file <a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a>.</p>
+
+<p class="reference">References <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#ad495ac6d9fd9e1ba5bb7a02c731a2d83">ITensorHandle::CopyInFrom()</a>, <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a4ec32790513ea4af4c5746f1ee48fbfe">ITensorHandle::CopyOutTo()</a>, <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#affd5aae75cad90f472f96cfd25a13f29">ITensorHandle::GetShape()</a>, <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a30c3e09ce55369b66469443a4ca5ef03">ITensorHandle::GetStrides()</a>, and <a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml#a563609828050f1b3a7868c23f3365923">ITensorHandle::Unmap()</a>.</p>
+<div class="fragment"><div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160; {</div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; <span class="keywordflow">return</span> <span class="keyword">static_cast&lt;</span><span class="keyword">const </span>ITensorHandle*<span class="keyword">&gt;</span>(<span class="keyword">this</span>)-&gt;<a class="code" href="classarmnn_1_1_i_tensor_handle.xhtml#a563609828050f1b3a7868c23f3365923">Unmap</a>();</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160; }</div><div class="ttc" id="classarmnn_1_1_i_tensor_handle_xhtml_a563609828050f1b3a7868c23f3365923"><div class="ttname"><a href="classarmnn_1_1_i_tensor_handle.xhtml#a563609828050f1b3a7868c23f3365923">armnn::ITensorHandle::Unmap</a></div><div class="ttdeci">virtual void Unmap() const =0</div><div class="ttdoc">Unmap the tensor data. </div></div>
+</div><!-- fragment -->
+</div>
+</div>
+<hr/>The documentation for this class was generated from the following file:<ul>
+<li>include/armnn/backends/<a class="el" href="include_2armnn_2backends_2_i_tensor_handle_8hpp_source.xhtml">ITensorHandle.hpp</a></li>
+</ul>
+</div><!-- contents -->
+</div><!-- doc-content -->
+<!-- start footer part -->
+<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
+ <ul>
+ <li class="navelem"><a class="el" href="namespacearmnn.xhtml">armnn</a></li><li class="navelem"><a class="el" href="classarmnn_1_1_i_tensor_handle.xhtml">ITensorHandle</a></li>
+ <li class="footer">Generated on Fri Mar 13 2020 16:09:18 for ArmNN by
+ <a href="http://www.doxygen.org/index.html">
+ <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.13 </li>
+ </ul>
+</div>
+</body>
+</html>