diff options
author | julie <julielangou@users.noreply.github.com> | 2008-12-16 17:06:58 +0000 |
---|---|---|
committer | julie <julielangou@users.noreply.github.com> | 2008-12-16 17:06:58 +0000 |
commit | ff981f106bde4ce6a74aa4f4a572c943f5a395b2 (patch) | |
tree | a386cad907bcaefd6893535c31d67ec9468e693e /TESTING/LIN/sdrvrf2.f | |
parent | e58b61578b55644f6391f3333262b72c1dc88437 (diff) |
Diffstat (limited to 'TESTING/LIN/sdrvrf2.f')
-rw-r--r-- | TESTING/LIN/sdrvrf2.f | 202 |
1 files changed, 202 insertions, 0 deletions
diff --git a/TESTING/LIN/sdrvrf2.f b/TESTING/LIN/sdrvrf2.f new file mode 100644 index 00000000..1a2abf2d --- /dev/null +++ b/TESTING/LIN/sdrvrf2.f @@ -0,0 +1,202 @@ + SUBROUTINE SDRVRF2( NOUT, NN, NVAL, A, LDA, ARF, AP, ASAV ) +* +* -- LAPACK test routine (version 3.2.0) -- +* Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd.. +* November 2008 +* +* .. Scalar Arguments .. + INTEGER LDA, NN, NOUT +* .. +* .. Array Arguments .. + INTEGER NVAL( NN ) + REAL A( LDA, * ), ARF( * ), AP(*), ASAV( LDA, * ) +* .. +* +* Purpose +* ======= +* +* SDRVRF2 tests the LAPACK RFP convertion routines. +* +* Arguments +* ========= +* +* NOUT (input) INTEGER +* The unit number for output. +* +* NN (input) INTEGER +* The number of values of N contained in the vector NVAL. +* +* NVAL (input) INTEGER array, dimension (NN) +* The values of the matrix dimension N. +* +* A (workspace) REAL array, dimension (LDA,NMAX) +* +* LDA (input) INTEGER +* The leading dimension of the array A. LDA >= max(1,NMAX). +* +* ARF (workspace) REAL array, dimension ((NMAX*(NMAX+1))/2). +* +* AP (workspace) REAL array, dimension ((NMAX*(NMAX+1))/2). +* +* A2 (workspace) REAL array, dimension (LDA,NMAX) +* +* ===================================================================== +* .. +* .. Local Scalars .. + LOGICAL LOWER, OK1, OK2 + CHARACTER UPLO, CFORM + INTEGER I, IFORM, IIN, INFO, IUPLO, J, N, + + NERRS, NRUN +* .. +* .. Local Arrays .. + CHARACTER UPLOS( 2 ), FORMS( 2 ) + INTEGER ISEED( 4 ), ISEEDY( 4 ) +* .. +* .. External Functions .. + REAL SLARND + EXTERNAL SLARND +* .. +* .. External Subroutines .. + EXTERNAL STFTTR, STFTTP, STRTTF, STRTTP, STPTTR, STPTTF +* .. +* .. Scalars in Common .. + CHARACTER*32 SRNAMT +* .. +* .. Common blocks .. + COMMON / SRNAMC / SRNAMT +* .. +* .. Data statements .. + DATA ISEEDY / 1988, 1989, 1990, 1991 / + DATA UPLOS / 'U', 'L' / + DATA FORMS / 'N', 'T' / +* .. +* .. Executable Statements .. +* +* Initialize constants and the random number seed. +* + NRUN = 0 + NERRS = 0 + INFO = 0 + DO 10 I = 1, 4 + ISEED( I ) = ISEEDY( I ) + 10 CONTINUE +* + DO 120 IIN = 1, NN +* + N = NVAL( IIN ) +* +* Do first for UPLO = 'U', then for UPLO = 'L' +* + DO 110 IUPLO = 1, 2 +* + UPLO = UPLOS( IUPLO ) + LOWER = .TRUE. + IF ( IUPLO.EQ.1 ) LOWER = .FALSE. +* +* Do first for CFORM = 'N', then for CFORM = 'T' +* + DO 100 IFORM = 1, 2 +* + CFORM = FORMS( IFORM ) +* + NRUN = NRUN + 1 +* + DO J = 1, N + DO I = 1, N + A( I, J) = SLARND( 2, ISEED ) + END DO + END DO +* + SRNAMT = 'DTRTTF' + CALL STRTTF( CFORM, UPLO, N, A, LDA, ARF, INFO ) +* + SRNAMT = 'DTFTTP' + CALL STFTTP( CFORM, UPLO, N, ARF, AP, INFO ) +* + SRNAMT = 'DTPTTR' + CALL STPTTR( UPLO, N, AP, ASAV, LDA, INFO ) +* + OK1 = .TRUE. + IF ( LOWER ) THEN + DO J = 1, N + DO I = J, N + IF ( A(I,J).NE.ASAV(I,J) ) THEN + OK1 = .FALSE. + END IF + END DO + END DO + ELSE + DO J = 1, N + DO I = 1, J + IF ( A(I,J).NE.ASAV(I,J) ) THEN + OK1 = .FALSE. + END IF + END DO + END DO + END IF +* + NRUN = NRUN + 1 +* + SRNAMT = 'DTRTTP' + CALL STRTTP( UPLO, N, A, LDA, AP, INFO ) +* + SRNAMT = 'DTPTTF' + CALL STPTTF( CFORM, UPLO, N, AP, ARF, INFO ) +* + SRNAMT = 'DTFTTR' + CALL STFTTR( CFORM, UPLO, N, ARF, ASAV, LDA, INFO ) +* + OK2 = .TRUE. + IF ( LOWER ) THEN + DO J = 1, N + DO I = J, N + IF ( A(I,J).NE.ASAV(I,J) ) THEN + OK2 = .FALSE. + END IF + END DO + END DO + ELSE + DO J = 1, N + DO I = 1, J + IF ( A(I,J).NE.ASAV(I,J) ) THEN + OK2 = .FALSE. + END IF + END DO + END DO + END IF +* + IF (( .NOT.OK1 ).OR.( .NOT.OK2 )) THEN + IF( NERRS.EQ.0 ) THEN + WRITE( NOUT, * ) + WRITE( NOUT, FMT = 9999 ) + END IF + WRITE( NOUT, FMT = 9998 ) N, UPLO, CFORM + NERRS = NERRS + 1 + END IF +* + 100 CONTINUE + 110 CONTINUE + 120 CONTINUE +* +* Print a summary of the results. +* + IF ( NERRS.EQ.0 ) THEN + WRITE( NOUT, FMT = 9997 ) NRUN + ELSE + WRITE( NOUT, FMT = 9996 ) NERRS, NRUN + END IF +* + 9999 FORMAT( 1X, ' *** Error(s) while testing the RFP convertion', + + ' routines ***') + 9998 FORMAT( 1X, ' Error in RFP,convertion routines N=',I5, + + ' UPLO=''', A1, ''', FORM =''',A1,'''') + 9997 FORMAT( 1X, 'All tests for the RFP convertion routines passed (', + + I5,' tests run)') + 9996 FORMAT( 1X, 'RFP convertion routines:',I5,' out of ',I5, + + ' error message recorded') +* + RETURN +* +* End of SDRVRF2 +* + END |