KShortestPaths_8h_source.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <meta name="generator" content="Doxygen 1.8.12"/>
  7. <meta name="viewport" content="width=device-width, initial-scale=1"/>
  8. <title>Tracore: algo/KShortestPaths.h Source File</title>
  9. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  13. <script type="text/javascript" src="search/searchdata.js"></script>
  14. <script type="text/javascript" src="search/search.js"></script>
  15. <script type="text/javascript">
  16. $(document).ready(function() { init_search(); });
  17. </script>
  18. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  19. </head>
  20. <body>
  21. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  22. <div id="titlearea">
  23. <table cellspacing="0" cellpadding="0">
  24. <tbody>
  25. <tr style="height: 56px;">
  26. <td id="projectalign" style="padding-left: 0.5em;">
  27. <div id="projectname">Tracore
  28. </div>
  29. </td>
  30. </tr>
  31. </tbody>
  32. </table>
  33. </div>
  34. <!-- end header part -->
  35. <!-- Generated by Doxygen 1.8.12 -->
  36. <script type="text/javascript">
  37. var searchBox = new SearchBox("searchBox", "search",false,'Search');
  38. </script>
  39. <div id="navrow1" class="tabs">
  40. <ul class="tablist">
  41. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  42. <li><a href="annotated.html"><span>Classes</span></a></li>
  43. <li class="current"><a href="files.html"><span>Files</span></a></li>
  44. <li>
  45. <div id="MSearchBox" class="MSearchBoxInactive">
  46. <span class="left">
  47. <img id="MSearchSelect" src="search/mag_sel.png"
  48. onmouseover="return searchBox.OnSearchSelectShow()"
  49. onmouseout="return searchBox.OnSearchSelectHide()"
  50. alt=""/>
  51. <input type="text" id="MSearchField" value="Search" accesskey="S"
  52. onfocus="searchBox.OnSearchFieldFocus(true)"
  53. onblur="searchBox.OnSearchFieldFocus(false)"
  54. onkeyup="searchBox.OnSearchFieldChange(event)"/>
  55. </span><span class="right">
  56. <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
  57. </span>
  58. </div>
  59. </li>
  60. </ul>
  61. </div>
  62. <div id="navrow2" class="tabs2">
  63. <ul class="tablist">
  64. <li><a href="files.html"><span>File&#160;List</span></a></li>
  65. </ul>
  66. </div>
  67. <!-- window showing the filter options -->
  68. <div id="MSearchSelectWindow"
  69. onmouseover="return searchBox.OnSearchSelectShow()"
  70. onmouseout="return searchBox.OnSearchSelectHide()"
  71. onkeydown="return searchBox.OnSearchSelectKey(event)">
  72. </div>
  73. <!-- iframe showing the search results (closed by default) -->
  74. <div id="MSearchResultsWindow">
  75. <iframe src="javascript:void(0)" frameborder="0"
  76. name="MSearchResults" id="MSearchResults">
  77. </iframe>
  78. </div>
  79. <div id="nav-path" class="navpath">
  80. <ul>
  81. <li class="navelem"><a class="el" href="dir_14879d16547af1f036be9d5915ae128f.html">algo</a></li> </ul>
  82. </div>
  83. </div><!-- top -->
  84. <div class="header">
  85. <div class="headertitle">
  86. <div class="title">KShortestPaths.h</div> </div>
  87. </div><!--header-->
  88. <div class="contents">
  89. <div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment">// Created by wrede on 28.06.16.</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="comment">//</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;</div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;<span class="preprocessor">#ifndef GBMOT_KSHORTESTPATHS_H</span></div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160;<span class="preprocessor">#define GBMOT_KSHORTESTPATHS_H</span></div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="preprocessor">#include &quot;../graph/Definitions.h&quot;</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160;</div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="keyword">namespace </span><a class="code" href="namespacealgo.html">algo</a></div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;{</div><div class="line"><a name="l00016"></a><span class="lineno"><a class="line" href="classalgo_1_1KShortestPaths.html"> 16</a></span>&#160; <span class="keyword">class </span><a class="code" href="classalgo_1_1KShortestPaths.html">KShortestPaths</a></div><div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160; {</div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160; <span class="keyword">private</span>:</div><div class="line"><a name="l00022"></a><span class="lineno"> 22</span>&#160; DirectedGraph orig_graph_;</div><div class="line"><a name="l00023"></a><span class="lineno"> 23</span>&#160;</div><div class="line"><a name="l00027"></a><span class="lineno"> 27</span>&#160; Vertex source_;</div><div class="line"><a name="l00028"></a><span class="lineno"> 28</span>&#160;</div><div class="line"><a name="l00032"></a><span class="lineno"> 32</span>&#160; Vertex sink_;</div><div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160;</div><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160; VertexPredecessorMap paths_;</div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160;</div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160; std::vector&lt;Vertex&gt; sink_neighbors_;</div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160;</div><div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160; <span class="keywordtype">bool</span> FindPath(DirectedGraph&amp; graph, Vertex&amp; source, Vertex&amp; sink,</div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160; VertexPredecessorMap&amp; predecessors, VertexDistanceMap&amp; distances);</div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160; <span class="keywordtype">bool</span> FindPath(DirectedGraph&amp; graph, Vertex&amp; source, Vertex&amp; sink,</div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160; VertexPredecessorMap&amp; predecessors);</div><div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160;</div><div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160; <span class="keywordtype">void</span> FindPathPair();</div><div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160;</div><div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160; <span class="keywordtype">void</span> FindPaths(<span class="keywordtype">size_t</span> count);</div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160;</div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; <span class="keywordtype">void</span> AddPath(VertexPredecessorMap&amp; path);</div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160;</div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; <span class="keywordtype">void</span> AddPath(VertexPredecessorMap&amp; in, MultiPredecessorMap&amp; out);</div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160;</div><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; <span class="keywordtype">void</span> AddPaths(MultiPredecessorMap&amp; paths);</div><div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <span class="keyword">public</span>:</div><div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; <a class="code" href="classalgo_1_1KShortestPaths.html#ad8654c43c8354f734870ec98783f9756">KShortestPaths</a>(DirectedGraph input_graph, Vertex source, Vertex sink);</div><div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160;</div><div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; <span class="keywordtype">void</span> <a class="code" href="classalgo_1_1KShortestPaths.html#a4ad79f2618bf3fc36b591ff69efd3c76">Run</a>(<span class="keywordtype">size_t</span> max_path_count);</div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160;</div><div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; <span class="keywordtype">void</span> <a class="code" href="classalgo_1_1KShortestPaths.html#a6af47b5af40e75786924941b3472ada2">GetPaths</a>(std::vector&lt;std::vector&lt;Vertex&gt;&gt;&amp; paths);</div><div class="line"><a name="l00118"></a><span class="lineno"> 118</span>&#160; };</div><div class="line"><a name="l00119"></a><span class="lineno"> 119</span>&#160;}</div><div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160;</div><div class="line"><a name="l00121"></a><span class="lineno"> 121</span>&#160;</div><div class="line"><a name="l00122"></a><span class="lineno"> 122</span>&#160;<span class="preprocessor">#endif //GBMOT_KSHORTESTPATHS_H</span></div><div class="ttc" id="classalgo_1_1KShortestPaths_html_a4ad79f2618bf3fc36b591ff69efd3c76"><div class="ttname"><a href="classalgo_1_1KShortestPaths.html#a4ad79f2618bf3fc36b591ff69efd3c76">algo::KShortestPaths::Run</a></div><div class="ttdeci">void Run(size_t max_path_count)</div><div class="ttdef"><b>Definition:</b> KShortestPaths.cpp:23</div></div>
  90. <div class="ttc" id="classalgo_1_1KShortestPaths_html_ad8654c43c8354f734870ec98783f9756"><div class="ttname"><a href="classalgo_1_1KShortestPaths.html#ad8654c43c8354f734870ec98783f9756">algo::KShortestPaths::KShortestPaths</a></div><div class="ttdeci">KShortestPaths(DirectedGraph input_graph, Vertex source, Vertex sink)</div><div class="ttdef"><b>Definition:</b> KShortestPaths.cpp:16</div></div>
  91. <div class="ttc" id="namespacealgo_html"><div class="ttname"><a href="namespacealgo.html">algo</a></div><div class="ttdef"><b>Definition:</b> Berclaz.cpp:10</div></div>
  92. <div class="ttc" id="classalgo_1_1KShortestPaths_html_a6af47b5af40e75786924941b3472ada2"><div class="ttname"><a href="classalgo_1_1KShortestPaths.html#a6af47b5af40e75786924941b3472ada2">algo::KShortestPaths::GetPaths</a></div><div class="ttdeci">void GetPaths(std::vector&lt; std::vector&lt; Vertex &gt;&gt; &amp;paths)</div><div class="ttdef"><b>Definition:</b> KShortestPaths.cpp:548</div></div>
  93. <div class="ttc" id="classalgo_1_1KShortestPaths_html"><div class="ttname"><a href="classalgo_1_1KShortestPaths.html">algo::KShortestPaths</a></div><div class="ttdef"><b>Definition:</b> KShortestPaths.h:16</div></div>
  94. </div><!-- fragment --></div><!-- contents -->
  95. <!-- start footer part -->
  96. <hr class="footer"/><address class="footer"><small>
  97. Generated by &#160;<a href="http://www.doxygen.org/index.html">
  98. <img class="footer" src="doxygen.png" alt="doxygen"/>
  99. </a> 1.8.12
  100. </small></address>
  101. </body>
  102. </html>