OpenLibm/slatec/dbnslv.f
Viral B. Shah c977aa998f Add Makefile.extras to build libopenlibm-extras.
Replace amos with slatec
2012-12-31 16:37:05 -05:00

81 lines
2.8 KiB
Fortran

*DECK DBNSLV
SUBROUTINE DBNSLV (W, NROWW, NROW, NBANDL, NBANDU, B)
C***BEGIN PROLOGUE DBNSLV
C***SUBSIDIARY
C***PURPOSE Subsidiary to DBINT4 and DBINTK
C***LIBRARY SLATEC
C***TYPE DOUBLE PRECISION (BNSLV-S, DBNSLV-D)
C***AUTHOR (UNKNOWN)
C***DESCRIPTION
C
C DBNSLV is the BANSLV routine from
C * A Practical Guide to Splines * by C. de Boor
C
C DBNSLV is a double precision routine
C
C Companion routine to DBNFAC . It returns the solution X of the
C linear system A*X = B in place of B , given the LU-factorization
C for A in the work array W from DBNFAC.
C
C ***** I N P U T ****** W,B are DOUBLE PRECISION
C W, NROWW,NROW,NBANDL,NBANDU.....Describe the LU-factorization of a
C banded matrix A of order NROW as constructed in DBNFAC .
C For details, see DBNFAC .
C B.....Right side of the system to be solved .
C
C ***** O U T P U T ****** B is DOUBLE PRECISION
C B.....Contains the solution X , of order NROW .
C
C ***** M E T H O D ******
C (With A = L*U, as stored in W,) the unit lower triangular system
C L(U*X) = B is solved for Y = U*X, and Y stored in B . Then the
C upper triangular system U*X = Y is solved for X . The calcul-
C ations are so arranged that the innermost loops stay within columns.
C
C***SEE ALSO DBINT4, DBINTK
C***ROUTINES CALLED (NONE)
C***REVISION HISTORY (YYMMDD)
C 800901 DATE WRITTEN
C 890531 Changed all specific intrinsics to generic. (WRB)
C 890831 Modified array declarations. (WRB)
C 891214 Prologue converted to Version 4.0 format. (BAB)
C 900328 Added TYPE section. (WRB)
C***END PROLOGUE DBNSLV
C
INTEGER NBANDL, NBANDU, NROW, NROWW, I, J, JMAX, MIDDLE, NROWM1
DOUBLE PRECISION W(NROWW,*), B(*)
C***FIRST EXECUTABLE STATEMENT DBNSLV
MIDDLE = NBANDU + 1
IF (NROW.EQ.1) GO TO 80
NROWM1 = NROW - 1
IF (NBANDL.EQ.0) GO TO 30
C FORWARD PASS
C FOR I=1,2,...,NROW-1, SUBTRACT RIGHT SIDE(I)*(I-TH COLUMN
C OF L ) FROM RIGHT SIDE (BELOW I-TH ROW) .
DO 20 I=1,NROWM1
JMAX = MIN(NBANDL,NROW-I)
DO 10 J=1,JMAX
B(I+J) = B(I+J) - B(I)*W(MIDDLE+J,I)
10 CONTINUE
20 CONTINUE
C BACKWARD PASS
C FOR I=NROW,NROW-1,...,1, DIVIDE RIGHT SIDE(I) BY I-TH DIAG-
C ONAL ENTRY OF U, THEN SUBTRACT RIGHT SIDE(I)*(I-TH COLUMN
C OF U) FROM RIGHT SIDE (ABOVE I-TH ROW).
30 IF (NBANDU.GT.0) GO TO 50
C A IS LOWER TRIANGULAR .
DO 40 I=1,NROW
B(I) = B(I)/W(1,I)
40 CONTINUE
RETURN
50 I = NROW
60 B(I) = B(I)/W(MIDDLE,I)
JMAX = MIN(NBANDU,I-1)
DO 70 J=1,JMAX
B(I-J) = B(I-J) - B(I)*W(MIDDLE-J,I)
70 CONTINUE
I = I - 1
IF (I.GT.1) GO TO 60
80 B(1) = B(1)/W(MIDDLE,1)
RETURN
END