Graph automorphism

From Wikipedia, the free encyclopedia
Jump to: navigation, search

In the mathematical field of graph theory, an automorphism of a graph is a form of symmetry in which the graph is mapped onto itself while preserving the edge–vertex connectivity.

Formally, an automorphism of a graph G = (V,E) is a permutation σ of the vertex set V, such that the pair of vertices (u,v) form an edge if and only if the pair (σ(u),σ(v)) also form an edge. That is, it is a graph isomorphism from G to itself. Automorphisms may be defined in this way both for directed graphs and for undirected graphs. The composition of two automorphisms is another automorphism, and the set of automorphisms of a given graph, under the composition operation, forms a group, the automorphism group of the graph. In the opposite direction, by Frucht's theorem, all groups can be represented as the automorphism group of a connected graph – indeed, of a cubic graph.[1][2]

Contents

[edit] Computational complexity

Constructing the automorphism group is at least as difficult (in terms of its computational complexity) as solving the graph isomorphism problem, determining whether two given graphs correspond vertex-for-vertex and edge-for-edge. For, G and H are isomorphic if and only if the disconnected graph formed by the disjoint union of graphs G and H has an automorphism that swaps the two components.[3]

This drawing of the Petersen graph displays a subgroup of its symmetries, isomorphic to the dihedral group D5, but the graph has additional symmetries that are not present in the drawing (since the graph is symmetric, all links are equivalent, for example).

The graph automorphism problem is the problem of testing whether a graph has a nontrivial automorphism. It belongs to the class NP of computational complexity. Similar to the graph isomorphism problem, it is unknown whether it has a polynomial time algorithm or it is NP-complete.[4] There is a polynomial time algorithm for solving the graph automorphism problem for graphs where vertex degrees are bounded by a constant (Luks 1982). It is known that the graph automorphism problem is polynomial-time many-one reducible to the graph isomorphism problem, but the converse reduction is unknown.[5][6][7]

[edit] Algorithms, software and applications

While no worst-case polynomial-time algorithms are known for the general Graph Automorphism problem, finding the automorphism group (and printing out an irredundant set of generators) for many large graphs arising in applications is rather easy. Several open-source software tools are available for this task, including NAUTY,[8] BLISS[9] and SAUCY.[10][11] SAUCY and BLISS are particularly efficient for sparse graphs, e.g., SAUCY processes some graphs with millions of vertices in mere seconds. However, BLISS and NAUTY can also produce Canonical Labeling, whereas SAUCY is currently optimized for solving Graph Automorphism.

Practical applications of Graph Automorphism include graph drawing and other visualization tasks, solving structured instances of Boolean Satisfiability arising in the context of Formal verification and Logistics. Molecular symmetry can predict or explain chemical properties.

[edit] Symmetry display

Several graph drawing researchers have investigated algorithms for drawing graphs in such a way that the automorphisms of the graph become visible as symmetries of the drawing. This may be done either by using a method that is not designed around symmetries, but that automatically generates symmetric drawings when possible,[12] or by explicitly identifying symmetries and using them to guide vertex placement in the drawing.[13] It is not always possible to display all symmetries of the graph simultaneously, so it may be necessary to choose which symmetries to display and which to leave unvisualized.

[edit] Graph families defined by their automorphisms

Several families of graphs are defined by having certain types of automorphisms:

  • An asymmetric graph is an undirected graph without any nontrivial automorphisms.
  • A vertex-transitive graph is an undirected graph in which every vertex may be mapped by an automorphism into any other vertex.
  • An edge-transitive graph is an undirected graph in which every edge may be mapped by an automorphism into any other edge.
  • A symmetric graph is a graph such that every pair of adjacent vertices may be mapped by an automorphism into any other pair of adjacent vertices.
  • A distance-transitive graph is a graph such that every pair of vertices may be mapped by an automorphism into any other pair of vertices that are the same distance apart.
  • A semi-symmetric graph is a graph that is edge-transitive but not vertex-transitive.
  • A half-transitive graph is a graph that is vertex-transitive and edge-transitive but not symmetric.
  • A skew-symmetric graph is a directed graph together with a permutation σ on the vertices that maps edges to edges but reverses the direction of each edge. Additionally, σ is required to be an involution.

Inclusion relationships between these families are indicated by the following table:

Skeleton of the dodecahedron
Arrow east.svg
Shrikhande graph
Arrow west.svg
Paley graph
distance-transitive distance-regular strongly regular
Arrow south.svg
F26A graph
Arrow west.svg
Nauru graph
symmetric (arc-transitive) t-transitive, t ≥ 2
Arrow south.svg
(if connected)
Holt graph
Arrow east.svg
Folkman graph
Arrow east.svg
Complete bipartite graph K3,5
vertex- and edge-transitive edge-transitive and regular edge-transitive
Arrow south.svg
Arrow south.svg
Skeleton of the truncated tetrahedron
Arrow east.svg
Frucht graph
vertex-transitive regular
Arrow north.svg
Skeleton of the triangular prism
Cayley graph

[edit] See also

[edit] References

  1. ^ Frucht, R. (1938), "Herstellung von Graphen mit vorgegebener abstrakter Gruppe" (in German), Compositio Mathematica 6: 239–250, ISSN 0010-437X, Zbl 0020.07804, http://www.numdam.org/item?id=CM_1939__6__239_0 .
  2. ^ Frucht, R. (1949), "Graphs of degree three with a given abstract group", Canadian Journal of Mathematics 1 (4): 365–378, doi:10.4153/CJM-1949-033-6, ISSN 0008-414X, MR0032987, http://cms.math.ca/cjm/v1/p365 .
  3. ^ Luks, Eugene M. (1982), "Isomorphism of graphs of bounded valence can be tested in polynomial time", Journal of Computer and System Sciences 25 (1): 42–65, doi:10.1016/0022-0000(82)90009-5 .
  4. ^ A. Lubiw, "Some NP-complete problems similar to Graph Isomorphism", SIAM Journal on Computing, 1O:ll-21, 1981.
  5. ^ R. Mathon, "A note on the graph isomorphism counting problem", Information Processing Letters, 8 (1979) pp. 131-132
  6. ^ Köbler, Johannes; Uwe Schöning, Jacobo Torán (1993), Graph Isomorphism Problem: The Structural Complexity, Birkhäuser Verlag, ISBN 0817636803, OCLC 246882287 
  7. ^ Jacobo Torán, "On the Hardness of Graph Isomorphism", SIAM Journal on Computing, vol. 33, no. 5, 2004, pp. 1093-1108, doi:10.1137/S009753970241096X
  8. ^ McKay, Brendan (1981), "Practical Graph Isomorphism", Congressus Numerantium 30: 45–87, http://cs.anu.edu.au/people/bdm/nauty/pgi.pdf, retrieved 14 April 2011. 
  9. ^ Junttila, Tommi; Kaski, Petteri (2007), "Engineering an efficient canonical labeling tool for large and sparse graphs", Proceedings of the Ninth Workshop on Algorithm Engineering and Experiments (ALENEX07), http://www.siam.org/proceedings/alenex/2007/alx07_013junttilat.pdf. 
  10. ^ Darga, Paul; Sakallah, Karem; Markov, Igor L. (June 2008), "Faster Symmetry Discovery using Sparsity of Symmetries", Proceedings of the 45st Design Automation Conference: 149–154, doi:10.1145/1391469.1391509, ISBN 9781605581156, http://vlsicad.eecs.umich.edu/BK/SAUCY/saucy-dac08.pdf. 
  11. ^ Katebi, Hadi; Sakallah, Karem; Markov, Igor L. (July 2010), "Symmetry and Satisfiability: An Update", Proc. Satisfiability Symposium (SAT), http://www.eecs.umich.edu/~imarkov/pubs/conf/sat10-sym.pdf. 
  12. ^ Di Battista, Giuseppe; Tamassia, Roberto; Tollis, Ioannis G. (1992), "Area requirement and symmetry display of planar upward drawings", Discrete and Computational Geometry 7 (1): 381–401, doi:10.1007/BF02187850 ; Eades, Peter; Lin, Xuemin (2000), "Spring algorithms and symmetry", Theoretical Computer Science 240 (2): 379–405, doi:10.1016/S0304-3975(99)00239-X .
  13. ^ Hong, Seok-Hee (2002), "Drawing Graphs Symmetrically in Three Dimensions", Proc. 9th Int. Symp. Graph Drawing (GD 2001), Lecture Notes in Computer Science, 2265, Springer-Verlag, pp. 106–108, doi:10.1007/3-540-45848-4_16, ISBN 978-3-540-43309-5 .
Personal tools
Namespaces
Variants
Actions
Navigation
Interaction
Toolbox
Print/export
Languages