1Graph(3)              User Contributed Perl Documentation             Graph(3)
2
3
4

NAME

6       Graph - graph data structures and algorithms
7

SYNOPSIS

9               use Graph;
10               my $g0 = Graph->new;             # A directed graph.
11
12               use Graph::Directed;
13               my $g1 = Graph::Directed->new;   # A directed graph.
14
15               use Graph::Undirected;
16               my $g2 = Graph::Undirected->new; # An undirected graph.
17
18               $g->add_edge(...);
19               $g->has_edge(...)
20               $g->delete_edge(...);
21
22               $g->add_vertex(...);
23               $g->has_vertex(...);
24               $g->delete_vertex(...);
25
26               $g->vertices(...)
27               $g->edges(...)
28
29               # And many, many more, see below.
30

DESCRIPTION

32   Non-Description
33       This module is not for drawing or rendering any sort of graphics or
34       images, business, visualization, or otherwise.
35
36   Description
37       Instead, this module is for creating abstract data structures called
38       graphs, and for doing various operations on those.
39
40   Perl 5.6.0 minimum
41       The implementation depends on a Perl feature called "weak references"
42       and Perl 5.6.0 was the first to have those.
43
44   Constructors
45       new Create an empty graph.
46
47       Graph->new(%options)
48           The options are a hash with option names as the hash keys and the
49           option values as the hash values.
50
51           The following options are available:
52
53           directed
54                   A boolean option telling that a directed graph should be
55                   created.  Often somewhat redundant because a directed graph
56                   is the default for the Graph class or one could simply use
57                   the "new()" constructor of the Graph::Directed class.
58
59                   You can test the directness of a graph with
60                   $g->is_directed() and $g->is_undirected().
61
62           undirected
63                   A boolean option telling that an undirected graph should be
64                   created.  One could also use the "new()" constructor the
65                   Graph::Undirected class instead.
66
67                   Note that while often it is possible to think undirected
68                   graphs as bidirectional graphs, or as directed graphs with
69                   edges going both ways, in this module directed graphs and
70                   undirected graphs are two different things that often
71                   behave differently.
72
73                   You can test the directness of a graph with
74                   $g->is_directed() and $g->is_undirected().
75
76           refvertexed
77           refvertexed_stringified
78                   If you want to use references (including Perl objects) as
79                   vertices, use "refvertexed".
80
81                   Note that using "refvertexed" means that internally the
82                   memory address of the reference (for example, a Perl
83                   object) is used as the "identifier" of the vertex, not the
84                   stringified form of the reference, even if you have defined
85                   your own stringification using "overload".
86
87                   This avoids the problem of the stringified references
88                   potentially being identical (because they are identical in
89                   value, for example) even if the references are different.
90                   If you really want to use references and their stringified
91                   forms as the identities, use the "refvertexed_stringified".
92                   But please do not stringify different objects to the same
93                   stringified value.
94
95           unionfind
96                   If the graph is undirected, you can specify the "unionfind"
97                   parameter to use the so-called union-find scheme to speed
98                   up the computation of connected components of the graph
99                   (see "is_connected", "connected_components",
100                   "connected_component_by_vertex",
101                   "connected_component_by_index", and
102                   "same_connected_components").  If "unionfind" is used,
103                   adding edges (and vertices) becomes slower, but
104                   connectedness queries become faster.  You must not delete
105                   egdes or vertices of an unionfind graph, only add them.
106                   You can test a graph for "union-findness" with
107
108           has_union_find
109                   Returns true if the graph was created with a true
110                   "unionfind" parameter.
111
112           vertices
113                   An array reference of vertices to add.
114
115           edges   An array reference of array references of edge vertices to
116                   add.
117
118       copy
119       copy_graph
120               my $c = $g->copy_graph;
121
122           Create a shallow copy of the structure (vertices and edges) of the
123           graph.  If you want a deep copy that includes attributes, see
124           "deep_copy".  The copy will have the same directedness as the
125           original, and if the original was a "compat02" graph, the copy will
126           be, too.
127
128           Also the following vertex/edge attributes are copied:
129
130             refvertexed/hypervertexed/countvertexed/multivertexed
131             hyperedged/countedged/multiedged/omniedged
132
133           NOTE: You can get an even shallower copy of a graph by
134
135               my $c = $g->new;
136
137           This will copy only the graph properties (directed, and so forth),
138           but none of the vertices or edges.
139
140       deep_copy
141       deep_copy_graph
142               my $c = $g->deep_copy_graph;
143
144           Create a deep copy of the graph (vertices, edges, and attributes)
145           of the graph.  If you want a shallow copy that does not include
146           attributes, see "copy".
147
148           Note that copying code references only works with Perls 5.8 or
149           later, and even then only if B::Deparse can reconstruct your code.
150           This functionality uses either Storable or Data::Dumper behind the
151           scenes, depending on which is available (Storable is preferred).
152
153       undirected_copy
154       undirected_copy_graph
155               my $c = $g->undirected_copy_graph;
156
157           Create an undirected shallow copy (vertices and edges) of the
158           directed graph so that for any directed edge (u, v) there is an
159           undirected edge (u, v).
160
161       undirected_copy_clear_cache
162               @path = $g->undirected_copy_clear_cache;
163
164           See "Clearing cached results".
165
166       directed_copy
167       directed_copy_graph
168               my $c = $g->directed_copy_graph;
169
170           Create a directed shallow copy (vertices and edges) of the
171           undirected graph so that for any undirected edge (u, v) there are
172           two directed edges (u, v) and (v, u).
173
174       transpose
175       transpose_graph
176               my $t = $g->transpose_graph;
177
178           Create a directed shallow transposed copy (vertices and edges) of
179           the directed graph so that for any directed edge (u, v) there is a
180           directed edge (v, u).
181
182           You can also transpose a single edge with
183
184           transpose_edge
185                       $g->transpose_edge($u, $v)
186
187       complete_graph
188       complete
189               my $c = $g->complete_graph;
190
191           Create a complete graph that has the same vertices as the original
192           graph.  A complete graph has an edge between every pair of
193           vertices.
194
195       complement_graph
196       complement
197               my $c = $g->complement_graph;
198
199           Create a complement graph that has the same vertices as the
200           original graph.  A complement graph has an edge (u,v) if and only
201           if the original graph does not have edge (u,v).
202
203       subgraph
204              my $c = $g->subgraph(\@src, \@dst);
205              my $c = $g->subgraph(\@src);
206
207           Creates a subgraph of a given graph.  The created subgraph has the
208           same graph properties (directedness, and so forth) as the original
209           graph, but none of the attributes (graph, vertex, or edge).
210
211           A vertex is added to the subgraph if it is in the original graph.
212
213           An edge is added to the subgraph if there is an edge in the
214           original graph that starts from the "src" set of vertices and ends
215           in the "dst" set of vertices.
216
217           You can leave out "dst" in which case "dst" is assumed to be the
218           same: this is called a vertex-induced subgraph.
219
220       See also "random_graph" for a random constructor.
221
222   Basics
223       add_vertex
224               $g->add_vertex($v)
225
226           Add the vertex to the graph.  Returns the graph.
227
228           By default idempotent, but a graph can be created countvertexed.
229
230           A vertex is also known as a node.
231
232           Adding "undef" as vertex is not allowed.
233
234           Note that unless you have isolated vertices (or countvertexed
235           vertices), you do not need to explicitly use "add_vertex" since
236           "add_edge" will implicitly add its vertices.
237
238       add_edge
239               $g->add_edge($u, $v)
240
241           Add the edge to the graph.  Implicitly first adds the vertices if
242           the graph does not have them.  Returns the graph.
243
244           By default idempotent, but a graph can be created countedged.
245
246           An edge is also known as an arc.
247
248       has_vertex
249               $g->has_vertex($v)
250
251           Return true if the vertex exists in the graph, false otherwise.
252
253       has_edge
254               $g->has_edge($u, $v)
255
256           Return true if the edge exists in the graph, false otherwise.
257
258       delete_vertex
259               $g->delete_vertex($v)
260
261           Delete the vertex from the graph.  Returns the graph, even if the
262           vertex did not exist in the graph.
263
264           If the graph has been created multivertexed or countvertexed and a
265           vertex has been added multiple times, the vertex will require at
266           least an equal number of deletions to become completely deleted.
267
268       delete_vertices
269               $g->delete_vertices($v1, $v2, ...)
270
271           Delete the vertices from the graph.  Returns the graph, even if
272           none of the vertices existed in the graph.
273
274           If the graph has been created multivertexed or countvertexed and a
275           vertex has been added multiple times, the vertex will require at
276           least an equal number of deletions to become completely deleteted.
277
278       delete_edge
279               $g->delete_edge($u, $v)
280
281           Delete the edge from the graph.  Returns the graph, even if the
282           edge did not exist in the graph.
283
284           If the graph has been created multivertexed or countedged and an
285           edge has been added multiple times, the edge will require at least
286           an equal number of deletions to become completely deleted.
287
288       delete_edges
289               $g->delete_edges($u1, $v1, $u2, $v2, ...)
290
291           Delete the edges from the graph.  Returns the graph, even if none
292           of the edges existed in the graph.
293
294           If the graph has been created multivertexed or countedged and an
295           edge has been added multiple times, the edge will require at least
296           an equal number of deletions to become completely deleted.
297
298   Displaying
299       Graphs have stringification overload, so you can do things like
300
301           print "The graph is $g\n"
302
303       One-way (directed, unidirected) edges are shown as '-', two-way
304       (undirected, bidirected) edges are shown as '='.  If you want to, you
305       can call the stringification via the method
306
307       stringify
308
309   Boolean
310       Graphs have boolifying overload, so you can do things like
311
312           if ($g) { print "The graph is: $g\n" }
313
314       which works even if the graph is empty.  In fact, the boolify always
315       returns true.  If you want to test for example for vertices, test for
316       vertices.
317
318       boolify
319
320   Comparing
321       Testing for equality can be done either by the overloaded "eq" operator
322
323           $g eq "a-b,a-c,d"
324
325       or by the method
326
327       eq
328               $g->eq("a-b,a-c,d")
329
330       The equality testing compares the stringified forms, and therefore it
331       assumes total equality, not isomorphism: all the vertices must be named
332       the same, and they must have identical edges between them.
333
334       For unequality there are correspondingly the overloaded "ne" operator
335       and the method
336
337       ne
338               $g->ne("a-b,a-c,d")
339
340       See also "Isomorphism".
341
342   Paths and Cycles
343       Paths and cycles are simple extensions of edges: paths are edges
344       starting from where the previous edge ended, and cycles are paths
345       returning back to the start vertex of the first edge.
346
347       add_path
348              $g->add_path($a, $b, $c, ..., $x, $y, $z)
349
350           Add the edges $a-$b, $b-$c, ..., $x-$y, $y-$z to the graph.
351           Returns the graph.
352
353       has_path
354              $g->has_path($a, $b, $c, ..., $x, $y, $z)
355
356           Return true if the graph has all the edges $a-$b, $b-$c, ...,
357           $x-$y, $y-$z, false otherwise.
358
359       delete_path
360              $g->delete_path($a, $b, $c, ..., $x, $y, $z)
361
362           Delete all the edges edges $a-$b, $b-$c, ..., $x-$y, $y-$z
363           (regardless of whether they exist or not).  Returns the graph.
364
365       add_cycle
366              $g->add_cycle($a, $b, $c, ..., $x, $y, $z)
367
368           Add the edges $a-$b, $b-$c, ..., $x-$y, $y-$z, and $z-$a to the
369           graph.  Returns the graph.
370
371       has_cycle
372       has_this_cycle
373              $g->has_cycle($a, $b, $c, ..., $x, $y, $z)
374
375           Return true if the graph has all the edges $a-$b, $b-$c, ...,
376           $x-$y, $y-$z, and $z-$a, false otherwise.
377
378           NOTE: This does not detect cycles, see "has_a_cycle" and
379           "find_a_cycle".
380
381       delete_cycle
382              $g->delete_cycle($a, $b, $c, ..., $x, $y, $z)
383
384           Delete all the edges edges $a-$b, $b-$c, ..., $x-$y, $y-$z, and
385           $z-$a (regardless of whether they exist or not).  Returns the
386           graph.
387
388       has_a_cycle
389              $g->has_a_cycle
390
391           Returns true if the graph has a cycle, false if not.
392
393       find_a_cycle
394              $g->find_a_cycle
395
396           Returns a cycle if the graph has one (as a list of vertices), an
397           empty list if no cycle can be found.
398
399           Note that this just returns the vertices of a cycle: not any
400           particular cycle, just the first one it finds.  A repeated call
401           might find the same cycle, or it might find a different one, and
402           you cannot call this repeatedly to find all the cycles.
403
404   Graph Types
405       is_simple_graph
406               $g->is_simple_graph
407
408           Return true if the graph has no multiedges, false otherwise.
409
410       is_pseudo_graph
411               $g->is_pseudo_graph
412
413           Return true if the graph has any multiedges or any self-loops,
414           false otherwise.
415
416       is_multi_graph
417               $g->is_multi_graph
418
419           Return true if the graph has any multiedges but no self-loops,
420           false otherwise.
421
422       is_directed_acyclic_graph
423       is_dag
424               $g->is_directed_acyclic_graph
425               $g->is_dag
426
427           Return true if the graph is directed and acyclic, false otherwise.
428
429       is_cyclic
430               $g->is_cyclic
431
432           Return true if the graph is cyclic (contains at least one cycle).
433           (This is identical to "has_a_cycle".)
434
435           To find at least one such cycle, see "find_a_cycle".
436
437       is_acyclic
438           Return true if the graph is acyclic (does not contain any cycles).
439
440       To find a cycle, use "find_a_cycle".
441
442   Transitivity
443       is_transitive
444               $g->is_transitive
445
446           Return true if the graph is transitive, false otherwise.
447
448       TransitiveClosure_Floyd_Warshall
449       transitive_closure
450               $tcg = $g->TransitiveClosure_Floyd_Warshall
451
452           Return the transitive closure graph of the graph.
453
454       You can query the reachability from $u to $v with
455
456       is_reachable
457               $tcg->is_reachable($u, $v)
458
459       See Graph::TransitiveClosure for more information about creating and
460       querying transitive closures.
461
462       With
463
464       transitive_closure_matrix
465              $tcm = $g->transitive_closure_matrix;
466
467       you can (create if not existing and) query the transitive closure
468       matrix that underlies the transitive closure graph.  See
469       Graph::TransitiveClosure::Matrix for more information.
470
471   Mutators
472       add_vertices
473               $g->add_vertices('d', 'e', 'f')
474
475           Add zero or more vertices to the graph.  Returns the graph.
476
477       add_edges
478               $g->add_edges(['d', 'e'], ['f', 'g'])
479               $g->add_edges(qw(d e f g));
480
481           Add zero or more edges to the graph.  The edges are specified as a
482           list of array references, or as a list of vertices where the even
483           (0th, 2nd, 4th, ...) items are start vertices and the odd (1st,
484           3rd, 5th, ...) are the corresponding end vertices.  Returns the
485           graph.
486
487   Accessors
488       is_directed
489       directed
490               $g->is_directed()
491               $g->directed()
492
493           Return true if the graph is directed, false otherwise.
494
495       is_undirected
496       undirected
497               $g->is_undirected()
498               $g->undirected()
499
500           Return true if the graph is undirected, false otherwise.
501
502       is_refvertexed
503       is_refvertexed_stringified
504       refvertexed
505       refvertexed_stringified
506           Return true if the graph can handle references (including Perl
507           objects) as vertices.
508
509       vertices
510               my $V = $g->vertices
511               my @V = $g->vertices
512
513           In scalar context, return the number of vertices in the graph.  In
514           list context, return the vertices, in no particular order.
515
516       has_vertices
517               $g->has_vertices()
518
519           Return true if the graph has any vertices, false otherwise.
520
521       edges
522               my $E = $g->edges
523               my @E = $g->edges
524
525           In scalar context, return the number of edges in the graph.  In
526           list context, return the edges, in no particular order.  The edges
527           are returned as anonymous arrays listing the vertices.
528
529       has_edges
530               $g->has_edges()
531
532           Return true if the graph has any edges, false otherwise.
533
534       is_connected
535               $g->is_connected
536
537           For an undirected graph, return true is the graph is connected,
538           false otherwise.  Being connected means that from every vertex it
539           is possible to reach every other vertex.
540
541           If the graph has been created with a true "unionfind" parameter,
542           the time complexity is (essentially) O(V), otherwise O(V log V).
543
544           See also "connected_components", "connected_component_by_index",
545           "connected_component_by_vertex", and "same_connected_components",
546           and "biconnectivity".
547
548           For directed graphs, see "is_strongly_connected" and
549           "is_weakly_connected".
550
551       connected_components
552               @cc = $g->connected_components()
553
554           For an undirected graph, returns the vertices of the connected
555           components of the graph as a list of anonymous arrays.  The
556           ordering of the anonymous arrays or the ordering of the vertices
557           inside the anonymous arrays (the components) is undefined.
558
559           For directed graphs, see "strongly_connected_components" and
560           "weakly_connected_components".
561
562       connected_component_by_vertex
563               $i = $g->connected_component_by_vertex($v)
564
565           For an undirected graph, return an index identifying the connected
566           component the vertex belongs to, the indexing starting from zero.
567
568           For the inverse, see "connected_component_by_index".
569
570           If the graph has been created with a true "unionfind" parameter,
571           the time complexity is (essentially) O(1), otherwise O(V log V).
572
573           See also "biconnectivity".
574
575           For directed graphs, see "strongly_connected_component_by_vertex"
576           and "weakly_connected_component_by_vertex".
577
578       connected_component_by_index
579               @v = $g->connected_component_by_index($i)
580
581           For an undirected graph, return the vertices of the ith connected
582           component, the indexing starting from zero.  The order of vertices
583           is undefined, while the order of the connected components is same
584           as from connected_components().
585
586           For the inverse, see "connected_component_by_vertex".
587
588           For directed graphs, see "strongly_connected_component_by_index"
589           and "weakly_connected_component_by_index".
590
591       same_connected_components
592               $g->same_connected_components($u, $v, ...)
593
594           For an undirected graph, return true if the vertices are in the
595           same connected component.
596
597           If the graph has been created with a true "unionfind" parameter,
598           the time complexity is (essentially) O(1), otherwise O(V log V).
599
600           For directed graphs, see "same_strongly_connected_components" and
601           "same_weakly_connected_components".
602
603       connected_graph
604               $cg = $g->connected_graph
605
606           For an undirected graph, return its connected graph.
607
608       connectivity_clear_cache
609               $g->connectivity_clear_cache
610
611           See "Clearing cached results".
612
613           See "Connected Graphs and Their Components" for further discussion.
614
615       biconnectivity
616               my ($ap, $bc, $br) = $g->biconnectivity
617
618           For an undirected graph, return the various biconnectivity
619           components of the graph: the articulation points (cut vertices),
620           biconnected components, and bridges.
621
622           Note: currently only handles connected graphs.
623
624       is_biconnected
625              $g->is_biconnected
626
627           For an undirected graph, return true if the graph is biconnected
628           (if it has no articulation points, also known as cut vertices).
629
630       is_edge_connected
631              $g->is_edge_connected
632
633           For an undirected graph, return true if the graph is edge-connected
634           (if it has no bridges).
635
636           Note: more precisely, this would be called is_edge_biconnected,
637           since there is a more general concept of being k-connected.
638
639       is_edge_separable
640              $g->is_edge_separable
641
642           For an undirected graph, return true if the graph is edge-separable
643           (if it has bridges).
644
645           Note: more precisely, this would be called is_edge_biseparable,
646           since there is a more general concept of being k-connected.
647
648       articulation_points
649       cut_vertices
650              $g->articulation_points
651
652           For an undirected graph, return the articulation points (cut
653           vertices) of the graph as a list of vertices.  The order is
654           undefined.
655
656       biconnected_components
657              $g->biconnected_components
658
659           For an undirected graph, return the biconnected components of the
660           graph as a list of anonymous arrays of vertices in the components.
661           The ordering of the anonymous arrays or the ordering of the
662           vertices inside the anonymous arrays (the components) is undefined.
663           Also note that one vertex can belong to more than one biconnected
664           component.
665
666       biconnected_component_by_vertex
667              $i = $g->biconnected_component_by_index($v)
668
669           For an undirected graph, return the indices identifying the
670           biconnected components the vertex belongs to, the indexing starting
671           from zero.  The order of of the components is undefined.
672
673           For the inverse, see "connected_component_by_index".
674
675           For directed graphs, see "strongly_connected_component_by_index"
676           and "weakly_connected_component_by_index".
677
678       biconnected_component_by_index
679              @v = $g->biconnected_component_by_index($i)
680
681           For an undirected graph, return the vertices in the ith biconnected
682           component of the graph as an anonymous arrays of vertices in the
683           component.  The ordering of the vertices within a component is
684           undefined.  Also note that one vertex can belong to more than one
685           biconnected component.
686
687       same_biconnected_components
688               $g->same_biconnected_components($u, $v, ...)
689
690           For an undirected graph, return true if the vertices are in the
691           same biconnected component.
692
693       biconnected_graph
694               $bcg = $g->biconnected_graph
695
696           For an undirected graph, return its biconnected graph.
697
698           See "Connected Graphs and Their Components" for further discussion.
699
700       bridges
701              $g->bridges
702
703           For an undirected graph, return the bridges of the graph as a list
704           of anonymous arrays of vertices in the bridges.  The order of
705           bridges and the order of vertices in them is undefined.
706
707       biconnectivity_clear_cache
708               $g->biconnectivity_clear_cache
709
710           See "Clearing cached results".
711
712       strongly_connected
713       is_strongly_connected
714               $g->is_strongly_connected
715
716           For a directed graph, return true is the directed graph is strongly
717           connected, false if not.
718
719           See also "is_weakly_connected".
720
721           For undirected graphs, see "is_connected", or "is_biconnected".
722
723       strongly_connected_component_by_vertex
724               $i = $g->strongly_connected_component_by_vertex($v)
725
726           For a directed graph, return an index identifying the strongly
727           connected component the vertex belongs to, the indexing starting
728           from zero.
729
730           For the inverse, see "strongly_connected_component_by_index".
731
732           See also "weakly_connected_component_by_vertex".
733
734           For undirected graphs, see "connected_components" or
735           "biconnected_components".
736
737       strongly_connected_component_by_index
738               @v = $g->strongly_connected_component_by_index($i)
739
740           For a directed graph, return the vertices of the ith connected
741           component, the indexing starting from zero.  The order of vertices
742           within a component is undefined, while the order of the connected
743           components is the as from strongly_connected_components().
744
745           For the inverse, see "strongly_connected_component_by_vertex".
746
747           For undirected graphs, see "weakly_connected_component_by_index".
748
749       same_strongly_connected_components
750               $g->same_strongly_connected_components($u, $v, ...)
751
752           For a directed graph, return true if the vertices are in the same
753           strongly connected component.
754
755           See also "same_weakly_connected_components".
756
757           For undirected graphs, see "same_connected_components" or
758           "same_biconnected_components".
759
760       strong_connectivity_clear_cache
761               $g->strong_connectivity_clear_cache
762
763           See "Clearing cached results".
764
765       weakly_connected
766       is_weakly_connected
767               $g->is_weakly_connected
768
769           For a directed graph, return true is the directed graph is weakly
770           connected, false if not.
771
772           Weakly connected graph is also known as semiconnected graph.
773
774           See also "is_strongly_connected".
775
776           For undirected graphs, see "is_connected" or "is_biconnected".
777
778       weakly_connected_components
779               @wcc = $g->weakly_connected_components()
780
781           For a directed graph, returns the vertices of the weakly connected
782           components of the graph as a list of anonymous arrays.  The
783           ordering of the anonymous arrays or the ordering of the vertices
784           inside the anonymous arrays (the components) is undefined.
785
786           See also "strongly_connected_components".
787
788           For undirected graphs, see "connected_components" or
789           "biconnected_components".
790
791       weakly_connected_component_by_vertex
792               $i = $g->weakly_connected_component_by_vertex($v)
793
794           For a directed graph, return an index identifying the weakly
795           connected component the vertex belongs to, the indexing starting
796           from zero.
797
798           For the inverse, see "weakly_connected_component_by_index".
799
800           For undirected graphs, see "connected_component_by_vertex" and
801           "biconnected_component_by_vertex".
802
803       weakly_connected_component_by_index
804               @v = $g->weakly_connected_component_by_index($i)
805
806           For a directed graph, return the vertices of the ith weakly
807           connected component, the indexing starting zero.  The order of
808           vertices within a component is undefined, while the order of the
809           weakly connected components is same as from
810           weakly_connected_components().
811
812           For the inverse, see "weakly_connected_component_by_vertex".
813
814           For undirected graphs, see connected_component_by_index and
815           biconnected_component_by_index.
816
817       same_weakly_connected_components
818               $g->same_weakly_connected_components($u, $v, ...)
819
820           Return true if the vertices are in the same weakly connected
821           component.
822
823       weakly_connected_graph
824               $wcg = $g->weakly_connected_graph
825
826           For a directed graph, return its weakly connected graph.
827
828           For undirected graphs, see "connected_graph" and
829           "biconnected_graph".
830
831       strongly_connected_components
832              my @scc = $g->strongly_connected_components;
833
834           For a directed graph, return the strongly connected components as a
835           list of anonymous arrays.  The elements in the anonymous arrays are
836           the vertices belonging to the strongly connected component; both
837           the elements and the components are in no particular order.
838
839           Note that strongly connected components can have single-element
840           components even without self-loops: if a vertex is any of isolated,
841           sink, or a source, the vertex is alone in its own strong component.
842
843           See also "weakly_connected_components".
844
845           For undirected graphs, see "connected_components", or see
846           "biconnected_components".
847
848       strongly_connected_graph
849              my $scg = $g->strongly_connected_graph;
850
851           See "Connected Graphs and Their Components" for further discussion.
852
853           Strongly connected graphs are also known as kernel graphs.
854
855           See also "weakly_connected_graph".
856
857           For undirected graphs, see "connected_graph", or
858           "biconnected_graph".
859
860       is_sink_vertex
861               $g->is_sink_vertex($v)
862
863           Return true if the vertex $v is a sink vertex, false if not.  A
864           sink vertex is defined as a vertex with predecessors but no
865           successors: this definition means that isolated vertices are not
866           sink vertices.  If you want also isolated vertices, use
867           is_successorless_vertex().
868
869       is_source_vertex
870               $g->is_source_vertex($v)
871
872           Return true if the vertex $v is a source vertex, false if not.  A
873           source vertex is defined as a vertex with successors but no
874           predecessors: the definition means that isolated vertices are not
875           source vertices.  If you want also isolated vertices, use
876           is_predecessorless_vertex().
877
878       is_successorless_vertex
879               $g->is_successorless_vertex($v)
880
881           Return true if the vertex $v has no succcessors (no edges leaving
882           the vertex), false if it has.
883
884           Isolated vertices will return true: if you do not want this, use
885           is_sink_vertex().
886
887       is_successorful_vertex
888               $g->is_successorful_vertex($v)
889
890           Return true if the vertex $v has successors, false if not.
891
892       is_predecessorless_vertex
893               $g->is_predecessorless_vertex($v)
894
895           Return true if the vertex $v has no predecessors (no edges entering
896           the vertex), false if it has.
897
898           Isolated vertices will return true: if you do not want this, use
899           is_source_vertex().
900
901       is_predecessorful_vertex
902               $g->is_predecessorful_vertex($v)
903
904           Return true if the vertex $v has predecessors, false if not.
905
906       is_isolated_vertex
907               $g->is_isolated_vertex($v)
908
909           Return true if the vertex $v is an isolated vertex: no successors
910           and no predecessors.
911
912       is_interior_vertex
913               $g->is_interior_vertex($v)
914
915           Return true if the vertex $v is an interior vertex: both successors
916           and predecessors.
917
918       is_exterior_vertex
919               $g->is_exterior_vertex($v)
920
921           Return true if the vertex $v is an exterior vertex: has either no
922           successors or no predecessors, or neither.
923
924       is_self_loop_vertex
925               $g->is_self_loop_vertex($v)
926
927           Return true if the vertex $v is a self loop vertex: has an edge
928           from itself to itself.
929
930       sink_vertices
931               @v = $g->sink_vertices()
932
933           Return the sink vertices of the graph.  In scalar context return
934           the number of sink vertices.  See "is_sink_vertex" for the
935           definition of a sink vertex.
936
937       source_vertices
938               @v = $g->source_vertices()
939
940           Return the source vertices of the graph.  In scalar context return
941           the number of source vertices.  See "is_source_vertex" for the
942           definition of a source vertex.
943
944       successorful_vertices
945               @v = $g->successorful_vertices()
946
947           Return the successorful vertices of the graph.  In scalar context
948           return the number of successorful vertices.
949
950       successorless_vertices
951               @v = $g->successorless_vertices()
952
953           Return the successorless vertices of the graph.  In scalar context
954           return the number of successorless vertices.
955
956       successors
957               @s = $g->successors($v)
958
959           Return the immediate successor vertices of the vertex.
960
961           See also "all_successors", "all_neighbours", and "all_reachable".
962
963       all_successors
964               @s = $g->all_successors(@v)
965
966           For a directed graph, returns all successor vertices of the
967           argument vertices, recursively.
968
969           For undirected graphs, see "all_neighbours" and "all_reachable".
970
971           See also "successors".
972
973       neighbors
974       neighbours
975               @n = $g->neighbours($v)
976
977           Return the neighboring/neighbouring vertices.  Also known as the
978           adjacent vertices.
979
980           See also "all_neighbours" and "all_reachable".
981
982       all_neighbors
983       all_neighbours
984              @n = $g->all_neighbours(@v)
985
986           Return the neighboring/neighbouring vertices of the argument
987           vertices, recursively.  For a directed graph, recurses up
988           predecessors and down successors.  For an undirected graph, returns
989           all the vertices reachable from the argument vertices: equivalent
990           to "all_reachable".
991
992           See also "neighbours" and "all_reachable".
993
994       all_reachable
995               @r = $g->all_reachable(@v)
996
997           Return all the vertices reachable from of the argument vertices,
998           recursively.  For a directed graph, equivalent to "all_successors".
999           For an undirected graph, equivalent to "all_neighbours".  The
1000           argument vertices are not included in the results unless there are
1001           explicit self-loops.
1002
1003           See also "neighbours", "all_neighbours", and "all_successors".
1004
1005       predecessorful_vertices
1006               @v = $g->predecessorful_vertices()
1007
1008           Return the predecessorful vertices of the graph.  In scalar context
1009           return the number of predecessorful vertices.
1010
1011       predecessorless_vertices
1012               @v = $g->predecessorless_vertices()
1013
1014           Return the predecessorless vertices of the graph.  In scalar
1015           context return the number of predecessorless vertices.
1016
1017       predecessors
1018               @p = $g->predecessors($v)
1019
1020           Return the immediate predecessor vertices of the vertex.
1021
1022           See also "all_predecessors", "all_neighbours", and "all_reachable".
1023
1024       all_predecessors
1025               @p = $g->all_predecessors(@v)
1026
1027           For a directed graph, returns all predecessor vertices of the
1028           argument vertices, recursively.
1029
1030           For undirected graphs, see "all_neighbours" and "all_reachable".
1031
1032           See also "predecessors".
1033
1034       isolated_vertices
1035               @v = $g->isolated_vertices()
1036
1037           Return the isolated vertices of the graph.  In scalar context
1038           return the number of isolated vertices.  See "is_isolated_vertex"
1039           for the definition of an isolated vertex.
1040
1041       interior_vertices
1042               @v = $g->interior_vertices()
1043
1044           Return the interior vertices of the graph.  In scalar context
1045           return the number of interior vertices.  See "is_interior_vertex"
1046           for the definition of an interior vertex.
1047
1048       exterior_vertices
1049               @v = $g->exterior_vertices()
1050
1051           Return the exterior vertices of the graph.  In scalar context
1052           return the number of exterior vertices.  See "is_exterior_vertex"
1053           for the definition of an exterior vertex.
1054
1055       self_loop_vertices
1056               @v = $g->self_loop_vertices()
1057
1058           Return the self-loop vertices of the graph.  In scalar context
1059           return the number of self-loop vertices.  See "is_self_loop_vertex"
1060           for the definition of a self-loop vertex.
1061
1062   Connected Graphs and Their Components
1063       In this discussion connected graph refers to any of connected graphs,
1064       biconnected graphs, and strongly connected graphs.
1065
1066       NOTE: if the vertices of the original graph are Perl objects, (in other
1067       words, references, so you must be using "refvertexed") the vertices of
1068       the connected graph are NOT by default usable as Perl objects because
1069       they are blessed into a package with a rather unusable name.
1070
1071       By default, the vertex names of the connected graph are formed from the
1072       names of the vertices of the original graph by (alphabetically sorting
1073       them and) concatenating their names with "+".  The vertex attribute
1074       "subvertices" is also used to store the list (as an array reference) of
1075       the original vertices.  To change the 'supercomponent' vertex names and
1076       the whole logic of forming these supercomponents use the
1077       "super_component") option to the method calls:
1078
1079         $g->connected_graph(super_component => sub { ... })
1080         $g->biconnected_graph(super_component => sub { ... })
1081         $g->strongly_connected_graph(super_component => sub { ... })
1082
1083       The subroutine reference gets the 'subcomponents' (the vertices of the
1084       original graph) as arguments, and it is supposed to return the new
1085       supercomponent vertex, the "stringified" form of which is used as the
1086       vertex name.
1087
1088   Degree
1089       A vertex has a degree based on the number of incoming and outgoing
1090       edges.  This really makes sense only for directed graphs.
1091
1092       degree
1093       vertex_degree
1094               $d = $g->degree($v)
1095               $d = $g->vertex_degree($v)
1096
1097           For directed graphs: the in-degree minus the out-degree at the
1098           vertex.
1099
1100           For undirected graphs: the number of edges at the vertex
1101           (identical to "in_degree()", "out_degree()").
1102
1103       in_degree
1104               $d = $g->in_degree($v)
1105
1106           For directed graphs: the number of incoming edges at the vertex.
1107
1108           For undirected graphs: the number of edges at the vertex (identical
1109           to "out_degree()", "degree()", "vertex_degree()").
1110
1111       out_degree
1112               $o = $g->out_degree($v)
1113
1114           For directed graphs: The number of outgoing edges at the vertex.
1115
1116           For undirected graphs: the number of edges at the vertex (identical
1117           to "in_degree()", "degree()", "vertex_degree()").
1118
1119       average_degree
1120              my $ad = $g->average_degree;
1121
1122           Return the average degree (as in "degree()" or "vertex_degree()")
1123           taken over all vertices.
1124
1125       Related methods are
1126
1127       edges_at
1128               @e = $g->edges_at($v)
1129
1130           The union of edges from and edges to at the vertex.
1131
1132       edges_from
1133               @e = $g->edges_from($v)
1134
1135           The edges leaving the vertex.
1136
1137       edges_to
1138               @e = $g->edges_to($v)
1139
1140           The edges entering the vertex.
1141
1142       See also "average_degree".
1143
1144   Counted Vertices
1145       Counted vertices are vertices with more than one instance, normally
1146       adding vertices is idempotent.  To enable counted vertices on a graph,
1147       give the "countvertexed" parameter a true value
1148
1149           use Graph;
1150           my $g = Graph->new(countvertexed => 1);
1151
1152       To find out how many times the vertex has been added:
1153
1154       get_vertex_count
1155               my $c = $g->get_vertex_count($v);
1156
1157           Return the count of the vertex, or undef if the vertex does not
1158           exist.
1159
1160   Multiedges, Multivertices, Multigraphs
1161       Multiedges are edges with more than one "life", meaning that one has to
1162       delete them as many times as they have been added.  Normally adding
1163       edges is idempotent (in other words, adding edges more than once makes
1164       no difference).
1165
1166       There are two kinds or degrees of creating multiedges and
1167       multivertices.  The two kinds are mutually exclusive.
1168
1169       The weaker kind is called counted, in which the edge or vertex has a
1170       count on it: add operations increase the count, and delete operations
1171       decrease the count, and once the count goes to zero, the edge or vertex
1172       is deleted.  If there are attributes, they all are attached to the same
1173       vertex.  You can think of this as the graph elements being refcounted,
1174       or reference counted, if that sounds more familiar.
1175
1176       The stronger kind is called (true) multi, in which the edge or vertex
1177       really has multiple separate identities, so that you can for example
1178       attach different attributes to different instances.
1179
1180       To enable multiedges on a graph:
1181
1182           use Graph;
1183           my $g0 = Graph->new(countedged => 1);
1184           my $g0 = Graph->new(multiedged => 1);
1185
1186       Similarly for vertices
1187
1188           use Graph;
1189           my $g1 = Graph->new(countvertexed => 1);
1190           my $g1 = Graph->new(multivertexed => 1);
1191
1192       You can test for these by
1193
1194       is_countedged
1195       countedged
1196               $g->is_countedged
1197               $g->countedged
1198
1199           Return true if the graph is countedged.
1200
1201       is_countvertexed
1202       countvertexed
1203               $g->is_countvertexed
1204               $g->countvertexed
1205
1206           Return true if the graph is countvertexed.
1207
1208       is_multiedged
1209       multiedged
1210               $g->is_multiedged
1211               $g->multiedged
1212
1213           Return true if the graph is multiedged.
1214
1215       is_multivertexed
1216       multivertexed
1217               $g->is_multivertexed
1218               $g->multivertexed
1219
1220           Return true if the graph is multivertexed.
1221
1222       A multiedged (either the weak kind or the strong kind) graph is a
1223       multigraph, for which you can test with "is_multi_graph()".
1224
1225       NOTE: The various graph algorithms do not in general work well with
1226       multigraphs (they often assume simple graphs, that is, no multiedges or
1227       loops), and no effort has been made to test the algorithms with
1228       multigraphs.
1229
1230       vertices() and edges() will return the multiple elements: if you want
1231       just the unique elements, use
1232
1233       unique_vertices
1234       unique_edges
1235               @uv = $g->unique_vertices; # unique
1236               @mv = $g->vertices;        # possible multiples
1237               @ue = $g->unique_edges;
1238               @me = $g->edges;
1239
1240       If you are using (the stronger kind of) multielements, you should use
1241       the by_id variants:
1242
1243       add_vertex_by_id
1244       has_vertex_by_id
1245       delete_vertex_by_id
1246       add_edge_by_id
1247       has_edge_by_id
1248       delete_edge_by_id
1249
1250           $g->add_vertex_by_id($v, $id)
1251           $g->has_vertex_by_id($v, $id)
1252           $g->delete_vertex_by_id($v, $id)
1253
1254           $g->add_edge_by_id($u, $v, $id)
1255           $g->has_edge_by_id($u, $v, $id)
1256           $g->delete_edge_by_id($u, $v, $id)
1257
1258       These interfaces only apply to multivertices and multiedges.  When you
1259       delete the last vertex/edge in a multivertex/edge, the whole
1260       vertex/edge is deleted.  You can use add_vertex()/add_edge() on a
1261       multivertex/multiedge graph, in which case an id is generated
1262       automatically.  To find out which the generated id was, you need to use
1263
1264       add_vertex_get_id
1265       add_edge_get_id
1266
1267           $idv = $g->add_vertex_get_id($v)
1268           $ide = $g->add_edge_get_id($u, $v)
1269
1270       To return all the ids of vertices/edges in a multivertex/multiedge, use
1271
1272       get_multivertex_ids
1273       get_multiedge_ids
1274
1275           $g->get_multivertex_ids($v)
1276           $g->get_multiedge_ids($u, $v)
1277
1278       The ids are returned in random order.
1279
1280       To find out how many times the edge has been added (this works for
1281       either kind of multiedges):
1282
1283       get_edge_count
1284               my $c = $g->get_edge_count($u, $v);
1285
1286           Return the count (the "countedness") of the edge, or undef if the
1287           edge does not exist.
1288
1289       The following multi-entity utility functions exist, mirroring the non-
1290       multi vertices and edges:
1291
1292       add_weighted_edge_by_id
1293       add_weighted_edges_by_id
1294       add_weighted_path_by_id
1295       add_weighted_vertex_by_id
1296       add_weighted_vertices_by_id
1297       delete_edge_weight_by_id
1298       delete_vertex_weight_by_id
1299       get_edge_weight_by_id
1300       get_vertex_weight_by_id
1301       has_edge_weight_by_id
1302       has_vertex_weight_by_id
1303       set_edge_weight_by_id
1304       set_vertex_weight_by_id
1305
1306   Topological Sort
1307       topological_sort
1308       toposort
1309               my @ts = $g->topological_sort;
1310
1311           Return the vertices of the graph sorted topologically.  Note that
1312           there may be several possible topological orderings; one of them is
1313           returned.
1314
1315           If the graph contains a cycle, a fatal error is thrown, you can
1316           either use "eval" to trap that, or supply the "empty_if_cyclic"
1317           argument with a true value
1318
1319               my @ts = $g->topological_sort(empty_if_cyclic => 1);
1320
1321           in which case an empty array is returned if the graph is cyclic.
1322
1323   Minimum Spanning Trees (MST)
1324       Minimum Spanning Trees or MSTs are tree subgraphs derived from an
1325       undirected graph.  MSTs "span the graph" (covering all the vertices)
1326       using as lightly weighted (hence the "minimum") edges as possible.
1327
1328       MST_Kruskal
1329               $mstg = $g->MST_Kruskal;
1330
1331           Returns the Kruskal MST of the graph.
1332
1333       MST_Prim
1334               $mstg = $g->MST_Prim(%opt);
1335
1336           Returns the Prim MST of the graph.
1337
1338           You can choose the first vertex with $opt{ first_root }.
1339
1340       MST_Dijkstra
1341       minimum_spanning_tree
1342               $mstg = $g->MST_Dijkstra;
1343               $mstg = $g->minimum_spanning_tree;
1344
1345           Aliases for MST_Prim.
1346
1347   Single-Source Shortest Paths (SSSP)
1348       Single-source shortest paths, also known as Shortest Path Trees (SPTs).
1349       For either a directed or an undirected graph, return a (tree) subgraph
1350       that from a single start vertex (the "single source") travels the
1351       shortest possible paths (the paths with the lightest weights) to all
1352       the other vertices.  Note that the SSSP is neither reflexive (the
1353       shortest paths do not include the zero-length path from the source
1354       vertex to the source vertex) nor transitive (the shortest paths do not
1355       include transitive closure paths).  If no weight is defined for an
1356       edge, 1 (one) is assumed.
1357
1358       SPT_Dijkstra
1359               $sptg = $g->SPT_Dijkstra($root)
1360               $sptg = $g->SPT_Dijkstra(%opt)
1361
1362           Return as a graph the the single-source shortest paths of the graph
1363           using Dijkstra's algorithm.  The graph cannot contain negative
1364           edges (negative edges cause the algorithm to abort with an error
1365           message "Graph::SPT_Dijkstra: edge ... is negative").
1366
1367           You can choose the first vertex of the result with either a single
1368           vertex argument or with $opt{ first_root }, otherwise a random
1369           vertex is chosen.
1370
1371           NOTE: note that all the vertices might not be reachable from the
1372           selected (explicit or random) start vertex.
1373
1374           NOTE: after the first reachable tree from the first start vertex
1375           has been finished, and if there still are unvisited vertices,
1376           SPT_Dijkstra will keep on selecting unvisited vertices.
1377
1378           The next roots (in case the first tree doesn't visit all the
1379           vertices) can be chosen by setting one of the following options to
1380           true: "next_root", "next_alphabetic", "next_numeric",
1381           "next_random".
1382
1383           The "next_root" is the most customizable: the value needs to be a
1384           subroutine reference which will receive the graph and the unvisited
1385           vertices as hash reference.  If you want to only visit the first
1386           tree, use "next_root =" sub { undef }>.  The rest of these options
1387           are booleans.  If none of them are true, a random unvisited vertex
1388           will be selected.
1389
1390           The first start vertex is be available as the graph attribute
1391           "SPT_Dijkstra_root").
1392
1393           The result weights of vertices can be retrieved from the result
1394           graph by
1395
1396                   my $w = $sptg->get_vertex_attribute($v, 'weight');
1397
1398           The predecessor vertex of a vertex in the result graph can be
1399           retrieved by
1400
1401                   my $u = $sptg->get_vertex_attribute($v, 'p');
1402
1403           ("A successor vertex" cannot be retrieved as simply because a
1404           single vertex can have several successors.  You can first find the
1405           "neighbors()" vertices and then remove the predecessor vertex.)
1406
1407           If you want to find the shortest path between two vertices, see
1408           "SP_Dijkstra".
1409
1410       SSSP_Dijkstra
1411       single_source_shortest_paths
1412           Aliases for SPT_Dijkstra.
1413
1414       SP_Dijkstra
1415               @path = $g->SP_Dijkstra($u, $v)
1416
1417           Return the vertices in the shortest path in the graph $g between
1418           the two vertices $u, $v.  If no path can be found, an empty list is
1419           returned.
1420
1421           Uses SPT_Dijkstra().
1422
1423       SPT_Dijkstra_clear_cache
1424               $g->SPT_Dijkstra_clear_cache
1425
1426           See "Clearing cached results".
1427
1428       SPT_Bellman_Ford
1429               $sptg = $g->SPT_Bellman_Ford(%opt)
1430
1431           Return as a graph the single-source shortest paths of the graph
1432           using Bellman-Ford's algorithm.  The graph can contain negative
1433           edges but not negative cycles (negative cycles cause the algorithm
1434           to abort with an error message "Graph::SPT_Bellman_Ford: negative
1435           cycle exists/").
1436
1437           You can choose the start vertex of the result with either a single
1438           vertex argument or with $opt{ first_root }, otherwise a random
1439           vertex is chosen.
1440
1441           NOTE: note that all the vertices might not be reachable from the
1442           selected (explicit or random) start vertex.
1443
1444           The start vertex is be available as the graph attribute
1445           "SPT_Bellman_Ford_root").
1446
1447           The result weights of vertices can be retrieved from the result
1448           graph by
1449
1450                   my $w = $sptg->get_vertex_attribute($v, 'weight');
1451
1452           The predecessor vertex of a vertex in the result graph can be
1453           retrieved by
1454
1455                   my $u = $sptg->get_vertex_attribute($v, 'p');
1456
1457           ("A successor vertex" cannot be retrieved as simply because a
1458           single vertex can have several successors.  You can first find the
1459           "neighbors()" vertices and then remove the predecessor vertex.)
1460
1461           If you want to find the shortes path between two vertices, see
1462           "SP_Bellman_Ford".
1463
1464       SSSP_Bellman_Ford
1465           Alias for SPT_Bellman_Ford.
1466
1467       SP_Bellman_Ford
1468               @path = $g->SP_Bellman_Ford($u, $v)
1469
1470           Return the vertices in the shortest path in the graph $g between
1471           the two vertices $u, $v.  If no path can be found, an empty list is
1472           returned.
1473
1474           Uses SPT_Bellman_Ford().
1475
1476       SPT_Bellman_Ford_clear_cache
1477               $g->SPT_Bellman_Ford_clear_cache
1478
1479           See "Clearing cached results".
1480
1481   All-Pairs Shortest Paths (APSP)
1482       For either a directed or an undirected graph, return the APSP object
1483       describing all the possible paths between any two vertices of the
1484       graph.  If no weight is defined for an edge, 1 (one) is assumed.
1485
1486       Note that weight of 0 (zero) does not mean do not use this edge, it
1487       means essentially the opposite: an edge that has zero cost, an edge
1488       that makes the vertices the same.
1489
1490       APSP_Floyd_Warshall
1491       all_pairs_shortest_paths
1492               my $apsp = $g->APSP_Floyd_Warshall(...);
1493
1494           Return the all-pairs shortest path object computed from the graph
1495           using Floyd-Warshall's algorithm.  The length of a path between two
1496           vertices is the sum of weight attribute of the edges along the
1497           shortest path between the two vertices.  If no weight attribute
1498           name is specified explicitly
1499
1500               $g->APSP_Floyd_Warshall(attribute_name => 'height');
1501
1502           the attribute "weight" is assumed.
1503
1504           If an edge has no defined weight attribute, the value of one is
1505           assumed when getting the attribute.
1506
1507           Once computed, you can query the APSP object with
1508
1509           path_length
1510                       my $l = $apsp->path_length($u, $v);
1511
1512                   Return the length of the shortest path between the two
1513                   vertices.
1514
1515           path_vertices
1516                       my @v = $apsp->path_vertices($u, $v);
1517
1518                   Return the list of vertices along the shortest path.
1519
1520           path_predecessor
1521                      my $u = $apsp->path_predecessor($v);
1522
1523                   Returns the predecessor of vertex $v in the all-pairs
1524                   shortest paths.
1525
1526           average_path_length
1527                       my $apl = $g->average_path_length; # All vertex pairs.
1528
1529                       my $apl = $g->average_path_length($u); # From $u.
1530                       my $apl = $g->average_path_length($u, undef); # From $u.
1531
1532                       my $apl = $g->average_path_length($u, $v); # From $u to $v.
1533
1534                       my $apl = $g->average_path_length(undef, $v); # To $v.
1535
1536                   Return the average (shortest) path length over all the
1537                   vertex pairs of the graph, from a vertex, between two
1538                   vertices, and to a vertex.
1539
1540           longest_path
1541                       my @lp = $g->longest_path;
1542                       my $lp = $g->longest_path;
1543
1544                   In scalar context return the longest shortest path length
1545                   over all the vertex pairs of the graph.  In list context
1546                   return the vertices along a longest shortest path.  Note
1547                   that there might be more than one such path; this interface
1548                   returns a random one of them.
1549
1550                   NOTE: this returns the longest shortest path, not the
1551                   longest path.
1552
1553           diameter
1554           graph_diameter
1555                       my $gd = $g->diameter;
1556
1557                   The longest path over all the vertex pairs is known as the
1558                   graph diameter.
1559
1560                   For an unconnected graph, single-vertex, or empty graph,
1561                   returns "undef".
1562
1563           shortest_path
1564                       my @sp = $g->shortest_path;
1565                       my $sp = $g->shortest_path;
1566
1567                   In scalar context return the shortest length over all the
1568                   vertex pairs of the graph.  In list context return the
1569                   vertices along a shortest path.  Note that there might be
1570                   more than one such path; this interface returns a random
1571                   one of them.
1572
1573                   For an unconnected, single-vertex, or empty graph, returns
1574                   "undef" or an empty list.
1575
1576           radius
1577                       my $gr = $g->radius;
1578
1579                   The shortest longest path over all the vertex pairs is
1580                   known as the graph radius.  See also "diameter".
1581
1582                   For an unconnected, single-vertex, or empty graph, returns
1583                   Infinity.
1584
1585           center_vertices
1586           centre_vertices
1587                       my @c = $g->center_vertices;
1588                       my @c = $g->center_vertices($delta);
1589
1590                   The graph center is the set of vertices for which the
1591                   vertex eccentricity is equal to the graph radius.  The
1592                   vertices are returned in random order.  By specifying a
1593                   delta value you can widen the criterion from strict
1594                   equality (handy for non-integer edge weights).
1595
1596                   For an unconnected, single-vertex, or empty graph, returns
1597                   an empty list.
1598
1599           vertex_eccentricity
1600                       my $ve = $g->vertex_eccentricity($v);
1601
1602                   The longest path to a vertex is known as the vertex
1603                   eccentricity.
1604
1605                   If the graph is unconnected, single-vertex, or empty graph,
1606                   returns Inf.
1607
1608           You can walk through the matrix of the shortest paths by using
1609
1610           for_shortest_paths
1611                   $n = $g->for_shortest_paths($callback)
1612
1613               The number of shortest paths is returned (this should be equal
1614               to V*V).  The $callback is a sub reference that receives four
1615               arguments: the transitive closure object from
1616               Graph::TransitiveClosure, the two vertices, and the index to
1617               the current shortest paths (0..V*V-1).
1618
1619   Clearing cached results
1620       For many graph algorithms there are several different but equally valid
1621       results.  (Pseudo)Randomness is used internally by the Graph module to
1622       for example pick a random starting vertex, and to select random edges
1623       from a vertex.
1624
1625       For efficiency the computed result is often cached to avoid recomputing
1626       the potentially expensive operation, and this also gives additional
1627       determinism (once a correct result has been computed, the same result
1628       will always be given).
1629
1630       However, sometimes the exact opposite is desireable, and the possible
1631       alternative results are wanted (within the limits of the
1632       pseudorandomness: not all the possible solutions are guaranteed to be
1633       returned, usually only a subset is retuned).  To undo the caching, the
1634       following methods are available:
1635
1636       ·   connectivity_clear_cache
1637
1638           Affects "connected_components", "connected_component_by_vertex",
1639           "connected_component_by_index", "same_connected_components",
1640           "connected_graph", "is_connected", "is_weakly_connected",
1641           "weakly_connected_components",
1642           "weakly_connected_component_by_vertex",
1643           "weakly_connected_component_by_index",
1644           "same_weakly_connected_components", "weakly_connected_graph".
1645
1646       ·   biconnectivity_clear_cache
1647
1648           Affects "biconnected_components",
1649           "biconnected_component_by_vertex",
1650           "biconnected_component_by_index", "is_edge_connected",
1651           "is_edge_separable", "articulation_points", "cut_vertices",
1652           "is_biconnected", "biconnected_graph",
1653           "same_biconnected_components", "bridges".
1654
1655       ·   strong_connectivity_clear_cache
1656
1657           Affects "strongly_connected_components",
1658           "strongly_connected_component_by_vertex",
1659           "strongly_connected_component_by_index",
1660           "same_strongly_connected_components", "is_strongly_connected",
1661           "strongly_connected", "strongly_connected_graph".
1662
1663       ·   SPT_Dijkstra_clear_cache
1664
1665           Affects "SPT_Dijkstra", "SSSP_Dijkstra",
1666           "single_source_shortest_paths", "SP_Dijkstra".
1667
1668       ·   SPT_Bellman_Ford_clear_cache
1669
1670           Affects "SPT_Bellman_Ford", "SSSP_Bellman_Ford", "SP_Bellman_Ford".
1671
1672       Note that any such computed and cached results are of course always
1673       automatically discarded whenever the graph is modified.
1674
1675   Random
1676       You can either ask for random elements of existing graphs or create
1677       random graphs.
1678
1679       random_vertex
1680               my $v = $g->random_vertex;
1681
1682           Return a random vertex of the graph, or undef if there are no
1683           vertices.
1684
1685       random_edge
1686               my $e = $g->random_edge;
1687
1688           Return a random edge of the graph as an array reference having the
1689           vertices as elements, or undef if there are no edges.
1690
1691       random_successor
1692               my $v = $g->random_successor($v);
1693
1694           Return a random successor of the vertex in the graph, or undef if
1695           there are no successors.
1696
1697       random_predecessor
1698               my $u = $g->random_predecessor($v);
1699
1700           Return a random predecessor of the vertex in the graph, or undef if
1701           there are no predecessors.
1702
1703       random_graph
1704               my $g = Graph->random_graph(%opt);
1705
1706           Construct a random graph.  The %opt must contain the "vertices"
1707           argument
1708
1709               vertices => vertices_def
1710
1711           where the vertices_def is one of
1712
1713           ·       an array reference where the elements of the array
1714                   reference are the vertices
1715
1716           ·       a number N in which case the vertices will be integers
1717                   0..N-1
1718
1719       The %opt may have either of the argument "edges" or the argument
1720       "edges_fill".  Both are used to define how many random edges to add to
1721       the graph; "edges" is an absolute number, while "edges_fill" is a
1722       relative number (relative to the number of edges in a complete graph,
1723       C).  The number of edges can be larger than C, but only if the graph is
1724       countedged.  The random edges will not include self-loops.  If neither
1725       "edges" nor "edges_fill" is specified, an "edges_fill" of 0.5 is
1726       assumed.
1727
1728       If you want repeatable randomness (what is an oxymoron?)  you can use
1729       the "random_seed" option:
1730
1731           $g = Graph->random_graph(vertices => 10, random_seed => 1234);
1732
1733       As this uses the standard Perl srand(), the usual caveat applies: use
1734       it sparingly, and consider instead using a single srand() call at the
1735       top level of your application.
1736
1737       The default random distribution of edges is flat, that is, any pair of
1738       vertices is equally likely to appear.  To define your own distribution,
1739       use the "random_edge" option:
1740
1741           $g = Graph->random_graph(vertices => 10, random_edge => \&d);
1742
1743       where "d" is a code reference receiving ($g, $u, $v, $p) as parameters,
1744       where the $g is the random graph, $u and $v are the vertices, and the
1745       $p is the probability ([0,1]) for a flat distribution.  It must return
1746       a probability ([0,1]) that the vertices $u and $v have an edge between
1747       them.  Note that returning one for a particular pair of vertices
1748       doesn't guarantee that the edge will be present in the resulting graph
1749       because the required number of edges might be reached before that
1750       particular pair is tested for the possibility of an edge.  Be very
1751       careful to adjust also "edges" or "edges_fill" so that there is a
1752       possibility of the filling process terminating.
1753
1754       NOTE: a known problem with randomness in openbsd pre-perl-5.20 is that
1755       using a seed does not give you deterministic randomness. This affects
1756       any Perl code, not just Graph.
1757
1758   Attributes
1759       You can attach free-form attributes (key-value pairs, in effect a full
1760       Perl hash) to each vertex, edge, and the graph itself.
1761
1762       Note that attaching attributes does slow down some other operations on
1763       the graph by a factor of three to ten.  For example adding edge
1764       attributes does slow down anything that walks through all the edges.
1765
1766       For vertex attributes:
1767
1768       set_vertex_attribute
1769               $g->set_vertex_attribute($v, $name, $value)
1770
1771           Set the named vertex attribute.
1772
1773           If the vertex does not exist, the set_...() will create it, and the
1774           other vertex attribute methods will return false or empty.
1775
1776           NOTE: any attributes beginning with an underscore/underline (_) are
1777           reserved for the internal use of the Graph module.
1778
1779       get_vertex_attribute
1780               $value = $g->get_vertex_attribute($v, $name)
1781
1782           Return the named vertex attribute.
1783
1784       has_vertex_attribute
1785               $g->has_vertex_attribute($v, $name)
1786
1787           Return true if the vertex has an attribute, false if not.
1788
1789       delete_vertex_attribute
1790               $g->delete_vertex_attribute($v, $name)
1791
1792           Delete the named vertex attribute.
1793
1794       set_vertex_attributes
1795               $g->set_vertex_attributes($v, $attr)
1796
1797           Set all the attributes of the vertex from the anonymous hash $attr.
1798
1799           NOTE: any attributes beginning with an underscore ("_") are
1800           reserved for the internal use of the Graph module.
1801
1802       get_vertex_attributes
1803               $attr = $g->get_vertex_attributes($v)
1804
1805           Return all the attributes of the vertex as an anonymous hash.
1806
1807       get_vertex_attribute_names
1808               @name = $g->get_vertex_attribute_names($v)
1809
1810           Return the names of vertex attributes.
1811
1812       get_vertex_attribute_values
1813               @value = $g->get_vertex_attribute_values($v)
1814
1815           Return the values of vertex attributes.
1816
1817       has_vertex_attributes
1818               $g->has_vertex_attributes($v)
1819
1820           Return true if the vertex has any attributes, false if not.
1821
1822       delete_vertex_attributes
1823               $g->delete_vertex_attributes($v)
1824
1825           Delete all the attributes of the named vertex.
1826
1827       If you are using multivertices, use the by_id variants:
1828
1829       set_vertex_attribute_by_id
1830       get_vertex_attribute_by_id
1831       has_vertex_attribute_by_id
1832       delete_vertex_attribute_by_id
1833       set_vertex_attributes_by_id
1834       get_vertex_attributes_by_id
1835       get_vertex_attribute_names_by_id
1836       get_vertex_attribute_values_by_id
1837       has_vertex_attributes_by_id
1838       delete_vertex_attributes_by_id
1839               $g->set_vertex_attribute_by_id($v, $id, $name, $value)
1840               $g->get_vertex_attribute_by_id($v, $id, $name)
1841               $g->has_vertex_attribute_by_id($v, $id, $name)
1842               $g->delete_vertex_attribute_by_id($v, $id, $name)
1843               $g->set_vertex_attributes_by_id($v, $id, $attr)
1844               $g->get_vertex_attributes_by_id($v, $id)
1845               $g->get_vertex_attribute_values_by_id($v, $id)
1846               $g->get_vertex_attribute_names_by_id($v, $id)
1847               $g->has_vertex_attributes_by_id($v, $id)
1848               $g->delete_vertex_attributes_by_id($v, $id)
1849
1850       For edge attributes:
1851
1852       set_edge_attribute
1853               $g->set_edge_attribute($u, $v, $name, $value)
1854
1855           Set the named edge attribute.
1856
1857           If the edge does not exist, the set_...() will create it, and the
1858           other edge attribute methods will return false or empty.
1859
1860           NOTE: any attributes beginning with an underscore ("_") are
1861           reserved for the internal use of the Graph module.
1862
1863       get_edge_attribute
1864               $value = $g->get_edge_attribute($u, $v, $name)
1865
1866           Return the named edge attribute.
1867
1868       has_edge_attribute
1869               $g->has_edge_attribute($u, $v, $name)
1870
1871           Return true if the edge has an attribute, false if not.
1872
1873       delete_edge_attribute
1874               $g->delete_edge_attribute($u, $v, $name)
1875
1876           Delete the named edge attribute.
1877
1878       set_edge_attributes
1879               $g->set_edge_attributes($u, $v, $attr)
1880
1881           Set all the attributes of the edge from the anonymous hash $attr.
1882
1883           NOTE: any attributes beginning with an underscore ("_") are
1884           reserved for the internal use of the Graph module.
1885
1886       get_edge_attributes
1887               $attr = $g->get_edge_attributes($u, $v)
1888
1889           Return all the attributes of the edge as an anonymous hash.
1890
1891       get_edge_attribute_names
1892               @name = $g->get_edge_attribute_names($u, $v)
1893
1894           Return the names of edge attributes.
1895
1896       get_edge_attribute_values
1897               @value = $g->get_edge_attribute_values($u, $v)
1898
1899           Return the values of edge attributes.
1900
1901       has_edge_attributes
1902               $g->has_edge_attributes($u, $v)
1903
1904           Return true if the edge has any attributes, false if not.
1905
1906       delete_edge_attributes
1907               $g->delete_edge_attributes($u, $v)
1908
1909           Delete all the attributes of the named edge.
1910
1911       If you are using multiedges, use the by_id variants:
1912
1913       set_edge_attribute_by_id
1914       get_edge_attribute_by_id
1915       has_edge_attribute_by_id
1916       delete_edge_attribute_by_id
1917       set_edge_attributes_by_id
1918       get_edge_attributes_by_id
1919       get_edge_attribute_names_by_id
1920       get_edge_attribute_values_by_id
1921       has_edge_attributes_by_id
1922       delete_edge_attributes_by_id
1923               $g->set_edge_attribute_by_id($u, $v, $id, $name, $value)
1924               $g->get_edge_attribute_by_id($u, $v, $id, $name)
1925               $g->has_edge_attribute_by_id($u, $v, $id, $name)
1926               $g->delete_edge_attribute_by_id($u, $v, $id, $name)
1927               $g->set_edge_attributes_by_id($u, $v, $id, $attr)
1928               $g->get_edge_attributes_by_id($u, $v, $id)
1929               $g->get_edge_attribute_values_by_id($u, $v, $id)
1930               $g->get_edge_attribute_names_by_id($u, $v, $id)
1931               $g->has_edge_attributes_by_id($u, $v, $id)
1932               $g->delete_edge_attributes_by_id($u, $v, $id)
1933
1934       For graph attributes:
1935
1936       set_graph_attribute
1937               $g->set_graph_attribute($name, $value)
1938
1939           Set the named graph attribute.
1940
1941           NOTE: any attributes beginning with an underscore ("_") are
1942           reserved for the internal use of the Graph module.
1943
1944       get_graph_attribute
1945               $value = $g->get_graph_attribute($name)
1946
1947           Return the named graph attribute.
1948
1949       has_graph_attribute
1950               $g->has_graph_attribute($name)
1951
1952           Return true if the graph has an attribute, false if not.
1953
1954       delete_graph_attribute
1955               $g->delete_graph_attribute($name)
1956
1957           Delete the named graph attribute.
1958
1959       set_graph_attributes
1960               $g->get_graph_attributes($attr)
1961
1962           Set all the attributes of the graph from the anonymous hash $attr.
1963
1964           NOTE: any attributes beginning with an underscore ("_") are
1965           reserved for the internal use of the Graph module.
1966
1967       get_graph_attributes
1968               $attr = $g->get_graph_attributes()
1969
1970           Return all the attributes of the graph as an anonymous hash.
1971
1972       get_graph_attribute_names
1973               @name = $g->get_graph_attribute_names()
1974
1975           Return the names of graph attributes.
1976
1977       get_graph_attribute_values
1978               @value = $g->get_graph_attribute_values()
1979
1980           Return the values of graph attributes.
1981
1982       has_graph_attributes
1983               $g->has_graph_attributes()
1984
1985           Return true if the graph has any attributes, false if not.
1986
1987       delete_graph_attributes
1988               $g->delete_graph_attributes()
1989
1990           Delete all the attributes of the named graph.
1991
1992   Weighted
1993       As convenient shortcuts the following methods add, query, and
1994       manipulate the attribute "weight" with the specified value to the
1995       respective Graph elements.
1996
1997       add_weighted_edge
1998               $g->add_weighted_edge($u, $v, $weight)
1999
2000       add_weighted_edges
2001               $g->add_weighted_edges($u1, $v1, $weight1, ...)
2002
2003       add_weighted_path
2004               $g->add_weighted_path($v1, $weight1, $v2, $weight2, $v3, ...)
2005
2006       add_weighted_vertex
2007               $g->add_weighted_vertex($v, $weight)
2008
2009       add_weighted_vertices
2010               $g->add_weighted_vertices($v1, $weight1, $v2, $weight2, ...)
2011
2012       delete_edge_weight
2013               $g->delete_edge_weight($u, $v)
2014
2015       delete_vertex_weight
2016               $g->delete_vertex_weight($v)
2017
2018       get_edge_weight
2019               $g->get_edge_weight($u, $v)
2020
2021       get_vertex_weight
2022               $g->get_vertex_weight($v)
2023
2024       has_edge_weight
2025               $g->has_edge_weight($u, $v)
2026
2027       has_vertex_weight
2028               $g->has_vertex_weight($v)
2029
2030       set_edge_weight
2031               $g->set_edge_weight($u, $v, $weight)
2032
2033       set_vertex_weight
2034               $g->set_vertex_weight($v, $weight)
2035
2036   Isomorphism
2037       Two graphs being isomorphic means that they are structurally the same
2038       graph, the difference being that the vertices might have been renamed
2039       or substituted.  For example in the below example $g0 and $g1 are
2040       isomorphic: the vertices "b c d" have been renamed as "z x y".
2041
2042               $g0 = Graph->new;
2043               $g0->add_edges(qw(a b a c c d));
2044               $g1 = Graph->new;
2045               $g1->add_edges(qw(a x x y a z));
2046
2047       In the general case determining isomorphism is NP-hard, in other words,
2048       really hard (time-consuming), no other ways of solving the problem are
2049       known than brute force check of of all the possibilities (with possible
2050       optimization tricks, of course, but brute force still rules at the end
2051       of the day).
2052
2053       A very rough guess at whether two graphs could be isomorphic is
2054       possible via the method
2055
2056       could_be_isomorphic
2057               $g0->could_be_isomorphic($g1)
2058
2059       If the graphs do not have the same number of vertices and edges, false
2060       is returned.  If the distribution of in-degrees and out-degrees at the
2061       vertices of the graphs does not match, false is returned.  Otherwise,
2062       true is returned.
2063
2064       What is actually returned is the maximum number of possible isomorphic
2065       graphs between the two graphs, after the above sanity checks have been
2066       conducted.  It is basically the product of the factorials of the
2067       absolute values of in-degrees and out-degree pairs at each vertex, with
2068       the isolated vertices ignored (since they could be reshuffled and
2069       renamed arbitrarily).  Note that for large graphs the product of these
2070       factorials can overflow the maximum presentable number (the floating
2071       point number) in your computer (in Perl) and you might get for example
2072       Infinity as the result.
2073
2074   Miscellaneous
2075       betweenness
2076               %b = $g->betweenness
2077
2078           Returns a map of vertices to their Freeman's betweennesses:
2079
2080             C_b(v) = \sum_{s \neq v \neq t \in V} \frac{\sigma_{s,t}(v)}{\sigma_{s,t}}
2081
2082           It is described in:
2083
2084               Freeman, A set of measures of centrality based on betweenness, http://arxiv.org/pdf/cond-mat/0309045
2085
2086           and based on the algorithm from:
2087
2088               "A Faster Algorithm for Betweenness Centrality"
2089
2090       clustering_coefficient
2091               $gamma = $g->clustering_coefficient()
2092               ($gamma, %clustering) = $g->clustering_coefficient()
2093
2094           Returns the clustering coefficient gamma as described in
2095
2096               Duncan J. Watts and Steven Strogatz, Collective dynamics of 'small-world' networks, http://audiophile.tam.cornell.edu/SS_nature_smallworld.pdf
2097
2098           In scalar context returns just the average gamma, in list context
2099           returns the average gamma and a hash of vertices to clustering
2100           coefficients.
2101
2102       subgraph_by_radius
2103               $s = $g->subgraph_by_radius($n, $radius);
2104
2105           Returns a subgraph representing the ball of $radius around node $n
2106           (breadth-first search).
2107
2108       The "expect" methods can be used to test a graph and croak if the graph
2109       call is not as expected.
2110
2111       expect_acyclic
2112       expect_dag
2113       expect_directed
2114       expect_hyperedged
2115       expect_hypervertexed
2116       expect_multiedged
2117       expect_multivertexed
2118       expect_no_args
2119       expect_non_multiedged
2120       expect_non_multivertexed
2121       expect_non_unionfind
2122       expect_undirected
2123
2124       In many algorithms it is useful to have a value representing the
2125       infinity.  The Graph provides (and itself uses):
2126
2127       Infinity
2128           (Not exported, use Graph::Infinity explicitly)
2129
2130   Size Requirements
2131       A graph takes up at least 1172 bytes of memory.
2132
2133       A vertex takes up at least 100 bytes of memory.
2134
2135       An edge takes up at least 400 bytes of memory.
2136
2137       (A Perl scalar value takes 16 bytes, or 12 bytes if it's a reference.)
2138
2139       These size approximations are very approximate and optimistic (they are
2140       based on total_size() of Devel::Size).  In real life many factors
2141       affect these numbers, for example how Perl is configured.  The numbers
2142       are for a 32-bit platform and for Perl 5.8.8.
2143
2144       Roughly, the above numbers mean that in a megabyte of memory you can
2145       fit for example a graph of about 1000 vertices and about 2500 edges.
2146
2147   Hyperedges, hypervertices, hypergraphs
2148       BEWARE: this is a rather thinly tested feature, and the theory is even
2149       less so.  Do not expect this to stay as it is (or at all) in future
2150       releases.
2151
2152       NOTE: most usual graph algorithms (and basic concepts) break horribly
2153       (or at least will look funny) with these hyperthingies.  Caveat emptor.
2154
2155       Hyperedges are edges that connect a number of vertices different from
2156       the usual two.
2157
2158       Hypervertices are vertices that consist of a number of vertices
2159       different from the usual one.
2160
2161       Note that for hypervertices there is an asymmetry: when adding
2162       hypervertices, the single vertices are also implicitly added.
2163
2164       Hypergraphs are graphs with hyperedges.
2165
2166       To enable hyperness when constructing Graphs use the "hyperedged" and
2167       "hypervertexed" attributes:
2168
2169          my $h = Graph->new(hyperedged => 1, hypervertexed => 1);
2170
2171       To add hypervertexes, either explicitly use more than one vertex (or,
2172       indeed, no vertices) when using add_vertex()
2173
2174          $h->add_vertex("a", "b")
2175          $h->add_vertex()
2176
2177       or implicitly with array references when using add_edge()
2178
2179          $h->add_edge(["a", "b"], "c")
2180          $h->add_edge()
2181
2182       Testing for existence and deletion of hypervertices and hyperedges
2183       works similarly.
2184
2185       To test for hyperness of a graph use the
2186
2187       is_hypervertexed
2188       hypervertexed
2189               $g->is_hypervertexed
2190               $g->hypervertexed
2191
2192       is_hyperedged
2193       hyperedged
2194               $g->is_hyperedged
2195               $g->hyperedged
2196
2197       Since hypervertices consist of more than one vertex:
2198
2199       vertices_at
2200               $g->vertices_at($v)
2201
2202       Return the vertices at the vertex.  This may return just the vertex or
2203       also other vertices.
2204
2205       To go with the concept of undirected in normal (non-hyper) graphs,
2206       there is a similar concept of omnidirected (this is my own coinage,
2207       "all-directions") for hypergraphs, and you can naturally test for it by
2208
2209       is_omnidirected
2210       omnidirected
2211       is_omniedged
2212       omniedged
2213              $g->is_omniedged
2214
2215              $g->omniedged
2216
2217              $g->is_omnidirected
2218
2219              $g->omnidirected
2220
2221           Return true if the graph is omnidirected (edges have no direction),
2222           false if not.
2223
2224       You may be wondering why on earth did I make up this new concept, why
2225       didn't the "undirected" work for me?  Well, because of this:
2226
2227          $g = Graph->new(hypervertexed => 1, omnivertexed => 1);
2228
2229       That's right, vertices can be omni, too - and that is indeed the
2230       default.  You can turn it off and then $g->add_vertex(qw(a b)) no more
2231       means adding also the (hyper)vertex qw(b a).  In other words, the
2232       "directivity" is orthogonal to (or independent of) the number of
2233       vertices in the vertex/edge.
2234
2235       is_omnivertexed
2236       omnivertexed
2237
2238       Another oddity that fell out of the implementation is the uniqueness
2239       attribute, that comes naturally in "uniqedged" and "uniqvertexed"
2240       flavours.  It does what it sounds like, to unique or not the vertices
2241       participating in edges and vertices (is the hypervertex qw(a b a) the
2242       same as the hypervertex qw(a b), for example).  Without too much
2243       explanation:
2244
2245       is_uniqedged
2246       uniqedged
2247       is_uniqvertexed
2248       uniqvertexed
2249
2250   Backward compatibility with Graph 0.2
2251       The Graph 0.2 (and 0.2xxxx) had the following features
2252
2253       ·   vertices() always sorted the vertex list, which most of the time is
2254           unnecessary and wastes CPU.
2255
2256       ·   edges() returned a flat list where the begin and end vertices of
2257           the edges were intermingled: every even index had an edge begin
2258           vertex, and every odd index had an edge end vertex.  This had the
2259           unfortunate consequence of "scalar(@e = edges)" being twice the
2260           number of edges, and complicating any algorithm walking through the
2261           edges.
2262
2263       ·   The vertex list returned by edges() was sorted, the primary key
2264           being the edge begin vertices, and the secondary key being the edge
2265           end vertices.
2266
2267       ·   The attribute API was oddly position dependent and dependent on the
2268           number of arguments.  Use ..._graph_attribute(),
2269           ..._vertex_attribute(), ..._edge_attribute() instead.
2270
2271       In future releases of Graph (any release after 0.50) the 0.2xxxx
2272       compatibility will be removed.  Upgrade your code now.
2273
2274       If you want to continue using these (mis)features you can use the
2275       "compat02" flag when creating a graph:
2276
2277           my $g = Graph->new(compat02 => 1);
2278
2279       This will change the vertices() and edges() appropriately.  This,
2280       however, is not recommended, since it complicates all the code using
2281       vertices() and edges().  Instead it is recommended that the
2282       vertices02() and edges02() methods are used.  The corresponding new
2283       style (unsorted, and edges() returning a list of references) methods
2284       are called vertices05() and edges05().
2285
2286       To test whether a graph has the compatibility turned on
2287
2288       is_compat02
2289       compat02
2290               $g->is_compat02
2291               $g->compat02
2292
2293       The following are not backward compatibility methods, strictly
2294       speaking, because they did not exist before.
2295
2296       edges02
2297           Return the edges as a flat list of vertices, elements at even
2298           indices being the start vertices and elements at odd indices being
2299           the end vertices.
2300
2301       edges05
2302           Return the edges as a list of array references, each element
2303           containing the vertices of each edge.  (This is not a backward
2304           compatibility interface as such since it did not exist before.)
2305
2306       vertices02
2307           Return the vertices in sorted order.
2308
2309       vertices05
2310           Return the vertices in random order.
2311
2312       For the attributes the recommended way is to use the new API.
2313
2314       Do not expect new methods to work for compat02 graphs.
2315
2316       The following compatibility methods exist:
2317
2318       has_attribute
2319       has_attributes
2320       get_attribute
2321       get_attributes
2322       set_attribute
2323       set_attributes
2324       delete_attribute
2325       delete_attributes
2326           Do not use the above, use the new attribute interfaces instead.
2327
2328       vertices_unsorted
2329           Alias for vertices() (or rather, vertices05()) since the vertices()
2330           now always returns the vertices in an unsorted order.  You can also
2331           use the unsorted_vertices import, but only with a true value (false
2332           values will cause an error).
2333
2334       density_limits
2335               my ($sparse, $dense, $complete) = $g->density_limits;
2336
2337           Return the "density limits" used to classify graphs as "sparse" or
2338           "dense".  The first limit is C/4 and the second limit is 3C/4,
2339           where C is the number of edges in a complete graph (the last
2340           "limit").
2341
2342       density
2343               my $density = $g->density;
2344
2345           Return the density of the graph, the ratio of the number of edges
2346           to the number of edges in a complete graph.
2347
2348       vertex
2349               my $v = $g->vertex($v);
2350
2351           Return the vertex if the graph has the vertex, undef otherwise.
2352
2353       out_edges
2354       in_edges
2355       edges($v)
2356           This is now called edges_at($v).
2357
2358   DIAGNOSTICS
2359       ·   Graph::...Map...: arguments X expected Y ...
2360
2361           If you see these (more user-friendly error messages should have
2362           been triggered above and before these) please report any such
2363           occurrences, but in general you should be happy to see these since
2364           it means that an attempt to call something with a wrong number of
2365           arguments was caught in time.
2366
2367       ·   Graph::add_edge: graph is not hyperedged ...
2368
2369           Maybe you used add_weighted_edge() with only the two vertex
2370           arguments.
2371
2372       ·   Not an ARRAY reference at lib/Graph.pm ...
2373
2374           One possibility is that you have code based on Graph 0.2xxxx that
2375           assumes Graphs being blessed hash references, possibly also
2376           assuming that certain hash keys are available to use for your own
2377           purposes.  In Graph 0.50 none of this is true.  Please do not
2378           expect any particular internal implementation of Graphs.  Use
2379           inheritance and graph/vertex/edge attributes instead.
2380
2381           Another possibility is that you meant to have objects (blessed
2382           references) as graph vertices, but forgot to use "refvertexed" (see
2383           "refvertexed") when creating the graph.
2384

ACKNOWLEDGEMENTS

2386       All bad terminology, bugs, and inefficiencies are naturally mine, all
2387       mine, and not the fault of the below.
2388
2389       Thanks to Nathan Goodman and Andras Salamon for bravely betatesting my
2390       pre-0.50 code.  If they missed something, that was only because of my
2391       fiendish code.
2392
2393       The following literature for algorithms and some test cases:
2394
2395       ·   Algorithms in C, Third Edition, Part 5, Graph Algorithms, Robert
2396           Sedgewick, Addison Wesley
2397
2398       ·   Introduction to Algorithms, First Edition, Cormen-Leiserson-Rivest,
2399           McGraw Hill
2400
2401       ·   Graphs, Networks and Algorithms, Dieter Jungnickel, Springer
2402

SEE ALSO

2404       Persistent/Serialized graphs?  You want to read/write Graphs?  See the
2405       Graph::Reader and Graph::Writer in CPAN.
2406

REPOSITORY

2408       <https://github.com/neilbowers/Graph>
2409

AUTHOR

2411       Jarkko Hietaniemi jhi@iki.fi
2412
2413       Now being maintained by Neil Bowers <neilb@cpan.org>
2414
2416       Copyright (c) 1998-2014 Jarkko Hietaniemi.  All rights reserved.
2417
2418       This is free software; you can redistribute it and/or modify it under
2419       the same terms as the Perl 5 programming language system itself.
2420
2421
2422
2423perl v5.32.0                      2020-07-28                          Graph(3)
Impressum