📄 c_cblat2.f
字号:
PROGRAM CBLAT2** Test program for the COMPLEX Level 2 Blas.** The program must be driven by a short data file. The first 17 records* of the file are read using list-directed input, the last 17 records* are read using the format ( A12, L2 ). An annotated example of a data* file can be obtained by deleting the first 3 characters from the* following 34 lines:* 'CBLAT2.SNAP' NAME OF SNAPSHOT OUTPUT FILE* -1 UNIT NUMBER OF SNAPSHOT FILE (NOT USED IF .LT. 0)* F LOGICAL FLAG, T TO REWIND SNAPSHOT FILE AFTER EACH RECORD.* F LOGICAL FLAG, T TO STOP ON FAILURES.* T LOGICAL FLAG, T TO TEST ERROR EXITS.* 2 0 TO TEST COLUMN-MAJOR, 1 TO TEST ROW-MAJOR, 2 TO TEST BOTH* 16.0 THRESHOLD VALUE OF TEST RATIO* 6 NUMBER OF VALUES OF N* 0 1 2 3 5 9 VALUES OF N* 4 NUMBER OF VALUES OF K* 0 1 2 4 VALUES OF K* 4 NUMBER OF VALUES OF INCX AND INCY* 1 2 -1 -2 VALUES OF INCX AND INCY* 3 NUMBER OF VALUES OF ALPHA* (0.0,0.0) (1.0,0.0) (0.7,-0.9) VALUES OF ALPHA* 3 NUMBER OF VALUES OF BETA* (0.0,0.0) (1.0,0.0) (1.3,-1.1) VALUES OF BETA* cblas_cgemv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_cgbmv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_chemv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_chbmv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_chpmv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_ctrmv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_ctbmv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_ctpmv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_ctrsv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_ctbsv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_ctpsv T PUT F FOR NO TEST. SAME COLUMNS.* cblas_cgerc T PUT F FOR NO TEST. SAME COLUMNS.* cblas_cgeru T PUT F FOR NO TEST. SAME COLUMNS.* cblas_cher T PUT F FOR NO TEST. SAME COLUMNS.* cblas_chpr T PUT F FOR NO TEST. SAME COLUMNS.* cblas_cher2 T PUT F FOR NO TEST. SAME COLUMNS.* cblas_chpr2 T PUT F FOR NO TEST. SAME COLUMNS.** See:** Dongarra J. J., Du Croz J. J., Hammarling S. and Hanson R. J..* An extended set of Fortran Basic Linear Algebra Subprograms.** Technical Memoranda Nos. 41 (revision 3) and 81, Mathematics* and Computer Science Division, Argonne National Laboratory,* 9700 South Cass Avenue, Argonne, Illinois 60439, US.** Or** NAG Technical Reports TR3/87 and TR4/87, Numerical Algorithms* Group Ltd., NAG Central Office, 256 Banbury Road, Oxford* OX2 7DE, UK, and Numerical Algorithms Group Inc., 1101 31st* Street, Suite 100, Downers Grove, Illinois 60515-1263, USA.*** -- Written on 10-August-1987.* Richard Hanson, Sandia National Labs.* Jeremy Du Croz, NAG Central Office.** .. Parameters .. INTEGER NIN, NOUT PARAMETER ( NIN = 5, NOUT = 6 ) INTEGER NSUBS PARAMETER ( NSUBS = 17 ) COMPLEX ZERO, ONE PARAMETER ( ZERO = ( 0.0, 0.0 ), ONE = ( 1.0, 0.0 ) ) REAL RZERO, RHALF, RONE PARAMETER ( RZERO = 0.0, RHALF = 0.5, RONE = 1.0 ) INTEGER NMAX, INCMAX PARAMETER ( NMAX = 65, INCMAX = 2 ) INTEGER NINMAX, NIDMAX, NKBMAX, NALMAX, NBEMAX PARAMETER ( NINMAX = 7, NIDMAX = 9, NKBMAX = 7, $ NALMAX = 7, NBEMAX = 7 )* .. Local Scalars .. REAL EPS, ERR, THRESH INTEGER I, ISNUM, J, N, NALF, NBET, NIDIM, NINC, NKB, $ NTRA, LAYOUT LOGICAL FATAL, LTESTT, REWI, SAME, SFATAL, TRACE, $ TSTERR, CORDER, RORDER CHARACTER*1 TRANS CHARACTER*12 SNAMET CHARACTER*32 SNAPS* .. Local Arrays .. COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ), $ ALF( NALMAX ), AS( NMAX*NMAX ), BET( NBEMAX ), $ X( NMAX ), XS( NMAX*INCMAX ), $ XX( NMAX*INCMAX ), Y( NMAX ), $ YS( NMAX*INCMAX ), YT( NMAX ), $ YY( NMAX*INCMAX ), Z( 2*NMAX ) REAL G( NMAX ) INTEGER IDIM( NIDMAX ), INC( NINMAX ), KB( NKBMAX ) LOGICAL LTEST( NSUBS ) CHARACTER*12 SNAMES( NSUBS )* .. External Functions .. REAL SDIFF LOGICAL LCE EXTERNAL SDIFF, LCE* .. External Subroutines .. EXTERNAL CCHK1, CCHK2, CCHK3, CCHK4, CCHK5, CCHK6, $ CC2CHKE, CMVCH* .. Intrinsic Functions .. INTRINSIC ABS, MAX, MIN* .. Scalars in Common .. INTEGER INFOT, NOUTC LOGICAL OK CHARACTER*12 SRNAMT* .. Common blocks .. COMMON /INFOC/INFOT, NOUTC, OK COMMON /SRNAMC/SRNAMT* .. Data statements .. DATA SNAMES/'cblas_cgemv ', 'cblas_cgbmv ', $ 'cblas_chemv ','cblas_chbmv ','cblas_chpmv ', $ 'cblas_ctrmv ','cblas_ctbmv ','cblas_ctpmv ', $ 'cblas_ctrsv ','cblas_ctbsv ','cblas_ctpsv ', $ 'cblas_cgerc ','cblas_cgeru ','cblas_cher ', $ 'cblas_chpr ','cblas_cher2 ','cblas_chpr2 '/* .. Executable Statements ..* NOUTC = NOUT** Read name and unit number for summary output file and open file.* READ( NIN, FMT = * )SNAPS READ( NIN, FMT = * )NTRA TRACE = NTRA.GE.0 IF( TRACE )THEN OPEN( NTRA, FILE = SNAPS ) END IF* Read the flag that directs rewinding of the snapshot file. READ( NIN, FMT = * )REWI REWI = REWI.AND.TRACE* Read the flag that directs stopping on any failure. READ( NIN, FMT = * )SFATAL* Read the flag that indicates whether error exits are to be tested. READ( NIN, FMT = * )TSTERR* Read the flag that indicates whether row-major data layout to be tested. READ( NIN, FMT = * )LAYOUT* Read the threshold value of the test ratio READ( NIN, FMT = * )THRESH** Read and check the parameter values for the tests.** Values of N READ( NIN, FMT = * )NIDIM IF( NIDIM.LT.1.OR.NIDIM.GT.NIDMAX )THEN WRITE( NOUT, FMT = 9997 )'N', NIDMAX GO TO 230 END IF READ( NIN, FMT = * )( IDIM( I ), I = 1, NIDIM ) DO 10 I = 1, NIDIM IF( IDIM( I ).LT.0.OR.IDIM( I ).GT.NMAX )THEN WRITE( NOUT, FMT = 9996 )NMAX GO TO 230 END IF 10 CONTINUE* Values of K READ( NIN, FMT = * )NKB IF( NKB.LT.1.OR.NKB.GT.NKBMAX )THEN WRITE( NOUT, FMT = 9997 )'K', NKBMAX GO TO 230 END IF READ( NIN, FMT = * )( KB( I ), I = 1, NKB ) DO 20 I = 1, NKB IF( KB( I ).LT.0 )THEN WRITE( NOUT, FMT = 9995 ) GO TO 230 END IF 20 CONTINUE* Values of INCX and INCY READ( NIN, FMT = * )NINC IF( NINC.LT.1.OR.NINC.GT.NINMAX )THEN WRITE( NOUT, FMT = 9997 )'INCX AND INCY', NINMAX GO TO 230 END IF READ( NIN, FMT = * )( INC( I ), I = 1, NINC ) DO 30 I = 1, NINC IF( INC( I ).EQ.0.OR.ABS( INC( I ) ).GT.INCMAX )THEN WRITE( NOUT, FMT = 9994 )INCMAX GO TO 230 END IF 30 CONTINUE* Values of ALPHA READ( NIN, FMT = * )NALF IF( NALF.LT.1.OR.NALF.GT.NALMAX )THEN WRITE( NOUT, FMT = 9997 )'ALPHA', NALMAX GO TO 230 END IF READ( NIN, FMT = * )( ALF( I ), I = 1, NALF )* Values of BETA READ( NIN, FMT = * )NBET IF( NBET.LT.1.OR.NBET.GT.NBEMAX )THEN WRITE( NOUT, FMT = 9997 )'BETA', NBEMAX GO TO 230 END IF READ( NIN, FMT = * )( BET( I ), I = 1, NBET )** Report values of parameters.* WRITE( NOUT, FMT = 9993 ) WRITE( NOUT, FMT = 9992 )( IDIM( I ), I = 1, NIDIM ) WRITE( NOUT, FMT = 9991 )( KB( I ), I = 1, NKB ) WRITE( NOUT, FMT = 9990 )( INC( I ), I = 1, NINC ) WRITE( NOUT, FMT = 9989 )( ALF( I ), I = 1, NALF ) WRITE( NOUT, FMT = 9988 )( BET( I ), I = 1, NBET ) IF( .NOT.TSTERR )THEN WRITE( NOUT, FMT = * ) WRITE( NOUT, FMT = 9980 ) END IF WRITE( NOUT, FMT = * ) WRITE( NOUT, FMT = 9999 )THRESH WRITE( NOUT, FMT = * ) RORDER = .FALSE. CORDER = .FALSE. IF (LAYOUT.EQ.2) THEN RORDER = .TRUE. CORDER = .TRUE. WRITE( *, FMT = 10002 ) ELSE IF (LAYOUT.EQ.1) THEN RORDER = .TRUE. WRITE( *, FMT = 10001 ) ELSE IF (LAYOUT.EQ.0) THEN CORDER = .TRUE. WRITE( *, FMT = 10000 ) END IF WRITE( *, FMT = * )** Read names of subroutines and flags which indicate* whether they are to be tested.* DO 40 I = 1, NSUBS LTEST( I ) = .FALSE. 40 CONTINUE 50 READ( NIN, FMT = 9984, END = 80 )SNAMET, LTESTT DO 60 I = 1, NSUBS IF( SNAMET.EQ.SNAMES( I ) ) $ GO TO 70 60 CONTINUE WRITE( NOUT, FMT = 9986 )SNAMET STOP 70 LTEST( I ) = LTESTT GO TO 50* 80 CONTINUE CLOSE ( NIN )** Compute EPS (the machine precision).* EPS = RONE 90 CONTINUE IF( SDIFF( RONE + EPS, RONE ).EQ.RZERO ) $ GO TO 100 EPS = RHALF*EPS GO TO 90 100 CONTINUE EPS = EPS + EPS WRITE( NOUT, FMT = 9998 )EPS** Check the reliability of CMVCH using exact data.* N = MIN( 32, NMAX ) DO 120 J = 1, N DO 110 I = 1, N A( I, J ) = MAX( I - J + 1, 0 ) 110 CONTINUE X( J ) = J Y( J ) = ZERO 120 CONTINUE DO 130 J = 1, N YY( J ) = J*( ( J + 1 )*J )/2 - ( ( J + 1 )*J*( J - 1 ) )/3 130 CONTINUE* YY holds the exact result. On exit from CMVCH YT holds* the result computed by CMVCH. TRANS = 'N' CALL CMVCH( TRANS, N, N, ONE, A, NMAX, X, 1, ZERO, Y, 1, YT, G, $ YY, EPS, ERR, FATAL, NOUT, .TRUE. ) SAME = LCE( YY, YT, N ) IF( .NOT.SAME.OR.ERR.NE.RZERO )THEN WRITE( NOUT, FMT = 9985 )TRANS, SAME, ERR STOP END IF TRANS = 'T' CALL CMVCH( TRANS, N, N, ONE, A, NMAX, X, -1, ZERO, Y, -1, YT, G, $ YY, EPS, ERR, FATAL, NOUT, .TRUE. ) SAME = LCE( YY, YT, N ) IF( .NOT.SAME.OR.ERR.NE.RZERO )THEN WRITE( NOUT, FMT = 9985 )TRANS, SAME, ERR STOP END IF** Test each subroutine in turn.* DO 210 ISNUM = 1, NSUBS WRITE( NOUT, FMT = * ) IF( .NOT.LTEST( ISNUM ) )THEN* Subprogram is not to be tested. WRITE( NOUT, FMT = 9983 )SNAMES( ISNUM ) ELSE SRNAMT = SNAMES( ISNUM )* Test error exits. IF( TSTERR )THEN CALL CC2CHKE( SNAMES( ISNUM ) ) WRITE( NOUT, FMT = * ) END IF* Test computations. INFOT = 0 OK = .TRUE. FATAL = .FALSE. GO TO ( 140, 140, 150, 150, 150, 160, 160, $ 160, 160, 160, 160, 170, 170, 180, $ 180, 190, 190 )ISNUM* Test CGEMV, 01, and CGBMV, 02. 140 IF (CORDER) THEN CALL CCHK1( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, $ REWI, FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF, $ NBET, BET, NINC, INC, NMAX, INCMAX, A, AA, AS, $ X, XX, XS, Y, YY, YS, YT, G, 0 ) END IF IF (RORDER) THEN CALL CCHK1( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, $ REWI, FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF, $ NBET, BET, NINC, INC, NMAX, INCMAX, A, AA, AS, $ X, XX, XS, Y, YY, YS, YT, G, 1 ) END IF GO TO 200* Test CHEMV, 03, CHBMV, 04, and CHPMV, 05. 150 IF (CORDER) THEN CALL CCHK2( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, $ REWI, FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF, $ NBET, BET, NINC, INC, NMAX, INCMAX, A, AA, AS, $ X, XX, XS, Y, YY, YS, YT, G, 0 ) END IF IF (RORDER) THEN CALL CCHK2( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, $ REWI, FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF, $ NBET, BET, NINC, INC, NMAX, INCMAX, A, AA, AS, $ X, XX, XS, Y, YY, YS, YT, G, 1 ) END IF GO TO 200
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -