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.

262 lines
6.8 KiB

2 years ago
*> \brief \b SDRVRF2
*
* =========== DOCUMENTATION ===========
*
* Online html documentation available at
* http://www.netlib.org/lapack/explore-html/
*
* Definition:
* ===========
*
* SUBROUTINE SDRVRF2( NOUT, NN, NVAL, A, LDA, ARF, AP, ASAV )
*
* .. Scalar Arguments ..
* INTEGER LDA, NN, NOUT
* ..
* .. Array Arguments ..
* INTEGER NVAL( NN )
* REAL A( LDA, * ), ARF( * ), AP(*), ASAV( LDA, * )
* ..
*
*
*> \par Purpose:
* =============
*>
*> \verbatim
*>
*> SDRVRF2 tests the LAPACK RFP conversion routines.
*> \endverbatim
*
* Arguments:
* ==========
*
*> \param[in] NOUT
*> \verbatim
*> NOUT is INTEGER
*> The unit number for output.
*> \endverbatim
*>
*> \param[in] NN
*> \verbatim
*> NN is INTEGER
*> The number of values of N contained in the vector NVAL.
*> \endverbatim
*>
*> \param[in] NVAL
*> \verbatim
*> NVAL is INTEGER array, dimension (NN)
*> The values of the matrix dimension N.
*> \endverbatim
*>
*> \param[out] A
*> \verbatim
*> A is REAL array, dimension (LDA,NMAX)
*> \endverbatim
*>
*> \param[in] LDA
*> \verbatim
*> LDA is INTEGER
*> The leading dimension of the array A. LDA >= max(1,NMAX).
*> \endverbatim
*>
*> \param[out] ARF
*> \verbatim
*> ARF is REAL array, dimension ((NMAX*(NMAX+1))/2).
*> \endverbatim
*>
*> \param[out] AP
*> \verbatim
*> AP is REAL array, dimension ((NMAX*(NMAX+1))/2).
*> \endverbatim
*>
*> \param[out] ASAV
*> \verbatim
*> ASAV is REAL array, dimension (LDA,NMAX)
*> \endverbatim
*
* Authors:
* ========
*
*> \author Univ. of Tennessee
*> \author Univ. of California Berkeley
*> \author Univ. of Colorado Denver
*> \author NAG Ltd.
*
*> \ingroup single_lin
*
* =====================================================================
SUBROUTINE SDRVRF2( NOUT, NN, NVAL, A, LDA, ARF, AP, ASAV )
*
* -- LAPACK test routine --
* -- LAPACK is a software package provided by Univ. of Tennessee, --
* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
*
* .. Scalar Arguments ..
INTEGER LDA, NN, NOUT
* ..
* .. Array Arguments ..
INTEGER NVAL( NN )
REAL A( LDA, * ), ARF( * ), AP(*), ASAV( LDA, * )
* ..
*
* =====================================================================
* ..
* .. 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 conversion',
+ ' routines ***')
9998 FORMAT( 1X, ' Error in RFP,conversion routines N=',I5,
+ ' UPLO=''', A1, ''', FORM =''',A1,'''')
9997 FORMAT( 1X, 'All tests for the RFP conversion routines passed ( ',
+ I5,' tests run)')
9996 FORMAT( 1X, 'RFP conversion routines: ',I5,' out of ',I5,
+ ' error message recorded')
*
RETURN
*
* End of SDRVRF2
*
END