mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2025-01-01 06:23:39 +01:00
c977aa998f
Replace amos with slatec
65 lines
2.2 KiB
Fortran
65 lines
2.2 KiB
Fortran
*DECK DDATRP
|
|
SUBROUTINE DDATRP (X, XOUT, YOUT, YPOUT, NEQ, KOLD, PHI, PSI)
|
|
C***BEGIN PROLOGUE DDATRP
|
|
C***SUBSIDIARY
|
|
C***PURPOSE Interpolation routine for DDASSL.
|
|
C***LIBRARY SLATEC (DASSL)
|
|
C***TYPE DOUBLE PRECISION (SDATRP-S, DDATRP-D)
|
|
C***AUTHOR Petzold, Linda R., (LLNL)
|
|
C***DESCRIPTION
|
|
C-----------------------------------------------------------------------
|
|
C THE METHODS IN SUBROUTINE DDASTP USE POLYNOMIALS
|
|
C TO APPROXIMATE THE SOLUTION. DDATRP APPROXIMATES THE
|
|
C SOLUTION AND ITS DERIVATIVE AT TIME XOUT BY EVALUATING
|
|
C ONE OF THESE POLYNOMIALS, AND ITS DERIVATIVE,THERE.
|
|
C INFORMATION DEFINING THIS POLYNOMIAL IS PASSED FROM
|
|
C DDASTP, SO DDATRP CANNOT BE USED ALONE.
|
|
C
|
|
C THE PARAMETERS ARE:
|
|
C X THE CURRENT TIME IN THE INTEGRATION.
|
|
C XOUT THE TIME AT WHICH THE SOLUTION IS DESIRED
|
|
C YOUT THE INTERPOLATED APPROXIMATION TO Y AT XOUT
|
|
C (THIS IS OUTPUT)
|
|
C YPOUT THE INTERPOLATED APPROXIMATION TO YPRIME AT XOUT
|
|
C (THIS IS OUTPUT)
|
|
C NEQ NUMBER OF EQUATIONS
|
|
C KOLD ORDER USED ON LAST SUCCESSFUL STEP
|
|
C PHI ARRAY OF SCALED DIVIDED DIFFERENCES OF Y
|
|
C PSI ARRAY OF PAST STEPSIZE HISTORY
|
|
C-----------------------------------------------------------------------
|
|
C***ROUTINES CALLED (NONE)
|
|
C***REVISION HISTORY (YYMMDD)
|
|
C 830315 DATE WRITTEN
|
|
C 901009 Finished conversion to SLATEC 4.0 format (F.N.Fritsch)
|
|
C 901019 Merged changes made by C. Ulrich with SLATEC 4.0 format.
|
|
C 901026 Added explicit declarations for all variables and minor
|
|
C cosmetic changes to prologue. (FNF)
|
|
C***END PROLOGUE DDATRP
|
|
C
|
|
INTEGER NEQ, KOLD
|
|
DOUBLE PRECISION X, XOUT, YOUT(*), YPOUT(*), PHI(NEQ,*), PSI(*)
|
|
C
|
|
INTEGER I, J, KOLDP1
|
|
DOUBLE PRECISION C, D, GAMMA, TEMP1
|
|
C
|
|
C***FIRST EXECUTABLE STATEMENT DDATRP
|
|
KOLDP1=KOLD+1
|
|
TEMP1=XOUT-X
|
|
DO 10 I=1,NEQ
|
|
YOUT(I)=PHI(I,1)
|
|
10 YPOUT(I)=0.0D0
|
|
C=1.0D0
|
|
D=0.0D0
|
|
GAMMA=TEMP1/PSI(1)
|
|
DO 30 J=2,KOLDP1
|
|
D=D*GAMMA+C/PSI(J-1)
|
|
C=C*GAMMA
|
|
GAMMA=(TEMP1+PSI(J-1))/PSI(J)
|
|
DO 20 I=1,NEQ
|
|
YOUT(I)=YOUT(I)+C*PHI(I,J)
|
|
20 YPOUT(I)=YPOUT(I)+D*PHI(I,J)
|
|
30 CONTINUE
|
|
RETURN
|
|
C
|
|
C------END OF SUBROUTINE DDATRP------
|
|
END
|