... |
... |
@@ -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
|