\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
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
integer | :: | N | ||||
double precision | :: | A(LDA,*) | ||||
integer | :: | LDA | ||||
integer | :: | IPIV(*) | ||||
double precision | :: | WORK(*) | ||||
integer | :: | LWORK | ||||
integer | :: | INFO |