Adjacency matrix
In graph theory and computer science, an adjacency matrix is a square matrix used to represent a finite graph. The elements of the
matrix indicate whether pairs of vertices are adjacent or not in the graph.
In the special case of a finite simple graph, the adjacency matrix is a (0,1)-matrix with zeros on its diagonal. If the graph is
undirected, the adjacency matrix is symmetric. The relationship between a graph and the eigenvalues and eigenvectors of its
adjacency matrix is studied inspectral graph theory.
The adjacency matrix should be distinguished from theincidence matrix for a graph, a different matrix representation whose elements
indicate whether vertex–edge pairs are incident or not, anddegree matrix which contains information about thedegree of each vertex.
Contents
1 Definition
1.1 Adjacency matrix of a bipartite graph
1.2 Variations
2 Examples
2.1 Undirected graphs
2.2 Directed graphs
2.3 Trivial graphs
3 Properties
3.1 Spectrum
3.2 Isomorphism and invariants
3.3 Matrix powers
4 Data structures
5 See also
6 References
7 External links
Definition
For a simple graph with vertex set V, the adjacency matrix is a square |V| × |V| matrix A such that its element Aij is one when there is
an edge from vertex i to vertex j, and zero when there is no edge.[1] The diagonal elements of the matrix are all zero, since edges from
a vertex to itself (loops) are not allowed in simple graphs. It is also sometimes useful in algebraic graph theory to replace the nonzero
elements with algebraic variables.[2]
The same concept can be extended tomultigraphs and graphs with loops by storing the number of edges between each two vertices in
the corresponding matrix element, and by allowing nonzero diagonal elements. Loops may be counted either once (as a single edge)
or twice (as two vertex-edge incidences), as long as a consistent convention is followed. Undirected graphs often use the latter
convention of counting loops twice, whereas directed graphs typically use the former convention.
Adjacency matrix of a bipartite graph
The adjacency matrixA of a bipartite graph whose two parts haver and s vertices can be written in the form
where B is an r × s matrix, and 0r,r and 0s,s represent the r × r and s × s zero matrices. In this case, the smaller matrix B uniquely
represents the graph, and the remaining parts ofA can be discarded as redundant.B is sometimes called the biadjacency matrix.
Formally, let G = (U, V, E) be a bipartite graph with parts U = {u1, …, ur} and V = {v1, …, vs}. The biadjacency matrix is the r × s
0–1 matrix B in which bi,j = 1 if and only if (ui, vj) ∈ E.
If G is a bipartite multigraph or weighted graph then the elements bi,j are taken to be the number of edges between the vertices or the
weight of the edge (ui, vj), respectively.
Variations
An (a, b, c)-adjacency matrix A of a simple graph has Ai,j = a if (i, j) is an edge, b if it is not, and c on the diagonal. The Seidel
adjacency matrix is a (−1, 1, 0)-adjacency matrix. This matrix is used in studyingstrongly regular graphsand two-graphs.[3]
The distance matrix has in position (i, j) the distance between vertices vi and vj. The distance is the length of a shortest path
connecting the vertices. Unless lengths of edges are explicitly provided, the length of a path is the number of edges in it. The distance
matrix resembles a high power of the adjacency matrix, but instead of telling only whether or not two vertices are connected (i.e., the
connection matrix, which contains boolean values), it gives the exact distance between them.
Examples
Undirected graphs
The convention followed here (for undirected graphs) is that each edge adds 1 to the appropriate cell in the matrix, and each loop
adds 2.[4] This allows the degree of a vertex to be easily found by taking the sum of the values in either its respective row or column
in the adjacency matrix.
Labeled graph Adjacency matrix
Coordinates are 1–6.
Coordinates are 0–23.
Nauru graph
White fields are zeros, colored fields are ones.
Directed graphs
In directed graphs, the in-degree of a vertex can be computed by summing the entries of the corresponding column, and the out-
degree can be computed by summing the entries of the corresponding row
.
Labeled graph Adjacency matrix
Coordinates are 0–23.
Directed Cayley graph of S4
As the graph is directed, the matrix is notsymmetric.
Trivial graphs
The adjacency matrix of a complete graph contains all ones except along the diagonal where there are only zeros. The adjacency
matrix of an empty graph is a zero matrix.
Properties
Spectrum
The adjacency matrix of an undirected simple graph is symmetric, and therefore has a complete set of real eigenvalues and an
orthogonal eigenvector basis. The set of eigenvalues of a graph is the spectrum of the graph.[5] It is common to denote the
eigenvalues by
The greatest eigenvalue is bounded above by the maximum degree. This can be seen as result of the Perron–Frobenius theorem,
but it can be proved easily. Let v be one eigenvector associated to and x the component in which v has maximum absolute value.
Without loss of generality assumevx is positive since otherwise you simply take the eigenvector , also associated to . Then
For d-regular graphs, d is the first eigenvalue of A for the vector v = (1, …, 1) (it is easy to check that it is an eigenvalue and it is the
maximum because of the above bound). The multiplicity of this eigenvalue is the number of connected components of G, in
particular for connected graphs. It can be shown that for each eigenvalue , its opposite is also an
eigenvalue of A if G is a bipartite graph. In particular −d is an eigenvalue of bipartite graphs.
The difference is called the spectral gap and it is related to the expansion of G. It is also useful to define the amount
. This number is bounded by . This bound is tight in the Ramanujan graphs, which
have applications in many areas.
Isomorphism and invariants
Suppose two directed or undirected graphs G1 and G2 with adjacency matrices A1 and A2 are given. G1 and G2 are isomorphic if and
only if there exists a permutation matrix P such that
In particular, A1 and A2 are similar and therefore have the same minimal polynomial, characteristic polynomial, eigenvalues,
determinant and trace. These can therefore serve as isomorphism invariants of graphs. However
, two graphs may possessthe same set
of eigenvalues but not be isomorphic.[6] Such linear operators are said to be isospectral.
Matrix powers
If A is the adjacency matrix of the directed or undirected graph G, then the matrix An (i.e., the matrix product of n copies of A) has an
interesting interpretation: the element (i, j) gives the number of (directed or undirected) walks of length n from vertex i to vertex j. If
n is the smallest nonnegative integer, such that for some i, j, the element (i, j) of An is positive, then n is the distance between vertex i
and vertex j. This implies, for example, that the number of triangles in an undirected graph G is exactly the trace of A3 divided by 6.
Note that the adjacency matrix can be used to determine whether or not the graph is
connected.
Data structures
The adjacency matrix may be used as a data structure for the representation of graphsin computer programs for manipulating graphs.
The main alternative data structure, also in use for this application, is theadjacency list.[7][8]
Because each entry in the adjacency matrix requires only one bit, it can be represented in a very compact way, occupying only |V |2/8
bytes to represent a directed graph, or (by using a packed triangular format and only storing the lower triangular part of the matrix)
approximately |V |2/16 bytes to represent an undirected graph. Although slightly more succinct representations are possible, this
method gets close to the information-theoretic lower bound for the minimum number of bits needed to represent all n-vertex
graphs.[9] For storing graphs in text files, fewer bits per byte can be used to ensure that all bytes are text characters, for instance by
using a Base64 representation.[10] Besides avoiding wasted space, this compactness encourages locality of reference. However, for a
large sparse graph, adjacency lists require less storage space, because they do not waste any space to represent edges that are not
present.[8][11]
An alternative form of adjacency matrix (which, however, requires a larger amount of space) replaces the numbers in each element of
the matrix with pointers to edge objects (when edges are present) or null pointers (when there is no edge).[11] It is also possible to
store edge weights directly in the elements of an adjacency matrix.[8]
Besides the space tradeoff, the different data structures also facilitate different operations. Finding all vertices adjacent to a given
vertex in an adjacency list is as simple as reading the list, and takes time proportional to the number of neighbors. With an adjacency
matrix, an entire row must instead be scanned, which takes a larger amount of time, proportional to the number of vertices in the
whole graph. On the other hand, testing whether there is an edge between two given vertices can be determined at once with an
[8][11]
adjacency matrix, while requiring time proportional to the minimum degree of the two vertices with the adjacency list.
See also
Laplacian matrix
Self-similarity matrix
References
1. Biggs, Norman (1993),Algebraic Graph Theory, Cambridge Mathematical Library (2nd ed.), Cambridge University
Press, Definition 2.1, p. 7.
2. Harary, Frank (1962), "The determinant of the adjacency matrix of a graph",SIAM Review, 4 (3): 202–210,
Bibcode:1962SIAMR...4..202H (http://adsabs.harvard.edu/abs/1962SIAMR...4..202H) , doi:10.1137/1004057 (https://
doi.org/10.1137%2F1004057), MR 0144330 (https://www.ams.org/mathscinet-getitem?mr=0144330).
3. Seidel, J. J. (1968). "Strongly Regular Graphs with (−1, 1, 0) Adjacency Matrix Having Eigenvalue 3".
Lin. Alg. Appl.
1 (2): 281–298. doi:10.1016/0024-3795(68)90008-6(https://doi.org/10.1016%2F0024-3795%2868%2990008-6) .
4. Shum, Kenneth; Blake, Ian (2003-12-18)."Expander graphs and codes"(https://books.google.com/books?id=wp7Xs
CAm_9EC&pg=PA63). Volume 68 of DIMACS series in discrete mathematics and theoretical computer science.
Algebraic Coding Theory and Information Theory: DIMACS W orkshop, Algebraic Coding Theory and Information
Theory. American Mathematical Society. p. 63.
5. Biggs (1993), Chapter 2 ("The spectrum of a graph"), pp. 7–13.
6. Godsil, Chris; Royle, Gordon Algebraic Graph Theory, Springer (2001), ISBN 0-387-95241-1, p.164
7. Goodrich & Tamassia (2015), p. 361: "There are two data structures that people often use to represent graphs, the
adjacency list and the adjacency matrix."
8. Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Stein, Clifford (2001), "Section 22.1: Representations
of graphs", Introduction to Algorithms(Second ed.), MIT Press and McGraw-Hill, pp. 527–531,ISBN 0-262-03293-7.
9. Turán, György (1984), "On the succinct representation of graphs", Discrete Applied Mathematics, 8 (3): 289–294,
doi:10.1016/0166-218X(84)90126-4(https://doi.org/10.1016%2F0166-218X%2884%2990126-4) , MR 0749658 (http
s://www.ams.org/mathscinet-getitem?mr=0749658).
10. McKay, Brendan, Description of graph6 and sparse6 encodings(http://cs.anu.edu.au/~bdm/data/formats.txt).
11. Goodrich, Michael T.; Tamassia, Roberto (2015), Algorithm Design and Applications, Wiley, p. 363.
External links
Weisstein, Eric W. "Adjacency matrix". MathWorld.
Fluffschack — an educational Java web start game demonstrating the relationship between adjacency matrices and
graphs.
Open Data Structures - Section 12.1 - AdjacencyMatrix: Representing a Graph by a Matrix
Café math : Adjacency Matrices of Graphs: Application of the adjacency matrices to the computation generating
series of walks.
Retrieved from "https://en.wikipedia.org/w/index.php?title=Adjacency_matrix&oldid=812588165
"
This page was last edited on 28 November 2017, at 18:27.
Text is available under theCreative Commons Attribution-ShareAlike License ; additional terms may apply. By using this
site, you agree to the Terms of Use and Privacy Policy. Wikipedia® is a registered trademark of theWikimedia
Foundation, Inc., a non-profit organization.