mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2025-01-01 06:23:39 +01:00
c977aa998f
Replace amos with slatec
88 lines
3.3 KiB
Fortran
88 lines
3.3 KiB
Fortran
*DECK SSDI
|
|
SUBROUTINE SSDI (N, B, X, NELT, IA, JA, A, ISYM, RWORK, IWORK)
|
|
C***BEGIN PROLOGUE SSDI
|
|
C***PURPOSE Diagonal Matrix Vector Multiply.
|
|
C Routine to calculate the product X = DIAG*B, where DIAG
|
|
C is a diagonal matrix.
|
|
C***LIBRARY SLATEC (SLAP)
|
|
C***CATEGORY D1B4
|
|
C***TYPE SINGLE PRECISION (SSDI-S, DSDI-D)
|
|
C***KEYWORDS ITERATIVE PRECONDITION, LINEAR SYSTEM SOLVE, SLAP, SPARSE
|
|
C***AUTHOR Greenbaum, Anne, (Courant Institute)
|
|
C Seager, Mark K., (LLNL)
|
|
C Lawrence Livermore National Laboratory
|
|
C PO BOX 808, L-60
|
|
C Livermore, CA 94550 (510) 423-3141
|
|
C seager@llnl.gov
|
|
C***DESCRIPTION
|
|
C
|
|
C *Usage:
|
|
C INTEGER N, NELT, IA(NELT), JA(NELT), ISYM, IWORK(10)
|
|
C REAL B(N), X(N), A(NELT), RWORK(USER DEFINED)
|
|
C
|
|
C CALL SSDI (N, B, X, NELT, IA, JA, A, ISYM, RWORK, IWORK)
|
|
C
|
|
C *Arguments:
|
|
C N :IN Integer
|
|
C Order of the Matrix.
|
|
C B :IN Real B(N).
|
|
C Vector to multiply the diagonal by.
|
|
C X :OUT Real X(N).
|
|
C Result of DIAG*B.
|
|
C NELT :DUMMY Integer.
|
|
C IA :DUMMY Integer IA(NELT).
|
|
C JA :DUMMY Integer JA(NELT).
|
|
C A :DUMMY Real A(NELT).
|
|
C ISYM :DUMMY Integer.
|
|
C These are for compatibility with SLAP MSOLVE calling sequence.
|
|
C RWORK :IN Real RWORK(USER DEFINED).
|
|
C Work array holding the diagonal of some matrix to scale
|
|
C B by. This array must be set by the user or by a call
|
|
C to the SLAP routine SSDS or SSD2S. The length of RWORK
|
|
C must be >= IWORK(4)+N.
|
|
C IWORK :IN Integer IWORK(10).
|
|
C IWORK(4) holds the offset into RWORK for the diagonal matrix
|
|
C to scale B by. This is usually set up by the SLAP pre-
|
|
C conditioner setup routines SSDS or SSD2S.
|
|
C
|
|
C *Description:
|
|
C This routine is supplied with the SLAP package to perform
|
|
C the MSOLVE operation for iterative drivers that require
|
|
C diagonal Scaling (e.g., SSDCG, SSDBCG). It conforms
|
|
C to the SLAP MSOLVE CALLING CONVENTION and hence does not
|
|
C require an interface routine as do some of the other pre-
|
|
C conditioners supplied with SLAP.
|
|
C
|
|
C***SEE ALSO SSDS, SSD2S
|
|
C***REFERENCES (NONE)
|
|
C***ROUTINES CALLED (NONE)
|
|
C***REVISION HISTORY (YYMMDD)
|
|
C 871119 DATE WRITTEN
|
|
C 881213 Previous REVISION DATE
|
|
C 890915 Made changes requested at July 1989 CML Meeting. (MKS)
|
|
C 890922 Numerous changes to prologue to make closer to SLATEC
|
|
C standard. (FNF)
|
|
C 890929 Numerous changes to reduce SP/DP differences. (FNF)
|
|
C 910411 Prologue converted to Version 4.0 format. (BAB)
|
|
C 920511 Added complete declaration section. (WRB)
|
|
C 930701 Updated CATEGORY section. (FNF, WRB)
|
|
C***END PROLOGUE SSDI
|
|
C .. Scalar Arguments ..
|
|
INTEGER ISYM, N, NELT
|
|
C .. Array Arguments ..
|
|
REAL A(NELT), B(N), RWORK(*), X(N)
|
|
INTEGER IA(NELT), IWORK(10), JA(NELT)
|
|
C .. Local Scalars ..
|
|
INTEGER I, LOCD
|
|
C***FIRST EXECUTABLE STATEMENT SSDI
|
|
C
|
|
C Determine where the inverse of the diagonal
|
|
C is in the work array and then scale by it.
|
|
C
|
|
LOCD = IWORK(4) - 1
|
|
DO 10 I = 1, N
|
|
X(I) = RWORK(LOCD+I)*B(I)
|
|
10 CONTINUE
|
|
RETURN
|
|
C------------- LAST LINE OF SSDI FOLLOWS ----------------------------
|
|
END
|