1586 lines
116 KiB
HTML
1586 lines
116 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>Kite - Detailed Router</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">Kite - Detailed Router</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 Page</span></a></li>
|
|
<li><a href="pages.html"><span>Related 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 List</span></a></li>
|
|
<li><a href="classes.html"><span>Class Index</span></a></li>
|
|
<li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li>
|
|
<li><a href="functions.html"><span>Class Members</span></a></li>
|
|
</ul>
|
|
</div>
|
|
<div id="nav-path" class="navpath">
|
|
<ul>
|
|
<li class="navelem"><a class="el" href="namespaceKite.html">Kite</a></li><li class="navelem"><a class="el" href="classKite_1_1Track.html">Track</a></li> </ul>
|
|
</div>
|
|
</div><!-- top -->
|
|
<div class="header">
|
|
<div class="summary">
|
|
<a href="#pub-types">Public Types</a> |
|
|
<a href="#pub-methods">Public Member Functions</a> |
|
|
<a href="#pub-static-attribs">Static Public Attributes</a> |
|
|
<a href="classKite_1_1Track-members.html">List of all members</a> </div>
|
|
<div class="headertitle">
|
|
<div class="title">Track Class Reference<span class="mlabels"><span class="mlabel">abstract</span></span></div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
|
|
<p>Structure managing one routing track.
|
|
<a href="classKite_1_1Track.html#details">More...</a></p>
|
|
<div class="dynheader">
|
|
Inheritance diagram for Track:</div>
|
|
<div class="dyncontent">
|
|
<div class="center"><img src="classKite_1_1Track__inherit__graph.png" border="0" usemap="#Track_inherit__map" alt="Inheritance graph"/></div>
|
|
<map name="Track_inherit__map" id="Track_inherit__map">
|
|
<area shape="rect" id="node2" href="classKite_1_1HorizontalTrack.html" title="Horizontal track managment. " alt="" coords="5,80,120,107"/><area shape="rect" id="node3" href="classKite_1_1VerticalTrack.html" title="Vertical track managment. " alt="" coords="144,80,243,107"/></map>
|
|
<center><span class="legend">[<a href="graph_legend.html">legend</a>]</span></center></div>
|
|
<table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
|
|
Public Types</h2></td></tr>
|
|
<tr class="memitem:af4bdc8469c0fee386fc2ff30e0666bca"><td class="memItemLeft" align="right" valign="top">enum  </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bca">IndexState</a> { <br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa8b61f6a736a067f2124ee5bd5cb8ac71">BeginIsTrackMin</a> = 0x00000001,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa2558894ee6c661f4c13276cc8f2464a4">BeginIsSegmentMin</a> = 0x00000002,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa8b6241764173838bf07e69fb78b688a4">BeginIsSegmentMax</a> = 0x00000004,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa405dc0d4b2391506d0dcc4a75d5f1ba2">EndIsTrackMax</a> = 0x00000008,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa24e6a845af9d42451a2c41f2f8d388d1">EndIsSegmentMin</a> = 0x00000010,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa03aebc159f233b883124bd19fdd2ea0f">EndIsNextSegmentMin</a> = 0x00000020,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaab507ecf157f576817fafc5e7deb71629">EndIsSegmentMax</a> = 0x00000040,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa5c7f72d6942ae38d66f530bea1063adf">BeforeFirstElement</a> = BeginIsTrackMin |EndIsSegmentMin,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa36e625d718c74f5ff503638360ba1166">InsideElement</a> = BeginIsSegmentMin|EndIsSegmentMax,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa55d08f66f21334eb8c0dca170f1cb8a4">OutsideElement</a> = BeginIsSegmentMax|EndIsNextSegmentMin,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa3fc579452c9779cd2865d5019a61c6a5">AfterLastElement</a> = BeginIsSegmentMax|EndIsTrackMax,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaaa697b71e325cea0980e9555654f8f3cf">EmptyTrack</a> = BeginIsTrackMin |EndIsTrackMax,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa8621fa6a5b7a491fd1bf8dd7f0dd3589">BeginMask</a> = BeginIsTrackMin |BeginIsSegmentMin|BeginIsSegmentMax,
|
|
<br/>
|
|
  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa0b5a81972d3a6718c3d68199467d2d11">EndMask</a> = EndIsTrackMax |EndIsSegmentMin |EndIsNextSegmentMin|EndIsSegmentMax
|
|
<br/>
|
|
}</td></tr>
|
|
<tr class="separator:af4bdc8469c0fee386fc2ff30e0666bca"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><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:a9d3db1f8a5aca58f8f54d291faebf873"><td class="memItemLeft" align="right" valign="top">virtual bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a9d3db1f8a5aca58f8f54d291faebf873">isHorizontal</a> () const =0</td></tr>
|
|
<tr class="separator:a9d3db1f8a5aca58f8f54d291faebf873"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a6fa2bf0568a2b295dd7cd1f7207247d5"><td class="memItemLeft" align="right" valign="top">virtual bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a6fa2bf0568a2b295dd7cd1f7207247d5">isVertical</a> () const =0</td></tr>
|
|
<tr class="separator:a6fa2bf0568a2b295dd7cd1f7207247d5"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ac9f5f43a21bc7b63a1237e10b5a6a53b"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ac9f5f43a21bc7b63a1237e10b5a6a53b">isLocalAssigned</a> () const </td></tr>
|
|
<tr class="separator:ac9f5f43a21bc7b63a1237e10b5a6a53b"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a3f7a5bbb3140598c747b1526998e6be7"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1RoutingPlane.html">RoutingPlane</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a3f7a5bbb3140598c747b1526998e6be7">getRoutingPlane</a> () const </td></tr>
|
|
<tr class="separator:a3f7a5bbb3140598c747b1526998e6be7"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a9ccc00efc7079210bc25122921382da4"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1KiteEngine.html">KiteEngine</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a9ccc00efc7079210bc25122921382da4">getKiteEngine</a> () const </td></tr>
|
|
<tr class="separator:a9ccc00efc7079210bc25122921382da4"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ae35b78590ed6aa546b626ef95f28c533"><td class="memItemLeft" align="right" valign="top">virtual unsigned int </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ae35b78590ed6aa546b626ef95f28c533">getDirection</a> () const =0</td></tr>
|
|
<tr class="separator:ae35b78590ed6aa546b626ef95f28c533"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a65742a66b3c3b66d5b619db492469900"><td class="memItemLeft" align="right" valign="top">size_t </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a65742a66b3c3b66d5b619db492469900">getIndex</a> () const </td></tr>
|
|
<tr class="separator:a65742a66b3c3b66d5b619db492469900"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ad43be8bb2a3c8247405feef4fa973734"><td class="memItemLeft" align="right" valign="top">unsigned int </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ad43be8bb2a3c8247405feef4fa973734">getDepth</a> () const </td></tr>
|
|
<tr class="separator:ad43be8bb2a3c8247405feef4fa973734"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ac1bbd63624eb1b4e394301c92adef62c"><td class="memItemLeft" align="right" valign="top">const <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Layer.html">Layer</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ac1bbd63624eb1b4e394301c92adef62c">getLayer</a> () const </td></tr>
|
|
<tr class="separator:ac1bbd63624eb1b4e394301c92adef62c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aceadd4784a0ae6394d2c75433f81ce59"><td class="memItemLeft" align="right" valign="top">const <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Layer.html">Layer</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#aceadd4784a0ae6394d2c75433f81ce59">getBlockageLayer</a> () const </td></tr>
|
|
<tr class="separator:aceadd4784a0ae6394d2c75433f81ce59"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af85576c58c70007850ad56e238e8d266"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#af85576c58c70007850ad56e238e8d266">getAxis</a> () const </td></tr>
|
|
<tr class="separator:af85576c58c70007850ad56e238e8d266"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a75e87715af5a758c37e5f1faeaf7ccc1"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a75e87715af5a758c37e5f1faeaf7ccc1">getMin</a> () const </td></tr>
|
|
<tr class="separator:a75e87715af5a758c37e5f1faeaf7ccc1"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a204f3392bd6abab056796ecdae72ce54"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a204f3392bd6abab056796ecdae72ce54">getMax</a> () const </td></tr>
|
|
<tr class="separator:a204f3392bd6abab056796ecdae72ce54"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ab83ae7101fae68a7db48b96a82cc42f5"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1Track.html">Track</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ab83ae7101fae68a7db48b96a82cc42f5">getNextTrack</a> () const </td></tr>
|
|
<tr class="separator:ab83ae7101fae68a7db48b96a82cc42f5"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a0647664eabb2f70005585316c3681b7f"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1Track.html">Track</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a0647664eabb2f70005585316c3681b7f">getPreviousTrack</a> () const </td></tr>
|
|
<tr class="separator:a0647664eabb2f70005585316c3681b7f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af55b3790622878d65ed5ff2bb2b3fcc4"><td class="memItemLeft" align="right" valign="top">size_t </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#af55b3790622878d65ed5ff2bb2b3fcc4">getSize</a> () const </td></tr>
|
|
<tr class="separator:af55b3790622878d65ed5ff2bb2b3fcc4"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a2a033f90e528d3d07aa33694dd733200"><td class="memItemLeft" align="right" valign="top">virtual <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Point.html">Point</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a2a033f90e528d3d07aa33694dd733200">getPosition</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> coordinate) const =0</td></tr>
|
|
<tr class="separator:a2a033f90e528d3d07aa33694dd733200"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ac2216be50494af61a7b16d20dd8cc5dd"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ac2216be50494af61a7b16d20dd8cc5dd">getSegment</a> (size_t index) const </td></tr>
|
|
<tr class="separator:ac2216be50494af61a7b16d20dd8cc5dd"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aa8a5a7f28e71bce3676d4a051ab1d6c6"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#aa8a5a7f28e71bce3676d4a051ab1d6c6">getSegment</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> position) const </td></tr>
|
|
<tr class="separator:aa8a5a7f28e71bce3676d4a051ab1d6c6"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:afaad0c947c459bab3b7ef742aaa5c59f"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#afaad0c947c459bab3b7ef742aaa5c59f">getNext</a> (size_t &index, <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> *) const </td></tr>
|
|
<tr class="separator:afaad0c947c459bab3b7ef742aaa5c59f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a4ebcb68fdea325b48de96a417a86d896"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a4ebcb68fdea325b48de96a417a86d896">getPrevious</a> (size_t &index, <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> *) const </td></tr>
|
|
<tr class="separator:a4ebcb68fdea325b48de96a417a86d896"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a13493827f36a960f3c443ff2b8ea0143"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a13493827f36a960f3c443ff2b8ea0143">getNextFixed</a> (size_t &index) const </td></tr>
|
|
<tr class="separator:a13493827f36a960f3c443ff2b8ea0143"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a92159b77cb6e17d1c81fe6b907953387"><td class="memItemLeft" align="right" valign="top">size_t </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a92159b77cb6e17d1c81fe6b907953387">find</a> (const <a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> *) const </td></tr>
|
|
<tr class="separator:a92159b77cb6e17d1c81fe6b907953387"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a67e86dd6909fb12706787ea738355fdf"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a67e86dd6909fb12706787ea738355fdf">getSourcePosition</a> (vector< <a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * >::iterator) const </td></tr>
|
|
<tr class="separator:a67e86dd6909fb12706787ea738355fdf"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a00032371424630b4fd99dc1c443ee1f3"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a00032371424630b4fd99dc1c443ee1f3">getMinimalPosition</a> (size_t index, unsigned int state) const </td></tr>
|
|
<tr class="separator:a00032371424630b4fd99dc1c443ee1f3"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a5c9424f73f1fafa422c8dca99c7216bd"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a5c9424f73f1fafa422c8dca99c7216bd">getMaximalPosition</a> (size_t index, unsigned int state) const </td></tr>
|
|
<tr class="separator:a5c9424f73f1fafa422c8dca99c7216bd"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a95a9fad401e395a6b0f73e755db6ddad"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a95a9fad401e395a6b0f73e755db6ddad">getFreeInterval</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> position, <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> *net=NULL) const </td></tr>
|
|
<tr class="separator:a95a9fad401e395a6b0f73e755db6ddad"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aeb4b9c2a20ec5f82da8781b11982ae7d"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#aeb4b9c2a20ec5f82da8781b11982ae7d">getOccupiedInterval</a> (size_t &begin) const </td></tr>
|
|
<tr class="separator:aeb4b9c2a20ec5f82da8781b11982ae7d"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aead0aa746d8c8ce14a11161baa1aafc4"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#aead0aa746d8c8ce14a11161baa1aafc4">expandFreeInterval</a> (size_t &begin, size_t &end, unsigned int state, <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> *) const </td></tr>
|
|
<tr class="separator:aead0aa746d8c8ce14a11161baa1aafc4"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a7386d7acfcd1dfbeb906bd4c482d797e"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a7386d7acfcd1dfbeb906bd4c482d797e">getBeginIndex</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> position, size_t &begin, unsigned int &state) const </td></tr>
|
|
<tr class="separator:a7386d7acfcd1dfbeb906bd4c482d797e"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a414e800da5aa8b03eb82aa0dba883f7f"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a414e800da5aa8b03eb82aa0dba883f7f">getOverlapBounds</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a>, size_t &begin, size_t &end) const </td></tr>
|
|
<tr class="separator:a414e800da5aa8b03eb82aa0dba883f7f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a91b5c29bec3f74b1194473d1eb274086"><td class="memItemLeft" align="right" valign="top">TrackCost </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a91b5c29bec3f74b1194473d1eb274086">getOverlapCost</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a>, <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> *, size_t begin, size_t end, unsigned int flags) const </td></tr>
|
|
<tr class="separator:a91b5c29bec3f74b1194473d1eb274086"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ae8e0a72955bd05677d82738ad032526d"><td class="memItemLeft" align="right" valign="top">TrackCost </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ae8e0a72955bd05677d82738ad032526d">getOverlapCost</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a>, <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> *, unsigned int flags) const </td></tr>
|
|
<tr class="separator:ae8e0a72955bd05677d82738ad032526d"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ac930c18bbcb0b25f2b5360f6ce6741e7"><td class="memItemLeft" align="right" valign="top">TrackCost </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ac930c18bbcb0b25f2b5360f6ce6741e7">getOverlapCost</a> (<a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> *, unsigned int flags) const </td></tr>
|
|
<tr class="separator:ac930c18bbcb0b25f2b5360f6ce6741e7"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a8b274bcf60589230f36f9798cce1e7d7"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a8b274bcf60589230f36f9798cce1e7d7">getTerminalWeight</a> (<a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a>, <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> *, size_t &count, unsigned int &weight) const </td></tr>
|
|
<tr class="separator:a8b274bcf60589230f36f9798cce1e7d7"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a6807aafaa83c1a2687c48d02510ced3a"><td class="memItemLeft" align="right" valign="top"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a6807aafaa83c1a2687c48d02510ced3a">getSourcePosition</a> (size_t index) const </td></tr>
|
|
<tr class="separator:a6807aafaa83c1a2687c48d02510ced3a"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ad21778972fbdf5cbffb470b2e36f9fcf"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ad21778972fbdf5cbffb470b2e36f9fcf">check</a> (unsigned int &overlaps, const char *message=NULL) const </td></tr>
|
|
<tr class="separator:ad21778972fbdf5cbffb470b2e36f9fcf"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a893f1101c650c08c98612515c2b1a89c"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a893f1101c650c08c98612515c2b1a89c">invalidate</a> ()</td></tr>
|
|
<tr class="separator:a893f1101c650c08c98612515c2b1a89c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aa392ba7cf1e3e485aac11cf326e31918"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#aa392ba7cf1e3e485aac11cf326e31918">insert</a> (<a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> *)</td></tr>
|
|
<tr class="separator:aa392ba7cf1e3e485aac11cf326e31918"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a31e8f4502866435ac898c7eec741175f"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a31e8f4502866435ac898c7eec741175f">insert</a> (<a class="el" href="classKite_1_1TrackMarker.html">TrackMarker</a> *)</td></tr>
|
|
<tr class="separator:a31e8f4502866435ac898c7eec741175f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a8b5d93406ef581c1be022417238a89ca"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#a8b5d93406ef581c1be022417238a89ca">setSegment</a> (<a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> *, size_t)</td></tr>
|
|
<tr class="separator:a8b5d93406ef581c1be022417238a89ca"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:abfffcd781865b94f62f27a1e7be99a38"><td class="memItemLeft" align="right" valign="top">size_t </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#abfffcd781865b94f62f27a1e7be99a38">doRemoval</a> ()</td></tr>
|
|
<tr class="separator:abfffcd781865b94f62f27a1e7be99a38"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aaccb9224f5b38ecd8506fd1eec9ef5ca"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#aaccb9224f5b38ecd8506fd1eec9ef5ca">doReorder</a> ()</td></tr>
|
|
<tr class="separator:aaccb9224f5b38ecd8506fd1eec9ef5ca"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-attribs"></a>
|
|
Static Public Attributes</h2></td></tr>
|
|
<tr class="memitem:ae0070ea45b2592ce3701ab9e486e58a0"><td class="memItemLeft" align="right" valign="top">static const size_t </td><td class="memItemRight" valign="bottom"><a class="el" href="classKite_1_1Track.html#ae0070ea45b2592ce3701ab9e486e58a0">npos</a> = (size_t)-1</td></tr>
|
|
<tr class="separator:ae0070ea45b2592ce3701ab9e486e58a0"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table>
|
|
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
|
|
<div class="textblock"><p>Structure managing one routing track. </p>
|
|
<h1><a class="anchor" id="secTrackPurpose"></a>
|
|
Track Purpose</h1>
|
|
<p>We use an array of <em>regularly spaced</em> <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> as a geometrical fast access structure. It allows to know whether an area is used or not. The whole area may be seen as a set of adjoining tiles of fixed <em>width</em> but variable <em>length</em>.</p>
|
|
<p>The figure <b>(1.b)</b> show, for an horizontal, track the relation between <code>y,min,max</code> and the occupied area of the plane. <code>min</code> and <code>max</code> must take into account segment extensions (<code>e</code>) and the minimal distance between two rectangles (<code>MD</code>) of the same layer. We assume that the width of the segment, augmented of all it's contraints is no greater than <code>TS</code> (in fact it's how <code>TS</code> must be calculated).</p>
|
|
<p>For the whole track array, see <a class="el" href="classKite_1_1RoutingPlane.html" title="Array of Tracks in one Layer. ">RoutingPlane</a>.</p>
|
|
<div class="image">
|
|
<img src="Track-0.png" alt="Track-0.png"/>
|
|
<div class="caption">
|
|
Fig 1: Track Area</div></div>
|
|
<h1><a class="anchor" id="secTrackImplementation"></a>
|
|
Track Implementation</h1>
|
|
<p>A <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> is implemented with a sorted vector of <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>. TrackElements from differents nets must not overlap. The sorting order is defined as follow:</p>
|
|
<ul>
|
|
<li>TrackElements are sorted by increasing source (<em>min</em>) positions.</li>
|
|
<li>In case of overlap (i.e. belongs to the same net), if they share the same source position, then they are sorted by <em>decreasing</em> length. This way, the longest one will be the first encountered when walking through the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> in increasing index order.</li>
|
|
</ul>
|
|
<p>Figure <b>2.b</b> shows the details of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> <b>[1]</b> of figure <b>1.a</b>. Net <b><d></b> show an exemple of overlapping.</p>
|
|
<div class="image">
|
|
<img src="Track-1.png" alt="Track-1.png"/>
|
|
<div class="caption">
|
|
Fig 2: Track Structure</div></div>
|
|
<p>In addition to the TrackSegments, the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> also manage additionnal informations through a second vector of TrackMarkers. <a class="el" href="classKite_1_1TrackMarker.html" title="Tag part of Track with a weight. ">TrackMarker</a> are currently used only to hints at how strongly a terminal is dependant on that portion of <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> to be accessed.</p>
|
|
<h2><a class="anchor" id="ssecTrackIndexes"></a>
|
|
Indexes vs. Iterators</h2>
|
|
<p>Numerical indexes have been prefered over iterators because they can be used more easily by objects other the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> itself for referencing. So internal managment follow the same rule, handling indexes or reference to indexes.</p>
|
|
<h2><a class="anchor" id="ssecTrackUpdate"></a>
|
|
Update Mechanism</h2>
|
|
<p>When a <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> is normaly inserted in a <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, a two way link is established. The <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> has an entry in it's vector refering to <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>, and conversely, the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> has it's <code>track</code> field pointing to it's owning <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>.</p>
|
|
<p><b><a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> Removal</b></p>
|
|
<p>To remove a <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> from a <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, we break one of those two links: the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> cease to refer to the owning <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, marking him for removal which will occurs at the next track revalidation (<a class="el" href="classKite_1_1Track.html#abfffcd781865b94f62f27a1e7be99a38">Track::doRemoval()</a>). In figure <b>3</b>, the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> belonging to net <b><b></b> is marked for removal.</p>
|
|
<div class="image">
|
|
<img src="Track-2.png" alt="Track-2.png"/>
|
|
<div class="caption">
|
|
Fig 3: TrackElement Removal</div></div>
|
|
<p> <b><a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> Insertion</b></p>
|
|
<p>When a <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> is inserted into a <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, the two way link is immediatly created (but the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> is not yet at it's final place in the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>'s vector). Before inserting a <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> we check that it's been already detached (<code>track</code> field to <code>NULL</code>).</p>
|
|
<p>It is at that step that the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> axis is actually updated through a call to <a class="el" href="classKite_1_1TrackElement.html#a45e685b1e3ee630d24bf43746553af4c">TrackElement::setAxis()</a>.</p>
|
|
<p><b>Revalidation Sequence</b></p>
|
|
<p>After a <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> has been modificated either the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> element vector or the MarkerElement vector (or both) has been invalidateds. Revalidation take place in three steps:</p>
|
|
<ul>
|
|
<li><a class="el" href="classKite_1_1Track.html#abfffcd781865b94f62f27a1e7be99a38">Track::doRemoval()</a>, remove all <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> marked for removal.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#aa392ba7cf1e3e485aac11cf326e31918">Track::insert()</a>, insert the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> into their new <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#aaccb9224f5b38ecd8506fd1eec9ef5ca">Track::doReorder()</a>, sort the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> of the vector, that is, put the newly inserted elements at their right place.</li>
|
|
</ul>
|
|
<p>Each step must be done <em>for all Tracks</em> before proceeding to the next. This way a <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> <code>track</code> field doesn't get set <em>before</em> it has been actually removed from it's previous <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>.</p>
|
|
<h2><a class="anchor" id="ssecTrackOperations"></a>
|
|
Main Operations on Tracks</h2>
|
|
<p><b>Helper Function:</b> <a class="el" href="classKite_1_1Track.html#a7386d7acfcd1dfbeb906bd4c482d797e">Track::getBeginIndex()</a></p>
|
|
<p>Return in <code>begin</code> the index of the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> whose minimum is immediately below the requested <code>position</code> on the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> axis. The second returned parameter <code>state</code> is a set of flags to tell how the <code>begin</code> index has to be interpreted.</p>
|
|
<p><b>Helper Function:</b> <a class="el" href="classKite_1_1Track.html#aeb4b9c2a20ec5f82da8781b11982ae7d">Track::getOccupiedInterval()</a></p>
|
|
<p>Returns the complete interval of a set of overlapping <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> from the same net. </p>
|
|
</div><h2 class="groupheader">Member Enumeration Documentation</h2>
|
|
<a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bca"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">enum <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bca">IndexState</a></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Indicates how to compute the bounds of the interval enclosing a given <code>position</code> on track axis.</p>
|
|
<dl class="section note"><dt>Note</dt><dd>According to <em>position</em>, the interval can be a free interval or a used interval. </dd></dl>
|
|
<table class="fieldtable">
|
|
<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa8b61f6a736a067f2124ee5bd5cb8ac71"></a>BeginIsTrackMin</em> </td><td class="fielddoc">
|
|
<p>(implies <code>begin=0</code>) there is no <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> <em>before</em> <code>position</code> </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa2558894ee6c661f4c13276cc8f2464a4"></a>BeginIsSegmentMin</em> </td><td class="fielddoc">
|
|
<p>The <code>begin</code> segment starts <em>before</em> <code>position</code> and ends <em>after</em>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa8b6241764173838bf07e69fb78b688a4"></a>BeginIsSegmentMax</em> </td><td class="fielddoc">
|
|
<p>The <code>begin</code> segment starts and ends <em>before</em> <code>position</code>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa405dc0d4b2391506d0dcc4a75d5f1ba2"></a>EndIsTrackMax</em> </td><td class="fielddoc">
|
|
<p>There is no <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> <em>after</em> <code>position</code>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa24e6a845af9d42451a2c41f2f8d388d1"></a>EndIsSegmentMin</em> </td><td class="fielddoc">
|
|
<p>The <code>begin</code> segment starts <em>before</em> <code>position</code>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa03aebc159f233b883124bd19fdd2ea0f"></a>EndIsNextSegmentMin</em> </td><td class="fielddoc">
|
|
<p>The <code>begin</code> segment starts and ends <em>before</em> <code>position</code>. So the maximum is given by the <code>minimum</code> of the <em>next</em> <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaab507ecf157f576817fafc5e7deb71629"></a>EndIsSegmentMax</em> </td><td class="fielddoc">
|
|
<p>The <code>begin</code> segment starts <em>before</em> <code>position</code> and ends <em>after</em>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa5c7f72d6942ae38d66f530bea1063adf"></a>BeforeFirstElement</em> </td><td class="fielddoc">
|
|
<p>the <code>position</code> is before the first <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa36e625d718c74f5ff503638360ba1166"></a>InsideElement</em> </td><td class="fielddoc">
|
|
<p>the <code>position</code> is inside a <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa55d08f66f21334eb8c0dca170f1cb8a4"></a>OutsideElement</em> </td><td class="fielddoc">
|
|
<p>the <code>position</code> is in free zone between two TrackElements. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa3fc579452c9779cd2865d5019a61c6a5"></a>AfterLastElement</em> </td><td class="fielddoc">
|
|
<p>the position is after the end of the last element. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaaa697b71e325cea0980e9555654f8f3cf"></a>EmptyTrack</em> </td><td class="fielddoc">
|
|
<p>the track is still empty. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa8621fa6a5b7a491fd1bf8dd7f0dd3589"></a>BeginMask</em> </td><td class="fielddoc">
|
|
<p>To extract the <em>begin</em> part from a combination of flags. </p>
|
|
</td></tr>
|
|
<tr><td class="fieldname"><em><a class="anchor" id="af4bdc8469c0fee386fc2ff30e0666bcaa0b5a81972d3a6718c3d68199467d2d11"></a>EndMask</em> </td><td class="fielddoc">
|
|
<p>To extract the <em>end</em> part from a combination of flags. </p>
|
|
</td></tr>
|
|
</table>
|
|
|
|
</div>
|
|
</div>
|
|
<h2 class="groupheader">Member Function Documentation</h2>
|
|
<a class="anchor" id="a9d3db1f8a5aca58f8f54d291faebf873"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool isHorizontal </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><b>Returns:</b> <b>true</b> if the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> in horizontal direction. </p>
|
|
|
|
<p>Implemented in <a class="el" href="classKite_1_1HorizontalTrack.html#ac46ac3b48d712750c7888b48964ac189">HorizontalTrack</a>, and <a class="el" href="classKite_1_1VerticalTrack.html#ac46ac3b48d712750c7888b48964ac189">VerticalTrack</a>.</p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1TrackFixedSegment.html#ac46ac3b48d712750c7888b48964ac189">TrackFixedSegment::isHorizontal()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a6fa2bf0568a2b295dd7cd1f7207247d5"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool isVertical </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><b>Returns:</b> <b>true</b> if the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> in vertical direction. </p>
|
|
|
|
<p>Implemented in <a class="el" href="classKite_1_1HorizontalTrack.html#a2bb30e82aad1f321af4a065338775f36">HorizontalTrack</a>, and <a class="el" href="classKite_1_1VerticalTrack.html#a2bb30e82aad1f321af4a065338775f36">VerticalTrack</a>.</p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1TrackFixedSegment.html#a2bb30e82aad1f321af4a065338775f36">TrackFixedSegment::isVertical()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ac9f5f43a21bc7b63a1237e10b5a6a53b"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool isLocalAssigned </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> is the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> should be preferentially used for local routing. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a3f7a5bbb3140598c747b1526998e6be7"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1RoutingPlane.html">RoutingPlane</a> * getRoutingPlane </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 <a class="el" href="classKite_1_1RoutingPlane.html" title="Array of Tracks in one Layer. ">RoutingPlane</a> owning this <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#ab83ae7101fae68a7db48b96a82cc42f5">Track::getNextTrack()</a>, and <a class="el" href="classKite_1_1Track.html#a0647664eabb2f70005585316c3681b7f">Track::getPreviousTrack()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a9ccc00efc7079210bc25122921382da4"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1KiteEngine.html">KiteEngine</a> * getKiteEngine </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The <a class="el" href="classKite_1_1KiteEngine.html" title="The Kite Tool. ">KiteEngine</a> owning this <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ae35b78590ed6aa546b626ef95f28c533"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">unsigned int getDirection </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><b>Returns:</b> The direction of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, either <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/namespaceKatabatic.html#a2af2ad6b6441614038caf59d04b3b217a1a9045673c5d3c30b067100f1440ae1b">Katabatic::KbHorizontal</a> or <a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/namespaceKatabatic.html#a2af2ad6b6441614038caf59d04b3b217a284cad95203a27172838b09e396e3590">Katabatic::KbVertical</a>. </p>
|
|
|
|
<p>Implemented in <a class="el" href="classKite_1_1HorizontalTrack.html#a09d03fbca9ab891c2f25bdae7f89a899">HorizontalTrack</a>, and <a class="el" href="classKite_1_1VerticalTrack.html#a09d03fbca9ab891c2f25bdae7f89a899">VerticalTrack</a>.</p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1TrackFixedSegment.html#a09d03fbca9ab891c2f25bdae7f89a899">TrackFixedSegment::getDirection()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a65742a66b3c3b66d5b619db492469900"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1RoutingPlane.html">RoutingPlane</a> * getIndex </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 index of this <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> in the <a class="el" href="classKite_1_1RoutingPlane.html" title="Array of Tracks in one Layer. ">RoutingPlane</a> <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> vector. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#ad21778972fbdf5cbffb470b2e36f9fcf">Track::check()</a>, <a class="el" href="classKite_1_1Track.html#ab83ae7101fae68a7db48b96a82cc42f5">Track::getNextTrack()</a>, and <a class="el" href="classKite_1_1Track.html#a0647664eabb2f70005585316c3681b7f">Track::getPreviousTrack()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ad43be8bb2a3c8247405feef4fa973734"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">unsigned int getDepth </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The depth (as given by the RoutingGauge) of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>'s layer. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ac1bbd63624eb1b4e394301c92adef62c"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Layer.html">Layer</a> * getLayer </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The <code>Layer</code> of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#aa392ba7cf1e3e485aac11cf326e31918">Track::insert()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="aceadd4784a0ae6394d2c75433f81ce59"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Layer.html">Layer</a> * getBlockageLayer </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The associated blockage <code>Layer</code> to the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>'s layer. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#aa392ba7cf1e3e485aac11cf326e31918">Track::insert()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="af85576c58c70007850ad56e238e8d266"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> getAxis </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 Axis of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#ad21778972fbdf5cbffb470b2e36f9fcf">Track::check()</a>, <a class="el" href="classKite_1_1NegociateWindow.html#a7bf31fcd4e4007e62454689ef7c553fc">NegociateWindow::createTrackSegment()</a>, <a class="el" href="classKite_1_1TrackFixedSegment.html#af85576c58c70007850ad56e238e8d266">TrackFixedSegment::getAxis()</a>, <a class="el" href="classKite_1_1VerticalTrack.html#a87f1520092c5421a57aa2468d2814c09">VerticalTrack::getPosition()</a>, <a class="el" href="classKite_1_1HorizontalTrack.html#a87f1520092c5421a57aa2468d2814c09">HorizontalTrack::getPosition()</a>, <a class="el" href="classKite_1_1Track.html#aa392ba7cf1e3e485aac11cf326e31918">Track::insert()</a>, <a class="el" href="classKite_1_1RoutingEvent.html#a5bd93abe1416952ace15a98dbeeed124">RoutingEvent::revalidate()</a>, <a class="el" href="classKite_1_1Manipulator.html#a147c24aa53f561c10d5d24b82b03448a">Manipulator::ripupPerpandiculars()</a>, and <a class="el" href="classKite_1_1SegmentFsm.html#a2a8eadaaf3ed213914e7b4a81cae6e6a">SegmentFsm::SegmentFsm()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a75e87715af5a758c37e5f1faeaf7ccc1"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> getMin </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 minimal allowed coordinate of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Manipulator.html#aa61f08642d981761687635be108b9837">Manipulator::minimize()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a204f3392bd6abab056796ecdae72ce54"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> getMax </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 maximal allowed coordinate of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ab83ae7101fae68a7db48b96a82cc42f5"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1Track.html">Track</a> * getNextTrack </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The next <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> in the <code><a class="el" href="classKite_1_1RoutingPlane.html" title="Array of Tracks in one Layer. ">RoutingPlane</a></code> vector. That is the one with the axis immediatly superior. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1NegociateWindow.html#a7bf31fcd4e4007e62454689ef7c553fc">NegociateWindow::createTrackSegment()</a>, <a class="el" href="classKite_1_1RoutingEvent.html#a5bd93abe1416952ace15a98dbeeed124">RoutingEvent::revalidate()</a>, and <a class="el" href="classKite_1_1Manipulator.html#a147c24aa53f561c10d5d24b82b03448a">Manipulator::ripupPerpandiculars()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a0647664eabb2f70005585316c3681b7f"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1Track.html">Track</a> * getPreviousTrack </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The previous <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> in the <code><a class="el" href="classKite_1_1RoutingPlane.html" title="Array of Tracks in one Layer. ">RoutingPlane</a></code> vector. That is the one with the axis immediatly inferior. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1NegociateWindow.html#a7bf31fcd4e4007e62454689ef7c553fc">NegociateWindow::createTrackSegment()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="af55b3790622878d65ed5ff2bb2b3fcc4"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">size_t getSize </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 total number of <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> in the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#a5c9424f73f1fafa422c8dca99c7216bd">Track::getMaximalPosition()</a>, and <a class="el" href="classKite_1_1Track.html#ac2216be50494af61a7b16d20dd8cc5dd">Track::getSegment()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a2a033f90e528d3d07aa33694dd733200"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Point.html">Point</a> getPosition </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td>
|
|
<td class="paramname"><em>position</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><b>Returns:</b> the point at <code></code>(position,<a class="el" href="classKite_1_1Track.html#af85576c58c70007850ad56e238e8d266">getAxis()</a>) for horizontal <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> at or <code></code>(<a class="el" href="classKite_1_1Track.html#af85576c58c70007850ad56e238e8d266">getAxis()</a>,position) for vertical <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. </p>
|
|
|
|
<p>Implemented in <a class="el" href="classKite_1_1HorizontalTrack.html#a87f1520092c5421a57aa2468d2814c09">HorizontalTrack</a>, and <a class="el" href="classKite_1_1VerticalTrack.html#a87f1520092c5421a57aa2468d2814c09">VerticalTrack</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ac2216be50494af61a7b16d20dd8cc5dd"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1TrackSegment.html">TrackSegment</a> * getSegment </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t </td>
|
|
<td class="paramname"><em>index</em></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">index</td><td>The index of the <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>The <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> at <em>index</em>. The result will be <code>NULL</code> in the follwing cases :<ul>
|
|
<li><em>index</em> is outside the sorted zone.</li>
|
|
<li><em>index</em> points to a hole in the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>.</li>
|
|
<li><em>index</em> is equal to <a class="el" href="classKite_1_1Track.html#ae0070ea45b2592ce3701ab9e486e58a0">Track::npos</a>. </li>
|
|
</ul>
|
|
</dd></dl>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1SegmentFsm.html#a9c0fa6a9067b6e027e24f38330f627dc">SegmentFsm::conflictSolveByPlaceds()</a>, <a class="el" href="classKite_1_1NegociateWindow.html#a7bf31fcd4e4007e62454689ef7c553fc">NegociateWindow::createTrackSegment()</a>, <a class="el" href="classKite_1_1SegmentFsm.html#a0b8e8be9d7c9501be9534d3c2a9dd586">SegmentFsm::desaturate()</a>, <a class="el" href="classKite_1_1Manipulator.html#add26b688d75a99a1ae781787eead08d5">Manipulator::forceOverLocals()</a>, <a class="el" href="classKite_1_1Manipulator.html#a76d3956660cfa624696e2a5f2916cd22">Manipulator::forceToTrack()</a>, <a class="el" href="classKite_1_1Track.html#aa8a5a7f28e71bce3676d4a051ab1d6c6">Track::getSegment()</a>, <a class="el" href="classKite_1_1Manipulator.html#a7140b507da2cab137d968a037bed19df">Manipulator::insertInTrack()</a>, <a class="el" href="classKite_1_1Manipulator.html#af4d93a43ea18ae124da71072c66d1e0a">Manipulator::makeDogleg()</a>, <a class="el" href="classKite_1_1Manipulator.html#aa61f08642d981761687635be108b9837">Manipulator::minimize()</a>, and <a class="el" href="classKite_1_1Manipulator.html#aba69c61ccb330e26aaa8211f0454795f">Manipulator::shrinkToTrack()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="aa8a5a7f28e71bce3676d4a051ab1d6c6"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1TrackSegment.html">TrackSegment</a> * getSegment </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td>
|
|
<td class="paramname"><em>position</em></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">position</td><td>The position where to search. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>The <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> whose starting point is immediatly inferior to <em>position</em>. </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="afaad0c947c459bab3b7ef742aaa5c59f"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1TrackSegment.html">TrackSegment</a> * getNext </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>index</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> * </td>
|
|
<td class="paramname"><em>net</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">index</td><td>Index of the starting <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. </td></tr>
|
|
<tr><td class="paramname">net</td><td>A <code>Net</code> to ignore. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>The next <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> (<code>NULL</code> if not found).</dd></dl>
|
|
<p>Find, starting from <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> at <em>index</em> the next <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> ignoring <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> from <em>net</em>. <em>index</em> is modified to point on the returned <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. If there's no next <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> (<code>NULL</code>) then index is set to <a class="el" href="classKite_1_1Track.html#ae0070ea45b2592ce3701ab9e486e58a0">Track::npos</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#aead0aa746d8c8ce14a11161baa1aafc4">Track::expandFreeInterval()</a>, <a class="el" href="classKite_1_1TrackFixedSegment.html#a5af0ac91c558873fea9703e7ab6f48df">TrackFixedSegment::getNext()</a>, <a class="el" href="classKite_1_1TrackSegment.html#a5af0ac91c558873fea9703e7ab6f48df">TrackSegment::getNext()</a>, <a class="el" href="classKite_1_1TrackElement.html#a5af0ac91c558873fea9703e7ab6f48df">TrackElement::getNext()</a>, and <a class="el" href="classKite_1_1Track.html#a13493827f36a960f3c443ff2b8ea0143">Track::getNextFixed()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a4ebcb68fdea325b48de96a417a86d896"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1TrackSegment.html">TrackSegment</a> * getPrevious </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>index</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> * </td>
|
|
<td class="paramname"><em>net</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">index</td><td>Index of the starting <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. </td></tr>
|
|
<tr><td class="paramname">net</td><td>A <code>Net</code> to ignore. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>The previous <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> (<code>NULL</code> if not found).</dd></dl>
|
|
<p>find, starting from <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> at <em>index</em> the previous <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> ignoring <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> from <em>net</em>. <em>index</em> is modified to point on the returned <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. If there's no previous <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> (<code>NULL</code>) then index is set to <a class="el" href="classKite_1_1Track.html#ae0070ea45b2592ce3701ab9e486e58a0">Track::npos</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#aead0aa746d8c8ce14a11161baa1aafc4">Track::expandFreeInterval()</a>, <a class="el" href="classKite_1_1TrackFixedSegment.html#acbb9c965449bf4502d71149563cec0a2">TrackFixedSegment::getPrevious()</a>, <a class="el" href="classKite_1_1TrackSegment.html#acbb9c965449bf4502d71149563cec0a2">TrackSegment::getPrevious()</a>, and <a class="el" href="classKite_1_1TrackElement.html#acbb9c965449bf4502d71149563cec0a2">TrackElement::getPrevious()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a13493827f36a960f3c443ff2b8ea0143"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classKite_1_1TrackSegment.html">TrackSegment</a> * getNextFixed </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>index</em></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">index</td><td>Index of the starting <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>The first previous <em>Fixed</em> <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>.</dd></dl>
|
|
<p>find, starting from <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> at <em>index</em> the first previous with a <em>Fixed</em> attribute set. <em>index</em> is modified to point on the returned <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. If there's no previous <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> (<code>NULL</code>) then index is set to <a class="el" href="classKite_1_1Track.html#ae0070ea45b2592ce3701ab9e486e58a0">Track::npos</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a92159b77cb6e17d1c81fe6b907953387"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">size_t find </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const <a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td>
|
|
<td class="paramname"><em>element</em></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> the <em>index</em> of <em>element</em> inside the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. If the <em>element</em> do not belongs to the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, return <a class="el" href="classKite_1_1Track.html#ae0070ea45b2592ce3701ab9e486e58a0">Track::npos</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a67e86dd6909fb12706787ea738355fdf"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> getSourcePosition </td>
|
|
<td>(</td>
|
|
<td class="paramtype">vector< <a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * >::iterator </td>
|
|
<td class="paramname"><em>it</em></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The source position of <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> pointed by iterator <em>it</em>. If <em>it</em> is equal to <code>end()</code> , returns zero. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a00032371424630b4fd99dc1c443ee1f3"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> getMinimalPosition </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t </td>
|
|
<td class="paramname"><em>index</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>state</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> Extract the minimal position from the interval at <code>index</code> in accordance to <code>state</code> hinting.</p>
|
|
<p><b>See also:</b>  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bca">Track::IndexState</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a5c9424f73f1fafa422c8dca99c7216bd"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> getMaximalPosition </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t </td>
|
|
<td class="paramname"><em>index</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>state</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> Extract the maximal position from the interval at <code>index</code> in accordance to <code>state</code> hinting.</p>
|
|
<p><b>See also:</b>  <a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bca">Track::IndexState</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#aead0aa746d8c8ce14a11161baa1aafc4">Track::expandFreeInterval()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a95a9fad401e395a6b0f73e755db6ddad"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> getFreeInterval </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td>
|
|
<td class="paramname"><em>position</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> * </td>
|
|
<td class="paramname"><em>net</em> = <code>NULL</code> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">position</td><td>where fo find a free interval. </td></tr>
|
|
<tr><td class="paramname">net</td><td>for which net to find the free interval. <b>Returns:</b> The longuest free interval enclosing <em>position</em> (may be empty). </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="aeb4b9c2a20ec5f82da8781b11982ae7d"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> getOccupiedInterval </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>begin</em></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">begin</td><td>index of one of the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> set. May be modificated. <b>Returns:</b> the whole interval used by a set of overlaping <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>.</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<p>As <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> from a same net can overlap, the interval of one of them do not give the full extend of the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> occupation at this point. This function looks for all overlaping segments and returns the merged interval. Additionnaly it sets <code>begin</code> to the index of the lowest <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> of the set.</p>
|
|
<div class="image">
|
|
<img src="TrackOccupiedInterval-1.png" alt="TrackOccupiedInterval-1.png"/>
|
|
<div class="caption">
|
|
Fig 4: Track::getOccuppiedInterval()</div></div>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#aead0aa746d8c8ce14a11161baa1aafc4">Track::expandFreeInterval()</a>, <a class="el" href="classKite_1_1Track.html#a7386d7acfcd1dfbeb906bd4c482d797e">Track::getBeginIndex()</a>, and <a class="el" href="classKite_1_1Track.html#a414e800da5aa8b03eb82aa0dba883f7f">Track::getOverlapBounds()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="aead0aa746d8c8ce14a11161baa1aafc4"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> expandFreeInterval </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>begin</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>end</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>state</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> * </td>
|
|
<td class="paramname"><em>net</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">begin</td><td>the lowest used <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. </td></tr>
|
|
<tr><td class="paramname">end</td><td>the highest used <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. </td></tr>
|
|
<tr><td class="paramname">state</td><td>tells how to interpret the <code>begin</code> & <code>end</code> indexes. </td></tr>
|
|
<tr><td class="paramname">net</td><td>the for wich we seek place. <b>Returns:</b> The longuest free interval between <code></code>]begin,end[ .</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<p>Starting from the initial <code>[begin,end]</code> interval, expand the interval to encompass all free space or segments belonging to <code>net</code>. <code>state</code> may be used to compute the interval bounds from <code>begin</code> and <code>end</code> instead of directly using the returned <code>interval</code>.</p>
|
|
<dl class="section note"><dt>Note</dt><dd><code></code>]begin,end[ must define a free interval between two <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. </dd></dl>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#a95a9fad401e395a6b0f73e755db6ddad">Track::getFreeInterval()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a7386d7acfcd1dfbeb906bd4c482d797e"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void getBeginIndex </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> </td>
|
|
<td class="paramname"><em>position</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>begin</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int & </td>
|
|
<td class="paramname"><em>state</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">position</td><td>The position where to search. </td></tr>
|
|
<tr><td class="paramname">begin</td><td>Index of the immediatly inferior <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>. </td></tr>
|
|
<tr><td class="paramname">state</td><td>how to interpret the returned <code>begin</code>.</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<p>Return in <code>begin</code> the index of the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> whose minimum is immediately below the requested <code>position</code> on the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> axis. The second returned parameter <code>state</code> is a set of flags to tell how the <code>begin</code> index has to be interpreted.</p>
|
|
<p>Flags for the <code>state</code> are:</p>
|
|
<ul>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa8b61f6a736a067f2124ee5bd5cb8ac71">Track::BeginIsTrackMin</a> : (implies <code>begin=0</code>) there is no <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> <em>before</em> <code>position</code>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa24e6a845af9d42451a2c41f2f8d388d1">Track::EndIsSegmentMin</a> : The <code>begin</code> segment starts <em>before</em> <code>position</code>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa2558894ee6c661f4c13276cc8f2464a4">Track::BeginIsSegmentMin</a> : The <code>begin</code> segment starts <em>before</em> <code>position</code> and ends <em>after</em>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaab507ecf157f576817fafc5e7deb71629">Track::EndIsSegmentMax</a> : The <code>begin</code> segment starts <em>before</em> <code>position</code> and ends <em>after</em>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa8b6241764173838bf07e69fb78b688a4">Track::BeginIsSegmentMax</a> : The <code>begin</code> segment starts and ends <em>before</em> <code>position</code>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa03aebc159f233b883124bd19fdd2ea0f">Track::EndIsNextSegmentMin</a> : The <code>begin</code> segment starts and ends <em>before</em> <code>position</code>. So the maximum is given by the <code>minimum</code> of the <em>next</em> <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa405dc0d4b2391506d0dcc4a75d5f1ba2">Track::EndIsTrackMax</a> : There is no <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> <em>after</em> <code>position</code>.</li>
|
|
</ul>
|
|
<p>Based on the previous flags, we build the <code>state</code> parameter:</p>
|
|
<ul>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa5c7f72d6942ae38d66f530bea1063adf">Track::BeforeFirstElement</a> : the <code>position</code> is before the first <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa36e625d718c74f5ff503638360ba1166">Track::InsideElement</a> : the <code>position</code> is inside a <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a>.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa55d08f66f21334eb8c0dca170f1cb8a4">Track::OutsideElement</a> : the <code>position</code> is in free zone between two TrackElements.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa3fc579452c9779cd2865d5019a61c6a5">Track::AfterLastElement</a> : the position is after the end of the last element.</li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaaa697b71e325cea0980e9555654f8f3cf">Track::EmptyTrack</a> : the track is still empty.</li>
|
|
</ul>
|
|
<p>To separate flags relevant to <em>begin</em> and <em>end</em> informations, two masks are provideds:</p>
|
|
<ul>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa8621fa6a5b7a491fd1bf8dd7f0dd3589">Track::BeginMask</a></li>
|
|
<li><a class="el" href="classKite_1_1Track.html#af4bdc8469c0fee386fc2ff30e0666bcaa0b5a81972d3a6718c3d68199467d2d11">Track::EndMask</a></li>
|
|
</ul>
|
|
<div class="image">
|
|
<img src="TrackBeginIndex-1.png" alt="TrackBeginIndex-1.png"/>
|
|
<div class="caption">
|
|
Fig 3: Track::getBeginIndex()</div></div>
|
|
<p> <b>Reminder for myself:</b> The <a class="el" href="classKite_1_1Track.html#a7386d7acfcd1dfbeb906bd4c482d797e">Track::getBeginIndex()</a> function relies on the <a href="http://www.sgi.com/tech/stl/">STL</a> <code>lower_bound()</code> function. <code>lower_bound()</code> finds the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> immediately <em>superior</em> to <code>position</code> (shown on Figure <b>3</b> by the <code>LB</code> label in white on black).</p>
|
|
<p>The relation between the returned <code>begin</code> index and the position is given through the <code>state</code> parameter. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#a95a9fad401e395a6b0f73e755db6ddad">Track::getFreeInterval()</a>, <a class="el" href="classKite_1_1Track.html#a414e800da5aa8b03eb82aa0dba883f7f">Track::getOverlapBounds()</a>, and <a class="el" href="classKite_1_1Track.html#aa8a5a7f28e71bce3676d4a051ab1d6c6">Track::getSegment()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a414e800da5aa8b03eb82aa0dba883f7f"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void getOverlapBounds </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> </td>
|
|
<td class="paramname"><em>interval</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>begin</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>end</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">interval</td><td>the overlaping interval. </td></tr>
|
|
<tr><td class="paramname">begin</td><td>where to store the starting bound. </td></tr>
|
|
<tr><td class="paramname">end</td><td>where to store the ending bound.</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<p>find the range of <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> intersecting <em>interval</em>. Note that when the <em>interval</em> lower bound crosses a set of overlaping intervals from the same <code>Net</code>, the interval at <em>begin</em> will crosses the lower bound but some following of the same <code>Net</code> may not. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1NegociateWindow.html#a7bf31fcd4e4007e62454689ef7c553fc">NegociateWindow::createTrackSegment()</a>, and <a class="el" href="classKite_1_1Track.html#ae8e0a72955bd05677d82738ad032526d">Track::getOverlapCost()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a91b5c29bec3f74b1194473d1eb274086"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">TrackCost getOverlapCost </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> </td>
|
|
<td class="paramname"><em>interval</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> * </td>
|
|
<td class="paramname"><em>net</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t </td>
|
|
<td class="paramname"><em>begin</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t </td>
|
|
<td class="paramname"><em>end</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>flags</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">interval</td><td>the overlaping interval. </td></tr>
|
|
<tr><td class="paramname">net</td><td>a Net to ignore (null cost). </td></tr>
|
|
<tr><td class="paramname">begin</td><td>the starting bound. </td></tr>
|
|
<tr><td class="paramname">end</td><td>the ending bound. </td></tr>
|
|
<tr><td class="paramname">flags</td><td>passed to the overlap cost function. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>The cost of the overlap.</dd></dl>
|
|
<p>Compute the cost of the overlap of <em>interval</em> with the range <code></code>[begin,end] of <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>. Any <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> belonging to <em>net</em> will be ignored. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#ae8e0a72955bd05677d82738ad032526d">Track::getOverlapCost()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ae8e0a72955bd05677d82738ad032526d"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">TrackCost getOverlapCost </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> </td>
|
|
<td class="paramname"><em>interval</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> * </td>
|
|
<td class="paramname"><em>net</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>flags</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">interval</td><td>the overlaping interval. </td></tr>
|
|
<tr><td class="paramname">net</td><td>a Net to ignore (null cost). </td></tr>
|
|
<tr><td class="paramname">flags</td><td>passed to the overlap cost function.</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<p>Compute the overlap cost of <em>interval</em> with <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> from the current <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, ignoring thoses belonging to <em>net</em>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ac930c18bbcb0b25f2b5360f6ce6741e7"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">TrackCost getOverlapCost </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td>
|
|
<td class="paramname"><em>segment</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int </td>
|
|
<td class="paramname"><em>flags</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">segment</td><td>under which to compute overlap cost. </td></tr>
|
|
<tr><td class="paramname">flags</td><td>passed to the overlap cost function.</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<p>Compute the overlap cost of <code>segment</code> with <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> from the current <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> (interval and net are deduced from <code>segment</code>). </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a8b274bcf60589230f36f9798cce1e7d7"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void getTerminalWeight </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> </td>
|
|
<td class="paramname"><em>interval</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a> * </td>
|
|
<td class="paramname"><em>net</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t & </td>
|
|
<td class="paramname"><em>count</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">unsigned int & </td>
|
|
<td class="paramname"><em>weight</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">interval</td><td>under which to compute terminal weight. </td></tr>
|
|
<tr><td class="paramname">net</td><td>a net to be ignored. </td></tr>
|
|
<tr><td class="paramname">count</td><td>incremented of the number of track markers under the <code>interval</code>. </td></tr>
|
|
<tr><td class="paramname">weight</td><td>incremented of the sum of the weight of the track markers under the <code>interval</code>.</td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<p>Compute and return the sum of the weight of the track markers (see <a class="el" href="classKite_1_1TrackMarker.html" title="Tag part of Track with a weight. ">TrackMarker</a>) under <code>interval</code> ignoring <code>net</code> (that is, <em>for</em> <code>net</code>).</p>
|
|
<dl class="section user"><dt>Remark:</dt><dd>The referenced variables <code>count</code> and <code>weight</code> are <b>not</b> reset to zero by this function. It is of the caller's responsability. </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a6807aafaa83c1a2687c48d02510ced3a"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="elRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">DbU::Unit</a> getSourcePosition </td>
|
|
<td>(</td>
|
|
<td class="paramtype">size_t </td>
|
|
<td class="paramname"><em>index</em></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The source position of <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> at index <em>index</em>. If <em>index</em> is equal to <a class="el" href="classKite_1_1Track.html#ae0070ea45b2592ce3701ab9e486e58a0">Track::npos</a>, returns zero. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="ad21778972fbdf5cbffb470b2e36f9fcf"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool check </td>
|
|
<td>(</td>
|
|
<td class="paramtype">unsigned int & </td>
|
|
<td class="paramname"><em>overlaps</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const char * </td>
|
|
<td class="paramname"><em>message</em> = <code>NULL</code> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td> const</td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">overlaps</td><td>The number of overlaping segments. </td></tr>
|
|
<tr><td class="paramname">message</td><td>An iformative message, only printed if an error occurs. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd><b>true</b> if the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> contains no incoherencies.</dd></dl>
|
|
<p>Perform a complete <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> check. Looks for the following incoherencies :</p>
|
|
<ul>
|
|
<li><a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> do not refers this <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>.</li>
|
|
<li><a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> is detached (<a class="el" href="classKite_1_1TrackElement.html#abfd8de286baf41eea066220773c7046d">TrackSegment::getTrack()</a> is <code>NULL</code>).</li>
|
|
<li><a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> is hollow, this one is very unlikely as hollow <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> are only created for the <code>lower_bound()</code>.</li>
|
|
<li><code>NULL</code> pointers (should never occurs, nevertheless...)</li>
|
|
<li>Two consecutive <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> from different <code>Net</code> must not overlap.</li>
|
|
<li>For <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> starting from the same position, the longuest must be first. </li>
|
|
</ul>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a893f1101c650c08c98612515c2b1a89c"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void invalidate </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Inconditionnaly invalidate the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>, regardless if it has been modificated. The <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> will be forced to be revalidated on closure of the current session. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="aa392ba7cf1e3e485aac11cf326e31918"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void insert </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td>
|
|
<td class="paramname"><em>segment</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Adds <em>segment</em> to the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. Must only be used inside a <a class="el" href="classKite_1_1Session.html" title="Kite update Session. ">Session</a>. They must appears <em>after</em> <a class="el" href="classKite_1_1Track.html#abfffcd781865b94f62f27a1e7be99a38">Track::doRemoval()</a> and <em>before</em> <a class="el" href="classKite_1_1Track.html#aaccb9224f5b38ecd8506fd1eec9ef5ca">Track::doReorder()</a>.</p>
|
|
<p><b>See also:</b>  <a class="el" href="classKite_1_1Session.html" title="Kite update Session. ">Kite::Session</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a31e8f4502866435ac898c7eec741175f"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void insert </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="classKite_1_1TrackMarker.html">TrackMarker</a> * </td>
|
|
<td class="paramname"><em>marker</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Adds <em>marker</em> to the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. Must only be used inside a <a class="el" href="classKite_1_1Session.html" title="Kite update Session. ">Session</a>.</p>
|
|
<p><b>See also:</b>  <a class="el" href="classKite_1_1Session.html" title="Kite update Session. ">Kite::Session</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="a8b5d93406ef581c1be022417238a89ca"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void setSegment </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="classKite_1_1TrackElement.html">TrackElement</a> * </td>
|
|
<td class="paramname"><em>element</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">size_t </td>
|
|
<td class="paramname"><em>index</em> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>Directly affect the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> entry at position <code>index</code> to <code>element</code> (use with great care).</p>
|
|
<p><b>See also:</b>  <a class="el" href="classKite_1_1Session.html" title="Kite update Session. ">Kite::Session</a>. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1TrackSegment.html#acc245ce084989d1c34816d0e61b9d510">TrackSegment::swapTrack()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="abfffcd781865b94f62f27a1e7be99a38"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">size_t doRemoval </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p><b>Returns:</b> The number of removeds <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a>.</p>
|
|
<p>Suppress all the <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> that have been withdraw from the <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a>. <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> must be withdraw trough the <a class="el" href="classKite_1_1TrackSegment.html#ac295bade8aee589f6718dfa79edc2a34">TrackSegment::detach()</a> method which sets their owning <a class="el" href="classKite_1_1Track.html" title="Structure managing one routing track. ">Track</a> to <code>NULL</code> (the removal criterion). It uses the <a href="http://www.sgi.com/tech/stl/">STL</a> <em>remove_if</em> algorithm that put all the to be removed elements at the end of the vector.</p>
|
|
<p><b>See also:</b>  <a class="el" href="classKite_1_1Session.html" title="Kite update Session. ">Kite::Session</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<a class="anchor" id="aaccb9224f5b38ecd8506fd1eec9ef5ca"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void doReorder </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>(Re)sort the <a class="el" href="classKite_1_1TrackElement.html" title="Abstract Class for all Elements inserted inside a Track. ">TrackElement</a> of the vector. Must be called <em>after:</em> </p>
|
|
<ul>
|
|
<li><a class="el" href="classKite_1_1Track.html#abfffcd781865b94f62f27a1e7be99a38">Track::doRemoval()</a> so no detached <a class="el" href="classKite_1_1TrackSegment.html" title="Derived Katabatic::AutoSegment for the router. ">TrackSegment</a> are presents.</li>
|
|
<li>All calls to <a class="el" href="classKite_1_1Track.html#aa392ba7cf1e3e485aac11cf326e31918">Track::insert()</a>, as the newly inserted elements are put at the back of the vector.</li>
|
|
</ul>
|
|
<p><b>See also:</b>  <a class="el" href="classKite_1_1Session.html" title="Kite update Session. ">Kite::Session</a>. </p>
|
|
|
|
</div>
|
|
</div>
|
|
<h2 class="groupheader">Member Data Documentation</h2>
|
|
<a class="anchor" id="ae0070ea45b2592ce3701ab9e486e58a0"></a>
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">npos = (size_t)-1</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">static</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
<p>A special index value (greatest integer) meaning that an index is invalid. </p>
|
|
|
|
<p>Referenced by <a class="el" href="classKite_1_1Track.html#aead0aa746d8c8ce14a11161baa1aafc4">Track::expandFreeInterval()</a>, <a class="el" href="classKite_1_1Track.html#a92159b77cb6e17d1c81fe6b907953387">Track::find()</a>, <a class="el" href="classKite_1_1Track.html#afaad0c947c459bab3b7ef742aaa5c59f">Track::getNext()</a>, <a class="el" href="classKite_1_1Track.html#aeb4b9c2a20ec5f82da8781b11982ae7d">Track::getOccupiedInterval()</a>, <a class="el" href="classKite_1_1Track.html#a414e800da5aa8b03eb82aa0dba883f7f">Track::getOverlapBounds()</a>, <a class="el" href="classKite_1_1Track.html#a91b5c29bec3f74b1194473d1eb274086">Track::getOverlapCost()</a>, <a class="el" href="classKite_1_1Track.html#a4ebcb68fdea325b48de96a417a86d896">Track::getPrevious()</a>, <a class="el" href="classKite_1_1Track.html#ac2216be50494af61a7b16d20dd8cc5dd">Track::getSegment()</a>, and <a class="el" href="classKite_1_1Track.html#a6807aafaa83c1a2687c48d02510ced3a">Track::getSourcePosition()</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<hr/>The documentation for this class was generated from the following files:<ul>
|
|
<li><a class="el" href="Track_8h_source.html">Track.h</a></li>
|
|
<li>Track.cpp</li>
|
|
<li>Track.dox</li>
|
|
</ul>
|
|
</div><!-- contents -->
|
|
<br>
|
|
<hr>
|
|
<table class="footer1">
|
|
<tr>
|
|
<td class="LFooter"><small>Generated by doxygen 1.8.5 on Sat Aug 18 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">Kite - Detailed Router</td>
|
|
<td class="RFooter"><small>Copyright © 2008-2016 UPMC. All rights reserved</small></td>
|
|
</tr>
|
|
</table>
|
|
</body>
|
|
</html>
|