Invertible matrix

From The Right Wiki
Revision as of 11:52, 5 October 2024 by imported>Marnanel
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigationJump to search

In linear algebra, an invertible matrix is a square matrix which has an inverse. In other words, if some other matrix is multiplied by the invertible matrix, the result can be multiplied by an inverse to undo the operation. Invertible matrices are the same size as their inverse.

Definition

An n-by-n square matrix A is called invertible (also nonsingular, nondegenerate or rarely regular) if there exists an n-by-n square matrix B such thatAB=BA=In,where In denotes the n-by-n identity matrix and the multiplication used is ordinary matrix multiplication.[1] If this is the case, then the matrix B is uniquely determined by A, and is called the (multiplicative) inverse of A, denoted by A−1. Matrix inversion is the process of finding the matrix which when multiplied by the original matrix gives the identity matrix.[2] Over a field, a square matrix that is not invertible is called singular or degenerate. A square matrix with entries in a field is singular if and only if its determinant is zero. Singular matrices are rare in the sense that if a square matrix's entries are randomly selected from any bounded region on the number line or complex plane, the probability that the matrix is singular is 0, that is, it will "almost never" be singular. Non-square matrices, i.e. m-by-n matrices for which mn, do not have an inverse. However, in some cases such a matrix may have a left inverse or right inverse. If A is m-by-n and the rank of A is equal to n, (nm), then A has a left inverse, an n-by-m matrix B such that BA = In. If A has rank m (mn), then it has a right inverse, an n-by-m matrix B such that AB = Im. While the most common case is that of matrices over the real or complex numbers, all these definitions can be given for matrices over any algebraic structure equipped with addition and multiplication (i.e. rings). However, in the case of a ring being commutative, the condition for a square matrix to be invertible is that its determinant is invertible in the ring, which in general is a stricter requirement than it being nonzero. For a noncommutative ring, the usual determinant is not defined. The conditions for existence of left-inverse or right-inverse are more complicated, since a notion of rank does not exist over rings. The set of n × n invertible matrices together with the operation of matrix multiplication and entries from ring R form a group, the general linear group of degree n, denoted GLn(R).

Properties

The invertible matrix theorem

Let A be a square n-by-n matrix over a field K (e.g., the field of real numbers). The following statements are equivalent, i.e., they are either all true or all false for any given matrix:[3]

  • A is invertible, i.e. it has an inverse under matrix multiplication, i.e., there exists a B such that AB = In = BA. (In this statement, "invertible" can equivalently be replaced with "left-invertible" or "right-invertible", in which one-sided inverses are considered.)
  • The linear transformation mapping x to Ax is invertible, i.e., has an inverse under function composition. (Here, again, "invertible" can equivalently be replaced with either "left-invertible" or "right-invertible")
  • The transpose AT is an invertible matrix.
  • A is row-equivalent to the n-by-n identity matrix In.
  • A is column-equivalent to the n-by-n identity matrix In.
  • A has n pivot positions.
  • A has full rank: rank A = n.
  • A has a trivial kernel: ker(A) = {0}.
  • The linear transformation mapping x to Ax is bijective; that is, the equation Ax = b has exactly one solution for each b in Kn. (Here, "bijective" can equivalently be replaced with "injective" or "surjective")
  • The columns of A form a basis of Kn. (In this statement, "basis" can equivalently be replaced with either "linearly independent set" or "spanning set")
  • The rows of A form a basis of Kn. (Similarly, here, "basis" can equivalently be replaced with either "linearly independent set" or "spanning set")
  • The determinant of A is nonzero: det A ≠ 0. (In general, a square matrix over a commutative ring is invertible if and only if its determinant is a unit (i.e. multiplicatively invertible element) of that ring.
  • The number 0 is not an eigenvalue of A. (More generally, a number λ is an eigenvalue of A if the matrix AλI is singular, where I is the identity matrix.)
  • The matrix A can be expressed as a finite product of elementary matrices.

Other properties

Furthermore, the following properties hold for an invertible matrix A:

  • (A1)1=A
  • (kA)1=k1A1 for nonzero scalar k
  • (Ax)+=x+A1 if A has orthonormal columns, where + denotes the Moore–Penrose inverse and x is a vector
  • (AT)1=(A1)T
  • For any invertible n-by-n matrices A and B, (AB)1=B1A1. More generally, if A1,,Ak are invertible n-by-n matrices, then (A1A2Ak1Ak)1=Ak1Ak11A21A11.
  • detA1=(detA)1.

The rows of the inverse matrix V of a matrix U are orthonormal to the columns of U (and vice versa interchanging rows for columns). To see this, suppose that UV = VU = I where the rows of V are denoted as viT and the columns of U as uj for 1i,jn. Then clearly, the Euclidean inner product of any two viTuj=δi,j. This property can also be useful in constructing the inverse of a square matrix in some instances, where a set of orthogonal vectors (but not necessarily orthonormal vectors) to the columns of U are known. In which case, one can apply the iterative Gram–Schmidt process to this initial set to determine the rows of the inverse V. A matrix that is its own inverse (i.e., a matrix A such that A = A−1, and consequently A2 = I), is called an involutory matrix.

In relation to its adjugate

The adjugate of a matrix A can be used to find the inverse of A as follows: If A is an invertible matrix, then

A1=1det(A)adj(A).

In relation to the identity matrix

It follows from the associativity of matrix multiplication that if

AB=I

for finite square matrices A and B, then also

BA=I[4]

Density

Over the field of real numbers, the set of singular n-by-n matrices, considered as a subset of n×n, is a null set, that is, has Lebesgue measure zero. This is true because singular matrices are the roots of the determinant function. This is a continuous function because it is a polynomial in the entries of the matrix. Thus in the language of measure theory, almost all n-by-n matrices are invertible. Furthermore, the set of n-by-n invertible matrices is open and dense in the topological space of all n-by-n matrices. Equivalently, the set of singular matrices is closed and nowhere dense in the space of n-by-n matrices. In practice however, one may encounter non-invertible matrices. And in numerical calculations, matrices which are invertible, but close to a non-invertible matrix, can still be problematic; such matrices are said to be ill-conditioned.

Examples

An example with rank of n − 1 is a non-invertible matrix

A=(2424).

We can see the rank of this 2-by-2 matrix is 1, which is n − 1 ≠ n, so it is non-invertible. Consider the following 2-by-2 matrix:

B=(13211).

The matrix B is invertible. To check this, one can compute that detB=12, which is non-zero. As an example of a non-invertible, or singular, matrix, consider the matrix

C=(132231).

The determinant of C is 0, which is a necessary and sufficient condition for a matrix to be non-invertible.

Methods of matrix inversion

Gaussian elimination

Gaussian elimination is a useful and easy way to compute the inverse of a matrix. To compute a matrix inverse using this method, an augmented matrix is first created with the left side being the matrix to invert and the right side being the identity matrix. Then, Gaussian elimination is used to convert the left side into the identity matrix, which causes the right side to become the inverse of the input matrix. For example, take the following matrix: A=(13211). The first step to compute its inverse is to create the augmented matrix (132101101). Call the first row of this matrix R1 and the second row R2. Then, add row 1 to row 2 (R1+R2R2). This yields (1321001211). Next, subtract row 2, multiplied by 3, from row 1 (R13R2R1), which yields (102301211). Finally, multiply row 1 by −1 (R1R1) and row 2 by 2 (2R2R2). This yields the identity matrix on the left side and the inverse matrix on the right:(10230122). Thus, A1=(2322). The reason it works is that the process of Gaussian elimination can be viewed as a sequence of applying left matrix multiplication using elementary row operations using elementary matrices (En), such as EnEn1E2E1A=I. Applying right-multiplication using A1, we get EnEn1E2E1I=IA1. And the right side IA1=A1, which is the inverse we want. To obtain EnEn1E2E1I, we create the augumented matrix by combining A with I and applying Gaussian elimination. The two portions will be transformed using the same sequence of elementary row operations. When the left portion becomes I, the right portion applied the same elementary row operation sequence will become A−1.

Newton's method

A generalization of Newton's method as used for a multiplicative inverse algorithm may be convenient, if it is convenient to find a suitable starting seed:

Xk+1=2XkXkAXk.

Victor Pan and John Reif have done work that includes ways of generating a starting seed.[5][6] Newton's method is particularly useful when dealing with families of related matrices that behave enough like the sequence manufactured for the homotopy above: sometimes a good starting point for refining an approximation for the new inverse can be the already obtained inverse of a previous matrix that nearly matches the current matrix, for example, the pair of sequences of inverse matrices used in obtaining matrix square roots by Denman–Beavers iteration; this may need more than one pass of the iteration at each new matrix, if they are not close enough together for just one to be enough. Newton's method is also useful for "touch up" corrections to the Gauss–Jordan algorithm which has been contaminated by small errors due to imperfect computer arithmetic.

Cayley–Hamilton method

The Cayley–Hamilton theorem allows the inverse of A to be expressed in terms of det(A), traces and powers of A:[7]

A1=1det(A)s=0n1Ask1,k2,,kn1l=1n1(1)kl+1lklkl!tr(Al)kl,

where n is size of A, and tr(A) is the trace of matrix A given by the sum of the main diagonal. The sum is taken over s and the sets of all kl0 satisfying the linear Diophantine equation

s+l=1n1lkl=n1.

The formula can be rewritten in terms of complete Bell polynomials of arguments tl=(l1)!tr(Al) as

A1=1det(A)s=1nAs1(1)n1(ns)!Bns(t1,t2,,tns).

This is described in more detail under Cayley–Hamilton method.

Eigendecomposition

If matrix A can be eigendecomposed, and if none of its eigenvalues are zero, then A is invertible and its inverse is given by

A1=QΛ1Q1,

where Q is the square (N × N) matrix whose ith column is the eigenvector qi of A, and Λ is the diagonal matrix whose diagonal entries are the corresponding eigenvalues, that is, Λii=λi. If A is symmetric, Q is guaranteed to be an orthogonal matrix, therefore Q1=QT. Furthermore, because Λ is a diagonal matrix, its inverse is easy to calculate:

[Λ1]ii=1λi.

Cholesky decomposition

If matrix A is positive definite, then its inverse can be obtained as

A1=(L*)1L1,

where L is the lower triangular Cholesky decomposition of A, and L* denotes the conjugate transpose of L.

Analytic solution

Writing the transpose of the matrix of cofactors, known as an adjugate matrix, can also be an efficient way to calculate the inverse of small matrices, but this recursive method is inefficient for large matrices. To determine the inverse, we calculate a matrix of cofactors:

A1=1|A|CT=1|A|(C11C21Cn1C12C22Cn2C1nC2nCnn)

so that

(A1)ij=1|A|(CT)ij=1|A|(Cji)

where |A| is the determinant of A, C is the matrix of cofactors, and CT represents the matrix transpose.

Inversion of 2 × 2 matrices

The cofactor equation listed above yields the following result for 2 × 2 matrices. Inversion of these matrices can be done as follows:[8]

A1=[abcd]1=1detA[dbca]=1adbc[dbca].

This is possible because 1/(adbc) is the reciprocal of the determinant of the matrix in question, and the same strategy could be used for other matrix sizes. The Cayley–Hamilton method gives

A1=1detA[(trA)IA].

Inversion of 3 × 3 matrices

A computationally efficient 3 × 3 matrix inversion is given by

A1=[abcdefghi]1=1det(A)[ABCDEFGHI]T=1det(A)[ADGBEHCFI]

(where the scalar A is not to be confused with the matrix A). If the determinant is non-zero, the matrix is invertible, with the entries of the intermediary matrix on the right side above given by

A=(eifh),D=(bich),G=(bfce),B=(difg),E=(aicg),H=(afcd),C=(dheg),F=(ahbg),I=(aebd).

The determinant of A can be computed by applying the rule of Sarrus as follows:

det(A)=aA+bB+cC.

The Cayley–Hamilton decomposition gives

A1=1det(A)(12[(trA)2tr(A2)]IAtrA+A2).

The general 3 × 3 inverse can be expressed concisely in terms of the cross product and triple product. If a matrix A=[x0x1x2] (consisting of three column vectors, x0, x1, and x2) is invertible, its inverse is given by

A1=1det(A)[(x1×x2)T(x2×x0)T(x0×x1)T].

The determinant of A, det(A), is equal to the triple product of x0, x1, and x2—the volume of the parallelepiped formed by the rows or columns:

det(A)=x0(x1×x2).

The correctness of the formula can be checked by using cross- and triple-product properties and by noting that for groups, left and right inverses always coincide. Intuitively, because of the cross products, each row of A–1 is orthogonal to the non-corresponding two columns of A (causing the off-diagonal terms of I=A1A be zero). Dividing by

det(A)=x0(x1×x2)

causes the diagonal entries of I = A−1A to be unity. For example, the first diagonal is:

1=1x0(x1×x2)x0(x1×x2).

Inversion of 4 × 4 matrices

With increasing dimension, expressions for the inverse of A get complicated. For n = 4, the Cayley–Hamilton method leads to an expression that is still tractable:

A1=1det(A)(16[(trA)33trAtr(A2)+2tr(A3)]I12A[(trA)2tr(A2)]+A2trAA3).

Blockwise inversion

Matrices can also be inverted blockwise by using the following analytic inversion formula:[9]

[ABCD]1=[A1+A1B(DCA1B)1CA1A1B(DCA1B)1(DCA1B)1CA1(DCA1B)1], (1)

where A, B, C and D are matrix sub-blocks of arbitrary size. (A must be square, so that it can be inverted. Furthermore, A and DCA−1B must be nonsingular.[10]) This strategy is particularly advantageous if A is diagonal and DCA−1B (the Schur complement of A) is a small matrix, since they are the only matrices requiring inversion. This technique was reinvented several times and is due to Hans Boltz (1923),[citation needed] who used it for the inversion of geodetic matrices, and Tadeusz Banachiewicz (1937), who generalized it and proved its correctness. The nullity theorem says that the nullity of A equals the nullity of the sub-block in the lower right of the inverse matrix, and that the nullity of B equals the nullity of the sub-block in the upper right of the inverse matrix. The inversion procedure that led to Equation (1) performed matrix block operations that operated on C and D first. Instead, if A and B are operated on first, and provided D and ABD−1C are nonsingular,[11] the result is

[ABCD]1=[(ABD1C)1(ABD1C)1BD1D1C(ABD1C)1D1+D1C(ABD1C)1BD1]. (2)

Equating Equations (1) and (2) leads to

(ABD1C)1=A1+A1B(DCA1B)1CA1(ABD1C)1BD1=A1B(DCA1B)1D1C(ABD1C)1=(DCA1B)1CA1D1+D1C(ABD1C)1BD1=(DCA1B)1 (3)

where Equation (3) is the Woodbury matrix identity, which is equivalent to the binomial inverse theorem. If A and D are both invertible, then the above two block matrix inverses can be combined to provide the simple factorization

[ABCD]1=[(ABD1C)100(DCA1B)1][IBD1CA1I]. (2)

By the Weinstein–Aronszajn identity, one of the two matrices in the block-diagonal matrix is invertible exactly when the other is. This formula simplifies significantly when the upper right block matrix B is the zero matrix. This formulation is useful when the matrices A and D have relatively simple inverse formulas (or pseudo inverses in the case where the blocks are not all square. In this special case, the block matrix inversion formula stated in full generality above becomes

[A0CD]1=[A10D1CA1D1].

If the given invertible matrix is a symmetric matrix with invertible block A the following block inverse formula holds[12]

[ACTCD]1=[A1+A1CTS1CA1A1CTS1S1CA1S1], (4)

where S=DCA1CT. This requires 2 inversions of the half-sized matrices A and S and only 4 multiplications of half-sized matrices, if organized properly W1=CA1, W2=W1CT=CA1CT, W3=S1W1=S1CA1, W4=W1TW3=A1CTS1CA1, together with some additions, subtractions, negations and transpositions of negligible complexity. Any matrix M has an associated positive semidefinite, symmetric matrix MTM, which is exactly invertible (and positive definite), if and only if M is invertible. By writing M1=(MTM)1MT matrix inversion can be reduced to inverting symmetric matrices and 2 additional matrix multiplications, because the positive definite matrix MTM satisfies the invertibility condition for its left upper block A. These formulas together allow to construct a divide and conquer algorithm that uses blockwise inversion of associated symmetric matrices to invert a matrix with the same time complexity as the matrix multiplication algorithm that is used internally.[12] Research into matrix multiplication complexity shows that there exist matrix multiplication algorithms with a complexity of O(n2.371552) operations, while the best proven lower bound is Ω(n2 log n).[13]

By Neumann series

If a matrix A has the property that

limn(IA)n=0

then A is nonsingular and its inverse may be expressed by a Neumann series:[14]

A1=n=0(IA)n.

Truncating the sum results in an "approximate" inverse which may be useful as a preconditioner. Note that a truncated series can be accelerated exponentially by noting that the Neumann series is a geometric sum. As such, it satisfies

n=02L1(IA)n=l=0L1(I+(IA)2l).

Therefore, only 2L − 2 matrix multiplications are needed to compute 2L terms of the sum. More generally, if A is "near" the invertible matrix X in the sense that

limn(IX1A)n=0orlimn(IAX1)n=0

then A is nonsingular and its inverse is

A1=n=0(X1(XA))nX1.

If it is also the case that AX has rank 1 then this simplifies to

A1=X1X1(AX)X11+tr(X1(AX)).

p-adic approximation

If A is a matrix with integer or rational entries and we seek a solution in arbitrary-precision rationals, then a p-adic approximation method converges to an exact solution in O(n4 log2 n), assuming standard O(n3) matrix multiplication is used.[15] The method relies on solving n linear systems via Dixon's method of p-adic approximation (each in O(n3 log2 n)) and is available as such in software specialized in arbitrary-precision matrix operations, for example, in IML.[16]

Reciprocal basis vectors method

Given an n × n square matrix X=[xij], 1i,jn, with n rows interpreted as n vectors xi=xijej (Einstein summation assumed) where the ej are a standard orthonormal basis of Euclidean space n (ei=ei,eiej=δij), then using Clifford algebra (or geometric algebra) we compute the reciprocal (sometimes called dual) column vectors:

xi=xjiej=(1)i1(x1()ixn)(x1x2xn)1

as the columns of the inverse matrix X1=[xji]. Note that, the place "()i" indicates that "xi" is removed from that place in the above expression for xi. We then have XX1=[xixj]=[δij]=In, where δij is the Kronecker delta. We also have X1X=[(eixk)(ejxk)]=[eiej]=[δij]=In, as required. If the vectors xi are not linearly independent, then (x1x2xn)=0 and the matrix X is not invertible (has no inverse).

Derivative of the matrix inverse

Suppose that the invertible matrix A depends on a parameter t. Then the derivative of the inverse of A with respect to t is given by[17]

dA1dt=A1dAdtA1.

To derive the above expression for the derivative of the inverse of A, one can differentiate the definition of the matrix inverse A1A=I and then solve for the inverse of A:

d(A1A)dt=dA1dtA+A1dAdt=dIdt=0.

Subtracting A1dAdt from both sides of the above and multiplying on the right by A1 gives the correct expression for the derivative of the inverse:

dA1dt=A1dAdtA1.

Similarly, if ε is a small number then

(A+εX)1=A1εA1XA1+𝒪(ε2).

More generally, if

df(A)dt=igi(A)dAdthi(A),

then,

f(A+εX)=f(A)+εigi(A)Xhi(A)+𝒪(ε2).

Given a positive integer n,

dAndt=i=1nAi1dAdtAni,dAndt=i=1nAidAdtA(n+1i).

Therefore,

(A+εX)n=An+εi=1nAi1XAni+𝒪(ε2),(A+εX)n=Anεi=1nAiXA(n+1i)+𝒪(ε2).

Generalized inverse

Some of the properties of inverse matrices are shared by generalized inverses (for example, the Moore–Penrose inverse), which can be defined for any m-by-n matrix.[18]

Applications

For most practical applications, it is not necessary to invert a matrix to solve a system of linear equations; however, for a unique solution, it is necessary that the matrix involved be invertible. Decomposition techniques like LU decomposition are much faster than inversion, and various fast algorithms for special classes of linear systems have also been developed.

Regression/least squares

Although an explicit inverse is not necessary to estimate the vector of unknowns, it is the easiest way to estimate their accuracy, found in the diagonal of a matrix inverse (the posterior covariance matrix of the vector of unknowns). However, faster algorithms to compute only the diagonal entries of a matrix inverse are known in many cases.[19]

Matrix inverses in real-time simulations

Matrix inversion plays a significant role in computer graphics, particularly in 3D graphics rendering and 3D simulations. Examples include screen-to-world ray casting, world-to-subspace-to-world object transformations, and physical simulations.

Matrix inverses in MIMO wireless communication

Matrix inversion also plays a significant role in the MIMO (Multiple-Input, Multiple-Output) technology in wireless communications. The MIMO system consists of N transmit and M receive antennas. Unique signals, occupying the same frequency band, are sent via N transmit antennas and are received via M receive antennas. The signal arriving at each receive antenna will be a linear combination of the N transmitted signals forming an N × M transmission matrix H. It is crucial for the matrix H to be invertible for the receiver to be able to figure out the transmitted information.

See also

References

  1. Axler, Sheldon (18 December 2014). Linear Algebra Done Right. Undergraduate Texts in Mathematics (3rd ed.). Springer Publishing (published 2015). p. 296. ISBN 978-3-319-11079-0.
  2. J.-S. Roger Jang (March 2001). "Matrix Inverse in Block Form".
  3. Weisstein, Eric W. "Invertible Matrix Theorem". mathworld.wolfram.com. Retrieved 2020-09-08.
  4. Horn, Roger A.; Johnson, Charles R. (1985). Matrix Analysis. Cambridge University Press. p. 14. ISBN 978-0-521-38632-6..
  5. Pan, Victor; Reif, John (1985), Efficient Parallel Solution of Linear Systems, Proceedings of the 17th Annual ACM Symposium on Theory of Computing, Providence: ACM
  6. Pan, Victor; Reif, John (1985), Harvard University Center for Research in Computing Technology Report TR-02-85, Cambridge, MA: Aiken Computation Laboratory
  7. A proof can be found in the Appendix B of Kondratyuk, L. A.; Krivoruchenko, M. I. (1992). "Superconducting quark matter in SU(2) color group". Zeitschrift für Physik A. 344 (1): 99–115. Bibcode:1992ZPhyA.344...99K. doi:10.1007/BF01291027. S2CID 120467300.
  8. Strang, Gilbert (2003). Introduction to linear algebra (3rd ed.). SIAM. p. 71. ISBN 978-0-9614088-9-3., Chapter 2, page 71
  9. Tzon-Tzer, Lu; Sheng-Hua, Shiou (2002). "Inverses of 2 × 2 block matrices". Computers & Mathematics with Applications. 43 (1–2): 119–129. doi:10.1016/S0898-1221(01)00278-4.
  10. Bernstein, Dennis (2005). Matrix Mathematics. Princeton University Press. p. 44. ISBN 978-0-691-11802-4.
  11. Bernstein, Dennis (2005). Matrix Mathematics. Princeton University Press. p. 45. ISBN 978-0-691-11802-4.
  12. 12.0 12.1 T. H. Cormen, C. E. Leiserson, R. L. Rivest, C. Stein, Introduction to Algorithms, 3rd ed., MIT Press, Cambridge, MA, 2009, §28.2.
  13. Ran Raz. On the complexity of matrix product. In Proceedings of the thirty-fourth annual ACM symposium on Theory of computing. ACM Press, 2002. doi:10.1145/509907.509932.
  14. Stewart, Gilbert (1998). Matrix Algorithms: Basic decompositions. SIAM. p. 55. ISBN 978-0-89871-414-2.
  15. Haramoto, H.; Matsumoto, M. (2009). "A p-adic algorithm for computing the inverse of integer matrices". Journal of Computational and Applied Mathematics. 225 (1): 320–322. Bibcode:2009JCoAM.225..320H. doi:10.1016/j.cam.2008.07.044.
  16. "IML - Integer Matrix Library". cs.uwaterloo.ca. Retrieved 14 April 2018.
  17. Magnus, Jan R.; Neudecker, Heinz (1999). Matrix Differential Calculus : with Applications in Statistics and Econometrics (Revised ed.). New York: John Wiley & Sons. pp. 151–152. ISBN 0-471-98633-X.
  18. Roman, Stephen (2008), Advanced Linear Algebra, Graduate Texts in Mathematics (Third ed.), Springer, p. 446, ISBN 978-0-387-72828-5.
  19. Lin, Lin; Lu, Jianfeng; Ying, Lexing; Car, Roberto; E, Weinan (2009). "Fast algorithm for extracting the diagonal of the inverse matrix with application to the electronic structure analysis of metallic systems". Communications in Mathematical Sciences. 7 (3): 755–777. doi:10.4310/CMS.2009.v7.n3.a12.

Further reading

External links