DACOPY
|
|
DAXPY
|
***PURPOSE Compute a constant times a vector plus a vector.
***CATEGORY D1A7
***TYPE DOUBLE PRECISION (SAXPY-S, DAXPY-D, CAXPY-C)
***KEYWORDS BLAS, LINEAR ALGEBRA, TRIAD, VECTOR
***AUTHOR Lawson, C. L., (JPL)
Hanson, R. J., (SNLA)
Kincaid, D. R., (U. of Texas)
Krogh, F. T., (JPL)
***DESCRIPTION
B L A S Subprogram
Description of Parameters
--Input--
N number of elements in input vector(s)
DA double precision scalar multiplier
DX double precision vector with N elements
INCX storage spacing between elements of DX
DY double precision vector with N elements
INCY storage spacing between elements of DY
--Output--
DY double precision result (unchanged if N .LE. 0)
Overwrite double precision DY with double precision DA*DX + DY.
For I = 0 to N-1, replace DY(LY+I*INCY) with DA*DX(LX+I*INCX) +
DY(LY+I*INCY),
where LX = 1 if INCX .GE. 0, else LX = 1+(1-N)*INCX, and LY is
defined in a similar way using INCY.
***REFERENCES C. L. Lawson, R. J. Hanson, D. R. Kincaid and F. T.
Krogh, Basic linear algebra subprograms for Fortran
usage, Algorithm No. 539, Transactions on Mathematical
Software 5, 3 (September 1979), pp. 308-323.
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791001 DATE WRITTEN
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
920310 Corrected definition of LX in DESCRIPTION. (WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DAXPY
***FIRST EXECUTABLE STATEMENT DAXPY
|
DCOPY
|
***PURPOSE Copy a vector.
***CATEGORY D1A5
***TYPE DOUBLE PRECISION (SCOPY-S, DCOPY-D, CCOPY-C, ICOPY-I)
***KEYWORDS BLAS, COPY, LINEAR ALGEBRA, VECTOR
***AUTHOR Lawson, C. L., (JPL)
Hanson, R. J., (SNLA)
Kincaid, D. R., (U. of Texas)
Krogh, F. T., (JPL)
***DESCRIPTION
B L A S Subprogram
Description of Parameters
--Input--
N number of elements in input vector(s)
DX double precision vector with N elements
INCX storage spacing between elements of DX
DY double precision vector with N elements
INCY storage spacing between elements of DY
--Output--
DY copy of vector DX (unchanged if N .LE. 0)
Copy double precision DX to double precision DY.
For I = 0 to N-1, copy DX(LX+I*INCX) to DY(LY+I*INCY),
where LX = 1 if INCX .GE. 0, else LX = 1+(1-N)*INCX, and LY is
defined in a similar way using INCY.
***REFERENCES C. L. Lawson, R. J. Hanson, D. R. Kincaid and F. T.
Krogh, Basic linear algebra subprograms for Fortran
usage, Algorithm No. 539, Transactions on Mathematical
Software 5, 3 (September 1979), pp. 308-323.
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791001 DATE WRITTEN
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
920310 Corrected definition of LX in DESCRIPTION. (WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DCOPY
***FIRST EXECUTABLE STATEMENT DCOPY
|
DDOT
|
***PURPOSE Compute the inner product of two vectors.
***CATEGORY D1A4
***TYPE DOUBLE PRECISION (SDOT-S, DDOT-D, CDOTU-C)
***KEYWORDS BLAS, INNER PRODUCT, LINEAR ALGEBRA, VECTOR
***AUTHOR Lawson, C. L., (JPL)
Hanson, R. J., (SNLA)
Kincaid, D. R., (U. of Texas)
Krogh, F. T., (JPL)
***DESCRIPTION
B L A S Subprogram
Description of Parameters
--Input--
N number of elements in input vector(s)
DX double precision vector with N elements
INCX storage spacing between elements of DX
DY double precision vector with N elements
INCY storage spacing between elements of DY
--Output--
DDOT double precision dot product (zero if N .LE. 0)
Returns the dot product of double precision DX and DY.
DDOT = sum for I = 0 to N-1 of DX(LX+I*INCX) * DY(LY+I*INCY),
where LX = 1 if INCX .GE. 0, else LX = 1+(1-N)*INCX, and LY is
defined in a similar way using INCY.
***REFERENCES C. L. Lawson, R. J. Hanson, D. R. Kincaid and F. T.
Krogh, Basic linear algebra subprograms for Fortran
usage, Algorithm No. 539, Transactions on Mathematical
Software 5, 3 (September 1979), pp. 308-323.
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791001 DATE WRITTEN
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
920310 Corrected definition of LX in DESCRIPTION. (WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DDOT
***FIRST EXECUTABLE STATEMENT DDOT
|
DEWSET
|
***PURPOSE Set error weight vector.
***TYPE DOUBLE PRECISION (SEWSET-S, DEWSET-D)
***AUTHOR Hindmarsh, Alan C., (LLNL)
***DESCRIPTION
This subroutine sets the error weight vector EWT according to
EWT(i) = RTOL(i)*ABS(YCUR(i)) + ATOL(i), i = 1,...,N,
with the subscript on RTOL and/or ATOL possibly replaced by 1 above,
depending on the value of ITOL.
***SEE ALSO DLSODE
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791129 DATE WRITTEN
890501 Modified prologue to SLATEC/LDOC format. (FNF)
890503 Minor cosmetic changes. (FNF)
930809 Renamed to allow single/double precision versions. (ACH)
***END PROLOGUE DEWSET
**End
***FIRST EXECUTABLE STATEMENT DEWSET
|
DGBFA
|
***PURPOSE Factor a band matrix using Gaussian elimination.
***CATEGORY D2A2
***TYPE DOUBLE PRECISION (SGBFA-S, DGBFA-D, CGBFA-C)
***KEYWORDS BANDED, LINEAR ALGEBRA, LINPACK, MATRIX FACTORIZATION
***AUTHOR Moler, C. B., (U. of New Mexico)
***DESCRIPTION
DGBFA factors a double precision band matrix by elimination.
DGBFA is usually called by DGBCO, but it can be called
directly with a saving in time if RCOND is not needed.
On Entry
ABD DOUBLE PRECISION(LDA, N)
contains the matrix in band storage. The columns
of the matrix are stored in the columns of ABD and
the diagonals of the matrix are stored in rows
ML+1 through 2*ML+MU+1 of ABD .
See the comments below for details.
LDA INTEGER
the leading dimension of the array ABD .
LDA must be .GE. 2*ML + MU + 1 .
N INTEGER
the order of the original matrix.
ML INTEGER
number of diagonals below the main diagonal.
0 .LE. ML .LT. N .
MU INTEGER
number of diagonals above the main diagonal.
0 .LE. MU .LT. N .
More efficient if ML .LE. MU .
On Return
ABD an upper triangular matrix in band storage and
the multipliers which were used to obtain it.
The factorization can be written A = L*U where
L is a product of permutation and unit lower
triangular matrices and U is upper triangular.
IPVT INTEGER(N)
an integer vector of pivot indices.
INFO INTEGER
= 0 normal value.
= K if U(K,K) .EQ. 0.0 . This is not an error
condition for this subroutine, but it does
indicate that DGBSL will divide by zero if
called. Use RCOND in DGBCO for a reliable
indication of singularity.
Band Storage
If A is a band matrix, the following program segment
will set up the input.
ML = (band width below the diagonal)
MU = (band width above the diagonal)
M = ML + MU + 1
DO 20 J = 1, N
I1 = MAX(1, J-MU)
I2 = MIN(N, J+ML)
DO 10 I = I1, I2
K = I - J + M
ABD(K,J) = A(I,J)
10 CONTINUE
20 CONTINUE
This uses rows ML+1 through 2*ML+MU+1 of ABD .
In addition, the first ML rows in ABD are used for
elements generated during the triangularization.
The total number of rows needed in ABD is 2*ML+MU+1 .
The ML+MU by ML+MU upper left triangle and the
ML by ML lower right triangle are not referenced.
***REFERENCES J. J. Dongarra, J. R. Bunch, C. B. Moler, and G. W.
Stewart, LINPACK Users' Guide, SIAM, 1979.
***ROUTINES CALLED DAXPY, DSCAL, IDAMAX
***REVISION HISTORY (YYMMDD)
780814 DATE WRITTEN
890531 Changed all specific intrinsics to generic. (WRB)
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
900326 Removed duplicate information from DESCRIPTION section.
(WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DGBFA
|
DGBSL
|
***PURPOSE Solve the real band system A*X=B or TRANS(A)*X=B using
the factors computed by DGBCO or DGBFA.
***CATEGORY D2A2
***TYPE DOUBLE PRECISION (SGBSL-S, DGBSL-D, CGBSL-C)
***KEYWORDS BANDED, LINEAR ALGEBRA, LINPACK, MATRIX, SOLVE
***AUTHOR Moler, C. B., (U. of New Mexico)
***DESCRIPTION
DGBSL solves the double precision band system
A * X = B or TRANS(A) * X = B
using the factors computed by DGBCO or DGBFA.
On Entry
ABD DOUBLE PRECISION(LDA, N)
the output from DGBCO or DGBFA.
LDA INTEGER
the leading dimension of the array ABD .
N INTEGER
the order of the original matrix.
ML INTEGER
number of diagonals below the main diagonal.
MU INTEGER
number of diagonals above the main diagonal.
IPVT INTEGER(N)
the pivot vector from DGBCO or DGBFA.
B DOUBLE PRECISION(N)
the right hand side vector.
JOB INTEGER
= 0 to solve A*X = B ,
= nonzero to solve TRANS(A)*X = B , where
TRANS(A) is the transpose.
On Return
B the solution vector X .
Error Condition
A division by zero will occur if the input factor contains a
zero on the diagonal. Technically this indicates singularity
but it is often caused by improper arguments or improper
setting of LDA . It will not occur if the subroutines are
called correctly and if DGBCO has set RCOND .GT. 0.0
or DGBFA has set INFO .EQ. 0 .
To compute INVERSE(A) * C where C is a matrix
with P columns
CALL DGBCO(ABD,LDA,N,ML,MU,IPVT,RCOND,Z)
IF (RCOND is too small) GO TO ...
DO 10 J = 1, P
CALL DGBSL(ABD,LDA,N,ML,MU,IPVT,C(1,J),0)
10 CONTINUE
***REFERENCES J. J. Dongarra, J. R. Bunch, C. B. Moler, and G. W.
Stewart, LINPACK Users' Guide, SIAM, 1979.
***ROUTINES CALLED DAXPY, DDOT
***REVISION HISTORY (YYMMDD)
780814 DATE WRITTEN
890531 Changed all specific intrinsics to generic. (WRB)
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
900326 Removed duplicate information from DESCRIPTION section.
(WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DGBSL
***FIRST EXECUTABLE STATEMENT DGBSL
|
DGEFA
|
***PURPOSE Factor a matrix using Gaussian elimination.
***CATEGORY D2A1
***TYPE DOUBLE PRECISION (SGEFA-S, DGEFA-D, CGEFA-C)
***KEYWORDS GENERAL MATRIX, LINEAR ALGEBRA, LINPACK,
MATRIX FACTORIZATION
***AUTHOR Moler, C. B., (U. of New Mexico)
***DESCRIPTION
DGEFA factors a double precision matrix by Gaussian elimination.
DGEFA is usually called by DGECO, but it can be called
directly with a saving in time if RCOND is not needed.
(Time for DGECO) = (1 + 9/N)*(Time for DGEFA) .
On Entry
A DOUBLE PRECISION(LDA, N)
the matrix to be factored.
LDA INTEGER
the leading dimension of the array A .
N INTEGER
the order of the matrix A .
On Return
A an upper triangular matrix and the multipliers
which were used to obtain it.
The factorization can be written A = L*U where
L is a product of permutation and unit lower
triangular matrices and U is upper triangular.
IPVT INTEGER(N)
an integer vector of pivot indices.
INFO INTEGER
= 0 normal value.
= K if U(K,K) .EQ. 0.0 . This is not an error
condition for this subroutine, but it does
indicate that DGESL or DGEDI will divide by zero
if called. Use RCOND in DGECO for a reliable
indication of singularity.
***REFERENCES J. J. Dongarra, J. R. Bunch, C. B. Moler, and G. W.
Stewart, LINPACK Users' Guide, SIAM, 1979.
***ROUTINES CALLED DAXPY, DSCAL, IDAMAX
***REVISION HISTORY (YYMMDD)
780814 DATE WRITTEN
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
900326 Removed duplicate information from DESCRIPTION section.
(WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DGEFA
|
DGESL
|
***PURPOSE Solve the real system A*X=B or TRANS(A)*X=B using the
factors computed by DGECO or DGEFA.
***CATEGORY D2A1
***TYPE DOUBLE PRECISION (SGESL-S, DGESL-D, CGESL-C)
***KEYWORDS LINEAR ALGEBRA, LINPACK, MATRIX, SOLVE
***AUTHOR Moler, C. B., (U. of New Mexico)
***DESCRIPTION
DGESL solves the double precision system
A * X = B or TRANS(A) * X = B
using the factors computed by DGECO or DGEFA.
On Entry
A DOUBLE PRECISION(LDA, N)
the output from DGECO or DGEFA.
LDA INTEGER
the leading dimension of the array A .
N INTEGER
the order of the matrix A .
IPVT INTEGER(N)
the pivot vector from DGECO or DGEFA.
B DOUBLE PRECISION(N)
the right hand side vector.
JOB INTEGER
= 0 to solve A*X = B ,
= nonzero to solve TRANS(A)*X = B where
TRANS(A) is the transpose.
On Return
B the solution vector X .
Error Condition
A division by zero will occur if the input factor contains a
zero on the diagonal. Technically this indicates singularity
but it is often caused by improper arguments or improper
setting of LDA . It will not occur if the subroutines are
called correctly and if DGECO has set RCOND .GT. 0.0
or DGEFA has set INFO .EQ. 0 .
To compute INVERSE(A) * C where C is a matrix
with P columns
CALL DGECO(A,LDA,N,IPVT,RCOND,Z)
IF (RCOND is too small) GO TO ...
DO 10 J = 1, P
CALL DGESL(A,LDA,N,IPVT,C(1,J),0)
10 CONTINUE
***REFERENCES J. J. Dongarra, J. R. Bunch, C. B. Moler, and G. W.
Stewart, LINPACK Users' Guide, SIAM, 1979.
***ROUTINES CALLED DAXPY, DDOT
***REVISION HISTORY (YYMMDD)
780814 DATE WRITTEN
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
900326 Removed duplicate information from DESCRIPTION section.
(WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DGESL
***FIRST EXECUTABLE STATEMENT DGESL
|
DNRM2
|
***PURPOSE Compute the Euclidean length (L2 norm) of a vector.
***CATEGORY D1A3B
***TYPE DOUBLE PRECISION (SNRM2-S, DNRM2-D, SCNRM2-C)
***KEYWORDS BLAS, EUCLIDEAN LENGTH, EUCLIDEAN NORM, L2,
LINEAR ALGEBRA, UNITARY, VECTOR
***AUTHOR Lawson, C. L., (JPL)
Hanson, R. J., (SNLA)
Kincaid, D. R., (U. of Texas)
Krogh, F. T., (JPL)
***DESCRIPTION
B L A S Subprogram
Description of parameters
--Input--
N number of elements in input vector(s)
DX double precision vector with N elements
INCX storage spacing between elements of DX
--Output--
DNRM2 double precision result (zero if N .LE. 0)
Euclidean norm of the N-vector stored in DX with storage
increment INCX.
If N .LE. 0, return with result = 0.
If N .GE. 1, then INCX must be .GE. 1
Four phase method using two built-in constants that are
hopefully applicable to all machines.
CUTLO = maximum of SQRT(U/EPS) over all known machines.
CUTHI = minimum of SQRT(V) over all known machines.
where
EPS = smallest no. such that EPS + 1. .GT. 1.
U = smallest positive no. (underflow limit)
V = largest no. (overflow limit)
Brief outline of algorithm.
Phase 1 scans zero components.
move to phase 2 when a component is nonzero and .LE. CUTLO
move to phase 3 when a component is .GT. CUTLO
move to phase 4 when a component is .GE. CUTHI/M
where M = N for X() real and M = 2*N for complex.
Values for CUTLO and CUTHI.
From the environmental parameters listed in the IMSL converter
document the limiting values are as follows:
CUTLO, S.P. U/EPS = 2**(-102) for Honeywell. Close seconds are
Univac and DEC at 2**(-103)
Thus CUTLO = 2**(-51) = 4.44089E-16
CUTHI, S.P. V = 2**127 for Univac, Honeywell, and DEC.
Thus CUTHI = 2**(63.5) = 1.30438E19
CUTLO, D.P. U/EPS = 2**(-67) for Honeywell and DEC.
Thus CUTLO = 2**(-33.5) = 8.23181D-11
CUTHI, D.P. same as S.P. CUTHI = 1.30438D19
DATA CUTLO, CUTHI /8.232D-11, 1.304D19/
DATA CUTLO, CUTHI /4.441E-16, 1.304E19/
***REFERENCES C. L. Lawson, R. J. Hanson, D. R. Kincaid and F. T.
Krogh, Basic linear algebra subprograms for Fortran
usage, Algorithm No. 539, Transactions on Mathematical
Software 5, 3 (September 1979), pp. 308-323.
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791001 DATE WRITTEN
890531 Changed all specific intrinsics to generic. (WRB)
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DNRM2
***FIRST EXECUTABLE STATEMENT DNRM2
|
DSCAL
|
***PURPOSE Multiply a vector by a constant.
***CATEGORY D1A6
***TYPE DOUBLE PRECISION (SSCAL-S, DSCAL-D, CSCAL-C)
***KEYWORDS BLAS, LINEAR ALGEBRA, SCALE, VECTOR
***AUTHOR Lawson, C. L., (JPL)
Hanson, R. J., (SNLA)
Kincaid, D. R., (U. of Texas)
Krogh, F. T., (JPL)
***DESCRIPTION
B L A S Subprogram
Description of Parameters
--Input--
N number of elements in input vector(s)
DA double precision scale factor
DX double precision vector with N elements
INCX storage spacing between elements of DX
--Output--
DX double precision result (unchanged if N.LE.0)
Replace double precision DX by double precision DA*DX.
For I = 0 to N-1, replace DX(IX+I*INCX) with DA * DX(IX+I*INCX),
where IX = 1 if INCX .GE. 0, else IX = 1+(1-N)*INCX.
***REFERENCES C. L. Lawson, R. J. Hanson, D. R. Kincaid and F. T.
Krogh, Basic linear algebra subprograms for Fortran
usage, Algorithm No. 539, Transactions on Mathematical
Software 5, 3 (September 1979), pp. 308-323.
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791001 DATE WRITTEN
890831 Modified array declarations. (WRB)
890831 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
900821 Modified to correct problem with a negative increment.
(WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE DSCAL
***FIRST EXECUTABLE STATEMENT DSCAL
|
DUMACH
|
***PURPOSE Compute the unit roundoff of the machine.
***CATEGORY R1
***TYPE DOUBLE PRECISION (RUMACH-S, DUMACH-D)
***KEYWORDS MACHINE CONSTANTS
***AUTHOR Hindmarsh, Alan C., (LLNL)
***DESCRIPTION
*Usage:
DOUBLE PRECISION A, DUMACH
A = DUMACH()
*Function Return Values:
A : the unit roundoff of the machine.
*Description:
The unit roundoff is defined as the smallest positive machine
number u such that 1.0 + u .ne. 1.0. This is computed by DUMACH
in a machine-independent manner.
***REFERENCES (NONE)
***ROUTINES CALLED DUMSUM
***REVISION HISTORY (YYYYMMDD)
19930216 DATE WRITTEN
19930818 Added SLATEC-format prologue. (FNF)
20030707 Added DUMSUM to force normal storage of COMP. (ACH)
***END PROLOGUE DUMACH
***FIRST EXECUTABLE STATEMENT DUMACH
|
DUMSUM
|
|
DVHIN
|
|
DVINDY
|
|
DVJAC
|
|
DVJUST
|
|
DVNLSD
|
|
DVNORM
|
***PURPOSE Weighted root-mean-square vector norm.
***TYPE DOUBLE PRECISION (SVNORM-S, DVNORM-D)
***AUTHOR Hindmarsh, Alan C., (LLNL)
***DESCRIPTION
This function routine computes the weighted root-mean-square norm
of the vector of length N contained in the array V, with weights
contained in the array W of length N:
DVNORM = SQRT( (1/N) * SUM( V(i)*W(i) )**2 )
***SEE ALSO DLSODE
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791129 DATE WRITTEN
890501 Modified prologue to SLATEC/LDOC format. (FNF)
890503 Minor cosmetic changes. (FNF)
930809 Renamed to allow single/double precision versions. (ACH)
***END PROLOGUE DVNORM
**End
***FIRST EXECUTABLE STATEMENT DVNORM
|
DVODE
|
|
DVSET
|
|
DVSOL
|
|
DVSRCO
|
|
DVSTEP
|
|
IDAMAX
|
***PURPOSE Find the smallest index of that component of a vector
having the maximum magnitude.
***CATEGORY D1A2
***TYPE DOUBLE PRECISION (ISAMAX-S, IDAMAX-D, ICAMAX-C)
***KEYWORDS BLAS, LINEAR ALGEBRA, MAXIMUM COMPONENT, VECTOR
***AUTHOR Lawson, C. L., (JPL)
Hanson, R. J., (SNLA)
Kincaid, D. R., (U. of Texas)
Krogh, F. T., (JPL)
***DESCRIPTION
B L A S Subprogram
Description of Parameters
--Input--
N number of elements in input vector(s)
DX double precision vector with N elements
INCX storage spacing between elements of DX
--Output--
IDAMAX smallest index (zero if N .LE. 0)
Find smallest index of maximum magnitude of double precision DX.
IDAMAX = first I, I = 1 to N, to maximize ABS(DX(IX+(I-1)*INCX)),
where IX = 1 if INCX .GE. 0, else IX = 1+(1-N)*INCX.
***REFERENCES C. L. Lawson, R. J. Hanson, D. R. Kincaid and F. T.
Krogh, Basic linear algebra subprograms for Fortran
usage, Algorithm No. 539, Transactions on Mathematical
Software 5, 3 (September 1979), pp. 308-323.
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
791001 DATE WRITTEN
890531 Changed all specific intrinsics to generic. (WRB)
890531 REVISION DATE from Version 3.2
891214 Prologue converted to Version 4.0 format. (BAB)
900821 Modified to correct problem with a negative increment.
(WRB)
920501 Reformatted the REFERENCES section. (WRB)
***END PROLOGUE IDAMAX
***FIRST EXECUTABLE STATEMENT IDAMAX
|
IDVNLSD
|
|
IFEX
|
|
IJEX
|
|
IUMACH
|
***PURPOSE Provide standard output unit number.
***CATEGORY R1
***TYPE INTEGER (IUMACH-I)
***KEYWORDS MACHINE CONSTANTS
***AUTHOR Hindmarsh, Alan C., (LLNL)
***DESCRIPTION
*Usage:
INTEGER LOUT, IUMACH
LOUT = IUMACH()
*Function Return Values:
LOUT : the standard logical unit for Fortran output.
***REFERENCES (NONE)
***ROUTINES CALLED (NONE)
***REVISION HISTORY (YYMMDD)
930915 DATE WRITTEN
930922 Made user-callable, and other cosmetic changes. (FNF)
***END PROLOGUE IUMACH
*Internal Notes:
The built-in value of 6 is standard on a wide range of Fortran
systems. This may be machine-dependent.
**End
***FIRST EXECUTABLE STATEMENT IUMACH
|
IXSAV
|
***PURPOSE Save and recall error message control parameters.
***CATEGORY R3C
***TYPE ALL (IXSAV-A)
***AUTHOR Hindmarsh, Alan C., (LLNL)
***DESCRIPTION
IXSAV saves and recalls one of two error message parameters:
LUNIT, the logical unit number to which messages are printed, and
MESFLG, the message print flag.
This is a modification of the SLATEC library routine J4SAVE.
Saved local variables..
LUNIT = Logical unit number for messages. The default is obtained
by a call to IUMACH (may be machine-dependent).
MESFLG = Print control flag..
1 means print all messages (the default).
0 means no printing.
On input..
IPAR = Parameter indicator (1 for LUNIT, 2 for MESFLG).
IVALUE = The value to be set for the parameter, if ISET = .TRUE.
ISET = Logical flag to indicate whether to read or write.
If ISET = .TRUE., the parameter will be given
the value IVALUE. If ISET = .FALSE., the parameter
will be unchanged, and IVALUE is a dummy argument.
On return..
IXSAV = The (old) value of the parameter.
***SEE ALSO XERRWD, XERRWV
***ROUTINES CALLED IUMACH
***REVISION HISTORY (YYMMDD)
921118 DATE WRITTEN
930329 Modified prologue to SLATEC format. (FNF)
930915 Added IUMACH call to get default output unit. (ACH)
930922 Minor cosmetic changes. (FNF)
010425 Type declaration for IUMACH added. (ACH)
***END PROLOGUE IXSAV
Subroutines called by IXSAV.. None
Function routine called by IXSAV.. IUMACH
-----------------------------------------------------------------------
**End
-----------------------------------------------------------------------
-----------------------------------------------------------------------
The following Fortran-77 declaration is to cause the values of the
listed (local) variables to be saved between calls to this routine.
-----------------------------------------------------------------------
***FIRST EXECUTABLE STATEMENT IXSAV
|
xBaseOdeGearsAndAdamsMoulton
|
Represents a base class for the Adams-Moulton and Gear’s BDF classes.
|
XERRWD
|
***PURPOSE Write error message with values.
***CATEGORY R3C
***TYPE DOUBLE PRECISION (XERRWV-S, XERRWD-D)
***AUTHOR Hindmarsh, Alan C., (LLNL)
***DESCRIPTION
Subroutines XERRWD, XSETF, XSETUN, and the function routine IXSAV,
as given here, constitute a simplified version of the SLATEC error
handling package.
All arguments are input arguments.
MSG = The message (character array).
NMES = The length of MSG (number of characters).
NERR = The error number (not used).
LEVEL = The error level..
0 or 1 means recoverable (control returns to caller).
2 means fatal (run is aborted--see note below).
NI = Number of integers (0, 1, or 2) to be printed with message.
I1,I2 = Integers to be printed, depending on NI.
NR = Number of reals (0, 1, or 2) to be printed with message.
R1,R2 = Reals to be printed, depending on NR.
Note.. this routine is machine-dependent and specialized for use
in limited context, in the following ways..
1. The argument MSG is assumed to be of type CHARACTER, and
the message is printed with a format of (1X,A).
2. The message is assumed to take only one line.
Multi-line messages are generated by repeated calls.
3. If LEVEL = 2, control passes to the statement STOP
to abort the run. This statement may be machine-dependent.
4. R1 and R2 are assumed to be in double precision and are printed
in D21.13 format.
***ROUTINES CALLED IXSAV
***REVISION HISTORY (YYMMDD)
920831 DATE WRITTEN
921118 Replaced MFLGSV/LUNSAV by IXSAV. (ACH)
930329 Modified prologue to SLATEC format. (FNF)
930407 Changed MSG from CHARACTER*1 array to variable. (FNF)
930922 Minor cosmetic change. (FNF)
***END PROLOGUE XERRWD
*Internal Notes:
For a different default logical unit number, IXSAV (or a subsidiary
routine that it calls) will need to be modified.
For a different run-abort command, change the statement following
statement 100 at the end.
-----------------------------------------------------------------------
Subroutines called by XERRWD.. None
Function routine called by XERRWD.. IXSAV
-----------------------------------------------------------------------
**End
Declare arguments.
|
XSETF
|
***PURPOSE Reset the error print control flag.
***CATEGORY R3A
***TYPE ALL (XSETF-A)
***KEYWORDS ERROR CONTROL
***AUTHOR Hindmarsh, Alan C., (LLNL)
***DESCRIPTION
XSETF sets the error print control flag to MFLAG:
MFLAG=1 means print all messages (the default).
MFLAG=0 means no printing.
***SEE ALSO XERRWD, XERRWV
***REFERENCES (NONE)
***ROUTINES CALLED IXSAV
***REVISION HISTORY (YYMMDD)
921118 DATE WRITTEN
930329 Added SLATEC format prologue. (FNF)
930407 Corrected SEE ALSO section. (FNF)
930922 Made user-callable, and other cosmetic changes. (FNF)
***END PROLOGUE XSETF
Subroutines called by XSETF.. None
Function routine called by XSETF.. IXSAV
-----------------------------------------------------------------------
**End
***FIRST EXECUTABLE STATEMENT XSETF
|
XSETUN
|
***PURPOSE Reset the logical unit number for error messages.
***CATEGORY R3B
***TYPE ALL (XSETUN-A)
***KEYWORDS ERROR CONTROL
***DESCRIPTION
XSETUN sets the logical unit number for error messages to LUN.
***AUTHOR Hindmarsh, Alan C., (LLNL)
***SEE ALSO XERRWD, XERRWV
***REFERENCES (NONE)
***ROUTINES CALLED IXSAV
***REVISION HISTORY (YYMMDD)
921118 DATE WRITTEN
930329 Added SLATEC format prologue. (FNF)
930407 Corrected SEE ALSO section. (FNF)
930922 Made user-callable, and other cosmetic changes. (FNF)
***END PROLOGUE XSETUN
Subroutines called by XSETUN.. None
Function routine called by XSETUN.. IXSAV
-----------------------------------------------------------------------
**End
***FIRST EXECUTABLE STATEMENT XSETUN
|