288 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Fortran
		
	
	
	
			
		
		
	
	
			288 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Fortran
		
	
	
	
*> \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
 |