Skip to content

Commit

Permalink
Update and extend the documentation of expm, logm and sqrtm
Browse files Browse the repository at this point in the history
  • Loading branch information
mfasi committed Aug 4, 2015
1 parent e66175b commit c4f8aea
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 8 deletions.
34 changes: 30 additions & 4 deletions base/docs/helpdb.jl
Original file line number Diff line number Diff line change
Expand Up @@ -7006,7 +7006,19 @@ doc"""
::
logm(A)
Compute the matrix logarithm of ``A``.
If ``A`` has no negative real eigenvalue, compute the principal matrix logarithm of ``A``, i.e. the unique matrix :math:`X` such that :math:`e^X = A` and :math:`-\pi < Im(\lambda) < \pi` for all the eigenvalues :math:`\lambda` of :math:`X`. If ``A`` has nonpositive eigenvalues, a warning is printed and whenever possible a nonprincipal matrix function is returned.
If `A` is symmetric or Hermitian, its eigendecomposition (:func:`eigfact`) is used, if `A` is triangular an improved version of the inverse scaling and squaring method is employed (see [AH12]_ and [AHR13]_). For general matrices, the complex Schur form (:func:`schur`) is computed and the triangular algorithm is used on the triangular factor.
.. [AH12] Awad H. Al-Mohy and Nicholas J. Higham, "Improved inverse scaling
and squaring algorithms for the matrix logarithm", SIAM Journal on
Scientific Computing, 34(4), 2012, C153-C169.
`doi:/10.1137/110852553 <http://dx.doi.org/10.1137/110852553>`
.. [AHR13] Awad H. Al-Mohy, Nicholas J. Higham and Samuel D. Relton,
"Computing the Fréchet derivative of the matrix logarithm and estimating
the condition number", SIAM Journal on Scientific Computing, 35(4), 2013,
C394-C410.
`doi:/10.1137/120885991 <http://dx.doi.org/10.1137/120885991>`
```
"""
logm
Expand Down Expand Up @@ -10713,9 +10725,13 @@ doc"""
::
sqrtm(A)
Compute the matrix square root of ``A``. If ``B = sqrtm(A)``, then ``B*B == A`` within roundoff error.
If ``A`` has no negative real eigenvalues, compute the principal matrix square root of ``A``, that is the unique matrix :math:`X` with eigenvalues having positive real part such that :math:`X^2 = A`. Otherwise, a nonprincipal square root is returned.
``sqrtm`` uses a polyalgorithm, computing the matrix square root using Schur factorizations (:func:`schurfact`) unless it detects the matrix to be Hermitian or real symmetric, in which case it computes the matrix square root from an eigendecomposition (:func:`eigfact`). In the latter situation for positive definite matrices, the matrix square root has ``Real`` elements, otherwise it has ``Complex`` elements.
If `A` is symmetric or Hermitian, its eigendecomposition (:func:`eigfact`) is used to compute the square root. Otherwise, the square root is determined by means of the Björck-Hammarling method, which computes the complex Schur form (:func:`schur`) and then the complex square root of the triangular factor.
.. [BH83] Åke Björck and Sven Hammarling, "A Schur method for the square root
of a matrix", Linear Algebra and its Applications, 52-53, 1983, 127-140.
`doi:/10.1016/0024-3795(83)80010-X <http://dx.doi.org/10.1016/0024-3795(83)80010-X>`
```
"""
sqrtm
Expand Down Expand Up @@ -10750,7 +10766,17 @@ doc"""
::
expm(A)
Compute the matrix exponential of ``A``.
Compute the matrix exponential of ``A``, defined by
.. math::
e^A = \sum_{n=0}^{\inf} \dfrac{A^n}{n!}.
For symmetric or Hermitian ``A``, an eigendecomposition (:func:`eigfact`) is used, otherwise the scaling and squaring algorithm (see [H05]_) is chosen.
.. [H05] Nicholas J. Higham, "The squaring and scaling method for the matrix
exponential revisited", SIAM Journal on Matrix Analysis and Applications,
26(4), 2005, 1179-1193.
`doi:/10.1137/090768539 <http://dx.doi.org/10.1137/090768539>`
```
"""
expm
Expand Down
2 changes: 1 addition & 1 deletion base/linalg.jl
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,6 @@ export
eigvals!,
eigvecs,
expm,
sqrtm,
eye,
factorize,
givens,
Expand Down Expand Up @@ -106,6 +105,7 @@ export
schur,
schurfact!,
schurfact,
sqrtm,
svd,
svdfact!,
svdfact,
Expand Down
2 changes: 1 addition & 1 deletion base/linalg/dense.jl
Original file line number Diff line number Diff line change
Expand Up @@ -304,7 +304,7 @@ function logm(A::StridedMatrix)
end
end
if np_real_eigs
warn("Matrix with nonpositive real eigenvalues, a nonprimary matrix logarithm will be returned.")
warn("Matrix with nonpositive real eigenvalues, a nonprincipal matrix logarithm will be returned.")
end

if isreal(A) && ~np_real_eigs
Expand Down
4 changes: 2 additions & 2 deletions test/linalg/dense.jl
Original file line number Diff line number Diff line change
Expand Up @@ -347,12 +347,12 @@ for elty in (Float64, Complex{Float64})
A5 = convert(Matrix{elty}, [1 1 0 1; 0 1 1 0; 0 0 1 1; 1 0 0 1])
@test_approx_eq expm(logm(A5)) A5
s = readline(rd)
@test contains(s, "WARNING: Matrix with nonpositive real eigenvalues, a nonprimary matrix logarithm will be returned.")
@test contains(s, "WARNING: Matrix with nonpositive real eigenvalues, a nonprincipal matrix logarithm will be returned.")

A6 = convert(Matrix{elty}, [-5 2 0 0 ; 1/2 -7 3 0; 0 1/3 -9 4; 0 0 1/4 -11])
@test_approx_eq expm(logm(A6)) A6
s = readline(rd)
@test contains(s, "WARNING: Matrix with nonpositive real eigenvalues, a nonprimary matrix logarithm will be returned.")
@test contains(s, "WARNING: Matrix with nonpositive real eigenvalues, a nonprincipal matrix logarithm will be returned.")
redirect_stderr(OLD_STDERR)

A7 = convert(Matrix{elty}, [1 0 0 1e-8; 0 1 0 0; 0 0 1 0; 0 0 0 1])
Expand Down

0 comments on commit c4f8aea

Please sign in to comment.