| ... |
... |
@@ -43,197 +43,197 @@
|
| 43 |
43 |
typedef Base Parent;
|
| 44 |
44 |
typedef DigraphExtender Digraph;
|
| 45 |
45 |
|
| 46 |
46 |
// Base extensions
|
| 47 |
47 |
|
| 48 |
48 |
typedef typename Parent::Node Node;
|
| 49 |
49 |
typedef typename Parent::Arc Arc;
|
| 50 |
50 |
|
| 51 |
51 |
int maxId(Node) const {
|
| 52 |
52 |
return Parent::maxNodeId();
|
| 53 |
53 |
}
|
| 54 |
54 |
|
| 55 |
55 |
int maxId(Arc) const {
|
| 56 |
56 |
return Parent::maxArcId();
|
| 57 |
57 |
}
|
| 58 |
58 |
|
| 59 |
59 |
Node fromId(int id, Node) const {
|
| 60 |
60 |
return Parent::nodeFromId(id);
|
| 61 |
61 |
}
|
| 62 |
62 |
|
| 63 |
63 |
Arc fromId(int id, Arc) const {
|
| 64 |
64 |
return Parent::arcFromId(id);
|
| 65 |
65 |
}
|
| 66 |
66 |
|
| 67 |
|
Node oppositeNode(const Node &n, const Arc &e) const {
|
| 68 |
|
if (n == Parent::source(e))
|
| 69 |
|
return Parent::target(e);
|
| 70 |
|
else if(n==Parent::target(e))
|
| 71 |
|
return Parent::source(e);
|
|
67 |
Node oppositeNode(const Node &node, const Arc &arc) const {
|
|
68 |
if (node == Parent::source(arc))
|
|
69 |
return Parent::target(arc);
|
|
70 |
else if(node == Parent::target(arc))
|
|
71 |
return Parent::source(arc);
|
| 72 |
72 |
else
|
| 73 |
73 |
return INVALID;
|
| 74 |
74 |
}
|
| 75 |
75 |
|
| 76 |
76 |
// Alterable extension
|
| 77 |
77 |
|
| 78 |
78 |
typedef AlterationNotifier<DigraphExtender, Node> NodeNotifier;
|
| 79 |
79 |
typedef AlterationNotifier<DigraphExtender, Arc> ArcNotifier;
|
| 80 |
80 |
|
| 81 |
81 |
|
| 82 |
82 |
protected:
|
| 83 |
83 |
|
| 84 |
84 |
mutable NodeNotifier node_notifier;
|
| 85 |
85 |
mutable ArcNotifier arc_notifier;
|
| 86 |
86 |
|
| 87 |
87 |
public:
|
| 88 |
88 |
|
| 89 |
89 |
NodeNotifier& notifier(Node) const {
|
| 90 |
90 |
return node_notifier;
|
| 91 |
91 |
}
|
| 92 |
92 |
|
| 93 |
93 |
ArcNotifier& notifier(Arc) const {
|
| 94 |
94 |
return arc_notifier;
|
| 95 |
95 |
}
|
| 96 |
96 |
|
| 97 |
97 |
class NodeIt : public Node {
|
| 98 |
|
const Digraph* digraph;
|
|
98 |
const Digraph* _digraph;
|
| 99 |
99 |
public:
|
| 100 |
100 |
|
| 101 |
101 |
NodeIt() {}
|
| 102 |
102 |
|
| 103 |
103 |
NodeIt(Invalid i) : Node(i) { }
|
| 104 |
104 |
|
| 105 |
|
explicit NodeIt(const Digraph& _digraph) : digraph(&_digraph) {
|
| 106 |
|
_digraph.first(static_cast<Node&>(*this));
|
|
105 |
explicit NodeIt(const Digraph& digraph) : _digraph(&digraph) {
|
|
106 |
_digraph->first(static_cast<Node&>(*this));
|
| 107 |
107 |
}
|
| 108 |
108 |
|
| 109 |
|
NodeIt(const Digraph& _digraph, const Node& node)
|
| 110 |
|
: Node(node), digraph(&_digraph) {}
|
|
109 |
NodeIt(const Digraph& digraph, const Node& node)
|
|
110 |
: Node(node), _digraph(&digraph) {}
|
| 111 |
111 |
|
| 112 |
112 |
NodeIt& operator++() {
|
| 113 |
|
digraph->next(*this);
|
|
113 |
_digraph->next(*this);
|
| 114 |
114 |
return *this;
|
| 115 |
115 |
}
|
| 116 |
116 |
|
| 117 |
117 |
};
|
| 118 |
118 |
|
| 119 |
119 |
|
| 120 |
120 |
class ArcIt : public Arc {
|
| 121 |
|
const Digraph* digraph;
|
|
121 |
const Digraph* _digraph;
|
| 122 |
122 |
public:
|
| 123 |
123 |
|
| 124 |
124 |
ArcIt() { }
|
| 125 |
125 |
|
| 126 |
126 |
ArcIt(Invalid i) : Arc(i) { }
|
| 127 |
127 |
|
| 128 |
|
explicit ArcIt(const Digraph& _digraph) : digraph(&_digraph) {
|
| 129 |
|
_digraph.first(static_cast<Arc&>(*this));
|
|
128 |
explicit ArcIt(const Digraph& digraph) : _digraph(&digraph) {
|
|
129 |
_digraph->first(static_cast<Arc&>(*this));
|
| 130 |
130 |
}
|
| 131 |
131 |
|
| 132 |
|
ArcIt(const Digraph& _digraph, const Arc& e) :
|
| 133 |
|
Arc(e), digraph(&_digraph) { }
|
|
132 |
ArcIt(const Digraph& digraph, const Arc& arc) :
|
|
133 |
Arc(arc), _digraph(&digraph) { }
|
| 134 |
134 |
|
| 135 |
135 |
ArcIt& operator++() {
|
| 136 |
|
digraph->next(*this);
|
|
136 |
_digraph->next(*this);
|
| 137 |
137 |
return *this;
|
| 138 |
138 |
}
|
| 139 |
139 |
|
| 140 |
140 |
};
|
| 141 |
141 |
|
| 142 |
142 |
|
| 143 |
143 |
class OutArcIt : public Arc {
|
| 144 |
|
const Digraph* digraph;
|
|
144 |
const Digraph* _digraph;
|
| 145 |
145 |
public:
|
| 146 |
146 |
|
| 147 |
147 |
OutArcIt() { }
|
| 148 |
148 |
|
| 149 |
149 |
OutArcIt(Invalid i) : Arc(i) { }
|
| 150 |
150 |
|
| 151 |
|
OutArcIt(const Digraph& _digraph, const Node& node)
|
| 152 |
|
: digraph(&_digraph) {
|
| 153 |
|
_digraph.firstOut(*this, node);
|
|
151 |
OutArcIt(const Digraph& digraph, const Node& node)
|
|
152 |
: _digraph(&digraph) {
|
|
153 |
_digraph->firstOut(*this, node);
|
| 154 |
154 |
}
|
| 155 |
155 |
|
| 156 |
|
OutArcIt(const Digraph& _digraph, const Arc& arc)
|
| 157 |
|
: Arc(arc), digraph(&_digraph) {}
|
|
156 |
OutArcIt(const Digraph& digraph, const Arc& arc)
|
|
157 |
: Arc(arc), _digraph(&digraph) {}
|
| 158 |
158 |
|
| 159 |
159 |
OutArcIt& operator++() {
|
| 160 |
|
digraph->nextOut(*this);
|
|
160 |
_digraph->nextOut(*this);
|
| 161 |
161 |
return *this;
|
| 162 |
162 |
}
|
| 163 |
163 |
|
| 164 |
164 |
};
|
| 165 |
165 |
|
| 166 |
166 |
|
| 167 |
167 |
class InArcIt : public Arc {
|
| 168 |
|
const Digraph* digraph;
|
|
168 |
const Digraph* _digraph;
|
| 169 |
169 |
public:
|
| 170 |
170 |
|
| 171 |
171 |
InArcIt() { }
|
| 172 |
172 |
|
| 173 |
173 |
InArcIt(Invalid i) : Arc(i) { }
|
| 174 |
174 |
|
| 175 |
|
InArcIt(const Digraph& _digraph, const Node& node)
|
| 176 |
|
: digraph(&_digraph) {
|
| 177 |
|
_digraph.firstIn(*this, node);
|
|
175 |
InArcIt(const Digraph& digraph, const Node& node)
|
|
176 |
: _digraph(&digraph) {
|
|
177 |
_digraph->firstIn(*this, node);
|
| 178 |
178 |
}
|
| 179 |
179 |
|
| 180 |
|
InArcIt(const Digraph& _digraph, const Arc& arc) :
|
| 181 |
|
Arc(arc), digraph(&_digraph) {}
|
|
180 |
InArcIt(const Digraph& digraph, const Arc& arc) :
|
|
181 |
Arc(arc), _digraph(&digraph) {}
|
| 182 |
182 |
|
| 183 |
183 |
InArcIt& operator++() {
|
| 184 |
|
digraph->nextIn(*this);
|
|
184 |
_digraph->nextIn(*this);
|
| 185 |
185 |
return *this;
|
| 186 |
186 |
}
|
| 187 |
187 |
|
| 188 |
188 |
};
|
| 189 |
189 |
|
| 190 |
190 |
/// \brief Base node of the iterator
|
| 191 |
191 |
///
|
| 192 |
192 |
/// Returns the base node (i.e. the source in this case) of the iterator
|
| 193 |
|
Node baseNode(const OutArcIt &e) const {
|
| 194 |
|
return Parent::source(e);
|
|
193 |
Node baseNode(const OutArcIt &arc) const {
|
|
194 |
return Parent::source(arc);
|
| 195 |
195 |
}
|
| 196 |
196 |
/// \brief Running node of the iterator
|
| 197 |
197 |
///
|
| 198 |
198 |
/// Returns the running node (i.e. the target in this case) of the
|
| 199 |
199 |
/// iterator
|
| 200 |
|
Node runningNode(const OutArcIt &e) const {
|
| 201 |
|
return Parent::target(e);
|
|
200 |
Node runningNode(const OutArcIt &arc) const {
|
|
201 |
return Parent::target(arc);
|
| 202 |
202 |
}
|
| 203 |
203 |
|
| 204 |
204 |
/// \brief Base node of the iterator
|
| 205 |
205 |
///
|
| 206 |
206 |
/// Returns the base node (i.e. the target in this case) of the iterator
|
| 207 |
|
Node baseNode(const InArcIt &e) const {
|
| 208 |
|
return Parent::target(e);
|
|
207 |
Node baseNode(const InArcIt &arc) const {
|
|
208 |
return Parent::target(arc);
|
| 209 |
209 |
}
|
| 210 |
210 |
/// \brief Running node of the iterator
|
| 211 |
211 |
///
|
| 212 |
212 |
/// Returns the running node (i.e. the source in this case) of the
|
| 213 |
213 |
/// iterator
|
| 214 |
|
Node runningNode(const InArcIt &e) const {
|
| 215 |
|
return Parent::source(e);
|
|
214 |
Node runningNode(const InArcIt &arc) const {
|
|
215 |
return Parent::source(arc);
|
| 216 |
216 |
}
|
| 217 |
217 |
|
| 218 |
218 |
|
| 219 |
219 |
template <typename _Value>
|
| 220 |
220 |
class NodeMap
|
| 221 |
221 |
: public MapExtender<DefaultMap<Digraph, Node, _Value> > {
|
| 222 |
222 |
public:
|
| 223 |
223 |
typedef DigraphExtender Digraph;
|
| 224 |
224 |
typedef MapExtender<DefaultMap<Digraph, Node, _Value> > Parent;
|
| 225 |
225 |
|
| 226 |
226 |
explicit NodeMap(const Digraph& digraph)
|
| 227 |
227 |
: Parent(digraph) {}
|
| 228 |
228 |
NodeMap(const Digraph& digraph, const _Value& value)
|
| 229 |
229 |
: Parent(digraph, value) {}
|
| 230 |
230 |
|
| 231 |
231 |
NodeMap& operator=(const NodeMap& cmap) {
|
| 232 |
232 |
return operator=<NodeMap>(cmap);
|
| 233 |
233 |
}
|
| 234 |
234 |
|
| 235 |
235 |
template <typename CMap>
|
| 236 |
236 |
NodeMap& operator=(const CMap& cmap) {
|
| 237 |
237 |
Parent::operator=(cmap);
|
| 238 |
238 |
return *this;
|
| 239 |
239 |
}
|
| ... |
... |
@@ -303,448 +303,448 @@
|
| 303 |
303 |
Parent::firstIn(arc, node);
|
| 304 |
304 |
}
|
| 305 |
305 |
|
| 306 |
306 |
notifier(Node()).erase(node);
|
| 307 |
307 |
Parent::erase(node);
|
| 308 |
308 |
}
|
| 309 |
309 |
|
| 310 |
310 |
void erase(const Arc& arc) {
|
| 311 |
311 |
notifier(Arc()).erase(arc);
|
| 312 |
312 |
Parent::erase(arc);
|
| 313 |
313 |
}
|
| 314 |
314 |
|
| 315 |
315 |
DigraphExtender() {
|
| 316 |
316 |
node_notifier.setContainer(*this);
|
| 317 |
317 |
arc_notifier.setContainer(*this);
|
| 318 |
318 |
}
|
| 319 |
319 |
|
| 320 |
320 |
|
| 321 |
321 |
~DigraphExtender() {
|
| 322 |
322 |
arc_notifier.clear();
|
| 323 |
323 |
node_notifier.clear();
|
| 324 |
324 |
}
|
| 325 |
325 |
};
|
| 326 |
326 |
|
| 327 |
|
/// \ingroup graphbits
|
|
327 |
/// \ingroup _graphbits
|
| 328 |
328 |
///
|
| 329 |
329 |
/// \brief Extender for the Graphs
|
| 330 |
330 |
template <typename Base>
|
| 331 |
331 |
class GraphExtender : public Base {
|
| 332 |
332 |
public:
|
| 333 |
333 |
|
| 334 |
334 |
typedef Base Parent;
|
| 335 |
|
typedef GraphExtender Digraph;
|
|
335 |
typedef GraphExtender Graph;
|
| 336 |
336 |
|
| 337 |
337 |
typedef True UndirectedTag;
|
| 338 |
338 |
|
| 339 |
339 |
typedef typename Parent::Node Node;
|
| 340 |
340 |
typedef typename Parent::Arc Arc;
|
| 341 |
341 |
typedef typename Parent::Edge Edge;
|
| 342 |
342 |
|
| 343 |
343 |
// Graph extension
|
| 344 |
344 |
|
| 345 |
345 |
int maxId(Node) const {
|
| 346 |
346 |
return Parent::maxNodeId();
|
| 347 |
347 |
}
|
| 348 |
348 |
|
| 349 |
349 |
int maxId(Arc) const {
|
| 350 |
350 |
return Parent::maxArcId();
|
| 351 |
351 |
}
|
| 352 |
352 |
|
| 353 |
353 |
int maxId(Edge) const {
|
| 354 |
354 |
return Parent::maxEdgeId();
|
| 355 |
355 |
}
|
| 356 |
356 |
|
| 357 |
357 |
Node fromId(int id, Node) const {
|
| 358 |
358 |
return Parent::nodeFromId(id);
|
| 359 |
359 |
}
|
| 360 |
360 |
|
| 361 |
361 |
Arc fromId(int id, Arc) const {
|
| 362 |
362 |
return Parent::arcFromId(id);
|
| 363 |
363 |
}
|
| 364 |
364 |
|
| 365 |
365 |
Edge fromId(int id, Edge) const {
|
| 366 |
366 |
return Parent::edgeFromId(id);
|
| 367 |
367 |
}
|
| 368 |
368 |
|
| 369 |
369 |
Node oppositeNode(const Node &n, const Edge &e) const {
|
| 370 |
370 |
if( n == Parent::source(e))
|
| 371 |
371 |
return Parent::target(e);
|
| 372 |
372 |
else if( n == Parent::target(e))
|
| 373 |
373 |
return Parent::source(e);
|
| 374 |
374 |
else
|
| 375 |
375 |
return INVALID;
|
| 376 |
376 |
}
|
| 377 |
377 |
|
| 378 |
|
Arc oppositeArc(const Arc &e) const {
|
| 379 |
|
return Parent::direct(e, !Parent::direction(e));
|
|
378 |
Arc oppositeArc(const Arc &arc) const {
|
|
379 |
return Parent::direct(arc, !Parent::direction(arc));
|
| 380 |
380 |
}
|
| 381 |
381 |
|
| 382 |
382 |
using Parent::direct;
|
| 383 |
|
Arc direct(const Edge &ue, const Node &s) const {
|
| 384 |
|
return Parent::direct(ue, Parent::source(ue) == s);
|
|
383 |
Arc direct(const Edge &edge, const Node &node) const {
|
|
384 |
return Parent::direct(edge, Parent::source(edge) == node);
|
| 385 |
385 |
}
|
| 386 |
386 |
|
| 387 |
387 |
// Alterable extension
|
| 388 |
388 |
|
| 389 |
389 |
typedef AlterationNotifier<GraphExtender, Node> NodeNotifier;
|
| 390 |
390 |
typedef AlterationNotifier<GraphExtender, Arc> ArcNotifier;
|
| 391 |
391 |
typedef AlterationNotifier<GraphExtender, Edge> EdgeNotifier;
|
| 392 |
392 |
|
| 393 |
393 |
|
| 394 |
394 |
protected:
|
| 395 |
395 |
|
| 396 |
396 |
mutable NodeNotifier node_notifier;
|
| 397 |
397 |
mutable ArcNotifier arc_notifier;
|
| 398 |
398 |
mutable EdgeNotifier edge_notifier;
|
| 399 |
399 |
|
| 400 |
400 |
public:
|
| 401 |
401 |
|
| 402 |
402 |
NodeNotifier& notifier(Node) const {
|
| 403 |
403 |
return node_notifier;
|
| 404 |
404 |
}
|
| 405 |
405 |
|
| 406 |
406 |
ArcNotifier& notifier(Arc) const {
|
| 407 |
407 |
return arc_notifier;
|
| 408 |
408 |
}
|
| 409 |
409 |
|
| 410 |
410 |
EdgeNotifier& notifier(Edge) const {
|
| 411 |
411 |
return edge_notifier;
|
| 412 |
412 |
}
|
| 413 |
413 |
|
| 414 |
414 |
|
| 415 |
415 |
|
| 416 |
416 |
class NodeIt : public Node {
|
| 417 |
|
const Digraph* digraph;
|
|
417 |
const Graph* _graph;
|
| 418 |
418 |
public:
|
| 419 |
419 |
|
| 420 |
420 |
NodeIt() {}
|
| 421 |
421 |
|
| 422 |
422 |
NodeIt(Invalid i) : Node(i) { }
|
| 423 |
423 |
|
| 424 |
|
explicit NodeIt(const Digraph& _digraph) : digraph(&_digraph) {
|
| 425 |
|
_digraph.first(static_cast<Node&>(*this));
|
|
424 |
explicit NodeIt(const Graph& graph) : _graph(&graph) {
|
|
425 |
_graph->first(static_cast<Node&>(*this));
|
| 426 |
426 |
}
|
| 427 |
427 |
|
| 428 |
|
NodeIt(const Digraph& _digraph, const Node& node)
|
| 429 |
|
: Node(node), digraph(&_digraph) {}
|
|
428 |
NodeIt(const Graph& graph, const Node& node)
|
|
429 |
: Node(node), _graph(&graph) {}
|
| 430 |
430 |
|
| 431 |
431 |
NodeIt& operator++() {
|
| 432 |
|
digraph->next(*this);
|
|
432 |
_graph->next(*this);
|
| 433 |
433 |
return *this;
|
| 434 |
434 |
}
|
| 435 |
435 |
|
| 436 |
436 |
};
|
| 437 |
437 |
|
| 438 |
438 |
|
| 439 |
439 |
class ArcIt : public Arc {
|
| 440 |
|
const Digraph* digraph;
|
|
440 |
const Graph* _graph;
|
| 441 |
441 |
public:
|
| 442 |
442 |
|
| 443 |
443 |
ArcIt() { }
|
| 444 |
444 |
|
| 445 |
445 |
ArcIt(Invalid i) : Arc(i) { }
|
| 446 |
446 |
|
| 447 |
|
explicit ArcIt(const Digraph& _digraph) : digraph(&_digraph) {
|
| 448 |
|
_digraph.first(static_cast<Arc&>(*this));
|
|
447 |
explicit ArcIt(const Graph& graph) : _graph(&graph) {
|
|
448 |
_graph->first(static_cast<Arc&>(*this));
|
| 449 |
449 |
}
|
| 450 |
450 |
|
| 451 |
|
ArcIt(const Digraph& _digraph, const Arc& e) :
|
| 452 |
|
Arc(e), digraph(&_digraph) { }
|
|
451 |
ArcIt(const Graph& graph, const Arc& arc) :
|
|
452 |
Arc(arc), _graph(&graph) { }
|
| 453 |
453 |
|
| 454 |
454 |
ArcIt& operator++() {
|
| 455 |
|
digraph->next(*this);
|
|
455 |
_graph->next(*this);
|
| 456 |
456 |
return *this;
|
| 457 |
457 |
}
|
| 458 |
458 |
|
| 459 |
459 |
};
|
| 460 |
460 |
|
| 461 |
461 |
|
| 462 |
462 |
class OutArcIt : public Arc {
|
| 463 |
|
const Digraph* digraph;
|
|
463 |
const Graph* _graph;
|
| 464 |
464 |
public:
|
| 465 |
465 |
|
| 466 |
466 |
OutArcIt() { }
|
| 467 |
467 |
|
| 468 |
468 |
OutArcIt(Invalid i) : Arc(i) { }
|
| 469 |
469 |
|
| 470 |
|
OutArcIt(const Digraph& _digraph, const Node& node)
|
| 471 |
|
: digraph(&_digraph) {
|
| 472 |
|
_digraph.firstOut(*this, node);
|
|
470 |
OutArcIt(const Graph& graph, const Node& node)
|
|
471 |
: _graph(&graph) {
|
|
472 |
_graph->firstOut(*this, node);
|
| 473 |
473 |
}
|
| 474 |
474 |
|
| 475 |
|
OutArcIt(const Digraph& _digraph, const Arc& arc)
|
| 476 |
|
: Arc(arc), digraph(&_digraph) {}
|
|
475 |
OutArcIt(const Graph& graph, const Arc& arc)
|
|
476 |
: Arc(arc), _graph(&graph) {}
|
| 477 |
477 |
|
| 478 |
478 |
OutArcIt& operator++() {
|
| 479 |
|
digraph->nextOut(*this);
|
|
479 |
_graph->nextOut(*this);
|
| 480 |
480 |
return *this;
|
| 481 |
481 |
}
|
| 482 |
482 |
|
| 483 |
483 |
};
|
| 484 |
484 |
|
| 485 |
485 |
|
| 486 |
486 |
class InArcIt : public Arc {
|
| 487 |
|
const Digraph* digraph;
|
|
487 |
const Graph* _graph;
|
| 488 |
488 |
public:
|
| 489 |
489 |
|
| 490 |
490 |
InArcIt() { }
|
| 491 |
491 |
|
| 492 |
492 |
InArcIt(Invalid i) : Arc(i) { }
|
| 493 |
493 |
|
| 494 |
|
InArcIt(const Digraph& _digraph, const Node& node)
|
| 495 |
|
: digraph(&_digraph) {
|
| 496 |
|
_digraph.firstIn(*this, node);
|
|
494 |
InArcIt(const Graph& graph, const Node& node)
|
|
495 |
: _graph(&graph) {
|
|
496 |
_graph->firstIn(*this, node);
|
| 497 |
497 |
}
|
| 498 |
498 |
|
| 499 |
|
InArcIt(const Digraph& _digraph, const Arc& arc) :
|
| 500 |
|
Arc(arc), digraph(&_digraph) {}
|
|
499 |
InArcIt(const Graph& graph, const Arc& arc) :
|
|
500 |
Arc(arc), _graph(&graph) {}
|
| 501 |
501 |
|
| 502 |
502 |
InArcIt& operator++() {
|
| 503 |
|
digraph->nextIn(*this);
|
|
503 |
_graph->nextIn(*this);
|
| 504 |
504 |
return *this;
|
| 505 |
505 |
}
|
| 506 |
506 |
|
| 507 |
507 |
};
|
| 508 |
508 |
|
| 509 |
509 |
|
| 510 |
510 |
class EdgeIt : public Parent::Edge {
|
| 511 |
|
const Digraph* digraph;
|
|
511 |
const Graph* _graph;
|
| 512 |
512 |
public:
|
| 513 |
513 |
|
| 514 |
514 |
EdgeIt() { }
|
| 515 |
515 |
|
| 516 |
516 |
EdgeIt(Invalid i) : Edge(i) { }
|
| 517 |
517 |
|
| 518 |
|
explicit EdgeIt(const Digraph& _digraph) : digraph(&_digraph) {
|
| 519 |
|
_digraph.first(static_cast<Edge&>(*this));
|
|
518 |
explicit EdgeIt(const Graph& graph) : _graph(&graph) {
|
|
519 |
_graph->first(static_cast<Edge&>(*this));
|
| 520 |
520 |
}
|
| 521 |
521 |
|
| 522 |
|
EdgeIt(const Digraph& _digraph, const Edge& e) :
|
| 523 |
|
Edge(e), digraph(&_digraph) { }
|
|
522 |
EdgeIt(const Graph& graph, const Edge& edge) :
|
|
523 |
Edge(edge), _graph(&graph) { }
|
| 524 |
524 |
|
| 525 |
525 |
EdgeIt& operator++() {
|
| 526 |
|
digraph->next(*this);
|
|
526 |
_graph->next(*this);
|
| 527 |
527 |
return *this;
|
| 528 |
528 |
}
|
| 529 |
529 |
|
| 530 |
530 |
};
|
| 531 |
531 |
|
| 532 |
|
class IncArcIt : public Parent::Edge {
|
|
532 |
class IncEdgeIt : public Parent::Edge {
|
| 533 |
533 |
friend class GraphExtender;
|
| 534 |
|
const Digraph* digraph;
|
| 535 |
|
bool direction;
|
|
534 |
const Graph* _graph;
|
|
535 |
bool _direction;
|
| 536 |
536 |
public:
|
| 537 |
537 |
|
| 538 |
|
IncArcIt() { }
|
|
538 |
IncEdgeIt() { }
|
| 539 |
539 |
|
| 540 |
|
IncArcIt(Invalid i) : Edge(i), direction(false) { }
|
|
540 |
IncEdgeIt(Invalid i) : Edge(i), _direction(false) { }
|
| 541 |
541 |
|
| 542 |
|
IncArcIt(const Digraph& _digraph, const Node &n) : digraph(&_digraph) {
|
| 543 |
|
_digraph.firstInc(*this, direction, n);
|
|
542 |
IncEdgeIt(const Graph& graph, const Node &node) : _graph(&graph) {
|
|
543 |
_graph->firstInc(*this, _direction, node);
|
| 544 |
544 |
}
|
| 545 |
545 |
|
| 546 |
|
IncArcIt(const Digraph& _digraph, const Edge &ue, const Node &n)
|
| 547 |
|
: digraph(&_digraph), Edge(ue) {
|
| 548 |
|
direction = (_digraph.source(ue) == n);
|
|
546 |
IncEdgeIt(const Graph& graph, const Edge &edge, const Node &node)
|
|
547 |
: _graph(&graph), Edge(edge) {
|
|
548 |
_direction = (_graph->source(edge) == node);
|
| 549 |
549 |
}
|
| 550 |
550 |
|
| 551 |
|
IncArcIt& operator++() {
|
| 552 |
|
digraph->nextInc(*this, direction);
|
|
551 |
IncEdgeIt& operator++() {
|
|
552 |
_graph->nextInc(*this, _direction);
|
| 553 |
553 |
return *this;
|
| 554 |
554 |
}
|
| 555 |
555 |
};
|
| 556 |
556 |
|
| 557 |
557 |
/// \brief Base node of the iterator
|
| 558 |
558 |
///
|
| 559 |
559 |
/// Returns the base node (ie. the source in this case) of the iterator
|
| 560 |
|
Node baseNode(const OutArcIt &e) const {
|
| 561 |
|
return Parent::source(static_cast<const Arc&>(e));
|
|
560 |
Node baseNode(const OutArcIt &arc) const {
|
|
561 |
return Parent::source(static_cast<const Arc&>(arc));
|
| 562 |
562 |
}
|
| 563 |
563 |
/// \brief Running node of the iterator
|
| 564 |
564 |
///
|
| 565 |
565 |
/// Returns the running node (ie. the target in this case) of the
|
| 566 |
566 |
/// iterator
|
| 567 |
|
Node runningNode(const OutArcIt &e) const {
|
| 568 |
|
return Parent::target(static_cast<const Arc&>(e));
|
|
567 |
Node runningNode(const OutArcIt &arc) const {
|
|
568 |
return Parent::target(static_cast<const Arc&>(arc));
|
| 569 |
569 |
}
|
| 570 |
570 |
|
| 571 |
571 |
/// \brief Base node of the iterator
|
| 572 |
572 |
///
|
| 573 |
573 |
/// Returns the base node (ie. the target in this case) of the iterator
|
| 574 |
|
Node baseNode(const InArcIt &e) const {
|
| 575 |
|
return Parent::target(static_cast<const Arc&>(e));
|
|
574 |
Node baseNode(const InArcIt &arc) const {
|
|
575 |
return Parent::target(static_cast<const Arc&>(arc));
|
| 576 |
576 |
}
|
| 577 |
577 |
/// \brief Running node of the iterator
|
| 578 |
578 |
///
|
| 579 |
579 |
/// Returns the running node (ie. the source in this case) of the
|
| 580 |
580 |
/// iterator
|
| 581 |
|
Node runningNode(const InArcIt &e) const {
|
| 582 |
|
return Parent::source(static_cast<const Arc&>(e));
|
|
581 |
Node runningNode(const InArcIt &arc) const {
|
|
582 |
return Parent::source(static_cast<const Arc&>(arc));
|
| 583 |
583 |
}
|
| 584 |
584 |
|
| 585 |
585 |
/// Base node of the iterator
|
| 586 |
586 |
///
|
| 587 |
587 |
/// Returns the base node of the iterator
|
| 588 |
|
Node baseNode(const IncArcIt &e) const {
|
| 589 |
|
return e.direction ? source(e) : target(e);
|
|
588 |
Node baseNode(const IncEdgeIt &edge) const {
|
|
589 |
return edge._direction ? source(edge) : target(edge);
|
| 590 |
590 |
}
|
| 591 |
591 |
/// Running node of the iterator
|
| 592 |
592 |
///
|
| 593 |
593 |
/// Returns the running node of the iterator
|
| 594 |
|
Node runningNode(const IncArcIt &e) const {
|
| 595 |
|
return e.direction ? target(e) : source(e);
|
|
594 |
Node runningNode(const IncEdgeIt &edge) const {
|
|
595 |
return edge._direction ? target(edge) : source(edge);
|
| 596 |
596 |
}
|
| 597 |
597 |
|
| 598 |
598 |
// Mappable extension
|
| 599 |
599 |
|
| 600 |
600 |
template <typename _Value>
|
| 601 |
601 |
class NodeMap
|
| 602 |
|
: public MapExtender<DefaultMap<Digraph, Node, _Value> > {
|
|
602 |
: public MapExtender<DefaultMap<Graph, Node, _Value> > {
|
| 603 |
603 |
public:
|
| 604 |
|
typedef GraphExtender Digraph;
|
| 605 |
|
typedef MapExtender<DefaultMap<Digraph, Node, _Value> > Parent;
|
|
604 |
typedef GraphExtender Graph;
|
|
605 |
typedef MapExtender<DefaultMap<Graph, Node, _Value> > Parent;
|
| 606 |
606 |
|
| 607 |
|
NodeMap(const Digraph& digraph)
|
| 608 |
|
: Parent(digraph) {}
|
| 609 |
|
NodeMap(const Digraph& digraph, const _Value& value)
|
| 610 |
|
: Parent(digraph, value) {}
|
|
607 |
NodeMap(const Graph& graph)
|
|
608 |
: Parent(graph) {}
|
|
609 |
NodeMap(const Graph& graph, const _Value& value)
|
|
610 |
: Parent(graph, value) {}
|
| 611 |
611 |
|
| 612 |
612 |
NodeMap& operator=(const NodeMap& cmap) {
|
| 613 |
613 |
return operator=<NodeMap>(cmap);
|
| 614 |
614 |
}
|
| 615 |
615 |
|
| 616 |
616 |
template <typename CMap>
|
| 617 |
617 |
NodeMap& operator=(const CMap& cmap) {
|
| 618 |
618 |
Parent::operator=(cmap);
|
| 619 |
619 |
return *this;
|
| 620 |
620 |
}
|
| 621 |
621 |
|
| 622 |
622 |
};
|
| 623 |
623 |
|
| 624 |
624 |
template <typename _Value>
|
| 625 |
625 |
class ArcMap
|
| 626 |
|
: public MapExtender<DefaultMap<Digraph, Arc, _Value> > {
|
|
626 |
: public MapExtender<DefaultMap<Graph, Arc, _Value> > {
|
| 627 |
627 |
public:
|
| 628 |
|
typedef GraphExtender Digraph;
|
| 629 |
|
typedef MapExtender<DefaultMap<Digraph, Arc, _Value> > Parent;
|
|
628 |
typedef GraphExtender Graph;
|
|
629 |
typedef MapExtender<DefaultMap<Graph, Arc, _Value> > Parent;
|
| 630 |
630 |
|
| 631 |
|
ArcMap(const Digraph& digraph)
|
| 632 |
|
: Parent(digraph) {}
|
| 633 |
|
ArcMap(const Digraph& digraph, const _Value& value)
|
| 634 |
|
: Parent(digraph, value) {}
|
|
631 |
ArcMap(const Graph& graph)
|
|
632 |
: Parent(graph) {}
|
|
633 |
ArcMap(const Graph& graph, const _Value& value)
|
|
634 |
: Parent(graph, value) {}
|
| 635 |
635 |
|
| 636 |
636 |
ArcMap& operator=(const ArcMap& cmap) {
|
| 637 |
637 |
return operator=<ArcMap>(cmap);
|
| 638 |
638 |
}
|
| 639 |
639 |
|
| 640 |
640 |
template <typename CMap>
|
| 641 |
641 |
ArcMap& operator=(const CMap& cmap) {
|
| 642 |
642 |
Parent::operator=(cmap);
|
| 643 |
643 |
return *this;
|
| 644 |
644 |
}
|
| 645 |
645 |
};
|
| 646 |
646 |
|
| 647 |
647 |
|
| 648 |
648 |
template <typename _Value>
|
| 649 |
649 |
class EdgeMap
|
| 650 |
|
: public MapExtender<DefaultMap<Digraph, Edge, _Value> > {
|
|
650 |
: public MapExtender<DefaultMap<Graph, Edge, _Value> > {
|
| 651 |
651 |
public:
|
| 652 |
|
typedef GraphExtender Digraph;
|
| 653 |
|
typedef MapExtender<DefaultMap<Digraph, Edge, _Value> > Parent;
|
|
652 |
typedef GraphExtender Graph;
|
|
653 |
typedef MapExtender<DefaultMap<Graph, Edge, _Value> > Parent;
|
| 654 |
654 |
|
| 655 |
|
EdgeMap(const Digraph& digraph)
|
| 656 |
|
: Parent(digraph) {}
|
|
655 |
EdgeMap(const Graph& graph)
|
|
656 |
: Parent(graph) {}
|
| 657 |
657 |
|
| 658 |
|
EdgeMap(const Digraph& digraph, const _Value& value)
|
| 659 |
|
: Parent(digraph, value) {}
|
|
658 |
EdgeMap(const Graph& graph, const _Value& value)
|
|
659 |
: Parent(graph, value) {}
|
| 660 |
660 |
|
| 661 |
661 |
EdgeMap& operator=(const EdgeMap& cmap) {
|
| 662 |
662 |
return operator=<EdgeMap>(cmap);
|
| 663 |
663 |
}
|
| 664 |
664 |
|
| 665 |
665 |
template <typename CMap>
|
| 666 |
666 |
EdgeMap& operator=(const CMap& cmap) {
|
| 667 |
667 |
Parent::operator=(cmap);
|
| 668 |
668 |
return *this;
|
| 669 |
669 |
}
|
| 670 |
670 |
|
| 671 |
671 |
};
|
| 672 |
672 |
|
| 673 |
673 |
// Alteration extension
|
| 674 |
674 |
|
| 675 |
675 |
Node addNode() {
|
| 676 |
676 |
Node node = Parent::addNode();
|
| 677 |
677 |
notifier(Node()).add(node);
|
| 678 |
678 |
return node;
|
| 679 |
679 |
}
|
| 680 |
680 |
|
| 681 |
681 |
Edge addEdge(const Node& from, const Node& to) {
|
| 682 |
682 |
Edge edge = Parent::addEdge(from, to);
|
| 683 |
683 |
notifier(Edge()).add(edge);
|
| 684 |
684 |
std::vector<Arc> ev;
|
| 685 |
685 |
ev.push_back(Parent::direct(edge, true));
|
| 686 |
686 |
ev.push_back(Parent::direct(edge, false));
|
| 687 |
687 |
notifier(Arc()).add(ev);
|
| 688 |
688 |
return edge;
|
| 689 |
689 |
}
|
| 690 |
690 |
|
| 691 |
691 |
void clear() {
|
| 692 |
692 |
notifier(Arc()).clear();
|
| 693 |
693 |
notifier(Edge()).clear();
|
| 694 |
694 |
notifier(Node()).clear();
|
| 695 |
695 |
Parent::clear();
|
| 696 |
696 |
}
|
| 697 |
697 |
|
| 698 |
|
template <typename Digraph, typename NodeRefMap, typename EdgeRefMap>
|
| 699 |
|
void build(const Digraph& digraph, NodeRefMap& nodeRef,
|
|
698 |
template <typename Graph, typename NodeRefMap, typename EdgeRefMap>
|
|
699 |
void build(const Graph& graph, NodeRefMap& nodeRef,
|
| 700 |
700 |
EdgeRefMap& edgeRef) {
|
| 701 |
|
Parent::build(digraph, nodeRef, edgeRef);
|
|
701 |
Parent::build(graph, nodeRef, edgeRef);
|
| 702 |
702 |
notifier(Node()).build();
|
| 703 |
703 |
notifier(Edge()).build();
|
| 704 |
704 |
notifier(Arc()).build();
|
| 705 |
705 |
}
|
| 706 |
706 |
|
| 707 |
707 |
void erase(const Node& node) {
|
| 708 |
708 |
Arc arc;
|
| 709 |
709 |
Parent::firstOut(arc, node);
|
| 710 |
710 |
while (arc != INVALID ) {
|
| 711 |
711 |
erase(arc);
|
| 712 |
712 |
Parent::firstOut(arc, node);
|
| 713 |
713 |
}
|
| 714 |
714 |
|
| 715 |
715 |
Parent::firstIn(arc, node);
|
| 716 |
716 |
while (arc != INVALID ) {
|
| 717 |
717 |
erase(arc);
|
| 718 |
718 |
Parent::firstIn(arc, node);
|
| 719 |
719 |
}
|
| 720 |
720 |
|
| 721 |
721 |
notifier(Node()).erase(node);
|
| 722 |
722 |
Parent::erase(node);
|
| 723 |
723 |
}
|
| 724 |
724 |
|
| 725 |
725 |
void erase(const Edge& edge) {
|
| 726 |
|
std::vector<Arc> ev;
|
| 727 |
|
ev.push_back(Parent::direct(edge, true));
|
| 728 |
|
ev.push_back(Parent::direct(edge, false));
|
| 729 |
|
notifier(Arc()).erase(ev);
|
|
726 |
std::vector<Arc> av;
|
|
727 |
av.push_back(Parent::direct(edge, true));
|
|
728 |
av.push_back(Parent::direct(edge, false));
|
|
729 |
notifier(Arc()).erase(av);
|
| 730 |
730 |
notifier(Edge()).erase(edge);
|
| 731 |
731 |
Parent::erase(edge);
|
| 732 |
732 |
}
|
| 733 |
733 |
|
| 734 |
734 |
GraphExtender() {
|
| 735 |
735 |
node_notifier.setContainer(*this);
|
| 736 |
736 |
arc_notifier.setContainer(*this);
|
| 737 |
737 |
edge_notifier.setContainer(*this);
|
| 738 |
738 |
}
|
| 739 |
739 |
|
| 740 |
740 |
~GraphExtender() {
|
| 741 |
741 |
edge_notifier.clear();
|
| 742 |
742 |
arc_notifier.clear();
|
| 743 |
743 |
node_notifier.clear();
|
| 744 |
744 |
}
|
| 745 |
745 |
|
| 746 |
746 |
};
|
| 747 |
747 |
|
| 748 |
748 |
}
|
| 749 |
749 |
|
| 750 |
750 |
#endif
|