aboutsummaryrefslogtreecommitdiff
path: root/23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml
diff options
context:
space:
mode:
authorDavid Monahan <david.monahan@arm.com>2023-03-22 16:48:58 +0000
committerDavid Monahan <david.monahan@arm.com>2023-03-22 16:48:58 +0000
commitae050524109f1ce827962665436ef7430f2ac479 (patch)
treea087fe0c77570971dd7979f2757426c24e91afc7 /23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml
parent8d2ca734165a068478df7cffa46185680b05cd20 (diff)
downloadarmnn-ae050524109f1ce827962665436ef7430f2ac479.tar.gz
IVGCVSW-7255 Update Doxygen Documentation and publish on GitHub.
* Updating Doxygen documentation for 23.02 release. Signed-off-by: David Monahan <david.monahan@arm.com> Change-Id: I545574ff7664b4595d2fe6a91a3c35d2ad55df82
Diffstat (limited to '23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml')
-rw-r--r--23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml114
1 files changed, 88 insertions, 26 deletions
diff --git a/23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml b/23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml
index 14ff8f952d..ac611693e7 100644
--- a/23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml
+++ b/23.02/_i_memory_optimizer_strategy_8hpp_source.xhtml
@@ -8,7 +8,7 @@
<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="generator" content="Doxygen 1.8.17"/>
<meta name="robots" content="NOINDEX, NOFOLLOW" />
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>ArmNN: include/armnn/backends/IMemoryOptimizerStrategy.hpp Source File</title>
@@ -19,9 +19,6 @@
<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>
@@ -30,7 +27,8 @@
extensions: ["tex2jax.js"],
jax: ["input/TeX","output/HTML-CSS"],
});
-</script><script type="text/javascript" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js"></script>
+</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="stylesheet.css" rel="stylesheet" type="text/css"/>
</head>
@@ -51,18 +49,21 @@
</table>
</div>
<!-- end header part -->
-<!-- Generated by Doxygen 1.8.13 -->
+<!-- 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(); });
});
-</script>
+/* @license-end */</script>
<div id="main-nav"></div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
@@ -76,7 +77,9 @@ $(function() {
</div>
</div>
<script type="text/javascript">
-$(document).ready(function(){initNavTree('_i_memory_optimizer_strategy_8hpp_source.xhtml','');});
+/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
+$(document).ready(function(){initNavTree('_i_memory_optimizer_strategy_8hpp_source.xhtml',''); initResizable(); });
+/* @license-end */
</script>
<div id="doc-content">
<!-- window showing the filter options -->
@@ -98,31 +101,90 @@ $(document).ready(function(){initNavTree('_i_memory_optimizer_strategy_8hpp_sour
<div class="title">IMemoryOptimizerStrategy.hpp</div> </div>
</div><!--header-->
<div class="contents">
-<a href="_i_memory_optimizer_strategy_8hpp.xhtml">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment">// Copyright © 2021 Arm Ltd and Contributors. All rights reserved.</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="comment">// SPDX-License-Identifier: MIT</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;<span class="preprocessor">#pragma once</span></div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160;</div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_types_8hpp.xhtml">armnn/Types.hpp</a>&gt;</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160;</div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="keyword">namespace </span><a class="code" href="namespacearmnn.xhtml">armnn</a></div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;{</div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span>&#160;</div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span>&#160;<span class="comment">// A MemBlock represents a memory usage requirement in time and space and can be seen as essentially a rectangle</span></div><div class="line"><a name="l00013"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml"> 13</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structarmnn_1_1_mem_block.xhtml">MemBlock</a></div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160;{</div><div class="line"><a name="l00015"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#aaa6babfc701410e0df93d41ccc2deff8"> 15</a></span>&#160; <a class="code" href="structarmnn_1_1_mem_block.xhtml#aaa6babfc701410e0df93d41ccc2deff8">MemBlock</a>(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> startOfLife,</div><div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> endOfLife,</div><div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160; <span class="keyword">const</span> <span class="keywordtype">size_t</span> memSize,</div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160; <span class="keywordtype">size_t</span> offset,</div><div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> index)</div><div class="line"><a name="l00020"></a><span class="lineno"> 20</span>&#160; : <a class="code" href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3">m_StartOfLife</a>(startOfLife), <a class="code" href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11">m_EndOfLife</a>(endOfLife), <a class="code" href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53">m_MemSize</a>(memSize), <a class="code" href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d">m_Offset</a>(offset), <a class="code" href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b">m_Index</a>(index) {}</div><div class="line"><a name="l00021"></a><span class="lineno"> 21</span>&#160;</div><div class="line"><a name="l00022"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3"> 22</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3">m_StartOfLife</a>; <span class="comment">// Y start inclusive</span></div><div class="line"><a name="l00023"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11"> 23</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11">m_EndOfLife</a>; <span class="comment">// Y end inclusive</span></div><div class="line"><a name="l00024"></a><span class="lineno"> 24</span>&#160;</div><div class="line"><a name="l00025"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53"> 25</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">size_t</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53">m_MemSize</a>; <span class="comment">// Offset + Memsize = X end</span></div><div class="line"><a name="l00026"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d"> 26</a></span>&#160; <span class="keywordtype">size_t</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d">m_Offset</a>; <span class="comment">// X start</span></div><div class="line"><a name="l00027"></a><span class="lineno"> 27</span>&#160;</div><div class="line"><a name="l00028"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b"> 28</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b">m_Index</a>; <span class="comment">// Index to keep order</span></div><div class="line"><a name="l00029"></a><span class="lineno"> 29</span>&#160;};</div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span>&#160;</div><div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160;<span class="comment">// A MemBin represents a single contiguous area of memory that can store 1-n number of MemBlocks</span></div><div class="line"><a name="l00032"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_bin.xhtml"> 32</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structarmnn_1_1_mem_bin.xhtml">MemBin</a></div><div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160;{</div><div class="line"><a name="l00034"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_bin.xhtml#aeb1783f0f3f528e11f9ce70f0214f8bb"> 34</a></span>&#160; std::vector&lt;MemBlock&gt; <a class="code" href="structarmnn_1_1_mem_bin.xhtml#aeb1783f0f3f528e11f9ce70f0214f8bb">m_MemBlocks</a>;</div><div class="line"><a name="l00035"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_bin.xhtml#a08e50de8fcc7560644bdabc7356bb270"> 35</a></span>&#160; <span class="keywordtype">size_t</span> <a class="code" href="structarmnn_1_1_mem_bin.xhtml#a08e50de8fcc7560644bdabc7356bb270">m_MemSize</a>;</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;</div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160;<span class="comment">// IMemoryOptimizerStrategy will set m_Offset of the MemBlocks,</span></div><div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160;<span class="comment">// sort them into 1-n bins, then pair each bin of MemBlocks with an int specifying it&#39;s total size</span></div><div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160;<span class="comment">// A IMemoryOptimizerStrategy must ensure that</span></div><div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160;<span class="comment">// 1: All MemBlocks have been assigned to a MemBin</span></div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160;<span class="comment">// 2: No MemBlock is assigned to multiple MemBins</span></div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160;<span class="comment">// 3: No two Memblocks in a MemBin overlap in both the X and Y axis</span></div><div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160;<span class="comment">// (a strategy cannot change the y axis or length of a MemBlock)</span></div><div class="line"><a name="l00045"></a><span class="lineno"><a class="line" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml"> 45</a></span>&#160;<span class="keyword">class </span><a class="code" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml">IMemoryOptimizerStrategy</a></div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160;{</div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160;<span class="keyword">public</span>:</div><div class="line"><a name="l00048"></a><span class="lineno"><a class="line" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a9b47d46d6792d6cbcd98ff4f26ac8489"> 48</a></span>&#160; <span class="keyword">virtual</span> <a class="code" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a9b47d46d6792d6cbcd98ff4f26ac8489">~IMemoryOptimizerStrategy</a>() {}</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; <span class="keyword">virtual</span> std::string GetName() <span class="keyword">const</span> = 0;</div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160;</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160; <span class="keyword">virtual</span> <a class="code" href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6">MemBlockStrategyType</a> GetMemBlockStrategyType() <span class="keyword">const</span> = 0;</div><div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160;</div><div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160; <span class="keyword">virtual</span> std::vector&lt;MemBin&gt; <a class="code" href="namespacearmnn.xhtml#a82e98ef05fd67036d1195ba17174d685">Optimize</a>(std::vector&lt;MemBlock&gt;&amp; memBlocks) = 0;</div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160;};</div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160;</div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160;} <span class="comment">// namespace armnn</span></div><div class="ttc" id="classarmnn_1_1_i_memory_optimizer_strategy_xhtml_a9b47d46d6792d6cbcd98ff4f26ac8489"><div class="ttname"><a href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a9b47d46d6792d6cbcd98ff4f26ac8489">armnn::IMemoryOptimizerStrategy::~IMemoryOptimizerStrategy</a></div><div class="ttdeci">virtual ~IMemoryOptimizerStrategy()</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00048">IMemoryOptimizerStrategy.hpp:48</a></div></div>
-<div class="ttc" id="classarmnn_1_1_i_memory_optimizer_strategy_xhtml"><div class="ttname"><a href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml">armnn::IMemoryOptimizerStrategy</a></div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00045">IMemoryOptimizerStrategy.hpp:45</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_block_xhtml_a709b862a06a33e0f77e0d5cfb95daaf3"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3">armnn::MemBlock::m_StartOfLife</a></div><div class="ttdeci">const unsigned int m_StartOfLife</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00022">IMemoryOptimizerStrategy.hpp:22</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_bin_xhtml_aeb1783f0f3f528e11f9ce70f0214f8bb"><div class="ttname"><a href="structarmnn_1_1_mem_bin.xhtml#aeb1783f0f3f528e11f9ce70f0214f8bb">armnn::MemBin::m_MemBlocks</a></div><div class="ttdeci">std::vector&lt; MemBlock &gt; m_MemBlocks</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00034">IMemoryOptimizerStrategy.hpp:34</a></div></div>
-<div class="ttc" id="namespacearmnn_xhtml"><div class="ttname"><a href="namespacearmnn.xhtml">armnn</a></div><div class="ttdoc">Copyright (c) 2021 ARM Limited and Contributors. </div><div class="ttdef"><b>Definition:</b> <a href="01__00__quick__start_8dox_source.xhtml#l00006">01_00_quick_start.dox:6</a></div></div>
-<div class="ttc" id="namespacearmnn_xhtml_a82e98ef05fd67036d1195ba17174d685"><div class="ttname"><a href="namespacearmnn.xhtml#a82e98ef05fd67036d1195ba17174d685">armnn::Optimize</a></div><div class="ttdeci">IOptimizedNetworkPtr Optimize(const INetwork &amp;network, const std::vector&lt; BackendId &gt; &amp;backendPreferences, const IDeviceSpec &amp;deviceSpec, const OptimizerOptions &amp;options=OptimizerOptions(), Optional&lt; std::vector&lt; std::string &gt; &amp;&gt; messages=EmptyOptional())</div><div class="ttdoc">Create an optimized version of the network. </div><div class="ttdef"><b>Definition:</b> <a href="_network_8cpp_source.xhtml#l01773">Network.cpp:1773</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_block_xhtml_a7fa2df31ffac52484e0612a31fd4256d"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d">armnn::MemBlock::m_Offset</a></div><div class="ttdeci">size_t m_Offset</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00026">IMemoryOptimizerStrategy.hpp:26</a></div></div>
-<div class="ttc" id="_types_8hpp_xhtml"><div class="ttname"><a href="_types_8hpp.xhtml">Types.hpp</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_block_xhtml"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml">armnn::MemBlock</a></div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00013">IMemoryOptimizerStrategy.hpp:13</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_bin_xhtml"><div class="ttname"><a href="structarmnn_1_1_mem_bin.xhtml">armnn::MemBin</a></div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00032">IMemoryOptimizerStrategy.hpp:32</a></div></div>
-<div class="ttc" id="namespacearmnn_xhtml_a7100de49939c3e393101f78d425a98c6"><div class="ttname"><a href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6">armnn::MemBlockStrategyType</a></div><div class="ttdeci">MemBlockStrategyType</div><div class="ttdef"><b>Definition:</b> <a href="_types_8hpp_source.xhtml#l00239">Types.hpp:239</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_block_xhtml_ac972eed0c811e23b9e1060cee4ac5a53"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53">armnn::MemBlock::m_MemSize</a></div><div class="ttdeci">const size_t m_MemSize</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00025">IMemoryOptimizerStrategy.hpp:25</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_bin_xhtml_a08e50de8fcc7560644bdabc7356bb270"><div class="ttname"><a href="structarmnn_1_1_mem_bin.xhtml#a08e50de8fcc7560644bdabc7356bb270">armnn::MemBin::m_MemSize</a></div><div class="ttdeci">size_t m_MemSize</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00035">IMemoryOptimizerStrategy.hpp:35</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_block_xhtml_aaa6babfc701410e0df93d41ccc2deff8"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#aaa6babfc701410e0df93d41ccc2deff8">armnn::MemBlock::MemBlock</a></div><div class="ttdeci">MemBlock(const unsigned int startOfLife, const unsigned int endOfLife, const size_t memSize, size_t offset, const unsigned int index)</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00015">IMemoryOptimizerStrategy.hpp:15</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_block_xhtml_afb654a0f03aca4f7f73a9008fab83b11"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11">armnn::MemBlock::m_EndOfLife</a></div><div class="ttdeci">const unsigned int m_EndOfLife</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00023">IMemoryOptimizerStrategy.hpp:23</a></div></div>
-<div class="ttc" id="structarmnn_1_1_mem_block_xhtml_a33204e9c0c3d6dc19cec97536ce9527b"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b">armnn::MemBlock::m_Index</a></div><div class="ttdeci">const unsigned int m_Index</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00028">IMemoryOptimizerStrategy.hpp:28</a></div></div>
+<a href="_i_memory_optimizer_strategy_8hpp.xhtml">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span>&#160;<span class="comment">//</span></div>
+<div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment">// Copyright © 2021 Arm Ltd and Contributors. All rights reserved.</span></div>
+<div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="comment">// SPDX-License-Identifier: MIT</span></div>
+<div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;<span class="comment">//</span></div>
+<div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;<span class="preprocessor">#pragma once</span></div>
+<div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160; </div>
+<div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="preprocessor">#include &lt;<a class="code" href="_types_8hpp.xhtml">armnn/Types.hpp</a>&gt;</span></div>
+<div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160; </div>
+<div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="keyword">namespace </span><a class="code" href="namespacearmnn.xhtml">armnn</a></div>
+<div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;{</div>
+<div class="line"><a name="l00011"></a><span class="lineno"> 11</span>&#160; </div>
+<div class="line"><a name="l00012"></a><span class="lineno"> 12</span>&#160;<span class="comment">// A MemBlock represents a memory usage requirement in time and space and can be seen as essentially a rectangle</span></div>
+<div class="line"><a name="l00013"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml"> 13</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structarmnn_1_1_mem_block.xhtml">MemBlock</a></div>
+<div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160;{</div>
+<div class="line"><a name="l00015"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#aaa6babfc701410e0df93d41ccc2deff8"> 15</a></span>&#160; <a class="code" href="structarmnn_1_1_mem_block.xhtml#aaa6babfc701410e0df93d41ccc2deff8">MemBlock</a>(<span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> startOfLife,</div>
+<div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> endOfLife,</div>
+<div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160; <span class="keyword">const</span> <span class="keywordtype">size_t</span> memSize,</div>
+<div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160; <span class="keywordtype">size_t</span> offset,</div>
+<div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> index)</div>
+<div class="line"><a name="l00020"></a><span class="lineno"> 20</span>&#160; : <a class="code" href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3">m_StartOfLife</a>(startOfLife), <a class="code" href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11">m_EndOfLife</a>(endOfLife), <a class="code" href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53">m_MemSize</a>(memSize), <a class="code" href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d">m_Offset</a>(offset), <a class="code" href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b">m_Index</a>(index) {}</div>
+<div class="line"><a name="l00021"></a><span class="lineno"> 21</span>&#160; </div>
+<div class="line"><a name="l00022"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3"> 22</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3">m_StartOfLife</a>; <span class="comment">// Y start inclusive</span></div>
+<div class="line"><a name="l00023"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11"> 23</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11">m_EndOfLife</a>; <span class="comment">// Y end inclusive</span></div>
+<div class="line"><a name="l00024"></a><span class="lineno"> 24</span>&#160; </div>
+<div class="line"><a name="l00025"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53"> 25</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">size_t</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53">m_MemSize</a>; <span class="comment">// Offset + Memsize = X end</span></div>
+<div class="line"><a name="l00026"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d"> 26</a></span>&#160; <span class="keywordtype">size_t</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d">m_Offset</a>; <span class="comment">// X start</span></div>
+<div class="line"><a name="l00027"></a><span class="lineno"> 27</span>&#160; </div>
+<div class="line"><a name="l00028"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b"> 28</a></span>&#160; <span class="keyword">const</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b">m_Index</a>; <span class="comment">// Index to keep order</span></div>
+<div class="line"><a name="l00029"></a><span class="lineno"> 29</span>&#160;};</div>
+<div class="line"><a name="l00030"></a><span class="lineno"> 30</span>&#160; </div>
+<div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160;<span class="comment">// A MemBin represents a single contiguous area of memory that can store 1-n number of MemBlocks</span></div>
+<div class="line"><a name="l00032"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_bin.xhtml"> 32</a></span>&#160;<span class="keyword">struct </span><a class="code" href="structarmnn_1_1_mem_bin.xhtml">MemBin</a></div>
+<div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160;{</div>
+<div class="line"><a name="l00034"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_bin.xhtml#aeb1783f0f3f528e11f9ce70f0214f8bb"> 34</a></span>&#160; std::vector&lt;MemBlock&gt; <a class="code" href="structarmnn_1_1_mem_bin.xhtml#aeb1783f0f3f528e11f9ce70f0214f8bb">m_MemBlocks</a>;</div>
+<div class="line"><a name="l00035"></a><span class="lineno"><a class="line" href="structarmnn_1_1_mem_bin.xhtml#a08e50de8fcc7560644bdabc7356bb270"> 35</a></span>&#160; <span class="keywordtype">size_t</span> <a class="code" href="structarmnn_1_1_mem_bin.xhtml#a08e50de8fcc7560644bdabc7356bb270">m_MemSize</a>;</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; </div>
+<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160;<span class="comment">// IMemoryOptimizerStrategy will set m_Offset of the MemBlocks,</span></div>
+<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160;<span class="comment">// sort them into 1-n bins, then pair each bin of MemBlocks with an int specifying it&#39;s total size</span></div>
+<div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160;<span class="comment">// A IMemoryOptimizerStrategy must ensure that</span></div>
+<div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160;<span class="comment">// 1: All MemBlocks have been assigned to a MemBin</span></div>
+<div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160;<span class="comment">// 2: No MemBlock is assigned to multiple MemBins</span></div>
+<div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160;<span class="comment">// 3: No two Memblocks in a MemBin overlap in both the X and Y axis</span></div>
+<div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160;<span class="comment">// (a strategy cannot change the y axis or length of a MemBlock)</span></div>
+<div class="line"><a name="l00045"></a><span class="lineno"><a class="line" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml"> 45</a></span>&#160;<span class="keyword">class </span><a class="code" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml">IMemoryOptimizerStrategy</a></div>
+<div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160;{</div>
+<div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160;<span class="keyword">public</span>:</div>
+<div class="line"><a name="l00048"></a><span class="lineno"><a class="line" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a9b47d46d6792d6cbcd98ff4f26ac8489"> 48</a></span>&#160; <span class="keyword">virtual</span> <a class="code" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a9b47d46d6792d6cbcd98ff4f26ac8489">~IMemoryOptimizerStrategy</a>() {}</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; <span class="keyword">virtual</span> std::string <a class="code" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a46f9918b14061163f435d80860b02b56">GetName</a>() <span class="keyword">const</span> = 0;</div>
+<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; </div>
+<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160; <span class="keyword">virtual</span> <a class="code" href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6">MemBlockStrategyType</a> <a class="code" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a33c9902a46246bcf4d44855b4d866dcb">GetMemBlockStrategyType</a>() <span class="keyword">const</span> = 0;</div>
+<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160; </div>
+<div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160; <span class="keyword">virtual</span> std::vector&lt;MemBin&gt; <a class="code" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a1a9447457df9be8f8186fe73bba4cb72">Optimize</a>(std::vector&lt;MemBlock&gt;&amp; memBlocks) = 0;</div>
+<div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160;};</div>
+<div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160; </div>
+<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160;} <span class="comment">// namespace armnn</span></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
+<div class="ttc" id="aclassarmnn_1_1_i_memory_optimizer_strategy_xhtml_a46f9918b14061163f435d80860b02b56"><div class="ttname"><a href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a46f9918b14061163f435d80860b02b56">armnn::IMemoryOptimizerStrategy::GetName</a></div><div class="ttdeci">virtual std::string GetName() const =0</div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_bin_xhtml_a08e50de8fcc7560644bdabc7356bb270"><div class="ttname"><a href="structarmnn_1_1_mem_bin.xhtml#a08e50de8fcc7560644bdabc7356bb270">armnn::MemBin::m_MemSize</a></div><div class="ttdeci">size_t m_MemSize</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00035">IMemoryOptimizerStrategy.hpp:35</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_block_xhtml_aaa6babfc701410e0df93d41ccc2deff8"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#aaa6babfc701410e0df93d41ccc2deff8">armnn::MemBlock::MemBlock</a></div><div class="ttdeci">MemBlock(const unsigned int startOfLife, const unsigned int endOfLife, const size_t memSize, size_t offset, const unsigned int index)</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00015">IMemoryOptimizerStrategy.hpp:15</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_i_memory_optimizer_strategy_xhtml_a33c9902a46246bcf4d44855b4d866dcb"><div class="ttname"><a href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a33c9902a46246bcf4d44855b4d866dcb">armnn::IMemoryOptimizerStrategy::GetMemBlockStrategyType</a></div><div class="ttdeci">virtual MemBlockStrategyType GetMemBlockStrategyType() const =0</div></div>
+<div class="ttc" id="aclassarmnn_1_1_i_memory_optimizer_strategy_xhtml_a1a9447457df9be8f8186fe73bba4cb72"><div class="ttname"><a href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a1a9447457df9be8f8186fe73bba4cb72">armnn::IMemoryOptimizerStrategy::Optimize</a></div><div class="ttdeci">virtual std::vector&lt; MemBin &gt; Optimize(std::vector&lt; MemBlock &gt; &amp;memBlocks)=0</div></div>
+<div class="ttc" id="anamespacearmnn_xhtml_a7100de49939c3e393101f78d425a98c6"><div class="ttname"><a href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6">armnn::MemBlockStrategyType</a></div><div class="ttdeci">MemBlockStrategyType</div><div class="ttdef"><b>Definition:</b> <a href="_types_8hpp_source.xhtml#l00239">Types.hpp:239</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_i_memory_optimizer_strategy_xhtml_a9b47d46d6792d6cbcd98ff4f26ac8489"><div class="ttname"><a href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a9b47d46d6792d6cbcd98ff4f26ac8489">armnn::IMemoryOptimizerStrategy::~IMemoryOptimizerStrategy</a></div><div class="ttdeci">virtual ~IMemoryOptimizerStrategy()</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00048">IMemoryOptimizerStrategy.hpp:48</a></div></div>
+<div class="ttc" id="anamespacearmnn_xhtml"><div class="ttname"><a href="namespacearmnn.xhtml">armnn</a></div><div class="ttdoc">Copyright (c) 2021 ARM Limited and Contributors.</div><div class="ttdef"><b>Definition:</b> <a href="01__00__quick__start_8dox_source.xhtml#l00006">01_00_quick_start.dox:6</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_block_xhtml_ac972eed0c811e23b9e1060cee4ac5a53"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#ac972eed0c811e23b9e1060cee4ac5a53">armnn::MemBlock::m_MemSize</a></div><div class="ttdeci">const size_t m_MemSize</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00025">IMemoryOptimizerStrategy.hpp:25</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_block_xhtml_a709b862a06a33e0f77e0d5cfb95daaf3"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#a709b862a06a33e0f77e0d5cfb95daaf3">armnn::MemBlock::m_StartOfLife</a></div><div class="ttdeci">const unsigned int m_StartOfLife</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00022">IMemoryOptimizerStrategy.hpp:22</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_block_xhtml"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml">armnn::MemBlock</a></div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00013">IMemoryOptimizerStrategy.hpp:13</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_block_xhtml_afb654a0f03aca4f7f73a9008fab83b11"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#afb654a0f03aca4f7f73a9008fab83b11">armnn::MemBlock::m_EndOfLife</a></div><div class="ttdeci">const unsigned int m_EndOfLife</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00023">IMemoryOptimizerStrategy.hpp:23</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_block_xhtml_a7fa2df31ffac52484e0612a31fd4256d"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#a7fa2df31ffac52484e0612a31fd4256d">armnn::MemBlock::m_Offset</a></div><div class="ttdeci">size_t m_Offset</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00026">IMemoryOptimizerStrategy.hpp:26</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_bin_xhtml_aeb1783f0f3f528e11f9ce70f0214f8bb"><div class="ttname"><a href="structarmnn_1_1_mem_bin.xhtml#aeb1783f0f3f528e11f9ce70f0214f8bb">armnn::MemBin::m_MemBlocks</a></div><div class="ttdeci">std::vector&lt; MemBlock &gt; m_MemBlocks</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00034">IMemoryOptimizerStrategy.hpp:34</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_block_xhtml_a33204e9c0c3d6dc19cec97536ce9527b"><div class="ttname"><a href="structarmnn_1_1_mem_block.xhtml#a33204e9c0c3d6dc19cec97536ce9527b">armnn::MemBlock::m_Index</a></div><div class="ttdeci">const unsigned int m_Index</div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00028">IMemoryOptimizerStrategy.hpp:28</a></div></div>
+<div class="ttc" id="astructarmnn_1_1_mem_bin_xhtml"><div class="ttname"><a href="structarmnn_1_1_mem_bin.xhtml">armnn::MemBin</a></div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00032">IMemoryOptimizerStrategy.hpp:32</a></div></div>
+<div class="ttc" id="a_types_8hpp_xhtml"><div class="ttname"><a href="_types_8hpp.xhtml">Types.hpp</a></div></div>
+<div class="ttc" id="aclassarmnn_1_1_i_memory_optimizer_strategy_xhtml"><div class="ttname"><a href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml">armnn::IMemoryOptimizerStrategy</a></div><div class="ttdef"><b>Definition:</b> <a href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00045">IMemoryOptimizerStrategy.hpp:45</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="dir_d44c64559bbebec7f509842c48db8b23.xhtml">include</a></li><li class="navelem"><a class="el" href="dir_2b72cc348e06937955e62ebdd8a13436.xhtml">armnn</a></li><li class="navelem"><a class="el" href="dir_8946eb9d8f826e973720979438627a91.xhtml">backends</a></li><li class="navelem"><a class="el" href="_i_memory_optimizer_strategy_8hpp.xhtml">IMemoryOptimizerStrategy.hpp</a></li>
- <li class="footer">Generated on Fri Feb 24 2023 10:24:24 for ArmNN by
+ <li class="footer">Generated on Wed Mar 22 2023 15:52:59 for ArmNN by
<a href="http://www.doxygen.org/index.html">
- <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.13 </li>
+ <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.17 </li>
</ul>
</div>
</body>