coriolis/kite/doc/html/TrackSegment_8h_source.html

122 lines
61 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.14 -->
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(function() {
initMenu('',false,false,'search.php','Search');
});
/* @license-end */</script>
<div id="main-nav"></div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="dir_68267d1309a1af8e8297ef4c3efbcdba.html">src</a></li><li class="navelem"><a class="el" href="dir_2916ee297f5e79ec495d393dfe8ba769.html">kite</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="headertitle">
<div class="title">TrackSegment.h</div> </div>
</div><!--header-->
<div class="contents">
<div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span>&#160;<span class="comment">// -*- C++ -*-</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="comment">// This file is part of the Coriolis Software.</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;<span class="comment">// Copyright (c) UPMC 2008-2018, All Rights Reserved</span></div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160;<span class="comment">// +-----------------------------------------------------------------+</span></div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="comment">// | C O R I O L I S |</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160;<span class="comment">// | K i t e - D e t a i l e d R o u t e r |</span></div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="comment">// | |</span></div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;<span class="comment">// | Author : Jean-Paul CHAPUT |</span></div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span>&#160;<span class="comment">// | E-mail : Jean-Paul.Chaput@asim.lip6.fr |</span></div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span>&#160;<span class="comment">// | =============================================================== |</span></div><div class="line"><a name="l00013"></a><span class="lineno"> 13</span>&#160;<span class="comment">// | C++ Header : &quot;./kite/TrackSegment.h&quot; |</span></div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160;<span class="comment">// +-----------------------------------------------------------------+</span></div><div class="line"><a name="l00015"></a><span class="lineno"> 15</span>&#160;</div><div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160;</div><div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160;<span class="preprocessor">#ifndef KITE_TRACK_SEGMENT_H</span></div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160;<span class="preprocessor">#define KITE_TRACK_SEGMENT_H</span></div><div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160;</div><div class="line"><a name="l00020"></a><span class="lineno"> 20</span>&#160;<span class="preprocessor">#include &lt;set&gt;</span></div><div class="line"><a name="l00021"></a><span class="lineno"> 21</span>&#160;<span class="preprocessor">#include &lt;functional&gt;</span></div><div class="line"><a name="l00022"></a><span class="lineno"> 22</span>&#160;<span class="preprocessor">#include &quot;kite/TrackElement.h&quot;</span></div><div class="line"><a name="l00023"></a><span class="lineno"> 23</span>&#160;</div><div class="line"><a name="l00024"></a><span class="lineno"> 24</span>&#160;</div><div class="line"><a name="l00025"></a><span class="lineno"> 25</span>&#160;<span class="keyword">namespace </span><a class="code" href="namespaceKite.html">Kite</a> {</div><div class="line"><a name="l00026"></a><span class="lineno"> 26</span>&#160;</div><div class="line"><a name="l00027"></a><span class="lineno"> 27</span>&#160; <span class="keyword">using</span> std::string;</div><div class="line"><a name="l00028"></a><span class="lineno"> 28</span>&#160; <span class="keyword">using</span> std::map;</div><div class="line"><a name="l00029"></a><span class="lineno"> 29</span>&#160; <span class="keyword">using</span> std::set;</div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span>&#160; <span class="keyword">using</span> std::binary_function;</div><div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160; <span class="keyword">using</span> Hurricane::Record;</div><div class="line"><a name="l00032"></a><span class="lineno"> 32</span>&#160; <span class="keyword">using</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Hurricane::Interval</a>;</div><div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160; <span class="keyword">using</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1DbU.html">Hurricane::DbU</a>;</div><div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160; <span class="keyword">using</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net_1_1Direction.html">Hurricane::Net</a>;</div><div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160; <span class="keyword">using</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Layer.html">Hurricane::Layer</a>;</div><div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160; <span class="keyword">using</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/classKatabatic_1_1AutoSegment.html">Katabatic::AutoSegment</a>;</div><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160;</div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160; <span class="keyword">class </span>DataNegociate;</div><div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160; <span class="keyword">class </span>Track;</div><div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160; <span class="keyword">class </span>TrackCost;</div><div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160;</div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160;</div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160;<span class="comment">// -------------------------------------------------------------------</span></div><div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160;<span class="comment">// Class : &quot;TrackSegment&quot;.</span></div><div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160;</div><div class="line"><a name="l00046"></a><span class="lineno"><a class="line" href="classKite_1_1TrackSegment.html"> 46</a></span>&#160; <span class="keyword">class </span><a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a> : <span class="keyword">public</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a> {</div><div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160; <span class="keyword">public</span>:</div><div class="line"><a name="l00048"></a><span class="lineno"> 48</span>&#160; <span class="keyword">class </span>CompareById : <span class="keyword">public</span> binary_function&lt;const TrackSegment*,const TrackSegment*,bool&gt; {</div><div class="line"><a name="l00049"></a><span class="lineno"> 49</span>&#160; <span class="keyword">public</span>:</div><div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160; <span class="keyword">inline</span> <span class="keywordtype">bool</span> operator() ( <span class="keyword">const</span> <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a>* lhs, <span class="keyword">const</span> <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a>* rhs );</div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; };</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160;</div><div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160; <span class="keyword">public</span>:</div><div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160; <span class="keyword">static</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a536f91d468e6c2097f85169e6d790f64">create</a> ( <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/classKatabatic_1_1AutoSegment.html">AutoSegment</a>*, <a class="code" href="classKite_1_1Track.html">Track</a>*, <span class="keywordtype">bool</span>&amp; created );</div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160; <span class="keyword">static</span> <span class="keywordtype">size_t</span> getAllocateds ();</div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160; <span class="keyword">public</span>: </div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160; <span class="comment">// Wrapped AutoSegment Functions (when applicable).</span></div><div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/classKatabatic_1_1AutoSegment.html">AutoSegment</a>* base () <span class="keyword">const</span>;</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#afd7362b850709bed8b61c1aa22399f97">isFixed</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#a21b9cefd33ae22e4c2070ad441bdd30b">isHorizontal</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#abd54544ef1710ee4b67cfb021d73446c">isVertical</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#add556a145a89fdbcea82346abfb873dc">isLocal</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#a19ba379112d6b29faa45c5eefbf38500">isGlobal</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#a72741158d19af38e84c5e9c08f91270f">isBipoint</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00065"></a><span class="lineno"> 65</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#a1e074cb3064037035548e5e6d238e315">isTerminal</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00066"></a><span class="lineno"> 66</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> isStrongTerminal ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags=0 ) <span class="keyword">const</span>;</div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#a62d61c231cf404a814ae37665fa8164f">isStrap</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00068"></a><span class="lineno"> 68</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#a782cff57d3fe10e758d19ee65a06643d">isSlackened</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#a75d91371e5281dd21f60ff39ae70a3e5">isDogleg</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> isReduced () <span class="keyword">const</span>;</div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> isUTurn () <span class="keyword">const</span>;</div><div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> isUserDefined () <span class="keyword">const</span>;</div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; <span class="comment">// Predicates.</span></div><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#aa0bb6f1592688e942ff67e0ac318a4fd">canDogleg</a> ();</div><div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#aa0bb6f1592688e942ff67e0ac318a4fd">canDogleg</a> ( <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a> );</div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#aa0bb6f1592688e942ff67e0ac318a4fd">canDogleg</a> ( <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/classKatabatic_1_1GCell_1_1CompareByDensity.html">Katabatic::GCell</a>*, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags=0 );</div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> canPivotUp ( <span class="keywordtype">float</span> reserve ) <span class="keyword">const</span>;</div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> canPivotDown ( <span class="keywordtype">float</span> reserve ) <span class="keyword">const</span>;</div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> canMoveUp ( <span class="keywordtype">float</span> reserve, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags ) <span class="keyword">const</span>;</div><div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> canSlacken () <span class="keyword">const</span>;</div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">float</span> <a class="code" href="classKite_1_1TrackSegment.html#abb61228ad7b29c19c6428902d34126f7">getMaxUnderDensity</a> ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags ) <span class="keyword">const</span>;</div><div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classKite_1_1TrackSegment.html#afdedcef127ad2a3677a5b48d7d3453f3">getId</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classKite_1_1TrackSegment.html#a0dd7cf705ace42c662c289955313b2e9">getDirection</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Net.html">Net</a>* <a class="code" href="classKite_1_1TrackSegment.html#a692492374623a5c6096b2c4a51190359">getNet</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; <span class="keyword">virtual</span> <span class="keyword">const</span> <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Layer.html">Layer</a>* <a class="code" href="classKite_1_1TrackSegment.html#ab045567c4f529dca7790d66c17c3084f">getLayer</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" 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> getPitch () <span class="keyword">const</span>;</div><div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" 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> getPPitch () <span class="keyword">const</span>;</div><div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> <a class="code" href="classKite_1_1TrackSegment.html#aa7552c20cc46abcac558627b2ca341f8">getFreedomDegree</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> <a class="code" href="classKite_1_1TrackSegment.html#add78c6f914788c549f144998caacda84">getDoglegLevel</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a010b7fc8801c5b88aefa4137cf85186d">getNext</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a55d6115d84c11ad147f4c38fe372ea24">getPrevious</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a95ec3b8e7e1ec87c20ee0b37bcc96df7">getParent</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" 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> <a class="code" href="classKite_1_1TrackSegment.html#ab5b5aaa5b318369feee6003dbad039c2">getAxis</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" 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="code" href="classKite_1_1TrackSegment.html#a034711e2d3617ea848ef9f5a18255e10">getFreeInterval</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" 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="code" href="classKite_1_1TrackSegment.html#a48f8b54f9489da3778d85c382a483f81">getSourceConstraints</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160; <span class="keyword">virtual</span> <a class="codeRef" 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="code" href="classKite_1_1TrackSegment.html#a69af7d4287bc0e44c9ca2c8e6f692be9">getTargetConstraints</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1DataNegociate.html">DataNegociate</a>* <a class="code" href="classKite_1_1TrackSegment.html#acd0170a05128ec4af16ecd0060c3a3b5">getDataNegociate</a> ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags=<a class="code" href="namespaceKite.html#acca8fffa3182dea5f94208f454f14b47a68e917ff37d4b5cef906303181836404">KtDataSelf</a> ) <span class="keyword">const</span>;</div><div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#af2d46d64cbd02bdbba53d5483d95e26d">getCanonical</a> ( <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a>&amp; );</div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">size_t</span> <a class="code" href="classKite_1_1TrackSegment.html#af45301f76558f613ccb605a8f851080e">getGCells</a> ( Katabatic::GCellVector&amp; ) <span class="keyword">const</span>;</div><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a7e79fbfe77f173d46b1959c41087930a">getSourceDogleg</a> ();</div><div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#aeb4e39bd925d093e6c45599433bb421c">getTargetDogleg</a> ();</div><div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; <span class="keyword">virtual</span> TrackElements <a class="code" href="classKite_1_1TrackSegment.html#aa0ba92ebf19f596537dc051c090d5736">getPerpandiculars</a> ();</div><div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">size_t</span> getPerpandicularsBound ( set&lt;TrackElement*&gt;&amp; );</div><div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160; <span class="comment">// Mutators.</span></div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#abd3d8093f871d3d1a7f24b053648026c">setTrack</a> ( <a class="code" href="classKite_1_1Track.html">Track</a>* );</div><div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#af5332d647c0482aa90ad7cc9b2a50f3a">updateFreedomDegree</a> ();</div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#a2b90319cb042b283aa5d1fdb1992f11f">setDoglegLevel</a> ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> );</div><div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#acc245ce084989d1c34816d0e61b9d510">swapTrack</a> ( <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* );</div><div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#a0ffe603ec7d46f21f5e56ccbe84c03fb">reschedule</a> ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> level );</div><div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#ac295bade8aee589f6718dfa79edc2a34">detach</a> ();</div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#a893f1101c650c08c98612515c2b1a89c">invalidate</a> ();</div><div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#a5bd93abe1416952ace15a98dbeeed124">revalidate</a> ();</div><div class="line"><a name="l00113"></a><span class="lineno"> 113</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> updatePPitch ();</div><div class="line"><a name="l00114"></a><span class="lineno"> 114</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#a262a915c38127d3722ec561b30d80f91">setAxis</a> ( <a class="codeRef" 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>, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags );</div><div class="line"><a name="l00115"></a><span class="lineno"> 115</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a7a9637875364e84e6862de0102341715">makeDogleg</a> ();</div><div class="line"><a name="l00116"></a><span class="lineno"> 116</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a7a9637875364e84e6862de0102341715">makeDogleg</a> ( <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/classKatabatic_1_1GCell_1_1CompareByDensity.html">Katabatic::GCell</a>*, <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>*&amp; perpandicular, <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>*&amp; parallel );</div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; <span class="keyword">virtual</span> <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>* <a class="code" href="classKite_1_1TrackSegment.html#a7a9637875364e84e6862de0102341715">makeDogleg</a> ( <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/hurricane/doc/hurricane/html/hurricane.tag:../hurricane/" href="../hurricane/classHurricane_1_1Interval.html">Interval</a>, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span>&amp; flags );</div><div class="line"><a name="l00118"></a><span class="lineno"> 118</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> <a class="code" href="classKite_1_1TrackSegment.html#a10a45c049d0bd7d01c7eff1c5441c7a2">_postDoglegs</a> ( <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>*&amp; perpandicular, <a class="code" href="classKite_1_1TrackElement.html">TrackElement</a>*&amp; parallel );</div><div class="line"><a name="l00119"></a><span class="lineno"> 119</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> moveAside ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags );</div><div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> slacken ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags=KbNoFlags );</div><div class="line"><a name="l00121"></a><span class="lineno"> 121</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> moveUp ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags );</div><div class="line"><a name="l00122"></a><span class="lineno"> 122</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> moveDown ( <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> flags );</div><div class="line"><a name="l00123"></a><span class="lineno"> 123</span>&#160;<span class="preprocessor">#if THIS_IS_DISABLED</span></div><div class="line"><a name="l00124"></a><span class="lineno"> 124</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> desalignate ();</div><div class="line"><a name="l00125"></a><span class="lineno"> 125</span>&#160;<span class="preprocessor">#endif</span></div><div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#ad79f4c6ea0fe1135b8264a29af085909">_check</a> () <span class="keyword">const</span>;</div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160; <span class="keyword">virtual</span> Record* _getRecord () <span class="keyword">const</span>;</div><div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">string</span> _getString () <span class="keyword">const</span>;</div><div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">string</span> _getTypeName () <span class="keyword">const</span>;</div><div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160;</div><div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; <span class="keyword">protected</span>:</div><div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160; <span class="comment">// Attributes.</span></div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; <span class="keyword">static</span> <span class="keywordtype">size_t</span> _allocateds;</div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/classKatabatic_1_1AutoSegment.html">AutoSegment</a>* _base;</div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; <span class="keywordtype">unsigned</span> <span class="keywordtype">long</span> _freedomDegree;</div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; <a class="codeRef" 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> _ppitch;</div><div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; <a class="code" href="classKite_1_1DataNegociate.html">DataNegociate</a>* _data;</div><div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> _dogLegLevel:4;</div><div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160;</div><div class="line"><a name="l00140"></a><span class="lineno"> 140</span>&#160; <span class="keyword">protected</span>:</div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; <span class="comment">// Constructors &amp; Destructors.</span></div><div class="line"><a name="l00142"></a><span class="lineno"> 142</span>&#160; <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a> ( <a class="codeRef" doxygen="/dsk/l1/jpc/coriolis-2.x/src/coriolis/katabatic/doc/html/katabatic.tag:../katabatic/" href="../katabatic/classKatabatic_1_1AutoSegment.html">AutoSegment</a>*, <a class="code" href="classKite_1_1Track.html">Track</a>* ) ;</div><div class="line"><a name="l00143"></a><span class="lineno"> 143</span>&#160; <span class="keyword">virtual</span> ~<a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a> ();</div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> _postCreate ();</div><div class="line"><a name="l00145"></a><span class="lineno"> 145</span>&#160; <span class="keyword">virtual</span> <span class="keywordtype">void</span> _preDestroy ();</div><div class="line"><a name="l00146"></a><span class="lineno"> 146</span>&#160; <span class="keyword">private</span>:</div><div class="line"><a name="l00147"></a><span class="lineno"> 147</span>&#160; <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a> ( <span class="keyword">const</span> <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a>&amp; );</div><div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160; <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a>&amp; operator= ( <span class="keyword">const</span> <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a>&amp; );</div><div class="line"><a name="l00149"></a><span class="lineno"> 149</span>&#160; </div><div class="line"><a name="l00150"></a><span class="lineno"> 150</span>&#160; };</div><div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160;</div><div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160;</div><div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160; <span class="keyword">inline</span> <span class="keywordtype">bool</span> TrackSegment::CompareById::operator() ( <span class="keyword">const</span> <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a>* lhs, <span class="keyword">const</span> <a class="code" href="classKite_1_1TrackSegment.html">TrackSegment</a>* rhs )</div><div class="line"><a name="l00154"></a><span class="lineno"> 154</span>&#160; { <span class="keywordflow">return</span> lhs-&gt;<a class="code" href="classKite_1_1TrackSegment.html#afdedcef127ad2a3677a5b48d7d3453f3">getId</a>() &lt; rhs-&gt;<a class="code" href="classKite_1_1TrackSegment.html#afdedcef127ad2a3677a5b48d7d3453f3">getId</a>(); }</div><div class="line"><a name="l00155"></a><span class="lineno"> 155</span>&#160;</div><div class="line"><a name="l00156"></a><span class="lineno"> 156</span>&#160;</div><div class="line"><a name="l00157"></a><span class="lineno"> 157</span>&#160; <span class="keyword">typedef</span> set&lt;TrackSegment*,TrackSegment::CompareById&gt; TrackSegmentSet;</div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160;</div><div class="line"><a name="l00159"></a><span class="lineno"> 159</span>&#160;</div><div class="line"><a name="l00160"></a><span class="lineno"> 160</span>&#160;} <span class="comment">// Kite namespace.</span></div><div class="line"><a name="l00161"></a><span class="lineno"> 161</span>&#160;</div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160;</div><div class="line"><a name="l00163"></a><span class="lineno"> 163</span>&#160;INSPECTOR_P_SUPPORT(<a class="code" href="classKite_1_1TrackSegment.html">Kite::TrackSegment</a>);</div><div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160;</div><div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160;<span class="preprocessor">#endif // KITE_TRACK_SEGMENT_H</span></div><div class="ttc" id="classKite_1_1TrackSegment_html_aeb4e39bd925d093e6c45599433bb421c"><div class="ttname"><a href="classKite_1_1TrackSegment.html#aeb4e39bd925d093e6c45599433bb421c">Kite::TrackSegment::getTargetDogleg</a></div><div class="ttdeci">virtual TrackElement * getTargetDogleg()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:528</div></div>
<div class="ttc" id="classKatabatic_1_1GCell_1_1CompareByDensity_html"><div class="ttname"><a href="../katabatic/classKatabatic_1_1GCell_1_1CompareByDensity.html">Katabatic::GCell</a></div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html"><div class="ttname"><a href="classKite_1_1TrackSegment.html">Kite::TrackSegment</a></div><div class="ttdoc">Derived Katabatic::AutoSegment for the router. </div><div class="ttdef"><b>Definition:</b> TrackSegment.h:46</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_abb61228ad7b29c19c6428902d34126f7"><div class="ttname"><a href="classKite_1_1TrackSegment.html#abb61228ad7b29c19c6428902d34126f7">Kite::TrackSegment::getMaxUnderDensity</a></div><div class="ttdeci">virtual float getMaxUnderDensity(unsigned int flags) const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:408</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_add556a145a89fdbcea82346abfb873dc"><div class="ttname"><a href="classKite_1_1TrackSegment.html#add556a145a89fdbcea82346abfb873dc">Kite::TrackSegment::isLocal</a></div><div class="ttdeci">virtual bool isLocal() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:151</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_afd7362b850709bed8b61c1aa22399f97"><div class="ttname"><a href="classKite_1_1TrackSegment.html#afd7362b850709bed8b61c1aa22399f97">Kite::TrackSegment::isFixed</a></div><div class="ttdeci">virtual bool isFixed() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:148</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a5bd93abe1416952ace15a98dbeeed124"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a5bd93abe1416952ace15a98dbeeed124">Kite::TrackSegment::revalidate</a></div><div class="ttdeci">virtual void revalidate()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:331</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a55d6115d84c11ad147f4c38fe372ea24"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a55d6115d84c11ad147f4c38fe372ea24">Kite::TrackSegment::getPrevious</a></div><div class="ttdeci">virtual TrackElement * getPrevious() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:197</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a536f91d468e6c2097f85169e6d790f64"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a536f91d468e6c2097f85169e6d790f64">Kite::TrackSegment::create</a></div><div class="ttdeci">static TrackElement * create(AutoSegment *, Track *, bool &amp;created)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:125</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_ab5b5aaa5b318369feee6003dbad039c2"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ab5b5aaa5b318369feee6003dbad039c2">Kite::TrackSegment::getAxis</a></div><div class="ttdeci">virtual DbU::Unit getAxis() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:170</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a893f1101c650c08c98612515c2b1a89c"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a893f1101c650c08c98612515c2b1a89c">Kite::TrackSegment::invalidate</a></div><div class="ttdeci">virtual void invalidate()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:178</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a010b7fc8801c5b88aefa4137cf85186d"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a010b7fc8801c5b88aefa4137cf85186d">Kite::TrackSegment::getNext</a></div><div class="ttdeci">virtual TrackElement * getNext() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:190</div></div>
<div class="ttc" id="classHurricane_1_1Net_1_1Direction_html"><div class="ttname"><a href="../hurricane/classHurricane_1_1Net_1_1Direction.html">Hurricane::Net</a></div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_aa0ba92ebf19f596537dc051c090d5736"><div class="ttname"><a href="classKite_1_1TrackSegment.html#aa0ba92ebf19f596537dc051c090d5736">Kite::TrackSegment::getPerpandiculars</a></div><div class="ttdeci">virtual TrackElements getPerpandiculars()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:176</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_acc245ce084989d1c34816d0e61b9d510"><div class="ttname"><a href="classKite_1_1TrackSegment.html#acc245ce084989d1c34816d0e61b9d510">Kite::TrackSegment::swapTrack</a></div><div class="ttdeci">virtual void swapTrack(TrackElement *)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:350</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a7a9637875364e84e6862de0102341715"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a7a9637875364e84e6862de0102341715">Kite::TrackSegment::makeDogleg</a></div><div class="ttdeci">virtual TrackElement * makeDogleg()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:705</div></div>
<div class="ttc" id="group__DbUGroup_html_ga4fbfa3e8c89347af76c9628ea06c4146"><div class="ttname"><a href="../hurricane/group__DbUGroup.html#ga4fbfa3e8c89347af76c9628ea06c4146">Hurricane::DbU::Unit</a></div><div class="ttdeci">std::int64_t Unit</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a95ec3b8e7e1ec87c20ee0b37bcc96df7"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a95ec3b8e7e1ec87c20ee0b37bcc96df7">Kite::TrackSegment::getParent</a></div><div class="ttdeci">virtual TrackElement * getParent() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:204</div></div>
<div class="ttc" id="classKite_1_1Track_html"><div class="ttname"><a href="classKite_1_1Track.html">Kite::Track</a></div><div class="ttdoc">Structure managing one routing track. </div><div class="ttdef"><b>Definition:</b> Track.h:42</div></div>
<div class="ttc" id="classHurricane_1_1Interval_html"><div class="ttname"><a href="../hurricane/classHurricane_1_1Interval.html">Hurricane::Interval</a></div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_add78c6f914788c549f144998caacda84"><div class="ttname"><a href="classKite_1_1TrackSegment.html#add78c6f914788c549f144998caacda84">Kite::TrackSegment::getDoglegLevel</a></div><div class="ttdeci">virtual unsigned int getDoglegLevel() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:172</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a692492374623a5c6096b2c4a51190359"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a692492374623a5c6096b2c4a51190359">Kite::TrackSegment::getNet</a></div><div class="ttdeci">virtual Net * getNet() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:166</div></div>
<div class="ttc" id="classKatabatic_1_1AutoSegment_html"><div class="ttname"><a href="../katabatic/classKatabatic_1_1AutoSegment.html">Katabatic::AutoSegment</a></div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_aa0bb6f1592688e942ff67e0ac318a4fd"><div class="ttname"><a href="classKite_1_1TrackSegment.html#aa0bb6f1592688e942ff67e0ac318a4fd">Kite::TrackSegment::canDogleg</a></div><div class="ttdeci">virtual bool canDogleg()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:545</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_af2d46d64cbd02bdbba53d5483d95e26d"><div class="ttname"><a href="classKite_1_1TrackSegment.html#af2d46d64cbd02bdbba53d5483d95e26d">Kite::TrackSegment::getCanonical</a></div><div class="ttdeci">virtual TrackElement * getCanonical(Interval &amp;)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:175</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a782cff57d3fe10e758d19ee65a06643d"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a782cff57d3fe10e758d19ee65a06643d">Kite::TrackSegment::isSlackened</a></div><div class="ttdeci">virtual bool isSlackened() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:157</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_afdedcef127ad2a3677a5b48d7d3453f3"><div class="ttname"><a href="classKite_1_1TrackSegment.html#afdedcef127ad2a3677a5b48d7d3453f3">Kite::TrackSegment::getId</a></div><div class="ttdeci">virtual unsigned long getId() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:164</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_acd0170a05128ec4af16ecd0060c3a3b5"><div class="ttname"><a href="classKite_1_1TrackSegment.html#acd0170a05128ec4af16ecd0060c3a3b5">Kite::TrackSegment::getDataNegociate</a></div><div class="ttdeci">virtual DataNegociate * getDataNegociate(unsigned int flags=KtDataSelf) const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:181</div></div>
<div class="ttc" id="namespaceKite_html_acca8fffa3182dea5f94208f454f14b47a68e917ff37d4b5cef906303181836404"><div class="ttname"><a href="namespaceKite.html#acca8fffa3182dea5f94208f454f14b47a68e917ff37d4b5cef906303181836404">Kite::KtDataSelf</a></div><div class="ttdef"><b>Definition:</b> Constants.h:40</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_ac295bade8aee589f6718dfa79edc2a34"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ac295bade8aee589f6718dfa79edc2a34">Kite::TrackSegment::detach</a></div><div class="ttdeci">virtual void detach()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:321</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a0ffe603ec7d46f21f5e56ccbe84c03fb"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a0ffe603ec7d46f21f5e56ccbe84c03fb">Kite::TrackSegment::reschedule</a></div><div class="ttdeci">virtual void reschedule(unsigned int level)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:392</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a1e074cb3064037035548e5e6d238e315"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a1e074cb3064037035548e5e6d238e315">Kite::TrackSegment::isTerminal</a></div><div class="ttdeci">virtual bool isTerminal() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:154</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_ab045567c4f529dca7790d66c17c3084f"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ab045567c4f529dca7790d66c17c3084f">Kite::TrackSegment::getLayer</a></div><div class="ttdeci">virtual const Layer * getLayer() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:167</div></div>
<div class="ttc" id="classHurricane_1_1DbU_html"><div class="ttname"><a href="../hurricane/classHurricane_1_1DbU.html">Hurricane::DbU</a></div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a72741158d19af38e84c5e9c08f91270f"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a72741158d19af38e84c5e9c08f91270f">Kite::TrackSegment::isBipoint</a></div><div class="ttdeci">virtual bool isBipoint() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:153</div></div>
<div class="ttc" id="classHurricane_1_1Layer_html"><div class="ttname"><a href="../hurricane/classHurricane_1_1Layer.html">Hurricane::Layer</a></div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_abd3d8093f871d3d1a7f24b053648026c"><div class="ttname"><a href="classKite_1_1TrackSegment.html#abd3d8093f871d3d1a7f24b053648026c">Kite::TrackSegment::setTrack</a></div><div class="ttdeci">virtual void setTrack(Track *)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:317</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_ad79f4c6ea0fe1135b8264a29af085909"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ad79f4c6ea0fe1135b8264a29af085909">Kite::TrackSegment::_check</a></div><div class="ttdeci">virtual bool _check() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:825</div></div>
<div class="ttc" id="classKite_1_1TrackElement_html"><div class="ttname"><a href="classKite_1_1TrackElement.html">Kite::TrackElement</a></div><div class="ttdoc">Abstract Class for all Elements inserted inside a Track. </div><div class="ttdef"><b>Definition:</b> TrackElement.h:100</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a10a45c049d0bd7d01c7eff1c5441c7a2"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a10a45c049d0bd7d01c7eff1c5441c7a2">Kite::TrackSegment::_postDoglegs</a></div><div class="ttdeci">virtual void _postDoglegs(TrackElement *&amp;perpandicular, TrackElement *&amp;parallel)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:758</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a034711e2d3617ea848ef9f5a18255e10"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a034711e2d3617ea848ef9f5a18255e10">Kite::TrackSegment::getFreeInterval</a></div><div class="ttdeci">virtual Interval getFreeInterval() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:214</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a75d91371e5281dd21f60ff39ae70a3e5"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a75d91371e5281dd21f60ff39ae70a3e5">Kite::TrackSegment::isDogleg</a></div><div class="ttdeci">virtual bool isDogleg() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:158</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a0dd7cf705ace42c662c289955313b2e9"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a0dd7cf705ace42c662c289955313b2e9">Kite::TrackSegment::getDirection</a></div><div class="ttdeci">virtual unsigned int getDirection() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:165</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a62d61c231cf404a814ae37665fa8164f"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a62d61c231cf404a814ae37665fa8164f">Kite::TrackSegment::isStrap</a></div><div class="ttdeci">virtual bool isStrap() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:156</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a262a915c38127d3722ec561b30d80f91"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a262a915c38127d3722ec561b30d80f91">Kite::TrackSegment::setAxis</a></div><div class="ttdeci">virtual void setAxis(DbU::Unit, unsigned int flags)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:343</div></div>
<div class="ttc" id="namespaceKite_html"><div class="ttname"><a href="namespaceKite.html">Kite</a></div><div class="ttdoc">The namespace dedicated to Kite. </div><div class="ttdef"><b>Definition:</b> Constants.h:22</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a69af7d4287bc0e44c9ca2c8e6f692be9"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a69af7d4287bc0e44c9ca2c8e6f692be9">Kite::TrackSegment::getTargetConstraints</a></div><div class="ttdeci">virtual Interval getTargetConstraints() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:174</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a2b90319cb042b283aa5d1fdb1992f11f"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a2b90319cb042b283aa5d1fdb1992f11f">Kite::TrackSegment::setDoglegLevel</a></div><div class="ttdeci">virtual void setDoglegLevel(unsigned int)</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:295</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a48f8b54f9489da3778d85c382a483f81"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a48f8b54f9489da3778d85c382a483f81">Kite::TrackSegment::getSourceConstraints</a></div><div class="ttdeci">virtual Interval getSourceConstraints() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:173</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a19ba379112d6b29faa45c5eefbf38500"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a19ba379112d6b29faa45c5eefbf38500">Kite::TrackSegment::isGlobal</a></div><div class="ttdeci">virtual bool isGlobal() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:152</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_af45301f76558f613ccb605a8f851080e"><div class="ttname"><a href="classKite_1_1TrackSegment.html#af45301f76558f613ccb605a8f851080e">Kite::TrackSegment::getGCells</a></div><div class="ttdeci">virtual size_t getGCells(Katabatic::GCellVector &amp;) const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:225</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_aa7552c20cc46abcac558627b2ca341f8"><div class="ttname"><a href="classKite_1_1TrackSegment.html#aa7552c20cc46abcac558627b2ca341f8">Kite::TrackSegment::getFreedomDegree</a></div><div class="ttdeci">virtual unsigned long getFreedomDegree() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:171</div></div>
<div class="ttc" id="classKite_1_1DataNegociate_html"><div class="ttname"><a href="classKite_1_1DataNegociate.html">Kite::DataNegociate</a></div><div class="ttdoc">Algorimthmic datas associated the TrackSegment. </div><div class="ttdef"><b>Definition:</b> DataNegociate.h:50</div></div>
<div class="ttc" id="classHurricane_1_1Net_html"><div class="ttname"><a href="../hurricane/classHurricane_1_1Net.html">Hurricane::Net</a></div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a7e79fbfe77f173d46b1959c41087930a"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a7e79fbfe77f173d46b1959c41087930a">Kite::TrackSegment::getSourceDogleg</a></div><div class="ttdeci">virtual TrackElement * getSourceDogleg()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:511</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_af5332d647c0482aa90ad7cc9b2a50f3a"><div class="ttname"><a href="classKite_1_1TrackSegment.html#af5332d647c0482aa90ad7cc9b2a50f3a">Kite::TrackSegment::updateFreedomDegree</a></div><div class="ttdeci">virtual void updateFreedomDegree()</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:306</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_abd54544ef1710ee4b67cfb021d73446c"><div class="ttname"><a href="classKite_1_1TrackSegment.html#abd54544ef1710ee4b67cfb021d73446c">Kite::TrackSegment::isVertical</a></div><div class="ttdeci">virtual bool isVertical() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:150</div></div>
<div class="ttc" id="classKite_1_1TrackSegment_html_a21b9cefd33ae22e4c2070ad441bdd30b"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a21b9cefd33ae22e4c2070ad441bdd30b">Kite::TrackSegment::isHorizontal</a></div><div class="ttdeci">virtual bool isHorizontal() const</div><div class="ttdef"><b>Definition:</b> TrackSegment.cpp:149</div></div>
</div><!-- fragment --></div><!-- contents -->
<br>
<hr>
<table class="footer1">
<tr>
<td class="LFooter"><small>Generated by doxygen 1.8.14 on Thu Nov 12 2020</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 &#169; 2008-2020 Sorbonne Universite. All rights reserved</small></td>
</tr>
</table>
</body>
</html>