21232
Comment:
|
22516
|
Deletions are marked like this. | Additions are marked like this. |
Line 134: | Line 134: |
I. [https://networkx.lanl.gov/ NetworkX], seems pretty comprehensive, released under "GNU Lesser General Public License", works on Python $\geq$ 2.3, interfaces with Matplotlib, Pygraphviz, Graphviz, Pydot, numpy or Numeric, Ipython, SciPy, PyGSL, sAsync, PyYAML: EXCELLENT documentation | I. [https://networkx.lanl.gov/ NetworkX], seems pretty comprehensive, released under "GNU Lesser General Public License", works on Python $\geq$ 2.3, interfaces with Matplotlib, Pygraphviz, Graphviz, Pydot, numpy or Numeric, Ipython, !SciPy, PyGSL, sAsync, PyYAML: EXCELLENT documentation with links to source code from each function descriptor (TODO: make sense of networkx.utils, networkx.threshold) |
Line 139: | Line 139: |
1. '''Construction''' 1. '''Decorations''' (Coloring, Weight, Flow, etc.) 1. '''Invariants''' 1. '''Predicates''' 1. '''Subgraphs and Subsets''' 1. '''Adjacency, etc.''' 1. '''Connectivity''' 1. '''Paths, etc.''' 1. '''Trees, etc.''' |
. 'convert' module converts NetworkX graphs to and from other formats: python dict of lists, python dict of dicts, numpy matrices, scipy sparse matrices, pygraphviz; 1. '''Construction''' . add path, add cycle, incremental construction, subgraphs, copy, directed $\leftrightarrow$ undirected 1. '''Decorations''' (Coloring, Weight, Flow, etc.) 1. '''Invariants''' . density, 1. '''Predicates''' . standard predicates, 1. '''Subgraphs and Subsets''' . find cliques (Bron & Kerbosch), maximal and bipartite clique graph constructor, project bipartite onto one part (connected if they share a common Top/Bottom Node), clique number and number of maximal cliques, find cliques containing specified node, 1. '''Adjacency, etc.''' . neighbors, degree, 1. '''Connectivity''' . find k-cores of a graph, 1. '''Paths, etc.''' 1. '''Trees, etc.''' . tree class, rooted/directed/forests (experimental classes) |
Line 150: | Line 158: |
. clustering: number of triangles for given nodes, clustering coefficients (fraction of triads, which is edge vertex edge, that are triangles), transitivity (3*triangles/triads); | |
Line 153: | Line 162: |
. non-isomorphic checker (does not check isomorphism; only conclusive in the not-isomorphic direction), three versions: fast, faster and fastest | |
Line 154: | Line 164: |
. betweenness, edge, degree, and closeness centrality |
Introduction
The SAGE Graph Theory Project aims to implement Graph objects and algorithms in ["SAGE"].
The main people working on this project are Emily Kirkman and Robert Miller.
Survey of existing Graph Theory software
- Software included with SAGE
- GAP
- Maxima
- Singular
- PARI, MWRANK, NTL
- Matplotlib
- GSL, Numeric
- Software SAGE interfaces with (but does not include)
[http://magma.maths.usyd.edu.au/magma/htmlhelp/text1452.htm Magma]
Representation
- Sparse support; function computes memory requirement for graph with n verts and m edges; consists of graph itself, vertex set, and edge set
Storage/Pipes
one function opens either file or stream, files stored in [http://cs.anu.edu.au/~bdm/data/formats.html Graph6 and Sparse6 format]
Construction
From matrix; from edge tuples; from vertex neighbors; from edges of other graphs; subgraphs; quotient graphs; incremental construction; complement; contraction; breaking edges; line graph; switch nbrs for non-nbrs of a vertex; disjoint unions, edge unions; complete unions; cartesian, lexicographic and tensor products; n-th power (same vert set, incident iff dist \leq n); graph \leftrightarrow digraph; Cayley graph constructor; Schreier graph constructor; Orbital graph constructor; Closure graph constructor (given G, add edges to make G invariant under a given permutation group); Paley graphs and tournaments; graphs from incidence structures; converse(reverse digraph); n-th odd graph; n-th triangular graph; n-th square lattice graph; Clebsch, Shrikhande, Gewirtz and Chang graphs;
Decorations (Coloring, Weight, Flow, etc.)
- Vertices have labels only; Edges have labels, capacity(non-negative integers, loops=0) and weights(totally ordered ring);
Invariants
- #verts, #edges; characteristic polynomial; spectrum
Predicates
- 2 verts incident, 2 edges incident, 1 vertex and 1 edge incident, subgraph, bipartite, complete, Eulerian, tree, forest, empty, null, path, polygon, regular
Subgraphs and Subsets
has k-clique, clique number, all cliques, maximum clique ([http://magma.maths.usyd.edu.au/magma/htmlhelp/text1473.htm "When comparing both algorithms in the situation where the problem is to find a maximum clique one observes that in general BranchAndBound does better. However Dynamic outperforms BranchAndBound when the graphs under consideration are large (more then 400 vertices) random graphs with high density (larger than 0.5%). So far, it can only be said that the comparative behaviour of both algorithms is highly dependent on the structure of the graphs."]), independent sets and number,
Adjacency, etc.
(in- & out-) degree, degree vector, valence (if regular), vertex nbrs, edge nbrs, bipartition, dominating sets
Connectivity
(strongly) connected, components, separable, 2-connected, 2-components, triconnectivity ([http://magma.maths.usyd.edu.au/magma/htmlhelp/text1466.htm "The linear-time triconnectivity algorithm by Hopcroft and Tarjan (HT73) has been implemented with corrections of our own and from C. Gutwenger and P. Mutzel (GM01). This algorithm requires that the graph has a sparse representation."]), k-vertex connectivity, vertex separator, k-edge connectivity, edge separator
Paths, etc.
- distance and geodesic, diameter and corr. path, ball and sphere, distance partition, equitable partition, girth and corr. cycle
Trees, etc.
- spanning tree, breadth first and depth first searches, rooted, root, parent, vertex paths
Colorings(see also Decorations)
- chromatic number and index, optimal vertex and edge colorings, chromatic polynomial
Optimization
Max flow min cut (2 algorithms: [http://magma.maths.usyd.edu.au/magma/htmlhelp/text1499.htm#15274 Dinic & push-relabel]), maximum matching for bipartite,
Embedding (Planar graphs, etc.)
- planarity, Kuratowski subgraphs, faces of a planar graph, embedding info as orientation of edges from a vertex
Algebra
- adjacency matrix, distance matrix, incidence matrix, intersection matrix
Morphisms/Group Actions
interfaces nauty
Symmetry
- vertex, edge and distance transitivity; orbit partitions; primitivity; symmetric; distance regularity and intersection array
Geometry
- Go back and forth between incidence and coset geometries and their graphs; finite planes;
Generation/Random Graphs
interfaces nauty
Database
- database interface, strongly regular graph DB, random graph from DB, slick implementation of for loops ("for G in D do ... end for;")
Maple: networks package, which includes:
Representation
- ?
Construction
- new (0 verts), void (n verts, 0 edges), incremental construction, complement, complete, contraction, hypercubes, cycle, petersen, cube, icosahedron, dodecahedron, octahedron, tetrahedron, simplify a multigraph, union, subgraphs,
Decorations (Coloring, Weight, Flow, etc.)
- vertex weights default to 0, edge weights default to 1 (can be any valid maple expression)
Invariants
- characteristic polynomial
Adjacency, etc.
in-nbrs(arrivals), out-nbrs(departures), degree sequence, endpoints, graphical ("tests whether intlist is the degree sequence of a simple graph"), edge-nbrs, vert-nbrs, in-degree, out-degree, max & min degree, edge span & span polynomial ("The span polynomial in variable p gives the probability that G is spanning when each edge operates with probability p.", "When G is connected, this is the all-terminal reliability polynomial of G, and gives the probability that G is connected when each edge operates independently with probability p."),
Connectivity
components, edge-connectivity, 2-components, count minimal cutsets, rank ("The rank of an edgeset e is the number of vertices of G minus the number of components of the subgraph induced by e."), Whitney rank polynomial ("The rank polynomial is a sum over all subgraphs H of G of x^{(rank(G) - rank(H))} y^{corank(H)}."),
Paths, etc.
- diameter, fundcyc ("Given a subset e of edges forming a unicyclic subgraph of a graph G, the edges forming the unique cycle are returned as a set. It is assumed that only one cycle is present."), girth, find path from a to b,
Trees, etc.
ancestor, daughter, count spanning trees (Kirchoff Matrix-Tree theorem), cycle base ("A spanning tree is found, and fundcyc() is then used to find all fundamental cycles with respect to this tree. They are returned as a set of cycles with each cycle being represented by a set of edges."), edge disjoint spanning tree, shortest path spanning tree, min weight spanning tree, Tutte polynomial ("The Tutte polynomial is a sum over all maximal forests H of G of t^{ia(H)} z^{ea(H)} where ia(H) is the internal activity of H and ea(H) is the external activity of H.")
Colorings
- chromatic polynomial,
Optimization
- maximum flow (flow), Dinic algorithm for max flow (see Magma), flow polynomial ("The flow polynomial in variable h gives the number of nowhere-zero flows on G with edge labels chosen from integers modulo h."), minimum cut,
Embedding (Planar graphs, etc.)
- isplanar,
Algebra
- acycpoly ("The acyclicity polynomial in variable p gives the probability that G is acyclic when each edge operates with probability p."), adjacency matrix, distance table (allpairs- optional table gives shortest path trees, rooted at each vertex), incidence matrix,
Generation/Random Graphs
- random graphs- specify #verts and prob of edge occuring, or #verts and #edges
Database
- show command shows a table of known information about a network
Visualization
- plots graphs either in lines (Linear) or in concentric circles (Concentric), ability to give specific graphs specific plotting procedures, 3d plots ("The location of the vertices of the graph is determined as follows. Let A be the adjacency matrix of G and let u, v and w be three eigenvectors of A with corresponding second, third, and fourth largest eigenvalue in absolute value. Then the (x,y,z) coordinates of the ith vertex of G is (u[i],v[i],w[i])."; "Sometimes other symmetries in the graph can be seen by using other eigenvectors. If the optional argument eigenvectors = [e1, e2, e3] is specified, where e1, e2, and e3 are vertex numbers (integers from 1 through the number of vertices), the eigenvectors corresponding to the eigenvalues of these relative magnitudes are used.")
Mathematica: [http://documents.wolfram.com/mathematica/Built-inFunctions/AdvancedDocumentation/DiscreteMath/GraphPlot/ GraphPlot] ([http://documents.wolfram.com/mathematica/Built-inFunctions/AdvancedDocumentation/DiscreteMath/GraphPlot/AdvancedDocumentationGraphPlotReferences.html biblio]) is built-in: also a few functions for "applications" (?); designed to work well with large graphs; also supports graphs from Combinatorica
Representation
graph simply is an adjacency matrix (could be sparse), or a list of rules (e.g. {1->2, 2->3, 3->4, 4->1})
Construction
- N/A (see representation)
Predicates
- vertex list (apparently only nontrivial when graph is a rule list, see representation)
Subgraphs and Subsets
- maximal independent vertex sets and edge sets,
Connectivity
- list strongly connected components,
Paths, etc.
distance, pseudo-diameter (see [http://documents.wolfram.com/mathematica/Built-inFunctions/AdvancedDocumentation/DiscreteMath/GraphPlot/AdvancedDocumentationGraphPlotPseudoDiameter.html Documentation])
Trees, etc.
[http://documents.wolfram.com/mathematica/Built-inFunctions/AdvancedDocumentation/DiscreteMath/GraphPlot/AdvancedDocumentationGraphPlotTreePlot.html TreePlot] uses the layered drawing algorithm, implements more control:
Optimization
maximum matching for bipartite, [http://documents.wolfram.com/mathematica/Built-inFunctions/AdvancedDocumentation/DiscreteMath/GraphPlot/AdvancedDocumentationGraphPlotMinCut.html min cut] problem
Visualization
[http://documents.wolfram.com/mathematica/Built-inFunctions/AdvancedDocumentation/DiscreteMath/GraphPlot/AdvancedDocumentationGraphPlotGraphPlotAndGraphPlot3D.html ALGORITHMS] include spring model, spring-electrical model, high-dimensional embedding (random seeds can be given for spring models, link includes options for the spring models); tree algorithms include radial drawing, layered drawing (see G. Di Battista, P. Eades, R. Tamassia, and I. G. Tollis, Algorithms for the Visualization of Graphs, Prentice-Hall, 1999.); vertex styles and colors, edge styles and colors; function to return coordinates without drawing
- Extensions of software that SAGE interfaces with
- Magma
- Maple
[http://www.math.uga.edu/~mbaker/REU/maple/laplacian-guide.html 'laplacian.mpl']; [http://www.fmf.uni-lj.si/~mohar/Papers/Spec.pdf here] is a paper on the Laplacian Spectrum
Storage/Pipes
- creation of certain spreadsheets, such as known eigenvalues and eigenvalues of increasing subdivisions of the graph
Construction
- banana graphs, star graphs, bouquets and flowers, hypercubes, supercirc (see docs), subdivide edges into n edges, contract, assign directions (apparently in a random way)
Decorations (Coloring, Weight, Flow, etc.)
- normalilze (so sum of weights = 1)
Algebra
- discrete laplacian matrix (this function may fight with the built-in laplacian in 'linalg'), compute its eigenvalues given a measure,
Topology
(laplacian matrix), effective resistance between vertices, discrete and continuous canonical measure [http://www.math.uga.edu/~mbaker/REU/tex/canonical.pdf#search=%22graph%20tau%22 an unrelated explanation?] and tau (also, taushorten "Investigates the behavior of tau as an edge is shortened"), discrete dx measure
[http://www.cecm.sfu.ca/CAG/papers/GTpaper.pdf GraphTheory] and [http://www.cecm.sfu.ca/CAG/papers/GT2006.pdf Part II] of the paper (haven't yet found the actual package...)
- Mathematica
[http://www.combinatorica.com/ Combinatorica] - for a list of functions, see [http://www.cs.sunysb.edu/~skiena/combinatorica/help.pdf help.pdf], page 13-14, 18, 21, 23, 25 - for a [http://www.amazon.com/exec/obidos/ASIN/0521806860/ref=nosim/thealgorithmrepo/ book]
- Software that SAGE can now include as is (not as an optional package...)
[http://gato.sourceforge.net/ Gato], a tool that animates algorithms, perhaps SAGE cannot actually include right now as is, but license is LGPL, and it requires Python and Tcl/Tk
- seems that you can write your algorithm in one window and watch it go, supports 3d
[https://networkx.lanl.gov/ NetworkX], seems pretty comprehensive, released under "GNU Lesser General Public License", works on Python \geq 2.3, interfaces with Matplotlib, Pygraphviz, Graphviz, Pydot, numpy or Numeric, Ipython, SciPy, PyGSL, sAsync, PyYAML: EXCELLENT documentation with links to source code from each function descriptor (TODO: make sense of networkx.utils, networkx.threshold)
Representation
in Graph and DiGraph, "data structures based on an adjacency list implemented as a node-centric dictionary of dictionaries. The dictionary contains keys corresponding to the nodes and the values are dictionaries of neighboring node keys with the value None (the Python None type). This allows fast addition, deletion and lookup of nodes and neighbors in large graphs"
"The XGraph and XDiGraph classes are extensions of the Graph and DiGraph classes... The key difference is that an XGraph edge is a 3-tuple e=(n1,n2,x), representing an undirected edge between nodes n1 and n2 that is decorated with the object x. Here n1 and n2 are (hashable) node objects and x is a (not necessarily hashable) edge object. Since the edge is undirected, edge (n1,n2,x) is equivalent to edge (n2,n1,x). An XDiGraph edge is a similar 3-tuple e=(n1,n2,x), with the additional property of directedness. I.e. e=(n1,n2,x) is a directed edge from n1 to n2 decorated with the object x, and is not equivalent to the edge (n2,n1,x). Whether a graph or digraph allow self-loops or multiple edges is determined at the time of object instantiation via specifying the parameters selfloops=True/False and multiedges=True/False."
Storage/Pipes
- 'convert' module converts NetworkX graphs to and from other formats: python dict of lists, python dict of dicts, numpy matrices, scipy sparse matrices, pygraphviz;
Construction
add path, add cycle, incremental construction, subgraphs, copy, directed \leftrightarrow undirected
Decorations (Coloring, Weight, Flow, etc.)
Invariants
- density,
Predicates
- standard predicates,
Subgraphs and Subsets
find cliques (Bron & Kerbosch), maximal and bipartite clique graph constructor, project bipartite onto one part (connected if they share a common Top/Bottom Node), clique number and number of maximal cliques, find cliques containing specified node,
Adjacency, etc.
- neighbors, degree,
Connectivity
- find k-cores of a graph,
Paths, etc.
Trees, etc.
- tree class, rooted/directed/forests (experimental classes)
Colorings
Optimization
- clustering: number of triangles for given nodes, clustering coefficients (fraction of triads, which is edge vertex edge, that are triangles), transitivity (3*triangles/triads);
Embedding (Planar graphs, etc.)
Algebra
Morphisms/Group Actions
- non-isomorphic checker (does not check isomorphism; only conclusive in the not-isomorphic direction), three versions: fast, faster and fastest
Symmetry
- betweenness, edge, degree, and closeness centrality
Geometry
Topology
Generation/Random Graphs
Database
Visualization
- Software that SAGE should include (or maybe interface with, or include as optional), pending stuff (e.g. licensing)
[http://cs.anu.edu.au/~bdm/nauty/ Nauty]
- Benchmark program
Source posted, but no public license - should contact Brendan McKay
- Written in portable subset of C, python wrapper already in existence (see pynauty)
- Nauty interfaces with MAGMA and GRAPE (GAP package)
Construction
- includes gtools - quick generators for non-isomorphic graphs, also generates bipartite graphs and digraphs
Invariants
- canonical labelling
Morphisms/Group Actions
- Computing automorphism groups of graphs and digraphs, isomorphism testing
[http://www.graphviz.org GraphViz]
- open source, Common Public License Version 1.0
- poorly documented, at least on the web
Visualization
- DOT makes "hierarchical" drawings of directed graphs. Algorithm aims edges in same direction and attempts to not cross edges and reduce length. NEATO uses spring method, via the Kamada-Kawai algorithm (statistical multi-dimensional scaling) fdp also uses the spring model, via the Fruchterman-Reingold heuristic (handles larger graphs and undirected, clustered graphs)
[http://cs.anu.edu.au/people/bdm/plantri/ plantri and fullgen] written in C, tested mainly on UNIX, weird license ('free for all purposes other than sale for profit. However, they remain subject to our copyright and are not "public domain".'): interesting note, co-authored by Brendan McKay, of nauty
Generation/Random Graphs
- plantri: "exactly one member of each isomorphism class is output without the need for storing them. The speed of generation is more than 100,000 graphs per second in most cases, so extremely large classes of graph can be exhaustively listed.", classes include planar triangulations, quadrangulations, simple graphs, triangulations of a disc, planar cubic and quartic graphs
- fullgen generates fullerenes
see also [http://hep.physics.indiana.edu/~tsulanke/graphs/surftri/ surftri], which generates triangulations of surfaces of higher genus
- Software that is incompatible with SAGE but still useful (e.g. web-based applets)
[http://www.geocities.com/pechv_ru/ GRIN]
- for windows only
- not open-source, but free download
Connectivity
- bridges and cutpoints
Paths, etc.
- Paths and Cycles (Eulerian and Hamiltonian), Shortest Paths, Max Capacity Path, K Shortest paths, Critical path
Trees, etc.
- Minimal spanning tree
Optimization
- Max Flow
Morphisms/Group Actions
- Automorphism group
Topology
- Metrics of the graph Density, Undensity and so on...)
Visualization
- 2d only, Clipboard edit, decomposition of edges, resize
[http://prolland.free.fr/works/research/dsatphp/dsat.html DSATUR], a program for computing graph colorings, algorithm [http://prolland.free.fr/works/research/dsat/index.html#anchor38034 documentation] in French, input in [http://mat.gsia.cmu.edu/COLOR/general/ccformat.ps DIMACS] format, [http://prolland.free.fr/works/research/dsatphp/dsat.txt source code]
- Algorithm descriptions for specific problems
[http://rtm.science.unitn.it/intertools/ InterTools]
- Maximum Clique in Graphs (MAX-CLIQUE)
- Graph Partitioning (equicut)
- Quadratic Assignment Problem (QAP)
- Apparently useless / and/or misc. / and/or etc.
[http://www.npac.syr.edu/NPAC1/PUB/ranka/part/part.html Scalable Libraries for Graph Partitioning], no software yet, but good references on page: "Efficient methods for graph partitioning and incremental graph partitioning are important for parallelization of a large number of unstructured and/or adaptive applications."
Functionality categories
Representation
Storage/Pipes
Construction
Decorations (Coloring, Weight, Flow, etc.)
Invariants
Predicates
Subgraphs and Subsets
Adjacency, etc.
Connectivity
Paths, etc.
Trees, etc.
Colorings
Optimization
Embedding (Planar graphs, etc.)
Algebra
Morphisms/Group Actions
Symmetry
Geometry
Topology
Generation/Random Graphs
Database
Visualization