F01 (Matop)
Chapter Introduction
FL CL
NAG CL Interface
F01 (Matop)
Matrix Operations, Including Inversion
F01 (Matop)
Chapter Introduction
FL CL
1
Scope of the Chapter
This chapter provides facilities for four types of problem:
-
(i)matrix inversion;
-
(ii)matrix factorizations;
-
(iii)matrix arithmetic and manipulation;
-
(iv)matrix functions.
See
Sections 2.1,
2.2,
2.3 and
2.4 where these problems are discussed.
2
Background to the Problems
2.1
Matrix Inversion
-
(i)Nonsingular square matrices of order .
If , a square matrix of order , is nonsingular (has rank ), then its inverse exists and satisfies the equations (the identity or unit matrix).
It is worth noting that if
, so that
is the ‘residual’ matrix, then a bound on the relative error is given by
, i.e.,
-
(ii)General real rectangular matrices.
A real matrix
has no inverse if it is square (
) and singular (has rank
), or if it is of shape (
) with
, but there is a
Generalized or
Pseudo-inverse
which satisfies the equations
(which of course are also satisfied by the inverse
of
if
is square and nonsingular).
-
(a)if and then can be factorized using a factorization, given by
where is an orthogonal matrix and is an , nonsingular, upper triangular matrix. The pseudo-inverse of is then given by
where consists of the first columns of .
-
(b)if and then can be factorized using an RQ factorization, given by
where is an orthogonal matrix and is an , nonsingular, upper triangular matrix. The pseudo-inverse of is then given by
where consists of the first columns of .
-
(c)if and then can be factorized using a factorization, with column interchanges, as
where is an orthogonal matrix, is an upper trapezoidal matrix and is an permutation matrix. The pseudo-inverse of is then given by
where consists of the first columns of .
-
(d)if then can be factorized as the singular value decomposition
where is an orthogonal matrix, is an orthogonal matrix and is an diagonal matrix with non-negative diagonal elements . The first columns of and are the left- and right-hand singular vectors of respectively and the diagonal elements of are the singular values of . may be chosen so that
and in this case, if then
If and consist of the first columns of and respectively and is an diagonal matrix with diagonal elements then is given by
and the pseudo-inverse of is given by
Notice that
which is the classical eigenvalue (spectral) factorization of .
-
(e)if is complex then the above relationships are still true if we use ‘unitary’ in place of ‘orthogonal’ and conjugate transpose in place of transpose. For example, the singular value decomposition of is
where and are unitary, the conjugate transpose of and is as in (ii)(d) above.
2.2
Matrix Factorizations
The functions in this section perform matrix factorizations which are required for the solution of systems of linear equations with various special structures. A few functions which perform associated computations are also included.
Other functions for matrix factorizations are to be found in
Chapters F07,
F08 and
F11.
This section also contains a few functions associated with eigenvalue problems (see
Chapter F02). (Historical note: this section used to contain many more such functions, but they have now been superseded by functions in
Chapter F08.)
Finally, this section contains functions for computing non-negative matrix factorizations, which are used for dimensional reduction and classification in data analysis. Given a rectangular matrix, , with non-negative elements, a non-negative matrix factorization of is an approximate factorization of into the product of an non-negative matrix and a non-negative matrix , so that . Typically is chosen so that . The matrices and are then computed to minimize . The factorization is not unique.
2.3
Matrix Arithmetic and Manipulation
The intention of functions in this section (f01d and f01v) is to cater for some of the commonly occurring operations in matrix manipulation, i.e., conversion between different storage formats,such as conversion between rectangular band matrix storage and packed band matrix storage. For vector or matrix-vector or matrix-matrix operations refer to
Chapters F06 and
F16.
2.4
Matrix Functions
Given a square matrix , the matrix function is a matrix with the same dimensions as which provides a generalization of the scalar function .
If
has a full set of eigenvectors
then
can be factorized as
where
is the diagonal matrix whose diagonal elements,
, are the eigenvalues of
.
is given by
where
is the diagonal matrix whose
th diagonal element is
.
In general,
may not have a full set of eigenvectors. The matrix function can then be defined via a Cauchy integral. For
,
where
is a closed contour surrounding the eigenvalues of
, and
is analytic within
.
Some matrix functions are defined implicitly. A matrix logarithm is a solution
to the equation
In general,
is not unique, but if
has no eigenvalues on the closed negative real line then a unique
principal logarithm exists whose eigenvalues have imaginary part between
and
. Similarly, a matrix square root is a solution
to the equation
If has no eigenvalues on the closed negative real line then a unique principal square root exists with eigenvalues in the right half-plane. If has a vanishing eigenvalue then cannot be computed. If the vanishing eigenvalue is defective (its algebraic multiplicity exceeds its geometric multiplicity, or equivalently it occurs in a Jordan block of size greater than ) then the square root cannot be computed. If the vanishing eigenvalue is semisimple (its algebraic and geometric multiplicities are equal, or equivalently it occurs only in Jordan blocks of size ) then a square root can be computed.
Algorithms for computing matrix functions are usually tailored to a specific function. Currently,
Chapter F01 contains routines for calculating the exponential, logarithm, sine, cosine, sinh, cosh, square root and the general real power of both real and complex matrices. In addition, there are routines to compute a general function of real symmetric and complex Hermitian matrices and a general function of general real and complex matrices.
The Fréchet derivative of a matrix function
in the direction of the matrix
is the linear function mapping
to
such that
The Fréchet derivative measures the first-order effect on
of perturbations in
.
Chapter F01 contains functions for calculating the Fréchet derivative of the exponential, logarithm and real powers of both real and complex matrices.
The condition number of a matrix function is a measure of its sensitivity to perturbations in the data. The absolute condition number measures these perturbations in an absolute sense and is defined by
The relative condition number, which is usually of more interest, measures these perturbations in a relative sense and is defined by
The absolute and relative condition numbers can be expressed in terms of the norm of the Fréchet derivative by
Chapter F01 contains routines for calculating the condition number of the matrix exponential, logarithm, sine, cosine, sinh, cosh, square root and the general real power of both real and complex matrices. It also contains routines for estimating the condition number of a general function of a real or complex matrix.
3
Recommendations on Choice and Use of Available Functions
3.1
Matrix Inversion
Note: before using any function for matrix inversion, consider carefully whether it is needed.
Although the solution of a set of linear equations
can be written as
, the solution should
never be computed by first inverting
and then computing
; the functions in
Chapters F04 or
F07 should
always be used to solve such sets of equations directly; they are faster in execution, and numerically more stable and accurate. Similar remarks apply to the solution of least squares problems which again should be solved by using the functions in
Chapters F04 and
F08
rather than by computing a pseudo-inverse.
-
(a)Nonsingular square matrices of order
This chapter describes techniques for inverting a general real matrix and matrices which are positive definite (have all eigenvalues positive) and are either real and symmetric or complex and Hermitian. It is wasteful and uneconomical not to use the appropriate function when a matrix is known to have one of these special forms. A general function must be used when the matrix is not known to be positive definite. In most functions, the inverse is computed by solving the linear equations , for , where is the th column of the identity matrix.
The residual matrix , where is a computed inverse of , conveys useful information. Firstly
is a bound on the relative error in and secondly guarantees the convergence of the iterative process in the ‘corrected’ inverse functions.
The decision trees for inversion show which functions in
Chapter F07 should be used for the inversion of other special types of matrices not treated in the chapter.
-
(b)General real rectangular matrices
For real matrices
f08aec returns the
factorization of the matrix and
f08bfc returns the
factorization with column interchanges. The corresponding complex functions are
f08asc and
f08btc respectively. Functions are also provided to form the orthogonal matrices and transform by the orthogonal matrices following the use of the above functions.
f08kbc and
f08kpc
compute the singular value decomposition as described in
Section 2 for real and complex matrices respectively. If
has rank
then the
smallest singular values will be negligible and the pseudo-inverse of
can be obtained as
as described in
Section 2. If the rank of
is not known in advance it can be estimated from the singular values (see
Section 2.4 in the
F04 Chapter Introduction).
For large sparse matrices, leading terms in the singular value decomposition can be computed using functions from
Chapter F12.
3.2
Matrix Factorizations
Most of these functions serve a special purpose required for the solution of sets of simultaneous linear equations or the eigenvalue problem. For further details, you should consult
Sections 3 or
4 in the
F02 Chapter Introduction or
Sections 3 or
4 in the
F04 Chapter Introduction.
f11dac is provided for factorizing general real sparse matrices. A more recent algorithm for the same problem is available through
f11mec. For factorizing real symmetric positive definite sparse matrices, see
f11jac. These functions should only be used when
is
not banded and when the total number of nonzero elements is less than 10% of the total number of elements. In all other cases, either the band functions or the general functions should be used.
f01mdc and
f01mec compute the Cheng–Higham modified Cholesky factorization of a real symmetric matrix and the positive definite perturbed input matrix from the factors.
The functions
f01sac (for dense matrices) and
f01sbc (sparse matrices, using a reverse communication interface) are provided for computing non-negative matrix factorizations.
3.3
Matrix Arithmetic and Manipulation
The functions in the f01d section perform arithmetic operations on triangular matrices.
The functions in the f01v (LAPACK) section are designed to allow conversion between full storage format and one of the packed storage schemes required by some of the functions in
Chapters F02,
F04,
F06,
F07 and
F08.
3.3.1
NAG Names and LAPACK Names
Functions with NAG short name beginning f01v may be called either by their NAG short names or by their NAG long names. The NAG long names for a function is simply the LAPACK name (in lower case) prepended by nag_, for example,
nag_matop_dtrttf is the long name for
f01vec.
When using the NAG Library, the double precision form of the LAPACK name must be used (beginning with d- or z-).
References to
Chapter F01 functions in the manual normally include the LAPACK double precision names, for example,
f01vec.
The LAPACK function names follow a simple scheme (which is similar to that used for the BLAS in
Chapter F16). Most names have the structure nag_xyytzz, where the components have the following meanings:
– the initial letter, x, indicates the data type (real or complex) and precision:
- d – real, double precision
- z – complex, double precision
– the fourth letter, t, indicates that the function is performing a storage scheme transformation (conversion)
– the letters yy indicate the original storage scheme used to store a triangular part of the matrix
, while the letters zz indicate the target storage scheme of the conversion (yy cannot equal zz since this would do nothing):
- tf – Rectangular Full Packed Format (RFP)
- tp – Packed Format
- tr – Full Format
3.4
Matrix Functions
f01ecc and
f01fcc compute the matrix exponential,
, of a real and complex square matrix
respectively. If estimates of the condition number of the matrix exponential are required then
f01jgc and
f01kgc should be used. If Fréchet derivatives are required then
f01jhc and
f01khc should be used.
f01edc and
f01fdc compute the matrix exponential,
, of a real symmetric and complex Hermitian matrix respectively. If the matrix is real symmetric, or complex Hermitian then it is recommended that
f01edc, or
f01fdc be used as they are more efficient and, in general, more accurate than
f01ecc and
f01fcc.
f01ejc and
f01fjc compute the principal matrix logarithm,
, of a real and complex square matrix
respectively. If estimates of the condition number of the matrix logarithm are required then
f01jjc and
f01kjc should be used. If Fréchet derivatives are required then
f01jkc and
f01kkc should be used.
f01ekc and
f01fkc compute the matrix exponential, sine, cosine, sinh or cosh of a real and complex square matrix
respectively. If the matrix exponential is required then it is recommended that
f01ecc or
f01fcc be used as they are, in general, more accurate than
f01ekc and
f01fkc. If estimates of the condition number of the matrix function are required then
f01jac and
f01kac should be used.
f01elc and
f01emc compute the matrix function,
, of a real square matrix.
f01flc and
f01fmc compute the matrix function of a complex square matrix. The derivatives of
are required for these computations.
f01elc and
f01flc use numerical differentiation to obtain the derivatives of
.
f01emc and
f01fmc use derivatives you have supplied. If estimates of the condition number are required but you are not supplying derivatives then
f01jbc and
f01kbc should be used.
If estimates of the condition number of the matrix function are required and you are supplying derivatives of
then
f01jcc and
f01kcc should be used.
If the matrix
is real symmetric or complex Hermitian then it is recommended that to compute the matrix function,
,
f01efc and
f01ffc are used respectively as they are more efficient and, in general, more accurate than
f01elc,
f01emc,
f01flc and
f01fmc.
f01gac and
f01hac compute the matrix function
for explicitly stored dense real and complex matrices
and
respectively while
f01gbc and
f01hbc compute the same using reverse communication. In the latter case, control is returned to you. You should calculate any required matrix-matrix products and then call the function again. See
Section 7 in How to Use the NAG Library for further information.
f01enc and
f01fnc compute the principal square root
of a real and complex square matrix
respectively. If
is complex and upper triangular then
f01fpc should be used. If
is real and upper quasi-triangular then
f01epc should be used. If estimates of the condition number of the matrix square root are required then
f01jdc and
f01kdc should be used.
f01eqc and
f01fqc compute the matrix power
, where
, of real and complex matrices respectively. If estimates of the condition number of the matrix power are required then
f01jec and
f01kec should be used. If Fréchet derivatives are required then
f01jfc and
f01kfc should be used.
4
Decision Trees
The decision trees show the functions in this chapter and in
Chapter F07 and
Chapter F08 that should be used for inverting matrices of various types. They also show which function should be used to calculate various matrix functions.
(i) Matrix Inversion:
Tree 1
Is an matrix of rank ? |
|
Is a real matrix? |
|
see Tree 2 |
yes | yes |
| no |
|
| no |
|
|
see Tree 3 |
|
|
see Tree 4 |
|
Tree 2: Inverse of a real n by n matrix of full rank
Tree 3: Inverse of a complex n by n matrix of full rank
Tree 4: Pseudo-inverses
Note 1: the inverse of a band matrix
does not, in general, have the same shape as
, and no functions are provided specifically for finding such an inverse. The matrix must either be treated as a full matrix or the equations
must be solved, where
has been initialized to the identity matrix
. In the latter case, see the decision trees in
Section 4 in the
F04 Chapter Introduction.
Note 2: by ‘guaranteed accuracy’ we mean that the accuracy of the inverse is improved by the use of the iterative refinement technique using additional precision.
(ii)
Matrix Factorizations: see the decision trees in Section 4 in the
F02 and
F04 Chapter Introductions.
(iii) Matrix Arithmetic and Manipulation: not appropriate.
(iv) Matrix Functions:
Tree 5: Matrix functions of an n by n real matrix
Is required? |
|
Is stored in dense format? |
|
f01gac |
yes | yes |
| no |
|
| no |
|
|
f01gbc |
|
|
Is real symmetric? |
|
Is required? |
|
f01edc |
yes | yes |
| no |
|
| no |
|
|
f01efc |
|
|
Is or
or
or
required? |
|
Is the condition number of the matrix function required? |
|
f01jac |
yes | yes |
| no |
|
| no |
|
|
f01ekc |
|
|
Is required? |
|
Is the condition number of the matrix logarithm required? |
|
f01jjc |
yes | yes |
| no |
|
| no |
|
|
Is the Fréchet derivative of the matrix logarithm required? |
|
f01jkc |
| yes |
|
| no |
|
|
f01ejc |
|
|
Is required? |
|
Is the condition number of the matrix exponential required? |
|
f01jgc |
yes | yes |
| no |
|
| no |
|
|
Is the Fréchet derivative of the matrix exponential required? |
|
f01jhc |
| yes |
|
| no |
|
|
f01ecc |
|
|
Is required? |
|
Is the condition number of the matrix square root required? |
|
f01jdc |
yes | yes |
| no |
|
| no |
|
|
Is the matrix upper quasi-triangular? |
|
f01epc |
| yes |
|
| no |
|
|
f01enc |
|
|
Is required? |
|
Is the condition number of the matrix power required? |
|
f01jec |
yes | yes |
| no |
|
| no |
|
|
Is the Fréchet derivative of the matrix power required? |
|
f01jfc |
| yes |
|
| no |
|
|
f01eqc |
|
|
will be computed. Will derivatives of be supplied by the user? |
|
Is the condition number of the matrix function required? |
|
f01jcc |
yes | yes |
| no |
|
| no |
|
|
f01emc |
|
|
Is the condition number of the matrix function required? |
|
f01jbc |
yes |
| no |
|
f01elc |
|
Tree 6: Matrix functions of an n by n complex matrix
Is required? |
|
Is stored in dense format? |
|
f01hac |
yes | yes |
| no |
|
| no |
|
|
f01hbc |
|
|
Is complex Hermitian? |
|
Is required? |
|
f01fdc |
yes | yes |
| no |
|
| no |
|
|
f01ffc |
|
|
Is or
or
or
required? |
|
Is the condition number of the matrix function required? |
|
f01kac |
yes | yes |
| no |
|
| no |
|
|
f01fkc |
|
|
Is required? |
|
Is the condition number of the matrix logarithm required? |
|
f01kjc |
yes | yes |
| no |
|
| no |
|
|
Is the Fréchet derivative of the matrix logarithm required? |
|
f01kkc |
| yes |
|
| no |
|
|
f01fjc |
|
|
Is required? |
|
Is the condition number of the matrix exponential required? |
|
f01kgc |
yes | yes |
| no |
|
| no |
|
|
Is the Fréchet derivative of the matrix exponential required? |
|
f01khc |
| yes |
|
| no |
|
|
f01fcc |
|
|
Is required? |
|
Is the condition number of the matrix square root required? |
|
f01kdc |
yes | yes |
| no |
|
| no |
|
|
Is the matrix upper triangular? |
|
f01fpc |
| yes |
|
| no |
|
|
f01fnc |
|
|
Is required? |
|
Is the condition number of the matrix power required? |
|
f01kec |
yes | yes |
| no |
|
| no |
|
|
Is the Fréchet derivative of the matrix power required? |
|
f01kfc |
| yes |
|
| no |
|
|
f01fqc |
|
|
will be computed. Will derivatives of be supplied by the user? |
|
Is the condition number of the matrix function required? |
|
f01kcc |
yes | yes |
| no |
|
| no |
|
|
f01fmc |
|
|
Is the condition number of the matrix function required? |
|
f01kbc |
yes |
| no |
|
f01flc |
|
5
Functionality Index
Action of the matrix exponential on a complex matrix
|
|
f01hac
|
Action of the matrix exponential on a complex matrix (reverse communication)
|
|
f01hbc
|
Action of the matrix exponential on a real matrix
|
|
f01gac
|
Action of the matrix exponential on a real matrix (reverse communication)
|
|
f01gbc
|
Matrix Arithmetic and Manipulation,
|
|
|
matrix storage conversion,
|
|
|
full to packed triangular storage,
|
|
|
full to Rectangular Full Packed storage,
|
|
|
packed triangular to full storage,
|
|
|
packed triangular to Rectangular Full Packed storage,
|
|
|
Rectangular Full Packed to full storage,
|
|
|
Rectangular Full Packed to packed triangular storage,
|
|
|
complex Hermitian matrix,
|
|
|
condition number for a matrix exponential
|
|
f01kgc
|
condition number for a matrix exponential, logarithm, sine, cosine, sinh or cosh
|
|
f01kac
|
condition number for a matrix function, using numerical differentiation
|
|
f01kbc
|
condition number for a matrix function, using user-supplied derivatives
|
|
f01kcc
|
condition number for a matrix logarithm
|
|
f01kjc
|
condition number for a matrix power
|
|
f01kec
|
condition number for the matrix square root, logarithm, sine, cosine, sinh or cosh
|
|
f01kdc
|
matrix exponential, sine, cosine, sinh or cosh
|
|
f01fkc
|
matrix function, using numerical differentiation
|
|
f01flc
|
matrix function, using user-supplied derivatives
|
|
f01fmc
|
condition number for a matrix exponential
|
|
f01jgc
|
condition number for a matrix function, using numerical differentiation
|
|
f01jbc
|
condition number for a matrix function, using user-supplied derivatives
|
|
f01jcc
|
condition number for a matrix logarithm
|
|
f01jjc
|
condition number for a matrix power
|
|
f01jec
|
condition number for the matrix exponential, logarithm, sine, cosine, sinh or cosh
|
|
f01jac
|
condition number for the matrix square root, logarithm, sine, cosine, sinh or cosh
|
|
f01jdc
|
matrix exponential, sine, cosine, sinh or cosh
|
|
f01ekc
|
matrix function, using numerical differentiation
|
|
f01elc
|
matrix function, using user-supplied derivatives
|
|
f01emc
|
real symmetric matrix,
|
|
|
modified Cholesky factorization, form positive definite perturbed input matrix
|
|
f01mec
|
modified Cholesky factorization of a real symmetric matrix
|
|
f01mdc
|
non-negative matrix factorization
|
|
f01sac
|
non-negative matrix factorization, reverse communication
|
|
f01sbc
|
real band symmetric positive definite matrix,
|
|
|
variable bandwidth, factorization
|
|
f01mcc
|
6
Auxiliary Functions Associated with Library Function Arguments
None.
7
Withdrawn or Deprecated Functions
The following lists all those functions that have been withdrawn since Mark 24 of the Library or are in the Library, but deprecated.
8
References
Golub G H and Van Loan C F (1996) Matrix Computations (3rd Edition) Johns Hopkins University Press, Baltimore
Higham N J (2008) Functions of Matrices: Theory and Computation SIAM, Philadelphia, PA, USA
Wilkinson J H (1965) The Algebraic Eigenvalue Problem Oxford University Press, Oxford
Wilkinson J H (1977) Some recent advances in numerical linear algebra The State of the Art in Numerical Analysis (ed D A H Jacobs) Academic Press
Wilkinson J H and Reinsch C (1971) Handbook for Automatic Computation II, Linear Algebra Springer–Verlag
F01 (Matop)
Chapter Introduction
FL CL