ESMF_DGETRI Subroutine

subroutine ESMF_DGETRI(N, A, LDA, IPIV, WORK, LWORK, INFO)

\brief \b ESMF_DGETRI \htmlonly Download ESMF_DGETRI + dependencies [TGZ] [ZIP] [TXT] \endhtmlonly \par Purpose:

\verbatim

ESMF_DGETRI computes the inverse of a matrix using the LU factorization computed by ESMF_DGETRF.

This method inverts U and then computes inv(A) by solving the system inv(A)*L = inv(U) for inv(A). \endverbatim \param[in] N \verbatim N is INTEGER The order of the matrix A. N >= 0. \endverbatim

\param[in,out] A \verbatim A is DOUBLE PRECISION array, dimension (LDA,N) On entry, the factors L and U from the factorization A = PLU as computed by ESMF_DGETRF. On exit, if INFO = 0, the inverse of the original matrix A. \endverbatim

\param[in] LDA \verbatim LDA is INTEGER The leading dimension of the array A. LDA >= max(1,N). \endverbatim

\param[in] IPIV \verbatim IPIV is INTEGER array, dimension (N) The pivot indices from ESMF_DGETRF; for 1<=i<=N, row i of the matrix was interchanged with row IPIV(i). \endverbatim

\param[out] WORK \verbatim WORK is DOUBLE PRECISION array, dimension (MAX(1,LWORK)) On exit, if INFO=0, then WORK(1) returns the optimal LWORK. \endverbatim

\param[in] LWORK \verbatim LWORK is INTEGER The dimension of the array WORK. LWORK >= max(1,N). For optimal performance LWORK >= N*NB, where NB is the optimal blocksize returned by ESMF_ILAENV.

     If LWORK = -1, then a workspace query is assumed; the routine
     only calculates the optimal size of the WORK array, returns
     this value as the first entry of the WORK array, and no error
     message related to LWORK is issued by ESMF_XERBLA.

\endverbatim

\param[out] INFO \verbatim INFO is INTEGER = 0: successful exit < 0: if INFO = -i, the i-th argument had an illegal value > 0: if INFO = i, U(i,i) is exactly zero; the matrix is singular and its inverse could not be computed. \endverbatim \author Univ. of Tennessee \author Univ. of California Berkeley \author Univ. of Colorado Denver \author NAG Ltd. \date December 2016 \ingroup doubleGEcomputational

Arguments

Type IntentOptional Attributes Name
integer :: N
double precision :: A(LDA,*)
integer :: LDA
integer :: IPIV(*)
double precision :: WORK(*)
integer :: LWORK
integer :: INFO