coriolis/kite/doc/html/TrackSegment_8h_source.html

291 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.5 -->
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
<li><a href="modules.html"><span>Modules</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li><a href="annotated.html"><span>Classes</span></a></li>
<li class="current"><a href="files.html"><span>Files</span></a></li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="files.html"><span>File&#160;List</span></a></li>
</ul>
</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"></span><span class="preprocessor">#define KITE_TRACK_SEGMENT_H</span></div>
<div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160;<span class="preprocessor"></span></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>Kite {</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.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#af5e7d3badddf2ec07159f1d83426d4c1">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#ac46ac3b48d712750c7888b48964ac189">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#a2bb30e82aad1f321af4a065338775f36">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#a69fb7e260ed2bc6fa82bfe12c2aeec5a">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#a017b1ead8e5988dd0e491cae93ac510c">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#ab5035e6d84cf3ec7b519a5acb109efaa">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#a8d6f4521b27f32080d7477cf8ee8a274">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#a4721fcbe9c93ed5392afd9a756b989a8">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#ab1f9e0bca70dea59558459a003a62d88">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#a172b2394f9c2cbaaf5bc4b19e0e76e65">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.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#a3bc51798c4b09a1537350822025adcea">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#ae68c47fdf838be02cbf6660cd25a0806">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#a09d03fbca9ab891c2f25bdae7f89a899">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#adf3e1a980233163de0ca34a5c3575998">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#a304ee4e02745811e04ac6fb688bf834f">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#a9f20f94d2d8aaa38c2b9ead5275ead27">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#ace669b962e7df815b92fe70e1f4ad755">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#a5af0ac91c558873fea9703e7ab6f48df">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#acbb9c965449bf4502d71149563cec0a2">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#ad1a03a36d5908ce44c3d0391ff9c7103">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#af85576c58c70007850ad56e238e8d266">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#a38d30a241d00a14943a06401d0d12923">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#a972921aeb7f907194710ea35ac7600be">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#a00d398bdc1837c6c1e4847895c557829">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#a76a45d5701f875711a03692e9bf6d5ce">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#a79b25d8199fe90446e99cf08d2d85674">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.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="preprocessor"></span> <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="preprocessor"></span> <span class="keyword">virtual</span> <span class="keywordtype">bool</span> <a class="code" href="classKite_1_1TrackSegment.html#aa1ef325b98fab61d2c7c5bdc1fcd92fc">_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#ae68c47fdf838be02cbf6660cd25a0806">getId</a>() &lt; rhs-&gt;<a class="code" href="classKite_1_1TrackSegment.html#ae68c47fdf838be02cbf6660cd25a0806">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="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_ae68c47fdf838be02cbf6660cd25a0806"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ae68c47fdf838be02cbf6660cd25a0806">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_ace669b962e7df815b92fe70e1f4ad755"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ace669b962e7df815b92fe70e1f4ad755">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_a09d03fbca9ab891c2f25bdae7f89a899"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a09d03fbca9ab891c2f25bdae7f89a899">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_a69fb7e260ed2bc6fa82bfe12c2aeec5a"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a69fb7e260ed2bc6fa82bfe12c2aeec5a">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_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_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_a00d398bdc1837c6c1e4847895c557829"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a00d398bdc1837c6c1e4847895c557829">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_adf3e1a980233163de0ca34a5c3575998"><div class="ttname"><a href="classKite_1_1TrackSegment.html#adf3e1a980233163de0ca34a5c3575998">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="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_acbb9c965449bf4502d71149563cec0a2"><div class="ttname"><a href="classKite_1_1TrackSegment.html#acbb9c965449bf4502d71149563cec0a2">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_a5af0ac91c558873fea9703e7ab6f48df"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a5af0ac91c558873fea9703e7ab6f48df">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="classKite_1_1TrackSegment_html_a972921aeb7f907194710ea35ac7600be"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a972921aeb7f907194710ea35ac7600be">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_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_a2bb30e82aad1f321af4a065338775f36"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a2bb30e82aad1f321af4a065338775f36">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_a76a45d5701f875711a03692e9bf6d5ce"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a76a45d5701f875711a03692e9bf6d5ce">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="classKite_1_1TrackSegment_html_ac46ac3b48d712750c7888b48964ac189"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ac46ac3b48d712750c7888b48964ac189">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 class="ttc" id="classKite_1_1TrackSegment_html_a172b2394f9c2cbaaf5bc4b19e0e76e65"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a172b2394f9c2cbaaf5bc4b19e0e76e65">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_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_aa1ef325b98fab61d2c7c5bdc1fcd92fc"><div class="ttname"><a href="classKite_1_1TrackSegment.html#aa1ef325b98fab61d2c7c5bdc1fcd92fc">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_1TrackSegment_html_af5e7d3badddf2ec07159f1d83426d4c1"><div class="ttname"><a href="classKite_1_1TrackSegment.html#af5e7d3badddf2ec07159f1d83426d4c1">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_a017b1ead8e5988dd0e491cae93ac510c"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a017b1ead8e5988dd0e491cae93ac510c">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="classKatabatic_1_1GCell_html"><div class="ttname"><a href="../katabatic/classKatabatic_1_1GCell.html">Katabatic::GCell</a></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_ab1f9e0bca70dea59558459a003a62d88"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ab1f9e0bca70dea59558459a003a62d88">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="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_a304ee4e02745811e04ac6fb688bf834f"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a304ee4e02745811e04ac6fb688bf834f">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="classKite_1_1TrackSegment_html_a4721fcbe9c93ed5392afd9a756b989a8"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a4721fcbe9c93ed5392afd9a756b989a8">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_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_ad1a03a36d5908ce44c3d0391ff9c7103"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ad1a03a36d5908ce44c3d0391ff9c7103">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="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_a38d30a241d00a14943a06401d0d12923"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a38d30a241d00a14943a06401d0d12923">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_af85576c58c70007850ad56e238e8d266"><div class="ttname"><a href="classKite_1_1TrackSegment.html#af85576c58c70007850ad56e238e8d266">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_a79b25d8199fe90446e99cf08d2d85674"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a79b25d8199fe90446e99cf08d2d85674">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="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_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_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="classKite_1_1TrackSegment_html_a3bc51798c4b09a1537350822025adcea"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a3bc51798c4b09a1537350822025adcea">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_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_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_a9f20f94d2d8aaa38c2b9ead5275ead27"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a9f20f94d2d8aaa38c2b9ead5275ead27">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_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_a8d6f4521b27f32080d7477cf8ee8a274"><div class="ttname"><a href="classKite_1_1TrackSegment.html#a8d6f4521b27f32080d7477cf8ee8a274">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_ab5035e6d84cf3ec7b519a5acb109efaa"><div class="ttname"><a href="classKite_1_1TrackSegment.html#ab5035e6d84cf3ec7b519a5acb109efaa">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><!-- fragment --></div><!-- contents -->
<br>
<hr>
<table class="footer1">
<tr>
<td class="LFooter"><small>Generated by doxygen 1.8.5 on Mon Oct 1 2018</small></td>
<td class="RFooter"><a href='#pagetop'><small>Return to top of page</small></a></td>
</tr>
</table>
<table class="footer2">
<tr>
<td class="LFooter">Kite - Detailed Router</td>
<td class="RFooter"><small>Copyright &#169; 2008-2016 UPMC. All rights reserved</small></td>
</tr>
</table>
</body>
</html>