The Hilbert matrix is the matrix with . For example,

It is probably the most famous test matrix and its conditioning and other properties were extensively studied in the early days of digital computing, especially by John Todd.

The Hilbert matrix is symmetric and it is a Hankel matrix (constant along the anti-diagonals). Less obviously, it is symmetric positive definite (all its eigenvalues are positive) and totally positive (every submatrix has positive determinant). Its condition number grows rapidly with ; indeed for the 2-norm the asymptotic growth rate is . An underlying reason for the ill conditioning is that the Hilbert matrix is obtained when least squares polynomial approximation is done using the monomial basis, and this is known to be an ill-conditioned polynomial basis.

The inverse of has integer entries, with entry

For example,

The alternating sign pattern is a consequence of total positivity.

The determinant is also known explicitly:

The Hilbert matrix is infinitely divisible, which means that the matrix with element is positive semidefinite for all nonnegative real numbers .

Other interesting matrices can be formed from the Hilbert matrix. The Lotkin matrix, `A = gallery('lotkin',n)`

in MATLAB, is the Hilbert matrix with the first row replaced by s, making it nonsymmetric. Like the Hilbert matrix, it is ill conditioned and has an inverse with integer entries. For the matrix with entry , which is a submatrix of , the largest singular value tends to as , with error decaying slowly as , as was shown by Taussky.

The Hilbert matrix is not a good test matrix, for several reasons. First, it is too ill conditioned, being numerically singular in IEEE double precision arithmetic for . Second, it is too special: the definiteness and total positivity, together with the fact that it is a special case of a Cauchy matrix (which has elements ), mean that certain quantities associated with it can be calculated more accurately than for a general positive definite matrix. The third reason why the Hilbert matrix is not a good test matrix is that most of its elements cannot be stored exactly in floating-point arithmetic, so the matrix actually stored is a perturbation of â€”and since is ill conditioned this means (for example) that the inverse of the stored matrix can be very different from the exact inverse. A way around this might be to work the integer matrix , but its elements are exactly representable in double precision only for .

MATLAB has functions `hilb`

and `invhilb`

for the Hilbert matrix and its inverse. How to efficiently form the Hilbert matrix in MATLAB is an interesting question. The `hilb`

function essentially uses the code

j = 1:n; H = 1./(j'+j-1)

This code is more concise and efficient than two nested loops would be. The second line may appear to be syntactically incorrect, because `j'+j`

adds a column vector to a row vector. However, the MATLAB implicit expansion feature expands `j'`

into an matrix in which every column is `j'`

, expands `j`

into an matrix in which every row is `j`

, then adds the two matrices. It is not hard to see that the Hilbert matrix is the result of these two lines of code.

## References

This is a minimal set of references, which contain further useful references within.

- Rajendra Bhatia, Infinitely divisible matrices, Amer. Math. Monthly 113(3), 221â€“235, 2006.
- Man-Duen Choi, Tricks or treats with the Hilbert matrix, Amer. Math. Monthly 90(5), 301â€“312, 1983
- Nicholas J. Higham, Accuracy and Stability of Numerical Algorithms, second edition, Society for Industrial and Applied Mathematics, Philadelphia, PA, USA, 2002. Section 28.1.
- M. Lotkin, A set of test matrices, M.T.A.C. 9(52), 153â€“161, 1955.

## Related Blog Posts

- Hilbert Matrices by Cleve Moler (2013)
- Hilbert Matrices by Cleve Moler (2017)
- Implicit Expansion: A Powerful New Feature of MATLAB R2016b (2016)

This article is part of the “What Is” series, available from https://nhigham.com/category/what-is and in PDF form from the GitHub repository https://github.com/higham/what-is.