<!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 Mon Oct 28 2019</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>