Cloned library LAPACK-3.11.0 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

287 lines
8.6 KiB

*> \brief \b DCHKRFP
*
* =========== DOCUMENTATION ===========
*
* Online html documentation available at
* http://www.netlib.org/lapack/explore-html/
*
* Definition:
* ===========
*
* PROGRAM DCHKRFP
*
*
*> \par Purpose:
* =============
*>
*> \verbatim
*>
*> DCHKRFP is the main test program for the DOUBLE PRECISION linear
*> equation routines with RFP storage format
*>
*> \endverbatim
*
* Arguments:
* ==========
*
*> \verbatim
*> MAXIN INTEGER
*> The number of different values that can be used for each of
*> M, N, or NB
*>
*> MAXRHS INTEGER
*> The maximum number of right hand sides
*>
*> NTYPES INTEGER
*>
*> NMAX INTEGER
*> The maximum allowable value for N.
*>
*> NIN INTEGER
*> The unit number for input
*>
*> NOUT INTEGER
*> The unit number for output
*> \endverbatim
*
* Authors:
* ========
*
*> \author Univ. of Tennessee
*> \author Univ. of California Berkeley
*> \author Univ. of Colorado Denver
*> \author NAG Ltd.
*
*> \ingroup double_lin
*
* =====================================================================
PROGRAM DCHKRFP
*
* -- LAPACK test routine --
* -- LAPACK is a software package provided by Univ. of Tennessee, --
* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
*
* =====================================================================
*
* .. Parameters ..
INTEGER MAXIN
PARAMETER ( MAXIN = 12 )
INTEGER NMAX
PARAMETER ( NMAX = 50 )
INTEGER MAXRHS
PARAMETER ( MAXRHS = 16 )
INTEGER NTYPES
PARAMETER ( NTYPES = 9 )
INTEGER NIN, NOUT
PARAMETER ( NIN = 5, NOUT = 6 )
* ..
* .. Local Scalars ..
LOGICAL FATAL, TSTERR
INTEGER VERS_MAJOR, VERS_MINOR, VERS_PATCH
INTEGER I, NN, NNS, NNT
DOUBLE PRECISION EPS, S1, S2, THRESH
* ..
* .. Local Arrays ..
INTEGER NVAL( MAXIN ), NSVAL( MAXIN ), NTVAL( NTYPES )
DOUBLE PRECISION WORKA( NMAX, NMAX )
DOUBLE PRECISION WORKASAV( NMAX, NMAX )
DOUBLE PRECISION WORKB( NMAX, MAXRHS )
DOUBLE PRECISION WORKXACT( NMAX, MAXRHS )
DOUBLE PRECISION WORKBSAV( NMAX, MAXRHS )
DOUBLE PRECISION WORKX( NMAX, MAXRHS )
DOUBLE PRECISION WORKAFAC( NMAX, NMAX )
DOUBLE PRECISION WORKAINV( NMAX, NMAX )
DOUBLE PRECISION WORKARF( (NMAX*(NMAX+1))/2 )
DOUBLE PRECISION WORKAP( (NMAX*(NMAX+1))/2 )
DOUBLE PRECISION WORKARFINV( (NMAX*(NMAX+1))/2 )
DOUBLE PRECISION D_WORK_DLATMS( 3 * NMAX )
DOUBLE PRECISION D_WORK_DPOT01( NMAX )
DOUBLE PRECISION D_TEMP_DPOT02( NMAX, MAXRHS )
DOUBLE PRECISION D_TEMP_DPOT03( NMAX, NMAX )
DOUBLE PRECISION D_WORK_DLANSY( NMAX )
DOUBLE PRECISION D_WORK_DPOT02( NMAX )
DOUBLE PRECISION D_WORK_DPOT03( NMAX )
* ..
* .. External Functions ..
DOUBLE PRECISION DLAMCH, DSECND
EXTERNAL DLAMCH, DSECND
* ..
* .. External Subroutines ..
EXTERNAL ILAVER, DDRVRFP, DDRVRF1, DDRVRF2, DDRVRF3,
+ DDRVRF4
* ..
* .. Executable Statements ..
*
S1 = DSECND( )
FATAL = .FALSE.
*
* Read a dummy line.
*
READ( NIN, FMT = * )
*
* Report LAPACK version tag (e.g. LAPACK-3.2.0)
*
CALL ILAVER( VERS_MAJOR, VERS_MINOR, VERS_PATCH )
WRITE( NOUT, FMT = 9994 ) VERS_MAJOR, VERS_MINOR, VERS_PATCH
*
* Read the values of N
*
READ( NIN, FMT = * )NN
IF( NN.LT.1 ) THEN
WRITE( NOUT, FMT = 9996 )' NN ', NN, 1
NN = 0
FATAL = .TRUE.
ELSE IF( NN.GT.MAXIN ) THEN
WRITE( NOUT, FMT = 9995 )' NN ', NN, MAXIN
NN = 0
FATAL = .TRUE.
END IF
READ( NIN, FMT = * )( NVAL( I ), I = 1, NN )
DO 10 I = 1, NN
IF( NVAL( I ).LT.0 ) THEN
WRITE( NOUT, FMT = 9996 )' M ', NVAL( I ), 0
FATAL = .TRUE.
ELSE IF( NVAL( I ).GT.NMAX ) THEN
WRITE( NOUT, FMT = 9995 )' M ', NVAL( I ), NMAX
FATAL = .TRUE.
END IF
10 CONTINUE
IF( NN.GT.0 )
$ WRITE( NOUT, FMT = 9993 )'N ', ( NVAL( I ), I = 1, NN )
*
* Read the values of NRHS
*
READ( NIN, FMT = * )NNS
IF( NNS.LT.1 ) THEN
WRITE( NOUT, FMT = 9996 )' NNS', NNS, 1
NNS = 0
FATAL = .TRUE.
ELSE IF( NNS.GT.MAXIN ) THEN
WRITE( NOUT, FMT = 9995 )' NNS', NNS, MAXIN
NNS = 0
FATAL = .TRUE.
END IF
READ( NIN, FMT = * )( NSVAL( I ), I = 1, NNS )
DO 30 I = 1, NNS
IF( NSVAL( I ).LT.0 ) THEN
WRITE( NOUT, FMT = 9996 )'NRHS', NSVAL( I ), 0
FATAL = .TRUE.
ELSE IF( NSVAL( I ).GT.MAXRHS ) THEN
WRITE( NOUT, FMT = 9995 )'NRHS', NSVAL( I ), MAXRHS
FATAL = .TRUE.
END IF
30 CONTINUE
IF( NNS.GT.0 )
$ WRITE( NOUT, FMT = 9993 )'NRHS', ( NSVAL( I ), I = 1, NNS )
*
* Read the matrix types
*
READ( NIN, FMT = * )NNT
IF( NNT.LT.1 ) THEN
WRITE( NOUT, FMT = 9996 )' NMA', NNT, 1
NNT = 0
FATAL = .TRUE.
ELSE IF( NNT.GT.NTYPES ) THEN
WRITE( NOUT, FMT = 9995 )' NMA', NNT, NTYPES
NNT = 0
FATAL = .TRUE.
END IF
READ( NIN, FMT = * )( NTVAL( I ), I = 1, NNT )
DO 320 I = 1, NNT
IF( NTVAL( I ).LT.0 ) THEN
WRITE( NOUT, FMT = 9996 )'TYPE', NTVAL( I ), 0
FATAL = .TRUE.
ELSE IF( NTVAL( I ).GT.NTYPES ) THEN
WRITE( NOUT, FMT = 9995 )'TYPE', NTVAL( I ), NTYPES
FATAL = .TRUE.
END IF
320 CONTINUE
IF( NNT.GT.0 )
$ WRITE( NOUT, FMT = 9993 )'TYPE', ( NTVAL( I ), I = 1, NNT )
*
* Read the threshold value for the test ratios.
*
READ( NIN, FMT = * )THRESH
WRITE( NOUT, FMT = 9992 )THRESH
*
* Read the flag that indicates whether to test the error exits.
*
READ( NIN, FMT = * )TSTERR
*
IF( FATAL ) THEN
WRITE( NOUT, FMT = 9999 )
STOP
END IF
*
* Calculate and print the machine dependent constants.
*
EPS = DLAMCH( 'Underflow threshold' )
WRITE( NOUT, FMT = 9991 )'underflow', EPS
EPS = DLAMCH( 'Overflow threshold' )
WRITE( NOUT, FMT = 9991 )'overflow ', EPS
EPS = DLAMCH( 'Epsilon' )
WRITE( NOUT, FMT = 9991 )'precision', EPS
WRITE( NOUT, FMT = * )
*
* Test the error exit of:
*
IF( TSTERR )
$ CALL DERRRFP( NOUT )
*
* Test the routines: dpftrf, dpftri, dpftrs (as in DDRVPO).
* This also tests the routines: dtfsm, dtftri, dtfttr, dtrttf.
*
CALL DDRVRFP( NOUT, NN, NVAL, NNS, NSVAL, NNT, NTVAL, THRESH,
$ WORKA, WORKASAV, WORKAFAC, WORKAINV, WORKB,
$ WORKBSAV, WORKXACT, WORKX, WORKARF, WORKARFINV,
$ D_WORK_DLATMS, D_WORK_DPOT01, D_TEMP_DPOT02,
$ D_TEMP_DPOT03, D_WORK_DLANSY, D_WORK_DPOT02,
$ D_WORK_DPOT03 )
*
* Test the routine: dlansf
*
CALL DDRVRF1( NOUT, NN, NVAL, THRESH, WORKA, NMAX, WORKARF,
+ D_WORK_DLANSY )
*
* Test the conversion routines:
* dtfttp, dtpttf, dtfttr, dtrttf, dtrttp and dtpttr.
*
CALL DDRVRF2( NOUT, NN, NVAL, WORKA, NMAX, WORKARF,
+ WORKAP, WORKASAV )
*
* Test the routine: dtfsm
*
CALL DDRVRF3( NOUT, NN, NVAL, THRESH, WORKA, NMAX, WORKARF,
+ WORKAINV, WORKAFAC, D_WORK_DLANSY,
+ D_WORK_DPOT03, D_WORK_DPOT01 )
*
*
* Test the routine: dsfrk
*
CALL DDRVRF4( NOUT, NN, NVAL, THRESH, WORKA, WORKAFAC, NMAX,
+ WORKARF, WORKAINV, NMAX, D_WORK_DLANSY)
*
CLOSE ( NIN )
S2 = DSECND( )
WRITE( NOUT, FMT = 9998 )
WRITE( NOUT, FMT = 9997 )S2 - S1
*
9999 FORMAT( / ' Execution not attempted due to input errors' )
9998 FORMAT( / ' End of tests' )
9997 FORMAT( ' Total time used = ', F12.2, ' seconds', / )
9996 FORMAT( ' !! Invalid input value: ', A4, '=', I6, '; must be >=',
$ I6 )
9995 FORMAT( ' !! Invalid input value: ', A4, '=', I6, '; must be <=',
$ I6 )
9994 FORMAT( / ' Tests of the DOUBLE PRECISION LAPACK RFP routines ',
$ / ' LAPACK VERSION ', I1, '.', I1, '.', I1,
$ / / ' The following parameter values will be used:' )
9993 FORMAT( 4X, A4, ': ', 10I6, / 11X, 10I6 )
9992 FORMAT( / ' Routines pass computational tests if test ratio is ',
$ 'less than', F8.2, / )
9991 FORMAT( ' Relative machine ', A, ' is taken to be', D16.6 )
*
* End of DCHKRFP
*
END