coriolis/katabatic/doc/html/classKatabatic_1_1GCellDens...

365 lines
19 KiB
HTML

<!DOCTYPE HTML PUBLIC '-//W3C//DTD HTML 4.0//EN'>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>Katabatic Documentation</title>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="SoC.css" rel="stylesheet" type="text/css">
<link href="tabs.css" rel="stylesheet" type="text/css">
</head>
<h1 id="pagetop" class="header">Katabatic - Routing Toolbox</h1>
<!--
<center class="header">
<table class="header">
<tr>
<td><a href="customSummary.html">Summary</a></td>
<td><a href="namespaces.html">Namespaces</a></td>
<td><a href="customHierarchy.html">Class Hierarchy</a></td>
<td><a href="annotated.html">Classes</a></td>
<td><a href="functions.html">Member Index</a></td>
</tr>
</table>
</center>
-->
<br>
<body onload="javascript:toggleLevel(1)">
<!-- Generated by Doxygen 1.8.5 -->
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
<li><a href="modules.html"><span>Modules</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li class="current"><a href="annotated.html"><span>Classes</span></a></li>
<li><a href="files.html"><span>Files</span></a></li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="annotated.html"><span>Class&#160;List</span></a></li>
<li><a href="classes.html"><span>Class&#160;Index</span></a></li>
<li><a href="hierarchy.html"><span>Class&#160;Hierarchy</span></a></li>
<li><a href="functions.html"><span>Class&#160;Members</span></a></li>
</ul>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="namespaceKatabatic.html">Katabatic</a></li><li class="navelem"><a class="el" href="classKatabatic_1_1GCellDensitySet.html">GCellDensitySet</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="summary">
<a href="classKatabatic_1_1GCellDensitySet-members.html">List of all members</a> &#124;
<a href="#pub-methods">Public Member Functions</a> </div>
<div class="headertitle">
<div class="title">GCellDensitySet Class Reference</div> </div>
</div><!--header-->
<div class="contents">
<p><a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> Set, sorted by density.
<a href="classKatabatic_1_1GCellDensitySet.html#details">More...</a></p>
<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:ad74cbb404ad28f734f5759462aa9f363"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#ad74cbb404ad28f734f5759462aa9f363">GCellDensitySet</a> (unsigned int depth)</td></tr>
<tr class="separator:ad74cbb404ad28f734f5759462aa9f363"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ada8d6c973310b9c4f66ec3c5b611bdf9"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#ada8d6c973310b9c4f66ec3c5b611bdf9">GCellDensitySet</a> (unsigned int depth, const std::vector&lt; <a class="el" href="classKatabatic_1_1GCell.html">GCell</a> * &gt; &amp;)</td></tr>
<tr class="separator:ada8d6c973310b9c4f66ec3c5b611bdf9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aef015ff8dc7d34fcb907281f71bb0003"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#aef015ff8dc7d34fcb907281f71bb0003">~GCellDensitySet</a> ()</td></tr>
<tr class="separator:aef015ff8dc7d34fcb907281f71bb0003"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac6e61de369e994009e36f344f99c15ad"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#ac6e61de369e994009e36f344f99c15ad">empty</a> () const </td></tr>
<tr class="separator:ac6e61de369e994009e36f344f99c15ad"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aac782da1f912bceb5d8ad00c8dc892ac"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#aac782da1f912bceb5d8ad00c8dc892ac">size</a> () const </td></tr>
<tr class="separator:aac782da1f912bceb5d8ad00c8dc892ac"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4ee769ef70539275bf4b500461250af0"><td class="memItemLeft" align="right" valign="top">const std::set&lt; <a class="el" href="classKatabatic_1_1GCell.html">GCell</a> <br class="typebreak"/>
*, GCell::CompareByKey &gt; &amp;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#a4ee769ef70539275bf4b500461250af0">getGCells</a> () const </td></tr>
<tr class="separator:a4ee769ef70539275bf4b500461250af0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a6b97afb6d814ba80a24a49b3ad8e540b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#a6b97afb6d814ba80a24a49b3ad8e540b">insert</a> (<a class="el" href="classKatabatic_1_1GCell.html">GCell</a> *)</td></tr>
<tr class="separator:a6b97afb6d814ba80a24a49b3ad8e540b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a743f7f98fe31b8a1c134aff01ba03acb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#a743f7f98fe31b8a1c134aff01ba03acb">erase</a> (<a class="el" href="classKatabatic_1_1GCell.html">GCell</a> *)</td></tr>
<tr class="separator:a743f7f98fe31b8a1c134aff01ba03acb"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a89099ec88eadcadb942b7d64a6ffd7ee"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#a89099ec88eadcadb942b7d64a6ffd7ee">unqueue</a> (<a class="el" href="classKatabatic_1_1GCell.html">GCell</a> *)</td></tr>
<tr class="separator:a89099ec88eadcadb942b7d64a6ffd7ee"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac84efe46d8a3c409e85bc3420240c3c2"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classKatabatic_1_1GCellDensitySet.html#ac84efe46d8a3c409e85bc3420240c3c2">requeue</a> ()</td></tr>
<tr class="separator:ac84efe46d8a3c409e85bc3420240c3c2"><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><a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> Set, sorted by density. </p>
<p>A small container helper to manage a set of <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> sorted by density on a specific layer <code>depth</code>.</p>
<p>The helper is implemented in term of a set. Once inserted in a set an element must not have is sorting key changed. But <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> density may change due to <a class="el" href="classKatabatic_1_1AutoSegment.html" title="Abstract base class for AutoSegment. ">AutoSegment</a> modifications during the lifetime of the set. To circumvent this problem, the <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> provide a key attribute to be used specifically with <a class="el" href="classKatabatic_1_1GCellDensitySet.html" title="GCell Set, sorted by density. ">GCellDensitySet</a>. This key act as a cached copy of the <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> density which is updated <em>only</em> by a call to <a class="el" href="classKatabatic_1_1GCell.html#a11beff0f0bec06d0f3e080969516dfc3">GCell::updateKey()</a> (and <em>not</em> <a class="el" href="classKatabatic_1_1GCell.html#a9b3455dce10eb98d0496175dd586528c">GCell::updateDensity()</a>). <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> which density have changed and key has to be updated must be signaled to set with the GCellDensityQueue::unqueue() method. When we want to update the sorting of the set on the new densities, we call <a class="el" href="classKatabatic_1_1GCellDensitySet.html#ac84efe46d8a3c409e85bc3420240c3c2">GCellDensitySet::requeue()</a> which, for each invalidated <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> do:</p>
<ul>
<li>Remove the <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> from the set.</li>
<li>Update the key (call <a class="el" href="classKatabatic_1_1GCell.html#a11beff0f0bec06d0f3e080969516dfc3">GCell::updateKey()</a>).</li>
<li>Reinsert the <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a> in the set (thus with the updated key).</li>
</ul>
<p>Typical usage: </p>
<div class="fragment"><div class="line"><a class="code" href="classKatabatic_1_1GCellDensitySet.html#ad74cbb404ad28f734f5759462aa9f363">GCellDensitySet</a> gcells ( 2, *(getGCellGrid()-&gt;getGCellVector()) );</div>
<div class="line"></div>
<div class="line"><span class="keywordflow">while</span> ( <span class="keyword">true</span> ) {</div>
<div class="line"> <span class="keywordtype">bool</span> optimized = <span class="keyword">false</span>;</div>
<div class="line"></div>
<div class="line"> std::set&lt;GCell*,GCell::CompareByKey&gt;::const_iterator igcell = gcells.getGCells().begin();</div>
<div class="line"> <span class="keywordflow">for</span> ( ; igcell != gcells.getGCells().end() ; ++igcell ) {</div>
<div class="line"> <span class="keywordflow">if</span> ( doSomeOptimization(*igcell) ) {</div>
<div class="line"> optimized = <span class="keyword">true</span>;</div>
<div class="line"> gcells.unqueue( *igcell );</div>
<div class="line"> }</div>
<div class="line"> }</div>
<div class="line"></div>
<div class="line"> <span class="keywordflow">if</span> (not optimized) <span class="keywordflow">break</span>;</div>
<div class="line"></div>
<div class="line"> gcells.requeue();</div>
<div class="line">}</div>
</div><!-- fragment --> </div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
<a class="anchor" id="ad74cbb404ad28f734f5759462aa9f363"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="classKatabatic_1_1GCellDensitySet.html">GCellDensitySet</a> </td>
<td>(</td>
<td class="paramtype">unsigned int&#160;</td>
<td class="paramname"><em>depth</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Create a new empty <a class="el" href="classKatabatic_1_1GCellDensitySet.html" title="GCell Set, sorted by density. ">GCellDensitySet</a>, sorting on density of layer <code>depth</code>. </p>
</div>
</div>
<a class="anchor" id="ada8d6c973310b9c4f66ec3c5b611bdf9"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="classKatabatic_1_1GCellDensitySet.html">GCellDensitySet</a> </td>
<td>(</td>
<td class="paramtype">unsigned int&#160;</td>
<td class="paramname"><em>depth</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">const std::vector&lt; <a class="el" href="classKatabatic_1_1GCell.html">GCell</a> * &gt; &amp;&#160;</td>
<td class="paramname"><em>gcells</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Create a new empty <a class="el" href="classKatabatic_1_1GCellDensitySet.html" title="GCell Set, sorted by density. ">GCellDensitySet</a>, sorting on density of layer <code>depth</code>. Load the queue with the GCells supplied in the <code>gcells</code> vector. </p>
<p>References <a class="el" href="classKatabatic_1_1GCellDensitySet.html#ac84efe46d8a3c409e85bc3420240c3c2">GCellDensitySet::requeue()</a>.</p>
</div>
</div>
<a class="anchor" id="aef015ff8dc7d34fcb907281f71bb0003"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">~<a class="el" href="classKatabatic_1_1GCellDensitySet.html">GCellDensitySet</a> </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Delete a <a class="el" href="classKatabatic_1_1GCellDensitySet.html" title="GCell Set, sorted by density. ">GCellDensitySet</a>, if the queue is not empty, issue a warning. </p>
</div>
</div>
<h2 class="groupheader">Member Function Documentation</h2>
<a class="anchor" id="ac6e61de369e994009e36f344f99c15ad"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">bool empty </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> </td>
</tr>
</table>
</div><div class="memdoc">
<p><b>Returns:</b> <b>true</b> if the queue is empty. </p>
</div>
</div>
<a class="anchor" id="aac782da1f912bceb5d8ad00c8dc892ac"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">size_t size </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> </td>
</tr>
</table>
</div><div class="memdoc">
<p><b>Returns:</b> the numbers of elements in the queue. </p>
</div>
</div>
<a class="anchor" id="a4ee769ef70539275bf4b500461250af0"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">const std::set&lt; <a class="el" href="classKatabatic_1_1GCell.html">GCell</a> *, GCell::CompareByKey &gt; &amp; getGCells </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> </td>
</tr>
</table>
</div><div class="memdoc">
<p><b>Returns:</b> the list of GCells currently in the queue. </p>
</div>
</div>
<a class="anchor" id="a6b97afb6d814ba80a24a49b3ad8e540b"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">size_t insert </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classKatabatic_1_1GCell.html">GCell</a> *&#160;</td>
<td class="paramname"><em>gcell</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Insert <code>gcell</code> into the set. </p>
</div>
</div>
<a class="anchor" id="a743f7f98fe31b8a1c134aff01ba03acb"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">size_t erase </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classKatabatic_1_1GCell.html">GCell</a> *&#160;</td>
<td class="paramname"><em>gcell</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Remove <code>gcell</code> from the set. </p>
</div>
</div>
<a class="anchor" id="a89099ec88eadcadb942b7d64a6ffd7ee"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void unqueue </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classKatabatic_1_1GCell.html">GCell</a> *&#160;</td>
<td class="paramname"><em>gcell</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Invalidate <code>gcell</code>. The density of <code>gcell</code> may have changed and needs to be reinserted into the queue. It is temporarily set asides until the next call to <a class="el" href="classKatabatic_1_1GCellDensitySet.html#ac84efe46d8a3c409e85bc3420240c3c2">GCellDensitySet::requeue()</a>. </p>
</div>
</div>
<a class="anchor" id="ac84efe46d8a3c409e85bc3420240c3c2"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void requeue </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Reinsert in the queue all the GCells that have been previously invalidated by a call to <a class="el" href="classKatabatic_1_1GCellDensitySet.html#a89099ec88eadcadb942b7d64a6ffd7ee">GCellDensitySet::unqueue()</a>. This function calls <a class="el" href="classKatabatic_1_1GCell.html#a11beff0f0bec06d0f3e080969516dfc3">GCell::updateKey()</a> before reinserting the <a class="el" href="classKatabatic_1_1GCell.html" title="Routing Global Cell. ">GCell</a>. </p>
<p>Referenced by <a class="el" href="classKatabatic_1_1GCellDensitySet.html#ada8d6c973310b9c4f66ec3c5b611bdf9">GCellDensitySet::GCellDensitySet()</a>.</p>
</div>
</div>
<hr/>The documentation for this class was generated from the following files:<ul>
<li><a class="el" href="GCell_8h_source.html">GCell.h</a></li>
<li>GCell.cpp</li>
<li>GCell.dox</li>
</ul>
</div><!-- contents -->
<br>
<hr>
<table class="footer1">
<tr>
<td class="LFooter"><small>Generated by doxygen 1.8.5 on Mon Oct 1 2018</small></td>
<td class="RFooter"><a href='#pagetop'><small>Return to top of page</small></a></td>
</tr>
</table>
<table class="footer2">
<tr>
<td class="LFooter">Katabatic - Routing Toolbox</td>
<td class="RFooter"><small>Copyright &#169; 2008-2016 UPMC. All rights reserved</small></td>
</tr>
</table>
</body>
</html>