blob: df08c73a1b6a177240c66f8ad41b927fa2860184 [file] [log] [blame]
Alexander Afanasyevad3757f2012-04-17 10:27:59 -07001/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
2/*
3 * Copyright (c) 2012 University of California, Los Angeles
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Author: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
19 */
20
21
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070022#ifndef BOOST_GRAPH_NDN_GLOBAL_ROUTING_HELPER_H
23#define BOOST_GRAPH_NDN_GLOBAL_ROUTING_HELPER_H
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070024
Alexander Afanasyev6315ef72012-06-01 20:56:31 -070025/// @cond include_hidden
26
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070027#include <boost/graph/graph_traits.hpp>
28#include <boost/graph/properties.hpp>
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -070029#include <boost/ref.hpp>
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070030
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070031#include "ns3/ndn-face.h"
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070032#include "ns3/node-list.h"
33#include "ns3/channel-list.h"
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070034#include "../model/ndn-global-router.h"
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070035#include <list>
36#include <map>
37
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070038namespace boost {
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070039
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070040class NdnGlobalRouterGraph
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070041{
42public:
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070043 typedef ns3::Ptr< ns3::ndn::GlobalRouter > Vertice;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070044 typedef uint16_t edge_property_type;
45 typedef uint32_t vertex_property_type;
46
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070047 NdnGlobalRouterGraph ()
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070048 {
49 for (ns3::NodeList::Iterator node = ns3::NodeList::Begin (); node != ns3::NodeList::End (); node++)
50 {
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070051 ns3::Ptr<ns3::ndn::GlobalRouter> gr = (*node)->GetObject<ns3::ndn::GlobalRouter> ();
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070052 if (gr != 0)
53 m_vertices.push_back (gr);
54 }
55
56 for (ns3::ChannelList::Iterator channel = ns3::ChannelList::Begin (); channel != ns3::ChannelList::End (); channel++)
57 {
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070058 ns3::Ptr<ns3::ndn::GlobalRouter> gr = (*channel)->GetObject<ns3::ndn::GlobalRouter> ();
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070059 if (gr != 0)
60 m_vertices.push_back (gr);
61 }
62 }
63
64 const std::list< Vertice > &
65 GetVertices () const
66 {
67 return m_vertices;
68 }
69
70public:
71 std::list< Vertice > m_vertices;
72};
73
74
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070075class ndn_global_router_graph_category :
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070076 public virtual vertex_list_graph_tag,
77 public virtual incidence_graph_tag
78{
79};
80
81
82template<>
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070083struct graph_traits< NdnGlobalRouterGraph >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070084{
85 // Graph concept
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070086 typedef NdnGlobalRouterGraph::Vertice vertex_descriptor;
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070087 typedef ns3::ndn::GlobalRouter::Incidency edge_descriptor;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070088 typedef directed_tag directed_category;
89 typedef disallow_parallel_edge_tag edge_parallel_category;
Alexander Afanasyev4aac5572012-08-09 10:49:55 -070090 typedef ndn_global_router_graph_category traversal_category;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070091
92 // VertexList concept
93 typedef std::list< vertex_descriptor >::const_iterator vertex_iterator;
94 typedef size_t vertices_size_type;
95
96 // AdjacencyGraph concept
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -070097 typedef ns3::ndn::GlobalRouter::IncidencyList::iterator out_edge_iterator;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -070098 typedef size_t degree_size_type;
99
100 // typedef size_t edges_size_type;
101};
102
103} // namespace boost
104
105namespace boost
106{
107
108inline
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700109graph_traits< NdnGlobalRouterGraph >::vertex_descriptor
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700110source(
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700111 graph_traits< NdnGlobalRouterGraph >::edge_descriptor e,
112 const NdnGlobalRouterGraph& g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700113{
114 return e.get<0> ();
115}
116
117inline
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700118graph_traits< NdnGlobalRouterGraph >::vertex_descriptor
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700119target(
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700120 graph_traits< NdnGlobalRouterGraph >::edge_descriptor e,
121 const NdnGlobalRouterGraph& g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700122{
123 return e.get<2> ();
124}
125
126inline
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700127std::pair< graph_traits< NdnGlobalRouterGraph >::vertex_iterator,
128 graph_traits< NdnGlobalRouterGraph >::vertex_iterator >
129vertices (const NdnGlobalRouterGraph&g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700130{
131 return make_pair (g.GetVertices ().begin (), g.GetVertices ().end ());
132}
133
134inline
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700135graph_traits< NdnGlobalRouterGraph >::vertices_size_type
136num_vertices(const NdnGlobalRouterGraph &g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700137{
138 return g.GetVertices ().size ();
139}
140
141
142inline
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700143std::pair< graph_traits< NdnGlobalRouterGraph >::out_edge_iterator,
144 graph_traits< NdnGlobalRouterGraph >::out_edge_iterator >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700145out_edges(
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700146 graph_traits< NdnGlobalRouterGraph >::vertex_descriptor u,
147 const NdnGlobalRouterGraph& g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700148{
149 return std::make_pair(u->GetIncidencies ().begin (),
150 u->GetIncidencies ().end ());
151}
152
153inline
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700154graph_traits< NdnGlobalRouterGraph >::degree_size_type
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700155out_degree(
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700156 graph_traits< NdnGlobalRouterGraph >::vertex_descriptor u,
157 const NdnGlobalRouterGraph& g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700158{
159 return u->GetIncidencies ().size ();
160}
161
162
163//////////////////////////////////////////////////////////////
164// Property maps
165
166struct EdgeWeights
167{
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700168 EdgeWeights (const NdnGlobalRouterGraph &graph)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700169 : m_graph (graph)
170 {
171 }
172
173private:
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700174 const NdnGlobalRouterGraph &m_graph;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700175};
176
177
178struct VertexIds
179{
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700180 VertexIds (const NdnGlobalRouterGraph &graph)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700181 : m_graph (graph)
182 {
183 }
184
185private:
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700186 const NdnGlobalRouterGraph &m_graph;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700187};
188
189template<>
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700190struct property_map< NdnGlobalRouterGraph, edge_weight_t >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700191{
192 typedef const EdgeWeights const_type;
193 typedef EdgeWeights type;
194};
195
196template<>
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700197struct property_map< NdnGlobalRouterGraph, vertex_index_t >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700198{
199 typedef const VertexIds const_type;
200 typedef VertexIds type;
201};
202
203
204template<>
205struct property_traits< EdgeWeights >
206{
207 // Metric property map
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700208 typedef tuple< ns3::Ptr<ns3::ndn::Face>, uint16_t > value_type;
209 typedef tuple< ns3::Ptr<ns3::ndn::Face>, uint16_t > reference;
210 typedef ns3::ndn::GlobalRouter::Incidency key_type;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700211 typedef readable_property_map_tag category;
212};
213
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700214const property_traits< EdgeWeights >::value_type WeightZero (0, 0);
215const property_traits< EdgeWeights >::value_type WeightInf (0, std::numeric_limits<uint16_t>::max ());
216
217struct WeightCompare :
218 public std::binary_function<property_traits< EdgeWeights >::reference,
219 property_traits< EdgeWeights >::reference,
220 bool>
221{
222 bool
223 operator () (property_traits< EdgeWeights >::reference a,
224 property_traits< EdgeWeights >::reference b) const
225 {
226 return a.get<1> () < b.get<1> ();
227 }
228
229 bool
230 operator () (property_traits< EdgeWeights >::reference a,
231 uint32_t b) const
232 {
233 return a.get<1> () < b;
234 }
235
236 bool
237 operator () (uint32_t a,
238 uint32_t b) const
239 {
240 return a < b;
241 }
242
243};
244
245struct WeightCombine :
246 public std::binary_function<uint32_t,
247 property_traits< EdgeWeights >::reference,
248 uint32_t>
249{
250 uint32_t
251 operator () (uint32_t a, property_traits< EdgeWeights >::reference b) const
252 {
253 return a + b.get<1> ();
254 }
255
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700256 tuple< ns3::Ptr<ns3::ndn::Face>, uint32_t >
257 operator () (tuple< ns3::Ptr<ns3::ndn::Face>, uint32_t > a,
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700258 property_traits< EdgeWeights >::reference b) const
259 {
260 if (a.get<0> () == 0)
261 return make_tuple (b.get<0> (), a.get<1> () + b.get<1> ());
262 else
263 return make_tuple (a.get<0> (), a.get<1> () + b.get<1> ());
264 }
265};
266
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700267template<>
268struct property_traits< VertexIds >
269{
270 // Metric property map
271 typedef uint32_t value_type;
272 typedef uint32_t reference;
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700273 typedef ns3::Ptr< ns3::ndn::GlobalRouter > key_type;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700274 typedef readable_property_map_tag category;
275};
276
277
278inline EdgeWeights
279get(edge_weight_t,
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700280 const NdnGlobalRouterGraph &g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700281{
282 return EdgeWeights (g);
283}
284
285
286inline VertexIds
287get(vertex_index_t,
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700288 const NdnGlobalRouterGraph &g)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700289{
290 return VertexIds (g);
291}
292
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700293template<class M, class K, class V>
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700294inline void
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700295put (reference_wrapper< M > mapp,
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700296 K a, V p)
297{
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700298 mapp.get ()[a] = p;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700299}
300
301// void
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700302// put (cref< std::map< ns3::Ptr<ns3::ndn::GlobalRouter>, ns3::Ptr<ns3::ndn::GlobalRouter> > > map,
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700303
304uint32_t
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700305get (const boost::VertexIds&, ns3::Ptr<ns3::ndn::GlobalRouter> &gr)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700306{
307 return gr->GetId ();
308}
309
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700310inline property_traits< EdgeWeights >::reference
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700311get(const boost::EdgeWeights&, ns3::ndn::GlobalRouter::Incidency &edge)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700312{
313 if (edge.get<1> () == 0)
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700314 return property_traits< EdgeWeights >::reference (0, 0);
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700315 else
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700316 return property_traits< EdgeWeights >::reference (edge.get<1> (), edge.get<1> ()->GetMetric ());
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700317}
318
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700319struct PredecessorsMap :
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700320 public std::map< ns3::Ptr< ns3::ndn::GlobalRouter >, ns3::Ptr< ns3::ndn::GlobalRouter > >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700321{
322};
323
324template<>
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700325struct property_traits< reference_wrapper<PredecessorsMap> >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700326{
327 // Metric property map
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700328 typedef ns3::Ptr< ns3::ndn::GlobalRouter > value_type;
329 typedef ns3::Ptr< ns3::ndn::GlobalRouter > reference;
330 typedef ns3::Ptr< ns3::ndn::GlobalRouter > key_type;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700331 typedef read_write_property_map_tag category;
332};
333
334
335struct DistancesMap :
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700336 public std::map< ns3::Ptr< ns3::ndn::GlobalRouter >, tuple< ns3::Ptr<ns3::ndn::Face>, uint32_t > >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700337{
338};
339
340template<>
Alexander Afanasyeva5abcd92012-04-17 13:34:43 -0700341struct property_traits< reference_wrapper<DistancesMap> >
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700342{
343 // Metric property map
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700344 typedef tuple< ns3::Ptr<ns3::ndn::Face>, uint32_t > value_type;
345 typedef tuple< ns3::Ptr<ns3::ndn::Face>, uint32_t > reference;
346 typedef ns3::Ptr< ns3::ndn::GlobalRouter > key_type;
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700347 typedef read_write_property_map_tag category;
348};
349
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700350inline tuple< ns3::Ptr<ns3::ndn::Face>, uint32_t >
351get (DistancesMap &map, ns3::Ptr<ns3::ndn::GlobalRouter> key)
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700352{
353 boost::DistancesMap::iterator i = map.find (key);
354 if (i == map.end ())
Alexander Afanasyev2b4c9472012-08-09 15:00:38 -0700355 return tuple< ns3::Ptr<ns3::ndn::Face>, uint32_t > (0, std::numeric_limits<uint32_t>::max ());
Alexander Afanasyevad3757f2012-04-17 10:27:59 -0700356 else
357 return i->second;
358}
359
360} // namespace boost
361
Alexander Afanasyev6315ef72012-06-01 20:56:31 -0700362/// @endcond
363
Alexander Afanasyev4aac5572012-08-09 10:49:55 -0700364#endif // BOOST_GRAPH_NDN_GLOBAL_ROUTING_HELPER_H