Hafnian
In mathematics, the hafnian of an adjacency matrix of a graph is the number of perfect matchings in the graph. It was so named by Eduardo R. Caianiello "to mark the fruitful period of stay in Copenhagen (Hafnia in Latin)."[1]
The hafnian of a symmetric matrix is computed as
where is the symmetric group on .[2]
Equivalently,
where is the set of all 1-factors (perfect matchings) on the complete graph , namely the set of all ways to partition the set into subsets of size .[3][4]
The definition of the hafnian is similar to that of the Pfaffian, but differs in that the signatures of the permutations are not taken into account. Thus the relationship of the hafnian to the Pfaffian is the same as relationship of the permanent to the determinant.[5]
Furthermore, the permanent and the hafnian are related as .[3]
If is a Hermitian positive semi-definite matrix and is a complex symmetric matrix, then we have the inequality
where denotes the complex conjugate of .[6] A simple way to see this when is positive semi-definite is to observe that, by Wick's probability theorem, when is a complex normal random vector with mean , covariance matrix and relation matrix .
Loop hafnian
The loop hafnian of an symmetric matrix is defined as
where is the set of all perfect matchings of the complete graph on vertices with loops, i.e., the set of all ways to partition the set into subsets of size or size (treated as a pair ).[7] Thus the loop hafnian depends on the diagonal entries of the matrix, whereas the hafnian does not.[7] Furthermore, the loop hafnian can be non-zero even when is odd.
The loop hafnian of the matrix obtained by taking the adjacency matrix of a graph and setting the diagonal elements to 1 is equal to the total number of matchings in the graph (perfect or non-perfect),[7] also known as its Hosoya index.
By Wick's probability theorem, the hafnian and loop hafnian of a real symmetric matrix can equivalently be defined as
and
where is any number large enough to make positive semi-definite (since this expectation does not depend on ).
Computation
Computing the hafnian of a (0,1)-matrix is #P-complete, because computing the permanent of a (0,1)-matrix is #P-complete.[5][7]
The hafnian of a matrix can be computed in time.[7]
If the entries of a matrix are non-negative, then its hafnian can be approximated to within an exponential factor in polynomial time.[8]
References
- F. Guerra, in Imagination and Rigor: Essays on Eduardo R. Caianiello's Scientific Heritage, edited by Settimo Termini, Springer Science & Business Media, 2006, page 98
- Rudelson, Mark; Samorodnitsky, Alex; Zeitouni, Ofer (2016). "Hafnians, perfect matchings and Gaussian matrices". The Annals of Probability. 44 (4): 2858–2888. arXiv:1409.3905. doi:10.1214/15-AOP1036. S2CID 14458608.
- Alexander Barvinok (13 March 2017). Combinatorics and Complexity of Partition Functions. p. 93. ISBN 9783319518299.
- Barvinok, Alexander; Regts, Guus (2019). "Weighted counting of integer points in a subspace". Combinator. Probab. Comp. 28: 696–719. arXiv:1706.05423. doi:10.1017/S0963548319000105. S2CID 126185737.
- Kocharovsky, Vitaly V.; Kocharovsky, Vladimir V.; Tarasov, Sergey V. (2022). "The Hafnian Master Theorem". Linear Algebra and Its Applications. Elsevier BV. 651: 144–161. doi:10.1016/j.laa.2022.06.021. ISSN 0024-3795. S2CID 249935016.
- Brádler, Kamil; Friedland, Shmuel; Israel, Robert B. (2021-02-24). "Nonnegativity for hafnians of certain matrices". Linear and Multilinear Algebra. Informa UK Limited. 70 (19): 4615–4619. arXiv:1811.10342. doi:10.1080/03081087.2021.1892022. ISSN 0308-1087. S2CID 119601142.
- Björklund, Andreas; Gupt, Brajesh; Quesada, Nicolás (2018). "A faster hafnian formula for complex matrices and its benchmarking on a supercomputer". arXiv:1805.12498 [cs.DS].
- Barvinok, Alexander (1999). "Polynomial Time Algorithms to Approximate Permanents and Mixed Discriminants Within a Simply Exponential Factor". Random Structures and Algorithms. Wiley. 14 (1): 29–61. doi:10.1002/(sici)1098-2418(1999010)14:1<29::aid-rsa2>3.0.co;2-x. hdl:2027.42/35110. ISSN 1042-9832.