diff options
author | David Monahan <david.monahan@arm.com> | 2023-03-22 16:48:58 +0000 |
---|---|---|
committer | David Monahan <david.monahan@arm.com> | 2023-03-22 16:48:58 +0000 |
commit | ae050524109f1ce827962665436ef7430f2ac479 (patch) | |
tree | a087fe0c77570971dd7979f2757426c24e91afc7 /23.02/classarmnn_1_1_single_axis_priority_list.xhtml | |
parent | 8d2ca734165a068478df7cffa46185680b05cd20 (diff) | |
download | armnn-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/classarmnn_1_1_single_axis_priority_list.xhtml')
-rw-r--r-- | 23.02/classarmnn_1_1_single_axis_priority_list.xhtml | 97 |
1 files changed, 71 insertions, 26 deletions
diff --git a/23.02/classarmnn_1_1_single_axis_priority_list.xhtml b/23.02/classarmnn_1_1_single_axis_priority_list.xhtml index 86669e537d..774d5fbcb9 100644 --- a/23.02/classarmnn_1_1_single_axis_priority_list.xhtml +++ b/23.02/classarmnn_1_1_single_axis_priority_list.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: SingleAxisPriorityList Class Reference</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&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&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('classarmnn_1_1_single_axis_priority_list.xhtml','');}); +/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ +$(document).ready(function(){initNavTree('classarmnn_1_1_single_axis_priority_list.xhtml',''); initResizable(); }); +/* @license-end */ </script> <div id="doc-content"> <!-- window showing the filter options --> @@ -113,8 +116,8 @@ Inheritance diagram for SingleAxisPriorityList:</div> <img src="classarmnn_1_1_single_axis_priority_list.png" usemap="#SingleAxisPriorityList_map" alt=""/> <map id="SingleAxisPriorityList_map" name="SingleAxisPriorityList_map"> <area href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml" alt="IMemoryOptimizerStrategy" shape="rect" coords="0,0,161,24"/> -</map> - </div></div> + </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> @@ -159,10 +162,11 @@ Public Member Functions</h2></td></tr> </div><div class="memdoc"> <p class="definition">Definition at line <a class="el" href="_single_axis_priority_list_8hpp_source.xhtml#l00023">23</a> of file <a class="el" href="_single_axis_priority_list_8hpp_source.xhtml">SingleAxisPriorityList.hpp</a>.</p> - -<p class="reference">References <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml#l00028">SingleAxisPriorityList::GetMemBlockStrategyType()</a>, <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml#l00024">SingleAxisPriorityList::GetName()</a>, and <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml#l00214">SingleAxisPriorityList::Optimize()</a>.</p> -<div class="fragment"><div class="line"><a name="l00024"></a><span class="lineno"> 24</span>  : m_Name(std::string(<span class="stringliteral">"SingleAxisPriorityList"</span>))</div><div class="line"><a name="l00025"></a><span class="lineno"> 25</span>  , m_MemBlockStrategyType(<a class="code" href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6a568437eb3752bdf14546b5c221ba5be7">MemBlockStrategyType::SingleAxisPacking</a>) {}</div><div class="ttc" id="namespacearmnn_xhtml_a7100de49939c3e393101f78d425a98c6a568437eb3752bdf14546b5c221ba5be7"><div class="ttname"><a href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6a568437eb3752bdf14546b5c221ba5be7">armnn::MemBlockStrategyType::SingleAxisPacking</a></div></div> +<div class="fragment"><div class="line"><a name="l00024"></a><span class="lineno"> 24</span>  : m_Name(std::string(<span class="stringliteral">"SingleAxisPriorityList"</span>))</div> +<div class="line"><a name="l00025"></a><span class="lineno"> 25</span>  , m_MemBlockStrategyType(<a class="code" href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6a568437eb3752bdf14546b5c221ba5be7">MemBlockStrategyType::SingleAxisPacking</a>) {}</div> </div><!-- fragment --> +<p class="reference">References <a class="el" href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6a568437eb3752bdf14546b5c221ba5be7">armnn::SingleAxisPacking</a>.</p> + </div> </div> <h2 class="groupheader">Member Function Documentation</h2> @@ -192,11 +196,10 @@ Public Member Functions</h2></td></tr> <p>Implements <a class="el" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a33c9902a46246bcf4d44855b4d866dcb">IMemoryOptimizerStrategy</a>.</p> <p class="definition">Definition at line <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml#l00028">28</a> of file <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml">SingleAxisPriorityList.cpp</a>.</p> - -<p class="reference">References <a class="el" href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00023">MemBlock::m_EndOfLife</a>, <a class="el" href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00025">MemBlock::m_MemSize</a>, <a class="el" href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00022">MemBlock::m_StartOfLife</a>, and <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml#l00022">armnn::wordSize</a>.</p> - -<p class="reference">Referenced by <a class="el" href="_single_axis_priority_list_8hpp_source.xhtml#l00023">SingleAxisPriorityList::SingleAxisPriorityList()</a>.</p> -<div class="fragment"><div class="line"><a name="l00028"></a><span class="lineno"> 28</span>  {</div><div class="line"><a name="l00029"></a><span class="lineno"> 29</span>  <span class="keywordflow">return</span> m_MemBlockStrategyType;</div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span> }</div></div><!-- fragment --> +<div class="fragment"><div class="line"><a name="l00028"></a><span class="lineno"> 28</span>  {</div> +<div class="line"><a name="l00029"></a><span class="lineno"> 29</span>  <span class="keywordflow">return</span> m_MemBlockStrategyType;</div> +<div class="line"><a name="l00030"></a><span class="lineno"> 30</span> }</div> +</div><!-- fragment --> </div> </div> <a id="a84ae72d221e80b93c2246b44a50fa361"></a> @@ -225,9 +228,10 @@ Public Member Functions</h2></td></tr> <p>Implements <a class="el" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a46f9918b14061163f435d80860b02b56">IMemoryOptimizerStrategy</a>.</p> <p class="definition">Definition at line <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml#l00024">24</a> of file <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml">SingleAxisPriorityList.cpp</a>.</p> - -<p class="reference">Referenced by <a class="el" href="_single_axis_priority_list_8hpp_source.xhtml#l00023">SingleAxisPriorityList::SingleAxisPriorityList()</a>.</p> -<div class="fragment"><div class="line"><a name="l00024"></a><span class="lineno"> 24</span>  {</div><div class="line"><a name="l00025"></a><span class="lineno"> 25</span>  <span class="keywordflow">return</span> m_Name;</div><div class="line"><a name="l00026"></a><span class="lineno"> 26</span> }</div></div><!-- fragment --> +<div class="fragment"><div class="line"><a name="l00024"></a><span class="lineno"> 24</span>  {</div> +<div class="line"><a name="l00025"></a><span class="lineno"> 25</span>  <span class="keywordflow">return</span> m_Name;</div> +<div class="line"><a name="l00026"></a><span class="lineno"> 26</span> }</div> +</div><!-- fragment --> </div> </div> <a id="ada820fb9d89d2fb75bacaffe511791b7"></a> @@ -257,11 +261,51 @@ Public Member Functions</h2></td></tr> <p>Implements <a class="el" href="classarmnn_1_1_i_memory_optimizer_strategy.xhtml#a1a9447457df9be8f8186fe73bba4cb72">IMemoryOptimizerStrategy</a>.</p> <p class="definition">Definition at line <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml#l00214">214</a> of file <a class="el" href="_single_axis_priority_list_8cpp_source.xhtml">SingleAxisPriorityList.cpp</a>.</p> - +<div class="fragment"><div class="line"><a name="l00215"></a><span class="lineno"> 215</span> {</div> +<div class="line"><a name="l00216"></a><span class="lineno"> 216</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxLifetime = 0;</div> +<div class="line"><a name="l00217"></a><span class="lineno"> 217</span>  std::list<MemBlock*> priorityList;</div> +<div class="line"><a name="l00218"></a><span class="lineno"> 218</span>  <span class="keywordflow">for</span> (<span class="keyword">auto</span>& block: blocks)</div> +<div class="line"><a name="l00219"></a><span class="lineno"> 219</span>  {</div> +<div class="line"><a name="l00220"></a><span class="lineno"> 220</span>  maxLifetime = std::max(maxLifetime, block.m_EndOfLife);</div> +<div class="line"><a name="l00221"></a><span class="lineno"> 221</span>  priorityList.emplace_back(&block);</div> +<div class="line"><a name="l00222"></a><span class="lineno"> 222</span>  }</div> +<div class="line"><a name="l00223"></a><span class="lineno"> 223</span>  maxLifetime++;</div> +<div class="line"><a name="l00224"></a><span class="lineno"> 224</span>  </div> +<div class="line"><a name="l00225"></a><span class="lineno"> 225</span>  <span class="comment">// From testing ordering by m_MemSize in non-descending order gives the best results overall</span></div> +<div class="line"><a name="l00226"></a><span class="lineno"> 226</span>  priorityList.sort([](<span class="keyword">const</span> MemBlock* lhs, <span class="keyword">const</span> MemBlock* rhs)</div> +<div class="line"><a name="l00227"></a><span class="lineno"> 227</span>  {</div> +<div class="line"><a name="l00228"></a><span class="lineno"> 228</span>  <span class="keywordflow">return</span> lhs->m_MemSize > rhs->m_MemSize ;</div> +<div class="line"><a name="l00229"></a><span class="lineno"> 229</span>  });</div> +<div class="line"><a name="l00230"></a><span class="lineno"> 230</span>  </div> +<div class="line"><a name="l00231"></a><span class="lineno"> 231</span>  </div> +<div class="line"><a name="l00232"></a><span class="lineno"> 232</span>  std::vector<BinTracker> placedBlocks;</div> +<div class="line"><a name="l00233"></a><span class="lineno"> 233</span>  placedBlocks.reserve(maxLifetime);</div> +<div class="line"><a name="l00234"></a><span class="lineno"> 234</span>  PlaceBlocks(priorityList, placedBlocks, maxLifetime);</div> +<div class="line"><a name="l00235"></a><span class="lineno"> 235</span>  </div> +<div class="line"><a name="l00236"></a><span class="lineno"> 236</span>  std::vector<MemBin> bins;</div> +<div class="line"><a name="l00237"></a><span class="lineno"> 237</span>  bins.reserve(placedBlocks.size());</div> +<div class="line"><a name="l00238"></a><span class="lineno"> 238</span>  <span class="keywordflow">for</span> (<span class="keyword">auto</span> blockList: placedBlocks)</div> +<div class="line"><a name="l00239"></a><span class="lineno"> 239</span>  {</div> +<div class="line"><a name="l00240"></a><span class="lineno"> 240</span>  MemBin bin;</div> +<div class="line"><a name="l00241"></a><span class="lineno"> 241</span>  bin.m_MemBlocks.reserve(blockList.m_PlacedBlocks.size());</div> +<div class="line"><a name="l00242"></a><span class="lineno"> 242</span>  bin.m_MemSize = blockList.m_MemSize;</div> +<div class="line"><a name="l00243"></a><span class="lineno"> 243</span>  </div> +<div class="line"><a name="l00244"></a><span class="lineno"> 244</span>  <span class="keywordflow">for</span> (<span class="keyword">auto</span> block : blockList.m_PlacedBlocks)</div> +<div class="line"><a name="l00245"></a><span class="lineno"> 245</span>  {</div> +<div class="line"><a name="l00246"></a><span class="lineno"> 246</span>  bin.m_MemBlocks.emplace_back(MemBlock{block->m_StartOfLife,</div> +<div class="line"><a name="l00247"></a><span class="lineno"> 247</span>  block->m_EndOfLife,</div> +<div class="line"><a name="l00248"></a><span class="lineno"> 248</span>  block->m_MemSize,</div> +<div class="line"><a name="l00249"></a><span class="lineno"> 249</span>  0,</div> +<div class="line"><a name="l00250"></a><span class="lineno"> 250</span>  block->m_Index,});</div> +<div class="line"><a name="l00251"></a><span class="lineno"> 251</span>  }</div> +<div class="line"><a name="l00252"></a><span class="lineno"> 252</span>  bins.push_back(std::move(bin));</div> +<div class="line"><a name="l00253"></a><span class="lineno"> 253</span>  }</div> +<div class="line"><a name="l00254"></a><span class="lineno"> 254</span>  </div> +<div class="line"><a name="l00255"></a><span class="lineno"> 255</span>  <span class="keywordflow">return</span> bins;</div> +<div class="line"><a name="l00256"></a><span class="lineno"> 256</span> }</div> +</div><!-- fragment --> <p class="reference">References <a class="el" href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00034">MemBin::m_MemBlocks</a>, <a class="el" href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00025">MemBlock::m_MemSize</a>, <a class="el" href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00035">MemBin::m_MemSize</a>, and <a class="el" href="_i_memory_optimizer_strategy_8hpp_source.xhtml#l00022">MemBlock::m_StartOfLife</a>.</p> -<p class="reference">Referenced by <a class="el" href="_single_axis_priority_list_8hpp_source.xhtml#l00023">SingleAxisPriorityList::SingleAxisPriorityList()</a>.</p> -<div class="fragment"><div class="line"><a name="l00215"></a><span class="lineno"> 215</span> {</div><div class="line"><a name="l00216"></a><span class="lineno"> 216</span>  <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> maxLifetime = 0;</div><div class="line"><a name="l00217"></a><span class="lineno"> 217</span>  std::list<MemBlock*> priorityList;</div><div class="line"><a name="l00218"></a><span class="lineno"> 218</span>  <span class="keywordflow">for</span> (<span class="keyword">auto</span>& block: blocks)</div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span>  {</div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>  maxLifetime = std::max(maxLifetime, block.m_EndOfLife);</div><div class="line"><a name="l00221"></a><span class="lineno"> 221</span>  priorityList.emplace_back(&block);</div><div class="line"><a name="l00222"></a><span class="lineno"> 222</span>  }</div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>  maxLifetime++;</div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span> </div><div class="line"><a name="l00225"></a><span class="lineno"> 225</span>  <span class="comment">// From testing ordering by m_MemSize in non-descending order gives the best results overall</span></div><div class="line"><a name="l00226"></a><span class="lineno"> 226</span>  priorityList.sort([](<span class="keyword">const</span> MemBlock* lhs, <span class="keyword">const</span> MemBlock* rhs)</div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span>  {</div><div class="line"><a name="l00228"></a><span class="lineno"> 228</span>  <span class="keywordflow">return</span> lhs->m_MemSize > rhs->m_MemSize ;</div><div class="line"><a name="l00229"></a><span class="lineno"> 229</span>  });</div><div class="line"><a name="l00230"></a><span class="lineno"> 230</span> </div><div class="line"><a name="l00231"></a><span class="lineno"> 231</span> </div><div class="line"><a name="l00232"></a><span class="lineno"> 232</span>  std::vector<BinTracker> placedBlocks;</div><div class="line"><a name="l00233"></a><span class="lineno"> 233</span>  placedBlocks.reserve(maxLifetime);</div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span>  PlaceBlocks(priorityList, placedBlocks, maxLifetime);</div><div class="line"><a name="l00235"></a><span class="lineno"> 235</span> </div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>  std::vector<MemBin> bins;</div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span>  bins.reserve(placedBlocks.size());</div><div class="line"><a name="l00238"></a><span class="lineno"> 238</span>  <span class="keywordflow">for</span> (<span class="keyword">auto</span> blockList: placedBlocks)</div><div class="line"><a name="l00239"></a><span class="lineno"> 239</span>  {</div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>  MemBin bin;</div><div class="line"><a name="l00241"></a><span class="lineno"> 241</span>  bin.m_MemBlocks.reserve(blockList.m_PlacedBlocks.size());</div><div class="line"><a name="l00242"></a><span class="lineno"> 242</span>  bin.m_MemSize = blockList.m_MemSize;</div><div class="line"><a name="l00243"></a><span class="lineno"> 243</span> </div><div class="line"><a name="l00244"></a><span class="lineno"> 244</span>  <span class="keywordflow">for</span> (<span class="keyword">auto</span> block : blockList.m_PlacedBlocks)</div><div class="line"><a name="l00245"></a><span class="lineno"> 245</span>  {</div><div class="line"><a name="l00246"></a><span class="lineno"> 246</span>  bin.m_MemBlocks.emplace_back(MemBlock{block->m_StartOfLife,</div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span>  block->m_EndOfLife,</div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span>  block->m_MemSize,</div><div class="line"><a name="l00249"></a><span class="lineno"> 249</span>  0,</div><div class="line"><a name="l00250"></a><span class="lineno"> 250</span>  block->m_Index,});</div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>  }</div><div class="line"><a name="l00252"></a><span class="lineno"> 252</span>  bins.push_back(std::move(bin));</div><div class="line"><a name="l00253"></a><span class="lineno"> 253</span>  }</div><div class="line"><a name="l00254"></a><span class="lineno"> 254</span> </div><div class="line"><a name="l00255"></a><span class="lineno"> 255</span>  <span class="keywordflow">return</span> bins;</div><div class="line"><a name="l00256"></a><span class="lineno"> 256</span> }</div></div><!-- fragment --> </div> </div> <hr/>The documentation for this class was generated from the following files:<ul> @@ -270,13 +314,14 @@ Public Member Functions</h2></td></tr> </ul> </div><!-- contents --> </div><!-- doc-content --> +<div class="ttc" id="anamespacearmnn_xhtml_a7100de49939c3e393101f78d425a98c6a568437eb3752bdf14546b5c221ba5be7"><div class="ttname"><a href="namespacearmnn.xhtml#a7100de49939c3e393101f78d425a98c6a568437eb3752bdf14546b5c221ba5be7">armnn::MemBlockStrategyType::SingleAxisPacking</a></div><div class="ttdeci">@ SingleAxisPacking</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.xhtml">armnn</a></li><li class="navelem"><a class="el" href="classarmnn_1_1_single_axis_priority_list.xhtml">SingleAxisPriorityList</a></li> - <li class="footer">Generated on Fri Feb 24 2023 10:24:33 for ArmNN by + <li class="footer">Generated on Wed Mar 22 2023 15:53:08 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> |