<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>DTN Reference Implementation: MultiGraph.h Source File</title> <link href="tabs.css" rel="stylesheet" type="text/css"> <link href="doxygen.css" rel="stylesheet" type="text/css"> </head><body> <!-- Generated by Doxygen 1.5.8 --> <div class="navigation" id="top"> <div class="tabs"> <ul> <li><a href="main.html"><span>Main Page</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 class="tabs"> <ul> <li><a href="files.html"><span>File List</span></a></li> <li><a href="globals.html"><span>File Members</span></a></li> </ul> </div> <h1>MultiGraph.h</h1><a href="MultiGraph_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span> <a name="l00002"></a>00002 <span class="comment"> * Copyright 2007 Intel Corporation</span> <a name="l00003"></a>00003 <span class="comment"> * </span> <a name="l00004"></a>00004 <span class="comment"> * Licensed under the Apache License, Version 2.0 (the "License");</span> <a name="l00005"></a>00005 <span class="comment"> * you may not use this file except in compliance with the License.</span> <a name="l00006"></a>00006 <span class="comment"> * You may obtain a copy of the License at</span> <a name="l00007"></a>00007 <span class="comment"> * </span> <a name="l00008"></a>00008 <span class="comment"> * http://www.apache.org/licenses/LICENSE-2.0</span> <a name="l00009"></a>00009 <span class="comment"> * </span> <a name="l00010"></a>00010 <span class="comment"> * Unless required by applicable law or agreed to in writing, software</span> <a name="l00011"></a>00011 <span class="comment"> * distributed under the License is distributed on an "AS IS" BASIS,</span> <a name="l00012"></a>00012 <span class="comment"> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span> <a name="l00013"></a>00013 <span class="comment"> * See the License for the specific language governing permissions and</span> <a name="l00014"></a>00014 <span class="comment"> * limitations under the License.</span> <a name="l00015"></a>00015 <span class="comment"> */</span> <a name="l00016"></a>00016 <a name="l00017"></a>00017 <span class="preprocessor">#ifndef _MULTIGRAPH_H_</span> <a name="l00018"></a>00018 <span class="preprocessor"></span><span class="preprocessor">#define _MULTIGRAPH_H_</span> <a name="l00019"></a>00019 <span class="preprocessor"></span> <a name="l00020"></a>00020 <span class="preprocessor">#include <vector></span> <a name="l00021"></a>00021 <span class="preprocessor">#include <oasys/debug/InlineFormatter.h></span> <a name="l00022"></a>00022 <span class="preprocessor">#include <oasys/debug/Formatter.h></span> <a name="l00023"></a>00023 <span class="preprocessor">#include <oasys/debug/Logger.h></span> <a name="l00024"></a>00024 <span class="preprocessor">#include <oasys/util/StringBuffer.h></span> <a name="l00025"></a>00025 <span class="preprocessor">#include <oasys/util/Time.h></span> <a name="l00026"></a>00026 <a name="l00027"></a>00027 <span class="keyword">namespace </span>dtn { <a name="l00028"></a>00028 <a name="l00029"></a>00029 <span class="keyword">class </span>Bundle; <a name="l00030"></a>00030 <a name="l00034"></a>00034 <span class="keyword">template</span> <<span class="keyword">typename</span> _NodeInfo, <span class="keyword">typename</span> _EdgeInfo> <a name="l00035"></a><a class="code" href="classdtn_1_1MultiGraph.html">00035</a> <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph.html" title="Data structure to represent a multigraph.">MultiGraph</a> : <span class="keyword">public</span> oasys::<a class="code" href="classoasys_1_1Formatter.html">Formatter</a>, <span class="keyword">public</span> oasys::<a class="code" href="classoasys_1_1Logger.html">Logger</a> { <a name="l00036"></a>00036 <span class="keyword">public</span>: <a name="l00038"></a>00038 <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>; <a name="l00039"></a>00039 <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a>; <a name="l00040"></a>00040 <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>; <a name="l00041"></a>00041 <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1NodeVector.html" title="Helper data structure for a vector of nodes.">NodeVector</a>; <a name="l00042"></a>00042 <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html" title="The abstract weight function class.">WeightFn</a>; <a name="l00044"></a>00044 <a name="l00046"></a>00046 <a class="code" href="classdtn_1_1MultiGraph.html#45465930b4c1e4be0f25ddc8ec3cc2c9" title="Constructor.">MultiGraph</a>(); <a name="l00047"></a>00047 <a name="l00049"></a>00049 <a class="code" href="classdtn_1_1MultiGraph.html#1ff6ca466b1a3d0d3ba7e1c9e7e1c7b0" title="Destructor.">~MultiGraph</a>(); <a name="l00050"></a>00050 <a name="l00052"></a>00052 <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph.html#c250f8c8d1b8970870067c6e73058ee9" title="Add a new node.">add_node</a>(<span class="keyword">const</span> std::string& <span class="keywordtype">id</span>, <span class="keyword">const</span> _NodeInfo& <a class="code" href="dtncat_8c.html#71f51a2e8cbe9a53031fa72596edc09f">info</a>); <a name="l00053"></a>00053 <a name="l00055"></a>00055 <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph.html#a9a0d61ec5663bc8954b0db5969b68f4" title="Find a node with the given id.">find_node</a>(<span class="keyword">const</span> std::string& <span class="keywordtype">id</span>) <span class="keyword">const</span>; <a name="l00056"></a>00056 <a name="l00058"></a>00058 <span class="keywordtype">bool</span> <a class="code" href="classdtn_1_1MultiGraph.html#c6c2ee3ec320168b2399e3ae4a77936b" title="Delete a node and all its edges.">del_node</a>(<span class="keyword">const</span> std::string& <span class="keywordtype">id</span>); <a name="l00059"></a>00059 <a name="l00061"></a>00061 <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>* <a class="code" href="classdtn_1_1MultiGraph.html#059a319c2a8018b46b292b3dbc01ce8a" title="Add an edge.">add_edge</a>(<a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* a, <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* b, <span class="keyword">const</span> _EdgeInfo& info); <a name="l00062"></a>00062 <a name="l00064"></a>00064 <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>* <a class="code" href="classdtn_1_1MultiGraph.html#45b321b90cabaab2d960b50bfa65f3ab" title="Find an edge.">find_edge</a>(<span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* a, <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* b, <span class="keyword">const</span> _EdgeInfo& info); <a name="l00065"></a>00065 <a name="l00068"></a>00068 <span class="keywordtype">bool</span> <a class="code" href="classdtn_1_1MultiGraph.html#32aff4a713436864c2f147c03393bbbe" title="Remove the specified edge from the given node, deleting the Edge object.">del_edge</a>(<a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* node, <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>* edge); <a name="l00069"></a>00069 <a name="l00074"></a>00074 <span class="keywordtype">void</span> <a class="code" href="classdtn_1_1MultiGraph.html#5d091d22c14ffe7c29ff7890d69c9f89" title="Find the shortest path between two nodes by running Dijkstra&#39;s algorithm, filling...">shortest_path</a>(<span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* a, <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* b, <a name="l00075"></a>00075 <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a>* path, <a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html" title="The abstract weight function class.">WeightFn</a>* weight_fn, <a name="l00076"></a>00076 <a class="code" href="classdtn_1_1Bundle.html" title="The internal representation of a bundle.">Bundle</a>* bundle = NULL); <a name="l00077"></a>00077 <a name="l00080"></a>00080 <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>* <a class="code" href="classdtn_1_1MultiGraph.html#05257dfbccf2c15813faef76b0a8ff6c" title="More limited version of the shortest path that just returns the next hop edge.">best_next_hop</a>(<span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* a, <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* b, <a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html" title="The abstract weight function class.">WeightFn</a>* weight_fn, <a name="l00081"></a>00081 <a class="code" href="classdtn_1_1Bundle.html" title="The internal representation of a bundle.">Bundle</a>* bundle = NULL); <a name="l00082"></a>00082 <a name="l00084"></a>00084 <span class="keywordtype">void</span> <a class="code" href="classdtn_1_1MultiGraph.html#8b4f62ab231dd63ea2fe3c45d59ead17" title="Clear the contents of the graph.">clear</a>(); <a name="l00085"></a>00085 <a name="l00087"></a>00087 <span class="keywordtype">int</span> <a class="code" href="classdtn_1_1MultiGraph.html#70aafb526a9df1513b7683549261ec47" title="Virtual from Formatter.">format</a>(<span class="keywordtype">char</span>* <a class="code" href="num2sdnv_8c.html#a81cdcc7ff6987bc85c073253e32715f">buf</a>, <span class="keywordtype">size_t</span> sz) <span class="keyword">const</span>; <a name="l00088"></a>00088 <a name="l00090"></a><a class="code" href="classdtn_1_1MultiGraph.html#6d2fd66634cd1087df9f6554abbf107a">00090</a> std::string <a class="code" href="classdtn_1_1MultiGraph.html#6d2fd66634cd1087df9f6554abbf107a" title="Return a string dump of the graph.">dump</a>()<span class="keyword"> const</span> <a name="l00091"></a>00091 <span class="keyword"> </span>{ <a name="l00092"></a>00092 <span class="keywordtype">char</span> buf[1024]; <a name="l00093"></a>00093 <span class="keywordtype">int</span> <a class="code" href="num2sdnv_8c.html#fed088663f8704004425cdae2120b9b3">len</a> = <a class="code" href="classdtn_1_1MultiGraph.html#70aafb526a9df1513b7683549261ec47" title="Virtual from Formatter.">format</a>(buf, <span class="keyword">sizeof</span>(buf)); <a name="l00094"></a>00094 <span class="keywordflow">return</span> std::string(buf, len); <a name="l00095"></a>00095 } <a name="l00096"></a>00096 <a name="l00098"></a><a class="code" href="classdtn_1_1MultiGraph.html#105482907b76044f8faa3720c8c97c4c">00098</a> <span class="keyword">const</span> NodeVector& <a class="code" href="classdtn_1_1MultiGraph.html#105482907b76044f8faa3720c8c97c4c" title="Accessor for the nodes array.">nodes</a>() { <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph.html#a195b6b49cc23c6af28dd923260b0641" title="The vector of all nodes.">nodes_</a>; } <a name="l00099"></a>00099 <a name="l00103"></a><a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html">00103</a> <span class="keyword">struct </span><a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html" title="Struct used to encapsulate state that may be needed by weight functors and which...">SearchInfo</a> { <a name="l00104"></a>00104 <a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html#f9f643f8c8ddd84a665c2fa10e74057d">SearchInfo</a>(<a class="code" href="classdtn_1_1Bundle.html" title="The internal representation of a bundle.">Bundle</a>* bundle); <a name="l00105"></a>00105 <a name="l00106"></a><a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html#58ad1c60ee685325198ed95dd31350e7">00106</a> <a class="code" href="classdtn_1_1Bundle.html" title="The internal representation of a bundle.">Bundle</a>* <a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html#58ad1c60ee685325198ed95dd31350e7">bundle_</a>; <a name="l00107"></a><a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html#f4da8a1370f6d8b84ca21e78d7cb0fa5">00107</a> oasys::Time <a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html#f4da8a1370f6d8b84ca21e78d7cb0fa5">now_</a>; <a name="l00108"></a>00108 }; <a name="l00109"></a>00109 <a name="l00111"></a><a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html">00111</a> <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html" title="The abstract weight function class.">WeightFn</a> { <a name="l00112"></a>00112 <span class="keyword">public</span>: <a name="l00113"></a><a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html#9c20479c77cc8eebcb3839d4377b3979">00113</a> <span class="keyword">virtual</span> <a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html#9c20479c77cc8eebcb3839d4377b3979">~WeightFn</a>() {} <a name="l00114"></a>00114 <span class="keyword">virtual</span> u_int32_t <a class="code" href="classdtn_1_1MultiGraph_1_1WeightFn.html#fa6025c41761990dd6533ef037cb8b26">operator()</a>(<span class="keyword">const</span> <a class="code" href="structdtn_1_1MultiGraph_1_1SearchInfo.html" title="Struct used to encapsulate state that may be needed by weight functors and which...">SearchInfo</a>& info, <a name="l00115"></a>00115 <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>* edge) = 0; <a name="l00116"></a>00116 }; <a name="l00117"></a>00117 <a name="l00119"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html">00119</a> <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a> { <a name="l00120"></a>00120 <span class="keyword">public</span>: <a name="l00122"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#975d995d642fa8e8a463323536dd489d">00122</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#975d995d642fa8e8a463323536dd489d" title="Constructor.">Node</a>(<span class="keyword">const</span> std::string& <span class="keywordtype">id</span>, <span class="keyword">const</span> _NodeInfo info) <a name="l00123"></a>00123 : <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#fadb2a326cef1150e0b56ba2cfd83373">id_</a>(id), <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#d15a061a7a6bcb20e69b5dc5908140c6">info_</a>(info) {} <a name="l00124"></a>00124 <a name="l00125"></a>00125 <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#ebd611881b0a08125223d852da0e52be">~Node</a>(); <a name="l00126"></a>00126 <a name="l00127"></a>00127 <span class="keywordtype">bool</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#207924155c453a7ef017feae573946bd">del_edge</a>(<a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>* edge); <a name="l00128"></a>00128 <a name="l00129"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#3b81a40a3bd4499065dd392bb0830300">00129</a> <span class="keyword">const</span> std::string& <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#3b81a40a3bd4499065dd392bb0830300">id</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#fadb2a326cef1150e0b56ba2cfd83373">id_</a>; } <a name="l00130"></a>00130 <a name="l00131"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#47fd8a0dc339076cd002fe1e2d459492">00131</a> <span class="keyword">const</span> _NodeInfo& <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#47fd8a0dc339076cd002fe1e2d459492">info</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#d15a061a7a6bcb20e69b5dc5908140c6">info_</a>; } <a name="l00132"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#a70cbd29828e38614c9addb3e3b13425">00132</a> _NodeInfo& <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#a70cbd29828e38614c9addb3e3b13425">mutable_info</a>() { <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#d15a061a7a6bcb20e69b5dc5908140c6">info_</a>; } <a name="l00133"></a>00133 <a name="l00134"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#13769cec4ccaea1b9363567da6ca0b07">00134</a> <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a>& <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#13769cec4ccaea1b9363567da6ca0b07">out_edges</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#4e1a2336338b7e80e13753f677a243a8">out_edges_</a>; } <a name="l00135"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#873a26ed7dc5968450b77d48ceea8b5a">00135</a> <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a>& <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#873a26ed7dc5968450b77d48ceea8b5a">in_edges</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#811afb05ebbc8874aed912e17c428825">in_edges_</a>; } <a name="l00136"></a>00136 <a name="l00137"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#16d8e6533c4422cda416a006fe42bf56">00137</a> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a>& <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#16d8e6533c4422cda416a006fe42bf56">out_edges</a>() { <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#4e1a2336338b7e80e13753f677a243a8">out_edges_</a>; } <a name="l00138"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#50dd6caba720d9dbf1f244839701aaf4">00138</a> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a>& <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#50dd6caba720d9dbf1f244839701aaf4">in_edges</a>() { <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#811afb05ebbc8874aed912e17c428825">in_edges_</a>; } <a name="l00139"></a>00139 <a name="l00140"></a>00140 <span class="keyword">private</span>: <a name="l00141"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#516ddcbe742d58fd5c1e5cd091134922">00141</a> <span class="keyword">friend</span> <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph.html" title="Data structure to represent a multigraph.">MultiGraph</a>; <a name="l00142"></a>00142 <a name="l00143"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#fadb2a326cef1150e0b56ba2cfd83373">00143</a> std::string <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#fadb2a326cef1150e0b56ba2cfd83373">id_</a>; <a name="l00144"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#d15a061a7a6bcb20e69b5dc5908140c6">00144</a> _NodeInfo <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#d15a061a7a6bcb20e69b5dc5908140c6">info_</a>; <a name="l00145"></a>00145 <a name="l00146"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#4e1a2336338b7e80e13753f677a243a8">00146</a> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#4e1a2336338b7e80e13753f677a243a8">out_edges_</a>; <a name="l00147"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#811afb05ebbc8874aed912e17c428825">00147</a> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#811afb05ebbc8874aed912e17c428825">in_edges_</a>; <a name="l00148"></a>00148 <a name="l00149"></a>00149 <span class="comment">// XXX/demmer see below</span> <a name="l00150"></a>00150 <span class="comment">// friend class MultiGraph::DijkstraCompare;</span> <a name="l00151"></a>00151 <a name="l00153"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#ddc8566d8678bc36ab8f82040790d497">00153</a> <span class="keyword">mutable</span> u_int32_t <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#ddc8566d8678bc36ab8f82040790d497" title="Dijkstra algorithm state.">distance_</a>; <a name="l00154"></a>00154 <a name="l00155"></a>00155 <span class="keyword">mutable</span> <span class="keyword">enum</span> { <a name="l00156"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#ab4f01861321459910276b49a88621ead6c1e48f4eb15ec59447f540eacc9a78">00156</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#ab4f01861321459910276b49a88621ead6c1e48f4eb15ec59447f540eacc9a78">WHITE</a>, <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#ab4f01861321459910276b49a88621ea489711053199a0375e19bf3c1c226986">GRAY</a>, <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#ab4f01861321459910276b49a88621eadd8faf310189c61bcc62ca3ad2988958">BLACK</a> <a name="l00157"></a>00157 } <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#bf6f5f9e385606ad4588e867c1816e64" title="Dijkstra algorithm state.">color_</a>; <a name="l00158"></a>00158 <a name="l00159"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#3943bd53fbbd4b72c2a88f2af6ea07f3">00159</a> <span class="keyword">mutable</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a>* <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html#3943bd53fbbd4b72c2a88f2af6ea07f3" title="Dijkstra algorithm state.">prev_</a>; <a name="l00161"></a>00161 }; <a name="l00162"></a>00162 <a name="l00166"></a><a class="code" href="classdtn_1_1MultiGraph.html#681a67ccaac7566e4f38ab36cf35d428">00166</a> <span class="keyword">static</span> u_int32_t <a class="code" href="classdtn_1_1MultiGraph.html#681a67ccaac7566e4f38ab36cf35d428" title="XXX/demmer this stupid helper function is needed because DijkstraCompare can&#39;t...">NodeDistance</a>(<span class="keyword">const</span> Node* n) { <a name="l00167"></a>00167 <span class="keywordflow">return</span> n->distance_; <a name="l00168"></a>00168 } <a name="l00169"></a>00169 <a name="l00171"></a><a class="code" href="structdtn_1_1MultiGraph_1_1DijkstraCompare.html">00171</a> <span class="keyword">struct </span><a class="code" href="structdtn_1_1MultiGraph_1_1DijkstraCompare.html" title="Helper class to compute Dijkstra distance.">DijkstraCompare</a> { <a name="l00172"></a><a class="code" href="structdtn_1_1MultiGraph_1_1DijkstraCompare.html#e68de8d579990ecd66e880630fc99ed7">00172</a> <span class="keywordtype">bool</span> <a class="code" href="structdtn_1_1MultiGraph_1_1DijkstraCompare.html#e68de8d579990ecd66e880630fc99ed7">operator()</a>(<span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* a, <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* b)<span class="keyword"> const </span>{ <a name="l00173"></a>00173 <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph.html#681a67ccaac7566e4f38ab36cf35d428" title="XXX/demmer this stupid helper function is needed because DijkstraCompare can&#39;t...">NodeDistance</a>(a) > <a class="code" href="classdtn_1_1MultiGraph.html#681a67ccaac7566e4f38ab36cf35d428" title="XXX/demmer this stupid helper function is needed because DijkstraCompare can&#39;t...">NodeDistance</a>(b); <a name="l00174"></a>00174 } <a name="l00175"></a>00175 }; <a name="l00176"></a>00176 <a name="l00178"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html">00178</a> <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html" title="The edge class.">Edge</a> { <a name="l00179"></a>00179 <span class="keyword">public</span>: <a name="l00181"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#71c7d2bb37705fa379d62bfbd19351bf">00181</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#71c7d2bb37705fa379d62bfbd19351bf" title="Constructor.">Edge</a>(<a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* s, <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* d, <span class="keyword">const</span> _EdgeInfo info) <a name="l00182"></a>00182 : <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#203ea93bb38d91f21fbb42d18753b78d">source_</a>(s), <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#550aa068ac76fa2524451fefcf6a35d9">dest_</a>(d), <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#e7eb483cc6b9ec503fc1f12878f73dee">info_</a>(info) {} <a name="l00183"></a>00183 <a name="l00185"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#e7b6567218472e0c1f8ec6303bd00a98">00185</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#e7b6567218472e0c1f8ec6303bd00a98" title="Destructor clears contents for debugging purposes.">~Edge</a>() { <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#203ea93bb38d91f21fbb42d18753b78d">source_</a> = NULL; <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#550aa068ac76fa2524451fefcf6a35d9">dest_</a> = NULL; } <a name="l00186"></a>00186 <a name="l00187"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#9a99f3a6ad30283abb402a51d2ea8a6b">00187</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#9a99f3a6ad30283abb402a51d2ea8a6b">source</a>() { <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#203ea93bb38d91f21fbb42d18753b78d">source_</a>; } <a name="l00188"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#ec26d95485cadbd6d36c6e9ae0fcf20b">00188</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#ec26d95485cadbd6d36c6e9ae0fcf20b">dest</a>() { <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#550aa068ac76fa2524451fefcf6a35d9">dest_</a>; } <a name="l00189"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#2be7ab0d5401e80890d6cc226ff95425">00189</a> <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#2be7ab0d5401e80890d6cc226ff95425">source</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#203ea93bb38d91f21fbb42d18753b78d">source_</a>; } <a name="l00190"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#672a6683417316c8c21602eb2fab4e71">00190</a> <span class="keyword">const</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#672a6683417316c8c21602eb2fab4e71">dest</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#550aa068ac76fa2524451fefcf6a35d9">dest_</a>; } <a name="l00191"></a>00191 <a name="l00192"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#efd6d3787aa42674f6e4454ef49b634b">00192</a> <span class="keyword">const</span> _EdgeInfo& <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#efd6d3787aa42674f6e4454ef49b634b">info</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#e7eb483cc6b9ec503fc1f12878f73dee">info_</a>; } <a name="l00193"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#7c906eee939e426198090e3d33146603">00193</a> _EdgeInfo& <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#7c906eee939e426198090e3d33146603">mutable_info</a>() { <span class="keywordflow">return</span> <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#e7eb483cc6b9ec503fc1f12878f73dee">info_</a>; } <a name="l00194"></a>00194 <a name="l00195"></a>00195 <span class="keyword">protected</span>: <a name="l00196"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#203ea93bb38d91f21fbb42d18753b78d">00196</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#203ea93bb38d91f21fbb42d18753b78d">source_</a>; <a name="l00197"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#550aa068ac76fa2524451fefcf6a35d9">00197</a> <a class="code" href="classdtn_1_1MultiGraph_1_1Node.html" title="The node class.">Node</a>* <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#550aa068ac76fa2524451fefcf6a35d9">dest_</a>; <a name="l00198"></a><a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#e7eb483cc6b9ec503fc1f12878f73dee">00198</a> _EdgeInfo <a class="code" href="classdtn_1_1MultiGraph_1_1Edge.html#e7eb483cc6b9ec503fc1f12878f73dee">info_</a>; <a name="l00199"></a>00199 }; <a name="l00200"></a>00200 <a name="l00201"></a><a class="code" href="classdtn_1_1MultiGraph.html#8da89fa48b9c6ef76cf3f700f2300115">00201</a> <span class="keyword">typedef</span> oasys::InlineFormatter<_EdgeInfo> <a class="code" href="classdtn_1_1MultiGraph.html#8da89fa48b9c6ef76cf3f700f2300115">EdgeFormatter</a>; <a name="l00202"></a>00202 <a name="l00204"></a><a class="code" href="classdtn_1_1MultiGraph_1_1NodeVector.html">00204</a> <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1NodeVector.html" title="Helper data structure for a vector of nodes.">NodeVector</a> : <span class="keyword">public</span> oasys::<a class="code" href="classoasys_1_1Formatter.html">Formatter</a>, <a name="l00205"></a>00205 <span class="keyword">public</span> std::<a class="code" href="classstd_1_1vector.html">vector</a><Node*> { <a name="l00206"></a>00206 <span class="keyword">public</span>: <a name="l00207"></a>00207 <span class="keywordtype">int</span> <a class="code" href="classdtn_1_1MultiGraph_1_1NodeVector.html#c7fdb2e7cc46c4ba6fef16152bb9ca18">format</a>(<span class="keywordtype">char</span>* buf, <span class="keywordtype">size_t</span> sz) <span class="keyword">const</span>; <a name="l00208"></a><a class="code" href="classdtn_1_1MultiGraph_1_1NodeVector.html#a8757931fb8e783c51ece22c3565d88d">00208</a> std::string <a class="code" href="classdtn_1_1MultiGraph_1_1NodeVector.html#a8757931fb8e783c51ece22c3565d88d">dump</a>()<span class="keyword"> const</span> <a name="l00209"></a>00209 <span class="keyword"> </span>{ <a name="l00210"></a>00210 <span class="keywordtype">char</span> buf[1024]; <a name="l00211"></a>00211 <span class="keywordtype">int</span> <a class="code" href="num2sdnv_8c.html#fed088663f8704004425cdae2120b9b3">len</a> = <a class="code" href="classdtn_1_1MultiGraph_1_1NodeVector.html#c7fdb2e7cc46c4ba6fef16152bb9ca18">format</a>(buf, <span class="keyword">sizeof</span>(buf)); <a name="l00212"></a>00212 <span class="keywordflow">return</span> std::string(buf, len); <a name="l00213"></a>00213 } <a name="l00214"></a>00214 }; <a name="l00215"></a>00215 <a name="l00217"></a><a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html">00217</a> <span class="keyword">class </span><a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html" title="Helper data structure for a vector of edges.">EdgeVector</a> : <span class="keyword">public</span> oasys::<a class="code" href="classoasys_1_1Formatter.html">Formatter</a>, <a name="l00218"></a>00218 <span class="keyword">public</span> std::<a class="code" href="classstd_1_1vector.html">vector</a><Edge*> { <a name="l00219"></a>00219 <span class="keyword">public</span>: <a name="l00220"></a>00220 <span class="keywordtype">int</span> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html#14ec5b653a3d660379a6dd82a5d221be">format</a>(<span class="keywordtype">char</span>* buf, <span class="keywordtype">size_t</span> sz) <span class="keyword">const</span>; <a name="l00221"></a>00221 <span class="keywordtype">void</span> <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html#28ec167089cb3629cbc12fdb88908318">debug_format</a>(oasys::StringBuffer* buf) <span class="keyword">const</span>; <a name="l00222"></a><a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html#25e01354c834e2205066cee489342420">00222</a> std::string <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html#25e01354c834e2205066cee489342420">dump</a>()<span class="keyword"> const</span> <a name="l00223"></a>00223 <span class="keyword"> </span>{ <a name="l00224"></a>00224 <span class="keywordtype">char</span> buf[1024]; <a name="l00225"></a>00225 <span class="keywordtype">int</span> <a class="code" href="num2sdnv_8c.html#fed088663f8704004425cdae2120b9b3">len</a> = <a class="code" href="classdtn_1_1MultiGraph_1_1EdgeVector.html#14ec5b653a3d660379a6dd82a5d221be">format</a>(buf, <span class="keyword">sizeof</span>(buf)); <a name="l00226"></a>00226 <span class="keywordflow">return</span> std::string(buf, len); <a name="l00227"></a>00227 } <a name="l00228"></a>00228 }; <a name="l00229"></a>00229 <a name="l00230"></a>00230 <span class="keyword">protected</span>: <a name="l00233"></a>00233 <span class="keywordtype">bool</span> <a class="code" href="classdtn_1_1MultiGraph.html#634989e9fdaa33497ebd44bf3dcb2f95" title="Helper function to follow the prev_ links that result from a Dijkstra search from...">get_reverse_path</a>(<span class="keyword">const</span> Node* a, <span class="keyword">const</span> Node* b, EdgeVector* path); <a name="l00234"></a>00234 <a name="l00236"></a><a class="code" href="classdtn_1_1MultiGraph.html#a195b6b49cc23c6af28dd923260b0641">00236</a> NodeVector <a class="code" href="classdtn_1_1MultiGraph.html#a195b6b49cc23c6af28dd923260b0641" title="The vector of all nodes.">nodes_</a>; <a name="l00237"></a>00237 }; <a name="l00238"></a>00238 <a name="l00239"></a>00239 } <span class="comment">// namespace dtn</span> <a name="l00240"></a>00240 <a name="l00241"></a>00241 <span class="preprocessor">#include "MultiGraph.tcc"</span> <a name="l00242"></a>00242 <a name="l00243"></a>00243 <span class="preprocessor">#endif </span><span class="comment">/* _MULTIGRAPH_H_ */</span> </pre></div></div> <hr size="1"><address style="text-align: right;"><small>Generated on Fri Jan 30 09:26:57 2009 for DTN Reference Implementation by <a href="http://www.doxygen.org/index.html"> <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.8 </small></address> </body> </html>