Routine ID: F012 | |
---|---|
Author(s): H. Lipps | Library: KERNLIB |
Submitter: | Submitted: 01.09.1983 |
Language: Fortran or Assembler or COMPASS | Revised: |
Subroutine tSINV (where or D as described below) computes the inverse of a symmetric positive-definite matrix A.
Subroutine tSEQN solves a set of linear equations
whose coefficient matrix A is symmetric and positive-definite. The determinant det( A) of A may be calculated by subroutine tSFACT described below.
If several systems of the form (*) are to be solved with the same A but differing B, a procedure which is appreciably faster than calling subroutine tSEQN repeatedly is to execute a single call to subroutine tSEQN (or subroutine tSFACT if the determinant is required), and then to call subroutine tSFEQN as many times as required. When the last system (*) has been solved, the inverse matrix , if required, may be computed by calling tSFINV.
Subroutine tSEQN and tSFACT both replace the matrix A by a lower triangular matrix L and an upper triangular matrix U such that . This LU decomposition is referred to below as lu(A).
Given lu(A) and some matrix B, subroutine tSFEQN replaces B by the solution X of equation (*) without changing lu(A). Subroutine tSFEQN may therefore be called repeatedly with differing B.
Given lu(A), subroutine tSFINV replaces lu(A) by the inverse of A.
Structure:
SUBROUTINE subprograms
User Entry Names:
RSFACT, RSEQN, RSFEQN, RSINV, RSFINV
DSFACT, DSEQN, DSFEQN, DSINV, DSFINV
Files Referenced: Printer
External References: TMPRNT (F011), KERMTR (N001),
ABEND (Z035)
Usage:
For (type REAL), (type DOUBLE PRECISION):
CALL tSINV (N,A,IDIM,IFAIL) CALL tSEQN (N,A,IDIM,IFAIL,K,B) CALL tSFACT(N,A,IDIM,IFAIL,DET,JFAIL) CALL tSFEQN(N,A,IDIM,K,B) CALL tSFINV(N,A,IDIM)
Method:
Modified Cholesky factorization (without square roots). See Ref. 1.
Accuracy:
On computers with IBM 370 architecture, inner products are accumulated using double precision arithmetic internally for arrays of type REAL.
Notes:
Only those elements of the original matrix A for which are required on entry to tSINV, tSEQN and tSFACT.
Error handling:
If or or (tSEQN) or (tSFEQN), a message is printed and program execution is terminated by calling ABEND (Z035).
Examples:
Assume that the matrix A and the
matrix B are stored according to the Fortran convention in arrays A and B respectively of a program containing the declarations
REAL A(25,30),B(25,10)To replace B by the solution matrix X of the system of equations , with a jump to label 100 if A is not positive definite:
CALL RSEQN(10,A,25,IFAIL,3,B) IF(IFAIL .NE. 0) GO TO 100
References: