3 * Test program for the COMPLEX Level 2 Blas.
5 * The program must be driven by a short data file. The first 18 records
6 * of the file are read using list-directed input, the last 17 records
7 * are read using the format ( A6, L2 ). An annotated example of a data
8 * file can be obtained by deleting the first 3 characters from the
10 * 'CBLAT2.SUMM' NAME OF SUMMARY OUTPUT FILE
11 * 6 UNIT NUMBER OF SUMMARY FILE
12 * 'CBLA2T.SNAP' NAME OF SNAPSHOT OUTPUT FILE
13 * -1 UNIT NUMBER OF SNAPSHOT FILE (NOT USED IF .LT. 0)
14 * F LOGICAL FLAG, T TO REWIND SNAPSHOT FILE AFTER EACH RECORD.
15 * F LOGICAL FLAG, T TO STOP ON FAILURES.
16 * T LOGICAL FLAG, T TO TEST ERROR EXITS.
17 * 16.0 THRESHOLD VALUE OF TEST RATIO
18 * 6 NUMBER OF VALUES OF N
19 * 0 1 2 3 5 9 VALUES OF N
20 * 4 NUMBER OF VALUES OF K
22 * 4 NUMBER OF VALUES OF INCX AND INCY
23 * 1 2 -1 -2 VALUES OF INCX AND INCY
24 * 3 NUMBER OF VALUES OF ALPHA
25 * (0.0,0.0) (1.0,0.0) (0.7,-0.9) VALUES OF ALPHA
26 * 3 NUMBER OF VALUES OF BETA
27 * (0.0,0.0) (1.0,0.0) (1.3,-1.1) VALUES OF BETA
28 * CGEMV T PUT F FOR NO TEST. SAME COLUMNS.
29 * CGBMV T PUT F FOR NO TEST. SAME COLUMNS.
30 * CHEMV T PUT F FOR NO TEST. SAME COLUMNS.
31 * CHBMV T PUT F FOR NO TEST. SAME COLUMNS.
32 * CHPMV T PUT F FOR NO TEST. SAME COLUMNS.
33 * CTRMV T PUT F FOR NO TEST. SAME COLUMNS.
34 * CTBMV T PUT F FOR NO TEST. SAME COLUMNS.
35 * CTPMV T PUT F FOR NO TEST. SAME COLUMNS.
36 * CTRSV T PUT F FOR NO TEST. SAME COLUMNS.
37 * CTBSV T PUT F FOR NO TEST. SAME COLUMNS.
38 * CTPSV T PUT F FOR NO TEST. SAME COLUMNS.
39 * CGERC T PUT F FOR NO TEST. SAME COLUMNS.
40 * CGERU T PUT F FOR NO TEST. SAME COLUMNS.
41 * CHER T PUT F FOR NO TEST. SAME COLUMNS.
42 * CHPR T PUT F FOR NO TEST. SAME COLUMNS.
43 * CHER2 T PUT F FOR NO TEST. SAME COLUMNS.
44 * CHPR2 T PUT F FOR NO TEST. SAME COLUMNS.
48 * Dongarra J. J., Du Croz J. J., Hammarling S. and Hanson R. J..
49 * An extended set of Fortran Basic Linear Algebra Subprograms.
51 * Technical Memoranda Nos. 41 (revision 3) and 81, Mathematics
52 * and Computer Science Division, Argonne National Laboratory,
53 * 9700 South Cass Avenue, Argonne, Illinois 60439, US.
57 * NAG Technical Reports TR3/87 and TR4/87, Numerical Algorithms
58 * Group Ltd., NAG Central Office, 256 Banbury Road, Oxford
59 * OX2 7DE, UK, and Numerical Algorithms Group Inc., 1101 31st
60 * Street, Suite 100, Downers Grove, Illinois 60515-1263, USA.
63 * -- Written on 10-August-1987.
64 * Richard Hanson, Sandia National Labs.
65 * Jeremy Du Croz, NAG Central Office.
71 PARAMETER ( NSUBS = 17 )
73 PARAMETER ( ZERO = ( 0.0, 0.0 ), ONE = ( 1.0, 0.0 ) )
74 REAL RZERO, RHALF, RONE
75 PARAMETER ( RZERO = 0.0, RHALF = 0.5, RONE = 1.0 )
77 PARAMETER ( NMAX = 65, INCMAX = 2 )
78 INTEGER NINMAX, NIDMAX, NKBMAX, NALMAX, NBEMAX
79 PARAMETER ( NINMAX = 7, NIDMAX = 9, NKBMAX = 7,
80 $ NALMAX = 7, NBEMAX = 7 )
83 INTEGER I, ISNUM, J, N, NALF, NBET, NIDIM, NINC, NKB,
85 LOGICAL FATAL, LTESTT, REWI, SAME, SFATAL, TRACE,
89 CHARACTER*32 SNAPS, SUMMRY
91 COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ),
92 $ ALF( NALMAX ), AS( NMAX*NMAX ), BET( NBEMAX ),
93 $ X( NMAX ), XS( NMAX*INCMAX ),
94 $ XX( NMAX*INCMAX ), Y( NMAX ),
95 $ YS( NMAX*INCMAX ), YT( NMAX ),
96 $ YY( NMAX*INCMAX ), Z( 2*NMAX )
98 INTEGER IDIM( NIDMAX ), INC( NINMAX ), KB( NKBMAX )
99 LOGICAL LTEST( NSUBS )
100 CHARACTER*6 SNAMES( NSUBS )
101 * .. External Functions ..
105 * .. External Subroutines ..
106 EXTERNAL CCHK1, CCHK2, CCHK3, CCHK4, CCHK5, CCHK6,
108 * .. Intrinsic Functions ..
109 INTRINSIC ABS, MAX, MIN
110 * .. Scalars in Common ..
114 * .. Common blocks ..
115 COMMON /INFOC/INFOT, NOUTC, OK, LERR
116 COMMON /SRNAMC/SRNAMT
117 * .. Data statements ..
118 DATA SNAMES/'CGEMV ', 'CGBMV ', 'CHEMV ', 'CHBMV ',
119 $ 'CHPMV ', 'CTRMV ', 'CTBMV ', 'CTPMV ',
120 $ 'CTRSV ', 'CTBSV ', 'CTPSV ', 'CGERC ',
121 $ 'CGERU ', 'CHER ', 'CHPR ', 'CHER2 ',
123 * .. Executable Statements ..
125 * Read name and unit number for summary output file and open file.
127 READ( NIN, FMT = * )SUMMRY
128 READ( NIN, FMT = * )NOUT
129 OPEN( NOUT, FILE = SUMMRY, STATUS = 'NEW' )
132 * Read name and unit number for snapshot output file and open file.
134 READ( NIN, FMT = * )SNAPS
135 READ( NIN, FMT = * )NTRA
138 OPEN( NTRA, FILE = SNAPS, STATUS = 'NEW' )
140 * Read the flag that directs rewinding of the snapshot file.
141 READ( NIN, FMT = * )REWI
142 REWI = REWI.AND.TRACE
143 * Read the flag that directs stopping on any failure.
144 READ( NIN, FMT = * )SFATAL
145 * Read the flag that indicates whether error exits are to be tested.
146 READ( NIN, FMT = * )TSTERR
147 * Read the threshold value of the test ratio
148 READ( NIN, FMT = * )THRESH
150 * Read and check the parameter values for the tests.
153 READ( NIN, FMT = * )NIDIM
154 IF( NIDIM.LT.1.OR.NIDIM.GT.NIDMAX )THEN
155 WRITE( NOUT, FMT = 9997 )'N', NIDMAX
158 READ( NIN, FMT = * )( IDIM( I ), I = 1, NIDIM )
160 IF( IDIM( I ).LT.0.OR.IDIM( I ).GT.NMAX )THEN
161 WRITE( NOUT, FMT = 9996 )NMAX
166 READ( NIN, FMT = * )NKB
167 IF( NKB.LT.1.OR.NKB.GT.NKBMAX )THEN
168 WRITE( NOUT, FMT = 9997 )'K', NKBMAX
171 READ( NIN, FMT = * )( KB( I ), I = 1, NKB )
173 IF( KB( I ).LT.0 )THEN
174 WRITE( NOUT, FMT = 9995 )
178 * Values of INCX and INCY
179 READ( NIN, FMT = * )NINC
180 IF( NINC.LT.1.OR.NINC.GT.NINMAX )THEN
181 WRITE( NOUT, FMT = 9997 )'INCX AND INCY', NINMAX
184 READ( NIN, FMT = * )( INC( I ), I = 1, NINC )
186 IF( INC( I ).EQ.0.OR.ABS( INC( I ) ).GT.INCMAX )THEN
187 WRITE( NOUT, FMT = 9994 )INCMAX
192 READ( NIN, FMT = * )NALF
193 IF( NALF.LT.1.OR.NALF.GT.NALMAX )THEN
194 WRITE( NOUT, FMT = 9997 )'ALPHA', NALMAX
197 READ( NIN, FMT = * )( ALF( I ), I = 1, NALF )
199 READ( NIN, FMT = * )NBET
200 IF( NBET.LT.1.OR.NBET.GT.NBEMAX )THEN
201 WRITE( NOUT, FMT = 9997 )'BETA', NBEMAX
204 READ( NIN, FMT = * )( BET( I ), I = 1, NBET )
206 * Report values of parameters.
208 WRITE( NOUT, FMT = 9993 )
209 WRITE( NOUT, FMT = 9992 )( IDIM( I ), I = 1, NIDIM )
210 WRITE( NOUT, FMT = 9991 )( KB( I ), I = 1, NKB )
211 WRITE( NOUT, FMT = 9990 )( INC( I ), I = 1, NINC )
212 WRITE( NOUT, FMT = 9989 )( ALF( I ), I = 1, NALF )
213 WRITE( NOUT, FMT = 9988 )( BET( I ), I = 1, NBET )
214 IF( .NOT.TSTERR )THEN
215 WRITE( NOUT, FMT = * )
216 WRITE( NOUT, FMT = 9980 )
218 WRITE( NOUT, FMT = * )
219 WRITE( NOUT, FMT = 9999 )THRESH
220 WRITE( NOUT, FMT = * )
222 * Read names of subroutines and flags which indicate
223 * whether they are to be tested.
228 50 READ( NIN, FMT = 9984, END = 80 )SNAMET, LTESTT
230 IF( SNAMET.EQ.SNAMES( I ) )
233 WRITE( NOUT, FMT = 9986 )SNAMET
235 70 LTEST( I ) = LTESTT
241 * Compute EPS (the machine precision).
245 IF( SDIFF( RONE + EPS, RONE ).EQ.RZERO )
251 WRITE( NOUT, FMT = 9998 )EPS
253 * Check the reliability of CMVCH using exact data.
258 A( I, J ) = MAX( I - J + 1, 0 )
264 YY( J ) = J*( ( J + 1 )*J )/2 - ( ( J + 1 )*J*( J - 1 ) )/3
266 * YY holds the exact result. On exit from CMVCH YT holds
267 * the result computed by CMVCH.
269 CALL CMVCH( TRANS, N, N, ONE, A, NMAX, X, 1, ZERO, Y, 1, YT, G,
270 $ YY, EPS, ERR, FATAL, NOUT, .TRUE. )
271 SAME = LCE( YY, YT, N )
272 IF( .NOT.SAME.OR.ERR.NE.RZERO )THEN
273 WRITE( NOUT, FMT = 9985 )TRANS, SAME, ERR
277 CALL CMVCH( TRANS, N, N, ONE, A, NMAX, X, -1, ZERO, Y, -1, YT, G,
278 $ YY, EPS, ERR, FATAL, NOUT, .TRUE. )
279 SAME = LCE( YY, YT, N )
280 IF( .NOT.SAME.OR.ERR.NE.RZERO )THEN
281 WRITE( NOUT, FMT = 9985 )TRANS, SAME, ERR
285 * Test each subroutine in turn.
287 DO 210 ISNUM = 1, NSUBS
288 WRITE( NOUT, FMT = * )
289 IF( .NOT.LTEST( ISNUM ) )THEN
290 * Subprogram is not to be tested.
291 WRITE( NOUT, FMT = 9983 )SNAMES( ISNUM )
293 SRNAMT = SNAMES( ISNUM )
296 CALL CCHKE( ISNUM, SNAMES( ISNUM ), NOUT )
297 WRITE( NOUT, FMT = * )
303 GO TO ( 140, 140, 150, 150, 150, 160, 160,
304 $ 160, 160, 160, 160, 170, 170, 180,
305 $ 180, 190, 190 )ISNUM
306 * Test CGEMV, 01, and CGBMV, 02.
307 140 CALL CCHK1( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE,
308 $ REWI, FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF,
309 $ NBET, BET, NINC, INC, NMAX, INCMAX, A, AA, AS,
310 $ X, XX, XS, Y, YY, YS, YT, G )
312 * Test CHEMV, 03, CHBMV, 04, and CHPMV, 05.
313 150 CALL CCHK2( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE,
314 $ REWI, FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF,
315 $ NBET, BET, NINC, INC, NMAX, INCMAX, A, AA, AS,
316 $ X, XX, XS, Y, YY, YS, YT, G )
318 * Test CTRMV, 06, CTBMV, 07, CTPMV, 08,
319 * CTRSV, 09, CTBSV, 10, and CTPSV, 11.
320 160 CALL CCHK3( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE,
321 $ REWI, FATAL, NIDIM, IDIM, NKB, KB, NINC, INC,
322 $ NMAX, INCMAX, A, AA, AS, Y, YY, YS, YT, G, Z )
324 * Test CGERC, 12, CGERU, 13.
325 170 CALL CCHK4( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE,
326 $ REWI, FATAL, NIDIM, IDIM, NALF, ALF, NINC, INC,
327 $ NMAX, INCMAX, A, AA, AS, X, XX, XS, Y, YY, YS,
330 * Test CHER, 14, and CHPR, 15.
331 180 CALL CCHK5( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE,
332 $ REWI, FATAL, NIDIM, IDIM, NALF, ALF, NINC, INC,
333 $ NMAX, INCMAX, A, AA, AS, X, XX, XS, Y, YY, YS,
336 * Test CHER2, 16, and CHPR2, 17.
337 190 CALL CCHK6( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE,
338 $ REWI, FATAL, NIDIM, IDIM, NALF, ALF, NINC, INC,
339 $ NMAX, INCMAX, A, AA, AS, X, XX, XS, Y, YY, YS,
342 200 IF( FATAL.AND.SFATAL )
346 WRITE( NOUT, FMT = 9982 )
350 WRITE( NOUT, FMT = 9981 )
354 WRITE( NOUT, FMT = 9987 )
362 9999 FORMAT( ' ROUTINES PASS COMPUTATIONAL TESTS IF TEST RATIO IS LES',
364 9998 FORMAT( ' RELATIVE MACHINE PRECISION IS TAKEN TO BE', 1P, E9.1 )
365 9997 FORMAT( ' NUMBER OF VALUES OF ', A, ' IS LESS THAN 1 OR GREATER ',
367 9996 FORMAT( ' VALUE OF N IS LESS THAN 0 OR GREATER THAN ', I2 )
368 9995 FORMAT( ' VALUE OF K IS LESS THAN 0' )
369 9994 FORMAT( ' ABSOLUTE VALUE OF INCX OR INCY IS 0 OR GREATER THAN ',
371 9993 FORMAT( ' TESTS OF THE COMPLEX LEVEL 2 BLAS', //' THE F',
372 $ 'OLLOWING PARAMETER VALUES WILL BE USED:' )
373 9992 FORMAT( ' FOR N ', 9I6 )
374 9991 FORMAT( ' FOR K ', 7I6 )
375 9990 FORMAT( ' FOR INCX AND INCY ', 7I6 )
376 9989 FORMAT( ' FOR ALPHA ',
377 $ 7( '(', F4.1, ',', F4.1, ') ', : ) )
378 9988 FORMAT( ' FOR BETA ',
379 $ 7( '(', F4.1, ',', F4.1, ') ', : ) )
380 9987 FORMAT( ' AMEND DATA FILE OR INCREASE ARRAY SIZES IN PROGRAM',
381 $ /' ******* TESTS ABANDONED *******' )
382 9986 FORMAT( ' SUBPROGRAM NAME ', A6, ' NOT RECOGNIZED', /' ******* T',
383 $ 'ESTS ABANDONED *******' )
384 9985 FORMAT( ' ERROR IN CMVCH - IN-LINE DOT PRODUCTS ARE BEING EVALU',
385 $ 'ATED WRONGLY.', /' CMVCH WAS CALLED WITH TRANS = ', A1,
386 $ ' AND RETURNED SAME = ', L1, ' AND ERR = ', F12.3, '.', /
387 $ ' THIS MAY BE DUE TO FAULTS IN THE ARITHMETIC OR THE COMPILER.'
388 $ , /' ******* TESTS ABANDONED *******' )
389 9984 FORMAT( A6, L2 )
390 9983 FORMAT( 1X, A6, ' WAS NOT TESTED' )
391 9982 FORMAT( /' END OF TESTS' )
392 9981 FORMAT( /' ******* FATAL ERROR - TESTS ABANDONED *******' )
393 9980 FORMAT( ' ERROR-EXITS WILL NOT BE TESTED' )
398 SUBROUTINE CCHK1( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI,
399 $ FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF, NBET,
400 $ BET, NINC, INC, NMAX, INCMAX, A, AA, AS, X, XX,
401 $ XS, Y, YY, YS, YT, G )
403 * Tests CGEMV and CGBMV.
405 * Auxiliary routine for test program for Level 2 Blas.
407 * -- Written on 10-August-1987.
408 * Richard Hanson, Sandia National Labs.
409 * Jeremy Du Croz, NAG Central Office.
413 PARAMETER ( ZERO = ( 0.0, 0.0 ), HALF = ( 0.5, 0.0 ) )
415 PARAMETER ( RZERO = 0.0 )
416 * .. Scalar Arguments ..
418 INTEGER INCMAX, NALF, NBET, NIDIM, NINC, NKB, NMAX,
420 LOGICAL FATAL, REWI, TRACE
422 * .. Array Arguments ..
423 COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ),
424 $ AS( NMAX*NMAX ), BET( NBET ), X( NMAX ),
425 $ XS( NMAX*INCMAX ), XX( NMAX*INCMAX ),
426 $ Y( NMAX ), YS( NMAX*INCMAX ), YT( NMAX ),
429 INTEGER IDIM( NIDIM ), INC( NINC ), KB( NKB )
430 * .. Local Scalars ..
431 COMPLEX ALPHA, ALS, BETA, BLS, TRANSL
433 INTEGER I, IA, IB, IC, IKU, IM, IN, INCX, INCXS, INCY,
434 $ INCYS, IX, IY, KL, KLS, KU, KUS, LAA, LDA,
435 $ LDAS, LX, LY, M, ML, MS, N, NARGS, NC, ND, NK,
437 LOGICAL BANDED, FULL, NULL, RESET, SAME, TRAN
438 CHARACTER*1 TRANS, TRANSS
442 * .. External Functions ..
445 * .. External Subroutines ..
446 EXTERNAL CGBMV, CGEMV, CMAKE, CMVCH
447 * .. Intrinsic Functions ..
448 INTRINSIC ABS, MAX, MIN
449 * .. Scalars in Common ..
452 * .. Common blocks ..
453 COMMON /INFOC/INFOT, NOUTC, OK, LERR
454 * .. Data statements ..
456 * .. Executable Statements ..
457 FULL = SNAME( 3: 3 ).EQ.'E'
458 BANDED = SNAME( 3: 3 ).EQ.'B'
459 * Define the number of arguments.
462 ELSE IF( BANDED )THEN
476 $ M = MAX( N - ND, 0 )
478 $ M = MIN( N + ND, NMAX )
488 KL = MAX( KU - 1, 0 )
493 * Set LDA to 1 more than minimum value if room.
501 * Skip tests if not enough room.
505 NULL = N.LE.0.OR.M.LE.0
507 * Generate the matrix A.
510 CALL CMAKE( SNAME( 2: 3 ), ' ', ' ', M, N, A, NMAX, AA,
511 $ LDA, KL, KU, RESET, TRANSL )
514 TRANS = ICH( IC: IC )
515 TRAN = TRANS.EQ.'T'.OR.TRANS.EQ.'C'
529 * Generate the vector X.
532 CALL CMAKE( 'GE', ' ', ' ', 1, NL, X, 1, XX,
533 $ ABS( INCX ), 0, NL - 1, RESET, TRANSL )
536 XX( 1 + ABS( INCX )*( NL/2 - 1 ) ) = ZERO
549 * Generate the vector Y.
552 CALL CMAKE( 'GE', ' ', ' ', 1, ML, Y, 1,
553 $ YY, ABS( INCY ), 0, ML - 1,
558 * Save every datum before calling the
581 * Call the subroutine.
585 $ WRITE( NTRA, FMT = 9994 )NC, SNAME,
586 $ TRANS, M, N, ALPHA, LDA, INCX, BETA,
590 CALL CGEMV( TRANS, M, N, ALPHA, AA,
591 $ LDA, XX, INCX, BETA, YY,
593 ELSE IF( BANDED )THEN
595 $ WRITE( NTRA, FMT = 9995 )NC, SNAME,
596 $ TRANS, M, N, KL, KU, ALPHA, LDA,
600 CALL CGBMV( TRANS, M, N, KL, KU, ALPHA,
601 $ AA, LDA, XX, INCX, BETA,
605 * Check if error-exit was taken incorrectly.
608 WRITE( NOUT, FMT = 9993 )
613 * See what data changed inside subroutines.
615 ISAME( 1 ) = TRANS.EQ.TRANSS
619 ISAME( 4 ) = ALS.EQ.ALPHA
620 ISAME( 5 ) = LCE( AS, AA, LAA )
621 ISAME( 6 ) = LDAS.EQ.LDA
622 ISAME( 7 ) = LCE( XS, XX, LX )
623 ISAME( 8 ) = INCXS.EQ.INCX
624 ISAME( 9 ) = BLS.EQ.BETA
626 ISAME( 10 ) = LCE( YS, YY, LY )
628 ISAME( 10 ) = LCERES( 'GE', ' ', 1,
632 ISAME( 11 ) = INCYS.EQ.INCY
633 ELSE IF( BANDED )THEN
634 ISAME( 4 ) = KLS.EQ.KL
635 ISAME( 5 ) = KUS.EQ.KU
636 ISAME( 6 ) = ALS.EQ.ALPHA
637 ISAME( 7 ) = LCE( AS, AA, LAA )
638 ISAME( 8 ) = LDAS.EQ.LDA
639 ISAME( 9 ) = LCE( XS, XX, LX )
640 ISAME( 10 ) = INCXS.EQ.INCX
641 ISAME( 11 ) = BLS.EQ.BETA
643 ISAME( 12 ) = LCE( YS, YY, LY )
645 ISAME( 12 ) = LCERES( 'GE', ' ', 1,
649 ISAME( 13 ) = INCYS.EQ.INCY
652 * If data was incorrectly changed, report
657 SAME = SAME.AND.ISAME( I )
658 IF( .NOT.ISAME( I ) )
659 $ WRITE( NOUT, FMT = 9998 )I
670 CALL CMVCH( TRANS, M, N, ALPHA, A,
671 $ NMAX, X, INCX, BETA, Y,
672 $ INCY, YT, G, YY, EPS, ERR,
673 $ FATAL, NOUT, .TRUE. )
674 ERRMAX = MAX( ERRMAX, ERR )
675 * If got really bad answer, report and
680 * Avoid repeating tests with M.le.0 or
703 IF( ERRMAX.LT.THRESH )THEN
704 WRITE( NOUT, FMT = 9999 )SNAME, NC
706 WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX
711 WRITE( NOUT, FMT = 9996 )SNAME
713 WRITE( NOUT, FMT = 9994 )NC, SNAME, TRANS, M, N, ALPHA, LDA,
715 ELSE IF( BANDED )THEN
716 WRITE( NOUT, FMT = 9995 )NC, SNAME, TRANS, M, N, KL, KU,
717 $ ALPHA, LDA, INCX, BETA, INCY
723 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL',
725 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH',
726 $ 'ANGED INCORRECTLY *******' )
727 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C',
728 $ 'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2,
729 $ ' - SUSPECT *******' )
730 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' )
731 9995 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', 4( I3, ',' ), '(',
732 $ F4.1, ',', F4.1, '), A,', I3, ', X,', I2, ',(', F4.1, ',',
733 $ F4.1, '), Y,', I2, ') .' )
734 9994 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', 2( I3, ',' ), '(',
735 $ F4.1, ',', F4.1, '), A,', I3, ', X,', I2, ',(', F4.1, ',',
736 $ F4.1, '), Y,', I2, ') .' )
737 9993 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *',
743 SUBROUTINE CCHK2( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI,
744 $ FATAL, NIDIM, IDIM, NKB, KB, NALF, ALF, NBET,
745 $ BET, NINC, INC, NMAX, INCMAX, A, AA, AS, X, XX,
746 $ XS, Y, YY, YS, YT, G )
748 * Tests CHEMV, CHBMV and CHPMV.
750 * Auxiliary routine for test program for Level 2 Blas.
752 * -- Written on 10-August-1987.
753 * Richard Hanson, Sandia National Labs.
754 * Jeremy Du Croz, NAG Central Office.
758 PARAMETER ( ZERO = ( 0.0, 0.0 ), HALF = ( 0.5, 0.0 ) )
760 PARAMETER ( RZERO = 0.0 )
761 * .. Scalar Arguments ..
763 INTEGER INCMAX, NALF, NBET, NIDIM, NINC, NKB, NMAX,
765 LOGICAL FATAL, REWI, TRACE
767 * .. Array Arguments ..
768 COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ),
769 $ AS( NMAX*NMAX ), BET( NBET ), X( NMAX ),
770 $ XS( NMAX*INCMAX ), XX( NMAX*INCMAX ),
771 $ Y( NMAX ), YS( NMAX*INCMAX ), YT( NMAX ),
774 INTEGER IDIM( NIDIM ), INC( NINC ), KB( NKB )
775 * .. Local Scalars ..
776 COMPLEX ALPHA, ALS, BETA, BLS, TRANSL
778 INTEGER I, IA, IB, IC, IK, IN, INCX, INCXS, INCY,
779 $ INCYS, IX, IY, K, KS, LAA, LDA, LDAS, LX, LY,
780 $ N, NARGS, NC, NK, NS
781 LOGICAL BANDED, FULL, NULL, PACKED, RESET, SAME
782 CHARACTER*1 UPLO, UPLOS
786 * .. External Functions ..
789 * .. External Subroutines ..
790 EXTERNAL CHBMV, CHEMV, CHPMV, CMAKE, CMVCH
791 * .. Intrinsic Functions ..
793 * .. Scalars in Common ..
796 * .. Common blocks ..
797 COMMON /INFOC/INFOT, NOUTC, OK, LERR
798 * .. Data statements ..
800 * .. Executable Statements ..
801 FULL = SNAME( 3: 3 ).EQ.'E'
802 BANDED = SNAME( 3: 3 ).EQ.'B'
803 PACKED = SNAME( 3: 3 ).EQ.'P'
804 * Define the number of arguments.
807 ELSE IF( BANDED )THEN
809 ELSE IF( PACKED )THEN
831 * Set LDA to 1 more than minimum value if room.
839 * Skip tests if not enough room.
843 LAA = ( N*( N + 1 ) )/2
852 * Generate the matrix A.
855 CALL CMAKE( SNAME( 2: 3 ), UPLO, ' ', N, N, A, NMAX, AA,
856 $ LDA, K, K, RESET, TRANSL )
862 * Generate the vector X.
865 CALL CMAKE( 'GE', ' ', ' ', 1, N, X, 1, XX,
866 $ ABS( INCX ), 0, N - 1, RESET, TRANSL )
869 XX( 1 + ABS( INCX )*( N/2 - 1 ) ) = ZERO
882 * Generate the vector Y.
885 CALL CMAKE( 'GE', ' ', ' ', 1, N, Y, 1, YY,
886 $ ABS( INCY ), 0, N - 1, RESET,
891 * Save every datum before calling the
912 * Call the subroutine.
916 $ WRITE( NTRA, FMT = 9993 )NC, SNAME,
917 $ UPLO, N, ALPHA, LDA, INCX, BETA, INCY
920 CALL CHEMV( UPLO, N, ALPHA, AA, LDA, XX,
921 $ INCX, BETA, YY, INCY )
922 ELSE IF( BANDED )THEN
924 $ WRITE( NTRA, FMT = 9994 )NC, SNAME,
925 $ UPLO, N, K, ALPHA, LDA, INCX, BETA,
929 CALL CHBMV( UPLO, N, K, ALPHA, AA, LDA,
930 $ XX, INCX, BETA, YY, INCY )
931 ELSE IF( PACKED )THEN
933 $ WRITE( NTRA, FMT = 9995 )NC, SNAME,
934 $ UPLO, N, ALPHA, INCX, BETA, INCY
937 CALL CHPMV( UPLO, N, ALPHA, AA, XX, INCX,
941 * Check if error-exit was taken incorrectly.
944 WRITE( NOUT, FMT = 9992 )
949 * See what data changed inside subroutines.
951 ISAME( 1 ) = UPLO.EQ.UPLOS
954 ISAME( 3 ) = ALS.EQ.ALPHA
955 ISAME( 4 ) = LCE( AS, AA, LAA )
956 ISAME( 5 ) = LDAS.EQ.LDA
957 ISAME( 6 ) = LCE( XS, XX, LX )
958 ISAME( 7 ) = INCXS.EQ.INCX
959 ISAME( 8 ) = BLS.EQ.BETA
961 ISAME( 9 ) = LCE( YS, YY, LY )
963 ISAME( 9 ) = LCERES( 'GE', ' ', 1, N,
964 $ YS, YY, ABS( INCY ) )
966 ISAME( 10 ) = INCYS.EQ.INCY
967 ELSE IF( BANDED )THEN
969 ISAME( 4 ) = ALS.EQ.ALPHA
970 ISAME( 5 ) = LCE( AS, AA, LAA )
971 ISAME( 6 ) = LDAS.EQ.LDA
972 ISAME( 7 ) = LCE( XS, XX, LX )
973 ISAME( 8 ) = INCXS.EQ.INCX
974 ISAME( 9 ) = BLS.EQ.BETA
976 ISAME( 10 ) = LCE( YS, YY, LY )
978 ISAME( 10 ) = LCERES( 'GE', ' ', 1, N,
979 $ YS, YY, ABS( INCY ) )
981 ISAME( 11 ) = INCYS.EQ.INCY
982 ELSE IF( PACKED )THEN
983 ISAME( 3 ) = ALS.EQ.ALPHA
984 ISAME( 4 ) = LCE( AS, AA, LAA )
985 ISAME( 5 ) = LCE( XS, XX, LX )
986 ISAME( 6 ) = INCXS.EQ.INCX
987 ISAME( 7 ) = BLS.EQ.BETA
989 ISAME( 8 ) = LCE( YS, YY, LY )
991 ISAME( 8 ) = LCERES( 'GE', ' ', 1, N,
992 $ YS, YY, ABS( INCY ) )
994 ISAME( 9 ) = INCYS.EQ.INCY
997 * If data was incorrectly changed, report and
1002 SAME = SAME.AND.ISAME( I )
1003 IF( .NOT.ISAME( I ) )
1004 $ WRITE( NOUT, FMT = 9998 )I
1015 CALL CMVCH( 'N', N, N, ALPHA, A, NMAX, X,
1016 $ INCX, BETA, Y, INCY, YT, G,
1017 $ YY, EPS, ERR, FATAL, NOUT,
1019 ERRMAX = MAX( ERRMAX, ERR )
1020 * If got really bad answer, report and
1025 * Avoid repeating tests with N.le.0
1045 IF( ERRMAX.LT.THRESH )THEN
1046 WRITE( NOUT, FMT = 9999 )SNAME, NC
1048 WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX
1053 WRITE( NOUT, FMT = 9996 )SNAME
1055 WRITE( NOUT, FMT = 9993 )NC, SNAME, UPLO, N, ALPHA, LDA, INCX,
1057 ELSE IF( BANDED )THEN
1058 WRITE( NOUT, FMT = 9994 )NC, SNAME, UPLO, N, K, ALPHA, LDA,
1060 ELSE IF( PACKED )THEN
1061 WRITE( NOUT, FMT = 9995 )NC, SNAME, UPLO, N, ALPHA, INCX,
1068 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL',
1070 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH',
1071 $ 'ANGED INCORRECTLY *******' )
1072 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C',
1073 $ 'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2,
1074 $ ' - SUSPECT *******' )
1075 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' )
1076 9995 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', I3, ',(', F4.1, ',',
1077 $ F4.1, '), AP, X,', I2, ',(', F4.1, ',', F4.1, '), Y,', I2,
1079 9994 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', 2( I3, ',' ), '(',
1080 $ F4.1, ',', F4.1, '), A,', I3, ', X,', I2, ',(', F4.1, ',',
1081 $ F4.1, '), Y,', I2, ') .' )
1082 9993 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', I3, ',(', F4.1, ',',
1083 $ F4.1, '), A,', I3, ', X,', I2, ',(', F4.1, ',', F4.1, '), ',
1085 9992 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *',
1091 SUBROUTINE CCHK3( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI,
1092 $ FATAL, NIDIM, IDIM, NKB, KB, NINC, INC, NMAX,
1093 $ INCMAX, A, AA, AS, X, XX, XS, XT, G, Z )
1095 * Tests CTRMV, CTBMV, CTPMV, CTRSV, CTBSV and CTPSV.
1097 * Auxiliary routine for test program for Level 2 Blas.
1099 * -- Written on 10-August-1987.
1100 * Richard Hanson, Sandia National Labs.
1101 * Jeremy Du Croz, NAG Central Office.
1104 COMPLEX ZERO, HALF, ONE
1105 PARAMETER ( ZERO = ( 0.0, 0.0 ), HALF = ( 0.5, 0.0 ),
1106 $ ONE = ( 1.0, 0.0 ) )
1108 PARAMETER ( RZERO = 0.0 )
1109 * .. Scalar Arguments ..
1111 INTEGER INCMAX, NIDIM, NINC, NKB, NMAX, NOUT, NTRA
1112 LOGICAL FATAL, REWI, TRACE
1114 * .. Array Arguments ..
1115 COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ),
1116 $ AS( NMAX*NMAX ), X( NMAX ), XS( NMAX*INCMAX ),
1117 $ XT( NMAX ), XX( NMAX*INCMAX ), Z( NMAX )
1119 INTEGER IDIM( NIDIM ), INC( NINC ), KB( NKB )
1120 * .. Local Scalars ..
1123 INTEGER I, ICD, ICT, ICU, IK, IN, INCX, INCXS, IX, K,
1124 $ KS, LAA, LDA, LDAS, LX, N, NARGS, NC, NK, NS
1125 LOGICAL BANDED, FULL, NULL, PACKED, RESET, SAME
1126 CHARACTER*1 DIAG, DIAGS, TRANS, TRANSS, UPLO, UPLOS
1127 CHARACTER*2 ICHD, ICHU
1129 * .. Local Arrays ..
1131 * .. External Functions ..
1133 EXTERNAL LCE, LCERES
1134 * .. External Subroutines ..
1135 EXTERNAL CMAKE, CMVCH, CTBMV, CTBSV, CTPMV, CTPSV,
1137 * .. Intrinsic Functions ..
1139 * .. Scalars in Common ..
1140 INTEGER INFOT, NOUTC
1142 * .. Common blocks ..
1143 COMMON /INFOC/INFOT, NOUTC, OK, LERR
1144 * .. Data statements ..
1145 DATA ICHU/'UL'/, ICHT/'NTC'/, ICHD/'UN'/
1146 * .. Executable Statements ..
1147 FULL = SNAME( 3: 3 ).EQ.'R'
1148 BANDED = SNAME( 3: 3 ).EQ.'B'
1149 PACKED = SNAME( 3: 3 ).EQ.'P'
1150 * Define the number of arguments.
1153 ELSE IF( BANDED )THEN
1155 ELSE IF( PACKED )THEN
1162 * Set up zero vector for CMVCH.
1167 DO 110 IN = 1, NIDIM
1181 * Set LDA to 1 more than minimum value if room.
1189 * Skip tests if not enough room.
1193 LAA = ( N*( N + 1 ) )/2
1200 UPLO = ICHU( ICU: ICU )
1203 TRANS = ICHT( ICT: ICT )
1206 DIAG = ICHD( ICD: ICD )
1208 * Generate the matrix A.
1211 CALL CMAKE( SNAME( 2: 3 ), UPLO, DIAG, N, N, A,
1212 $ NMAX, AA, LDA, K, K, RESET, TRANSL )
1218 * Generate the vector X.
1221 CALL CMAKE( 'GE', ' ', ' ', 1, N, X, 1, XX,
1222 $ ABS( INCX ), 0, N - 1, RESET,
1226 XX( 1 + ABS( INCX )*( N/2 - 1 ) ) = ZERO
1231 * Save every datum before calling the subroutine.
1247 * Call the subroutine.
1249 IF( SNAME( 4: 5 ).EQ.'MV' )THEN
1252 $ WRITE( NTRA, FMT = 9993 )NC, SNAME,
1253 $ UPLO, TRANS, DIAG, N, LDA, INCX
1256 CALL CTRMV( UPLO, TRANS, DIAG, N, AA, LDA,
1258 ELSE IF( BANDED )THEN
1260 $ WRITE( NTRA, FMT = 9994 )NC, SNAME,
1261 $ UPLO, TRANS, DIAG, N, K, LDA, INCX
1264 CALL CTBMV( UPLO, TRANS, DIAG, N, K, AA,
1266 ELSE IF( PACKED )THEN
1268 $ WRITE( NTRA, FMT = 9995 )NC, SNAME,
1269 $ UPLO, TRANS, DIAG, N, INCX
1272 CALL CTPMV( UPLO, TRANS, DIAG, N, AA, XX,
1275 ELSE IF( SNAME( 4: 5 ).EQ.'SV' )THEN
1278 $ WRITE( NTRA, FMT = 9993 )NC, SNAME,
1279 $ UPLO, TRANS, DIAG, N, LDA, INCX
1282 CALL CTRSV( UPLO, TRANS, DIAG, N, AA, LDA,
1284 ELSE IF( BANDED )THEN
1286 $ WRITE( NTRA, FMT = 9994 )NC, SNAME,
1287 $ UPLO, TRANS, DIAG, N, K, LDA, INCX
1290 CALL CTBSV( UPLO, TRANS, DIAG, N, K, AA,
1292 ELSE IF( PACKED )THEN
1294 $ WRITE( NTRA, FMT = 9995 )NC, SNAME,
1295 $ UPLO, TRANS, DIAG, N, INCX
1298 CALL CTPSV( UPLO, TRANS, DIAG, N, AA, XX,
1303 * Check if error-exit was taken incorrectly.
1306 WRITE( NOUT, FMT = 9992 )
1311 * See what data changed inside subroutines.
1313 ISAME( 1 ) = UPLO.EQ.UPLOS
1314 ISAME( 2 ) = TRANS.EQ.TRANSS
1315 ISAME( 3 ) = DIAG.EQ.DIAGS
1316 ISAME( 4 ) = NS.EQ.N
1318 ISAME( 5 ) = LCE( AS, AA, LAA )
1319 ISAME( 6 ) = LDAS.EQ.LDA
1321 ISAME( 7 ) = LCE( XS, XX, LX )
1323 ISAME( 7 ) = LCERES( 'GE', ' ', 1, N, XS,
1326 ISAME( 8 ) = INCXS.EQ.INCX
1327 ELSE IF( BANDED )THEN
1328 ISAME( 5 ) = KS.EQ.K
1329 ISAME( 6 ) = LCE( AS, AA, LAA )
1330 ISAME( 7 ) = LDAS.EQ.LDA
1332 ISAME( 8 ) = LCE( XS, XX, LX )
1334 ISAME( 8 ) = LCERES( 'GE', ' ', 1, N, XS,
1337 ISAME( 9 ) = INCXS.EQ.INCX
1338 ELSE IF( PACKED )THEN
1339 ISAME( 5 ) = LCE( AS, AA, LAA )
1341 ISAME( 6 ) = LCE( XS, XX, LX )
1343 ISAME( 6 ) = LCERES( 'GE', ' ', 1, N, XS,
1346 ISAME( 7 ) = INCXS.EQ.INCX
1349 * If data was incorrectly changed, report and
1354 SAME = SAME.AND.ISAME( I )
1355 IF( .NOT.ISAME( I ) )
1356 $ WRITE( NOUT, FMT = 9998 )I
1364 IF( SNAME( 4: 5 ).EQ.'MV' )THEN
1368 CALL CMVCH( TRANS, N, N, ONE, A, NMAX, X,
1369 $ INCX, ZERO, Z, INCX, XT, G,
1370 $ XX, EPS, ERR, FATAL, NOUT,
1372 ELSE IF( SNAME( 4: 5 ).EQ.'SV' )THEN
1374 * Compute approximation to original vector.
1377 Z( I ) = XX( 1 + ( I - 1 )*
1379 XX( 1 + ( I - 1 )*ABS( INCX ) )
1382 CALL CMVCH( TRANS, N, N, ONE, A, NMAX, Z,
1383 $ INCX, ZERO, X, INCX, XT, G,
1384 $ XX, EPS, ERR, FATAL, NOUT,
1387 ERRMAX = MAX( ERRMAX, ERR )
1388 * If got really bad answer, report and return.
1392 * Avoid repeating tests with N.le.0.
1410 IF( ERRMAX.LT.THRESH )THEN
1411 WRITE( NOUT, FMT = 9999 )SNAME, NC
1413 WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX
1418 WRITE( NOUT, FMT = 9996 )SNAME
1420 WRITE( NOUT, FMT = 9993 )NC, SNAME, UPLO, TRANS, DIAG, N, LDA,
1422 ELSE IF( BANDED )THEN
1423 WRITE( NOUT, FMT = 9994 )NC, SNAME, UPLO, TRANS, DIAG, N, K,
1425 ELSE IF( PACKED )THEN
1426 WRITE( NOUT, FMT = 9995 )NC, SNAME, UPLO, TRANS, DIAG, N, INCX
1432 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL',
1434 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH',
1435 $ 'ANGED INCORRECTLY *******' )
1436 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C',
1437 $ 'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2,
1438 $ ' - SUSPECT *******' )
1439 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' )
1440 9995 FORMAT( 1X, I6, ': ', A6, '(', 3( '''', A1, ''',' ), I3, ', AP, ',
1442 9994 FORMAT( 1X, I6, ': ', A6, '(', 3( '''', A1, ''',' ), 2( I3, ',' ),
1443 $ ' A,', I3, ', X,', I2, ') .' )
1444 9993 FORMAT( 1X, I6, ': ', A6, '(', 3( '''', A1, ''',' ), I3, ', A,',
1445 $ I3, ', X,', I2, ') .' )
1446 9992 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *',
1452 SUBROUTINE CCHK4( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI,
1453 $ FATAL, NIDIM, IDIM, NALF, ALF, NINC, INC, NMAX,
1454 $ INCMAX, A, AA, AS, X, XX, XS, Y, YY, YS, YT, G,
1457 * Tests CGERC and CGERU.
1459 * Auxiliary routine for test program for Level 2 Blas.
1461 * -- Written on 10-August-1987.
1462 * Richard Hanson, Sandia National Labs.
1463 * Jeremy Du Croz, NAG Central Office.
1466 COMPLEX ZERO, HALF, ONE
1467 PARAMETER ( ZERO = ( 0.0, 0.0 ), HALF = ( 0.5, 0.0 ),
1468 $ ONE = ( 1.0, 0.0 ) )
1470 PARAMETER ( RZERO = 0.0 )
1471 * .. Scalar Arguments ..
1473 INTEGER INCMAX, NALF, NIDIM, NINC, NMAX, NOUT, NTRA
1474 LOGICAL FATAL, REWI, TRACE
1476 * .. Array Arguments ..
1477 COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ),
1478 $ AS( NMAX*NMAX ), X( NMAX ), XS( NMAX*INCMAX ),
1479 $ XX( NMAX*INCMAX ), Y( NMAX ),
1480 $ YS( NMAX*INCMAX ), YT( NMAX ),
1481 $ YY( NMAX*INCMAX ), Z( NMAX )
1483 INTEGER IDIM( NIDIM ), INC( NINC )
1484 * .. Local Scalars ..
1485 COMPLEX ALPHA, ALS, TRANSL
1487 INTEGER I, IA, IM, IN, INCX, INCXS, INCY, INCYS, IX,
1488 $ IY, J, LAA, LDA, LDAS, LX, LY, M, MS, N, NARGS,
1490 LOGICAL CONJ, NULL, RESET, SAME
1491 * .. Local Arrays ..
1494 * .. External Functions ..
1496 EXTERNAL LCE, LCERES
1497 * .. External Subroutines ..
1498 EXTERNAL CGERC, CGERU, CMAKE, CMVCH
1499 * .. Intrinsic Functions ..
1500 INTRINSIC ABS, CONJG, MAX, MIN
1501 * .. Scalars in Common ..
1502 INTEGER INFOT, NOUTC
1504 * .. Common blocks ..
1505 COMMON /INFOC/INFOT, NOUTC, OK, LERR
1506 * .. Executable Statements ..
1507 CONJ = SNAME( 5: 5 ).EQ.'C'
1508 * Define the number of arguments.
1515 DO 120 IN = 1, NIDIM
1521 $ M = MAX( N - ND, 0 )
1523 $ M = MIN( N + ND, NMAX )
1525 * Set LDA to 1 more than minimum value if room.
1529 * Skip tests if not enough room.
1533 NULL = N.LE.0.OR.M.LE.0
1539 * Generate the vector X.
1542 CALL CMAKE( 'GE', ' ', ' ', 1, M, X, 1, XX, ABS( INCX ),
1543 $ 0, M - 1, RESET, TRANSL )
1546 XX( 1 + ABS( INCX )*( M/2 - 1 ) ) = ZERO
1553 * Generate the vector Y.
1556 CALL CMAKE( 'GE', ' ', ' ', 1, N, Y, 1, YY,
1557 $ ABS( INCY ), 0, N - 1, RESET, TRANSL )
1560 YY( 1 + ABS( INCY )*( N/2 - 1 ) ) = ZERO
1566 * Generate the matrix A.
1569 CALL CMAKE( SNAME( 2: 3 ), ' ', ' ', M, N, A, NMAX,
1570 $ AA, LDA, M - 1, N - 1, RESET, TRANSL )
1574 * Save every datum before calling the subroutine.
1592 * Call the subroutine.
1595 $ WRITE( NTRA, FMT = 9994 )NC, SNAME, M, N,
1596 $ ALPHA, INCX, INCY, LDA
1600 CALL CGERC( M, N, ALPHA, XX, INCX, YY, INCY, AA,
1605 CALL CGERU( M, N, ALPHA, XX, INCX, YY, INCY, AA,
1609 * Check if error-exit was taken incorrectly.
1612 WRITE( NOUT, FMT = 9993 )
1617 * See what data changed inside subroutine.
1619 ISAME( 1 ) = MS.EQ.M
1620 ISAME( 2 ) = NS.EQ.N
1621 ISAME( 3 ) = ALS.EQ.ALPHA
1622 ISAME( 4 ) = LCE( XS, XX, LX )
1623 ISAME( 5 ) = INCXS.EQ.INCX
1624 ISAME( 6 ) = LCE( YS, YY, LY )
1625 ISAME( 7 ) = INCYS.EQ.INCY
1627 ISAME( 8 ) = LCE( AS, AA, LAA )
1629 ISAME( 8 ) = LCERES( 'GE', ' ', M, N, AS, AA,
1632 ISAME( 9 ) = LDAS.EQ.LDA
1634 * If data was incorrectly changed, report and return.
1638 SAME = SAME.AND.ISAME( I )
1639 IF( .NOT.ISAME( I ) )
1640 $ WRITE( NOUT, FMT = 9998 )I
1649 * Check the result column by column.
1657 Z( I ) = X( M - I + 1 )
1664 W( 1 ) = Y( N - J + 1 )
1667 $ W( 1 ) = CONJG( W( 1 ) )
1668 CALL CMVCH( 'N', M, 1, ALPHA, Z, NMAX, W, 1,
1669 $ ONE, A( 1, J ), 1, YT, G,
1670 $ AA( 1 + ( J - 1 )*LDA ), EPS,
1671 $ ERR, FATAL, NOUT, .TRUE. )
1672 ERRMAX = MAX( ERRMAX, ERR )
1673 * If got really bad answer, report and return.
1678 * Avoid repeating tests with M.le.0 or N.le.0.
1694 IF( ERRMAX.LT.THRESH )THEN
1695 WRITE( NOUT, FMT = 9999 )SNAME, NC
1697 WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX
1702 WRITE( NOUT, FMT = 9995 )J
1705 WRITE( NOUT, FMT = 9996 )SNAME
1706 WRITE( NOUT, FMT = 9994 )NC, SNAME, M, N, ALPHA, INCX, INCY, LDA
1711 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL',
1713 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH',
1714 $ 'ANGED INCORRECTLY *******' )
1715 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C',
1716 $ 'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2,
1717 $ ' - SUSPECT *******' )
1718 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' )
1719 9995 FORMAT( ' THESE ARE THE RESULTS FOR COLUMN ', I3 )
1720 9994 FORMAT( 1X, I6, ': ', A6, '(', 2( I3, ',' ), '(', F4.1, ',', F4.1,
1721 $ '), X,', I2, ', Y,', I2, ', A,', I3, ') ',
1723 9993 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *',
1729 SUBROUTINE CCHK5( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI,
1730 $ FATAL, NIDIM, IDIM, NALF, ALF, NINC, INC, NMAX,
1731 $ INCMAX, A, AA, AS, X, XX, XS, Y, YY, YS, YT, G,
1734 * Tests CHER and CHPR.
1736 * Auxiliary routine for test program for Level 2 Blas.
1738 * -- Written on 10-August-1987.
1739 * Richard Hanson, Sandia National Labs.
1740 * Jeremy Du Croz, NAG Central Office.
1743 COMPLEX ZERO, HALF, ONE
1744 PARAMETER ( ZERO = ( 0.0, 0.0 ), HALF = ( 0.5, 0.0 ),
1745 $ ONE = ( 1.0, 0.0 ) )
1747 PARAMETER ( RZERO = 0.0 )
1748 * .. Scalar Arguments ..
1750 INTEGER INCMAX, NALF, NIDIM, NINC, NMAX, NOUT, NTRA
1751 LOGICAL FATAL, REWI, TRACE
1753 * .. Array Arguments ..
1754 COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ),
1755 $ AS( NMAX*NMAX ), X( NMAX ), XS( NMAX*INCMAX ),
1756 $ XX( NMAX*INCMAX ), Y( NMAX ),
1757 $ YS( NMAX*INCMAX ), YT( NMAX ),
1758 $ YY( NMAX*INCMAX ), Z( NMAX )
1760 INTEGER IDIM( NIDIM ), INC( NINC )
1761 * .. Local Scalars ..
1762 COMPLEX ALPHA, TRANSL
1763 REAL ERR, ERRMAX, RALPHA, RALS
1764 INTEGER I, IA, IC, IN, INCX, INCXS, IX, J, JA, JJ, LAA,
1765 $ LDA, LDAS, LJ, LX, N, NARGS, NC, NS
1766 LOGICAL FULL, NULL, PACKED, RESET, SAME, UPPER
1767 CHARACTER*1 UPLO, UPLOS
1769 * .. Local Arrays ..
1772 * .. External Functions ..
1774 EXTERNAL LCE, LCERES
1775 * .. External Subroutines ..
1776 EXTERNAL CHER, CHPR, CMAKE, CMVCH
1777 * .. Intrinsic Functions ..
1778 INTRINSIC ABS, CMPLX, CONJG, MAX, REAL
1779 * .. Scalars in Common ..
1780 INTEGER INFOT, NOUTC
1782 * .. Common blocks ..
1783 COMMON /INFOC/INFOT, NOUTC, OK, LERR
1784 * .. Data statements ..
1786 * .. Executable Statements ..
1787 FULL = SNAME( 3: 3 ).EQ.'E'
1788 PACKED = SNAME( 3: 3 ).EQ.'P'
1789 * Define the number of arguments.
1792 ELSE IF( PACKED )THEN
1800 DO 100 IN = 1, NIDIM
1802 * Set LDA to 1 more than minimum value if room.
1806 * Skip tests if not enough room.
1810 LAA = ( N*( N + 1 ) )/2
1816 UPLO = ICH( IC: IC )
1823 * Generate the vector X.
1826 CALL CMAKE( 'GE', ' ', ' ', 1, N, X, 1, XX, ABS( INCX ),
1827 $ 0, N - 1, RESET, TRANSL )
1830 XX( 1 + ABS( INCX )*( N/2 - 1 ) ) = ZERO
1834 RALPHA = REAL( ALF( IA ) )
1835 ALPHA = CMPLX( RALPHA, RZERO )
1836 NULL = N.LE.0.OR.RALPHA.EQ.RZERO
1838 * Generate the matrix A.
1841 CALL CMAKE( SNAME( 2: 3 ), UPLO, ' ', N, N, A, NMAX,
1842 $ AA, LDA, N - 1, N - 1, RESET, TRANSL )
1846 * Save every datum before calling the subroutine.
1860 * Call the subroutine.
1864 $ WRITE( NTRA, FMT = 9993 )NC, SNAME, UPLO, N,
1868 CALL CHER( UPLO, N, RALPHA, XX, INCX, AA, LDA )
1869 ELSE IF( PACKED )THEN
1871 $ WRITE( NTRA, FMT = 9994 )NC, SNAME, UPLO, N,
1875 CALL CHPR( UPLO, N, RALPHA, XX, INCX, AA )
1878 * Check if error-exit was taken incorrectly.
1881 WRITE( NOUT, FMT = 9992 )
1886 * See what data changed inside subroutines.
1888 ISAME( 1 ) = UPLO.EQ.UPLOS
1889 ISAME( 2 ) = NS.EQ.N
1890 ISAME( 3 ) = RALS.EQ.RALPHA
1891 ISAME( 4 ) = LCE( XS, XX, LX )
1892 ISAME( 5 ) = INCXS.EQ.INCX
1894 ISAME( 6 ) = LCE( AS, AA, LAA )
1896 ISAME( 6 ) = LCERES( SNAME( 2: 3 ), UPLO, N, N, AS,
1899 IF( .NOT.PACKED )THEN
1900 ISAME( 7 ) = LDAS.EQ.LDA
1903 * If data was incorrectly changed, report and return.
1907 SAME = SAME.AND.ISAME( I )
1908 IF( .NOT.ISAME( I ) )
1909 $ WRITE( NOUT, FMT = 9998 )I
1918 * Check the result column by column.
1926 Z( I ) = X( N - I + 1 )
1931 W( 1 ) = CONJG( Z( J ) )
1939 CALL CMVCH( 'N', LJ, 1, ALPHA, Z( JJ ), LJ, W,
1940 $ 1, ONE, A( JJ, J ), 1, YT, G,
1941 $ AA( JA ), EPS, ERR, FATAL, NOUT,
1952 ERRMAX = MAX( ERRMAX, ERR )
1953 * If got really bad answer, report and return.
1958 * Avoid repeating tests if N.le.0.
1973 IF( ERRMAX.LT.THRESH )THEN
1974 WRITE( NOUT, FMT = 9999 )SNAME, NC
1976 WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX
1981 WRITE( NOUT, FMT = 9995 )J
1984 WRITE( NOUT, FMT = 9996 )SNAME
1986 WRITE( NOUT, FMT = 9993 )NC, SNAME, UPLO, N, RALPHA, INCX, LDA
1987 ELSE IF( PACKED )THEN
1988 WRITE( NOUT, FMT = 9994 )NC, SNAME, UPLO, N, RALPHA, INCX
1994 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL',
1996 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH',
1997 $ 'ANGED INCORRECTLY *******' )
1998 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C',
1999 $ 'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2,
2000 $ ' - SUSPECT *******' )
2001 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' )
2002 9995 FORMAT( ' THESE ARE THE RESULTS FOR COLUMN ', I3 )
2003 9994 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', I3, ',', F4.1, ', X,',
2005 9993 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', I3, ',', F4.1, ', X,',
2006 $ I2, ', A,', I3, ') .' )
2007 9992 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *',
2013 SUBROUTINE CCHK6( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI,
2014 $ FATAL, NIDIM, IDIM, NALF, ALF, NINC, INC, NMAX,
2015 $ INCMAX, A, AA, AS, X, XX, XS, Y, YY, YS, YT, G,
2018 * Tests CHER2 and CHPR2.
2020 * Auxiliary routine for test program for Level 2 Blas.
2022 * -- Written on 10-August-1987.
2023 * Richard Hanson, Sandia National Labs.
2024 * Jeremy Du Croz, NAG Central Office.
2027 COMPLEX ZERO, HALF, ONE
2028 PARAMETER ( ZERO = ( 0.0, 0.0 ), HALF = ( 0.5, 0.0 ),
2029 $ ONE = ( 1.0, 0.0 ) )
2031 PARAMETER ( RZERO = 0.0 )
2032 * .. Scalar Arguments ..
2034 INTEGER INCMAX, NALF, NIDIM, NINC, NMAX, NOUT, NTRA
2035 LOGICAL FATAL, REWI, TRACE
2037 * .. Array Arguments ..
2038 COMPLEX A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ),
2039 $ AS( NMAX*NMAX ), X( NMAX ), XS( NMAX*INCMAX ),
2040 $ XX( NMAX*INCMAX ), Y( NMAX ),
2041 $ YS( NMAX*INCMAX ), YT( NMAX ),
2042 $ YY( NMAX*INCMAX ), Z( NMAX, 2 )
2044 INTEGER IDIM( NIDIM ), INC( NINC )
2045 * .. Local Scalars ..
2046 COMPLEX ALPHA, ALS, TRANSL
2048 INTEGER I, IA, IC, IN, INCX, INCXS, INCY, INCYS, IX,
2049 $ IY, J, JA, JJ, LAA, LDA, LDAS, LJ, LX, LY, N,
2051 LOGICAL FULL, NULL, PACKED, RESET, SAME, UPPER
2052 CHARACTER*1 UPLO, UPLOS
2054 * .. Local Arrays ..
2057 * .. External Functions ..
2059 EXTERNAL LCE, LCERES
2060 * .. External Subroutines ..
2061 EXTERNAL CHER2, CHPR2, CMAKE, CMVCH
2062 * .. Intrinsic Functions ..
2063 INTRINSIC ABS, CONJG, MAX
2064 * .. Scalars in Common ..
2065 INTEGER INFOT, NOUTC
2067 * .. Common blocks ..
2068 COMMON /INFOC/INFOT, NOUTC, OK, LERR
2069 * .. Data statements ..
2071 * .. Executable Statements ..
2072 FULL = SNAME( 3: 3 ).EQ.'E'
2073 PACKED = SNAME( 3: 3 ).EQ.'P'
2074 * Define the number of arguments.
2077 ELSE IF( PACKED )THEN
2085 DO 140 IN = 1, NIDIM
2087 * Set LDA to 1 more than minimum value if room.
2091 * Skip tests if not enough room.
2095 LAA = ( N*( N + 1 ) )/2
2101 UPLO = ICH( IC: IC )
2108 * Generate the vector X.
2111 CALL CMAKE( 'GE', ' ', ' ', 1, N, X, 1, XX, ABS( INCX ),
2112 $ 0, N - 1, RESET, TRANSL )
2115 XX( 1 + ABS( INCX )*( N/2 - 1 ) ) = ZERO
2122 * Generate the vector Y.
2125 CALL CMAKE( 'GE', ' ', ' ', 1, N, Y, 1, YY,
2126 $ ABS( INCY ), 0, N - 1, RESET, TRANSL )
2129 YY( 1 + ABS( INCY )*( N/2 - 1 ) ) = ZERO
2134 NULL = N.LE.0.OR.ALPHA.EQ.ZERO
2136 * Generate the matrix A.
2139 CALL CMAKE( SNAME( 2: 3 ), UPLO, ' ', N, N, A,
2140 $ NMAX, AA, LDA, N - 1, N - 1, RESET,
2145 * Save every datum before calling the subroutine.
2163 * Call the subroutine.
2167 $ WRITE( NTRA, FMT = 9993 )NC, SNAME, UPLO, N,
2168 $ ALPHA, INCX, INCY, LDA
2171 CALL CHER2( UPLO, N, ALPHA, XX, INCX, YY, INCY,
2173 ELSE IF( PACKED )THEN
2175 $ WRITE( NTRA, FMT = 9994 )NC, SNAME, UPLO, N,
2179 CALL CHPR2( UPLO, N, ALPHA, XX, INCX, YY, INCY,
2183 * Check if error-exit was taken incorrectly.
2186 WRITE( NOUT, FMT = 9992 )
2191 * See what data changed inside subroutines.
2193 ISAME( 1 ) = UPLO.EQ.UPLOS
2194 ISAME( 2 ) = NS.EQ.N
2195 ISAME( 3 ) = ALS.EQ.ALPHA
2196 ISAME( 4 ) = LCE( XS, XX, LX )
2197 ISAME( 5 ) = INCXS.EQ.INCX
2198 ISAME( 6 ) = LCE( YS, YY, LY )
2199 ISAME( 7 ) = INCYS.EQ.INCY
2201 ISAME( 8 ) = LCE( AS, AA, LAA )
2203 ISAME( 8 ) = LCERES( SNAME( 2: 3 ), UPLO, N, N,
2206 IF( .NOT.PACKED )THEN
2207 ISAME( 9 ) = LDAS.EQ.LDA
2210 * If data was incorrectly changed, report and return.
2214 SAME = SAME.AND.ISAME( I )
2215 IF( .NOT.ISAME( I ) )
2216 $ WRITE( NOUT, FMT = 9998 )I
2225 * Check the result column by column.
2233 Z( I, 1 ) = X( N - I + 1 )
2242 Z( I, 2 ) = Y( N - I + 1 )
2247 W( 1 ) = ALPHA*CONJG( Z( J, 2 ) )
2248 W( 2 ) = CONJG( ALPHA )*CONJG( Z( J, 1 ) )
2256 CALL CMVCH( 'N', LJ, 2, ONE, Z( JJ, 1 ),
2257 $ NMAX, W, 1, ONE, A( JJ, J ), 1,
2258 $ YT, G, AA( JA ), EPS, ERR, FATAL,
2269 ERRMAX = MAX( ERRMAX, ERR )
2270 * If got really bad answer, report and return.
2275 * Avoid repeating tests with N.le.0.
2292 IF( ERRMAX.LT.THRESH )THEN
2293 WRITE( NOUT, FMT = 9999 )SNAME, NC
2295 WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX
2300 WRITE( NOUT, FMT = 9995 )J
2303 WRITE( NOUT, FMT = 9996 )SNAME
2305 WRITE( NOUT, FMT = 9993 )NC, SNAME, UPLO, N, ALPHA, INCX,
2307 ELSE IF( PACKED )THEN
2308 WRITE( NOUT, FMT = 9994 )NC, SNAME, UPLO, N, ALPHA, INCX, INCY
2314 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL',
2316 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH',
2317 $ 'ANGED INCORRECTLY *******' )
2318 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C',
2319 $ 'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2,
2320 $ ' - SUSPECT *******' )
2321 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' )
2322 9995 FORMAT( ' THESE ARE THE RESULTS FOR COLUMN ', I3 )
2323 9994 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', I3, ',(', F4.1, ',',
2324 $ F4.1, '), X,', I2, ', Y,', I2, ', AP) ',
2326 9993 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',', I3, ',(', F4.1, ',',
2327 $ F4.1, '), X,', I2, ', Y,', I2, ', A,', I3, ') ',
2329 9992 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *',
2335 SUBROUTINE CCHKE( ISNUM, SRNAMT, NOUT )
2337 * Tests the error exits from the Level 2 Blas.
2338 * Requires a special version of the error-handling routine XERBLA.
2339 * ALPHA, RALPHA, BETA, A, X and Y should not need to be defined.
2341 * Auxiliary routine for test program for Level 2 Blas.
2343 * -- Written on 10-August-1987.
2344 * Richard Hanson, Sandia National Labs.
2345 * Jeremy Du Croz, NAG Central Office.
2347 * .. Scalar Arguments ..
2350 * .. Scalars in Common ..
2351 INTEGER INFOT, NOUTC
2353 * .. Local Scalars ..
2356 * .. Local Arrays ..
2357 COMPLEX A( 1, 1 ), X( 1 ), Y( 1 )
2358 * .. External Subroutines ..
2359 EXTERNAL CGBMV, CGEMV, CGERC, CGERU, CHBMV, CHEMV, CHER,
2360 $ CHER2, CHKXER, CHPMV, CHPR, CHPR2, CTBMV,
2361 $ CTBSV, CTPMV, CTPSV, CTRMV, CTRSV
2362 * .. Common blocks ..
2363 COMMON /INFOC/INFOT, NOUTC, OK, LERR
2364 * .. Executable Statements ..
2365 * OK is set to .FALSE. by the special version of XERBLA or by CHKXER
2366 * if anything is wrong.
2368 * LERR is set to .TRUE. by the special version of XERBLA each time
2369 * it is called, and is then tested and re-set by CHKXER.
2371 GO TO ( 10, 20, 30, 40, 50, 60, 70, 80,
2372 $ 90, 100, 110, 120, 130, 140, 150, 160,
2375 CALL CGEMV( '/', 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2376 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2378 CALL CGEMV( 'N', -1, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2379 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2381 CALL CGEMV( 'N', 0, -1, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2382 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2384 CALL CGEMV( 'N', 2, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2385 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2387 CALL CGEMV( 'N', 0, 0, ALPHA, A, 1, X, 0, BETA, Y, 1 )
2388 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2390 CALL CGEMV( 'N', 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 0 )
2391 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2394 CALL CGBMV( '/', 0, 0, 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2395 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2397 CALL CGBMV( 'N', -1, 0, 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2398 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2400 CALL CGBMV( 'N', 0, -1, 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2401 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2403 CALL CGBMV( 'N', 0, 0, -1, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2404 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2406 CALL CGBMV( 'N', 2, 0, 0, -1, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2407 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2409 CALL CGBMV( 'N', 0, 0, 1, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2410 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2412 CALL CGBMV( 'N', 0, 0, 0, 0, ALPHA, A, 1, X, 0, BETA, Y, 1 )
2413 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2415 CALL CGBMV( 'N', 0, 0, 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 0 )
2416 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2419 CALL CHEMV( '/', 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2420 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2422 CALL CHEMV( 'U', -1, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2423 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2425 CALL CHEMV( 'U', 2, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2426 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2428 CALL CHEMV( 'U', 0, ALPHA, A, 1, X, 0, BETA, Y, 1 )
2429 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2431 CALL CHEMV( 'U', 0, ALPHA, A, 1, X, 1, BETA, Y, 0 )
2432 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2435 CALL CHBMV( '/', 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2436 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2438 CALL CHBMV( 'U', -1, 0, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2439 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2441 CALL CHBMV( 'U', 0, -1, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2442 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2444 CALL CHBMV( 'U', 0, 1, ALPHA, A, 1, X, 1, BETA, Y, 1 )
2445 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2447 CALL CHBMV( 'U', 0, 0, ALPHA, A, 1, X, 0, BETA, Y, 1 )
2448 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2450 CALL CHBMV( 'U', 0, 0, ALPHA, A, 1, X, 1, BETA, Y, 0 )
2451 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2454 CALL CHPMV( '/', 0, ALPHA, A, X, 1, BETA, Y, 1 )
2455 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2457 CALL CHPMV( 'U', -1, ALPHA, A, X, 1, BETA, Y, 1 )
2458 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2460 CALL CHPMV( 'U', 0, ALPHA, A, X, 0, BETA, Y, 1 )
2461 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2463 CALL CHPMV( 'U', 0, ALPHA, A, X, 1, BETA, Y, 0 )
2464 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2467 CALL CTRMV( '/', 'N', 'N', 0, A, 1, X, 1 )
2468 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2470 CALL CTRMV( 'U', '/', 'N', 0, A, 1, X, 1 )
2471 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2473 CALL CTRMV( 'U', 'N', '/', 0, A, 1, X, 1 )
2474 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2476 CALL CTRMV( 'U', 'N', 'N', -1, A, 1, X, 1 )
2477 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2479 CALL CTRMV( 'U', 'N', 'N', 2, A, 1, X, 1 )
2480 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2482 CALL CTRMV( 'U', 'N', 'N', 0, A, 1, X, 0 )
2483 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2486 CALL CTBMV( '/', 'N', 'N', 0, 0, A, 1, X, 1 )
2487 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2489 CALL CTBMV( 'U', '/', 'N', 0, 0, A, 1, X, 1 )
2490 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2492 CALL CTBMV( 'U', 'N', '/', 0, 0, A, 1, X, 1 )
2493 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2495 CALL CTBMV( 'U', 'N', 'N', -1, 0, A, 1, X, 1 )
2496 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2498 CALL CTBMV( 'U', 'N', 'N', 0, -1, A, 1, X, 1 )
2499 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2501 CALL CTBMV( 'U', 'N', 'N', 0, 1, A, 1, X, 1 )
2502 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2504 CALL CTBMV( 'U', 'N', 'N', 0, 0, A, 1, X, 0 )
2505 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2508 CALL CTPMV( '/', 'N', 'N', 0, A, X, 1 )
2509 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2511 CALL CTPMV( 'U', '/', 'N', 0, A, X, 1 )
2512 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2514 CALL CTPMV( 'U', 'N', '/', 0, A, X, 1 )
2515 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2517 CALL CTPMV( 'U', 'N', 'N', -1, A, X, 1 )
2518 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2520 CALL CTPMV( 'U', 'N', 'N', 0, A, X, 0 )
2521 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2524 CALL CTRSV( '/', 'N', 'N', 0, A, 1, X, 1 )
2525 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2527 CALL CTRSV( 'U', '/', 'N', 0, A, 1, X, 1 )
2528 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2530 CALL CTRSV( 'U', 'N', '/', 0, A, 1, X, 1 )
2531 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2533 CALL CTRSV( 'U', 'N', 'N', -1, A, 1, X, 1 )
2534 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2536 CALL CTRSV( 'U', 'N', 'N', 2, A, 1, X, 1 )
2537 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2539 CALL CTRSV( 'U', 'N', 'N', 0, A, 1, X, 0 )
2540 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2543 CALL CTBSV( '/', 'N', 'N', 0, 0, A, 1, X, 1 )
2544 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2546 CALL CTBSV( 'U', '/', 'N', 0, 0, A, 1, X, 1 )
2547 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2549 CALL CTBSV( 'U', 'N', '/', 0, 0, A, 1, X, 1 )
2550 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2552 CALL CTBSV( 'U', 'N', 'N', -1, 0, A, 1, X, 1 )
2553 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2555 CALL CTBSV( 'U', 'N', 'N', 0, -1, A, 1, X, 1 )
2556 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2558 CALL CTBSV( 'U', 'N', 'N', 0, 1, A, 1, X, 1 )
2559 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2561 CALL CTBSV( 'U', 'N', 'N', 0, 0, A, 1, X, 0 )
2562 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2565 CALL CTPSV( '/', 'N', 'N', 0, A, X, 1 )
2566 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2568 CALL CTPSV( 'U', '/', 'N', 0, A, X, 1 )
2569 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2571 CALL CTPSV( 'U', 'N', '/', 0, A, X, 1 )
2572 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2574 CALL CTPSV( 'U', 'N', 'N', -1, A, X, 1 )
2575 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2577 CALL CTPSV( 'U', 'N', 'N', 0, A, X, 0 )
2578 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2581 CALL CGERC( -1, 0, ALPHA, X, 1, Y, 1, A, 1 )
2582 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2584 CALL CGERC( 0, -1, ALPHA, X, 1, Y, 1, A, 1 )
2585 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2587 CALL CGERC( 0, 0, ALPHA, X, 0, Y, 1, A, 1 )
2588 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2590 CALL CGERC( 0, 0, ALPHA, X, 1, Y, 0, A, 1 )
2591 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2593 CALL CGERC( 2, 0, ALPHA, X, 1, Y, 1, A, 1 )
2594 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2597 CALL CGERU( -1, 0, ALPHA, X, 1, Y, 1, A, 1 )
2598 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2600 CALL CGERU( 0, -1, ALPHA, X, 1, Y, 1, A, 1 )
2601 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2603 CALL CGERU( 0, 0, ALPHA, X, 0, Y, 1, A, 1 )
2604 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2606 CALL CGERU( 0, 0, ALPHA, X, 1, Y, 0, A, 1 )
2607 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2609 CALL CGERU( 2, 0, ALPHA, X, 1, Y, 1, A, 1 )
2610 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2613 CALL CHER( '/', 0, RALPHA, X, 1, A, 1 )
2614 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2616 CALL CHER( 'U', -1, RALPHA, X, 1, A, 1 )
2617 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2619 CALL CHER( 'U', 0, RALPHA, X, 0, A, 1 )
2620 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2622 CALL CHER( 'U', 2, RALPHA, X, 1, A, 1 )
2623 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2626 CALL CHPR( '/', 0, RALPHA, X, 1, A )
2627 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2629 CALL CHPR( 'U', -1, RALPHA, X, 1, A )
2630 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2632 CALL CHPR( 'U', 0, RALPHA, X, 0, A )
2633 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2636 CALL CHER2( '/', 0, ALPHA, X, 1, Y, 1, A, 1 )
2637 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2639 CALL CHER2( 'U', -1, ALPHA, X, 1, Y, 1, A, 1 )
2640 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2642 CALL CHER2( 'U', 0, ALPHA, X, 0, Y, 1, A, 1 )
2643 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2645 CALL CHER2( 'U', 0, ALPHA, X, 1, Y, 0, A, 1 )
2646 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2648 CALL CHER2( 'U', 2, ALPHA, X, 1, Y, 1, A, 1 )
2649 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2652 CALL CHPR2( '/', 0, ALPHA, X, 1, Y, 1, A )
2653 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2655 CALL CHPR2( 'U', -1, ALPHA, X, 1, Y, 1, A )
2656 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2658 CALL CHPR2( 'U', 0, ALPHA, X, 0, Y, 1, A )
2659 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2661 CALL CHPR2( 'U', 0, ALPHA, X, 1, Y, 0, A )
2662 CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
2665 WRITE( NOUT, FMT = 9999 )SRNAMT
2667 WRITE( NOUT, FMT = 9998 )SRNAMT
2671 9999 FORMAT( ' ', A6, ' PASSED THE TESTS OF ERROR-EXITS' )
2672 9998 FORMAT( ' ******* ', A6, ' FAILED THE TESTS OF ERROR-EXITS *****',
2678 SUBROUTINE CMAKE( TYPE, UPLO, DIAG, M, N, A, NMAX, AA, LDA, KL,
2679 $ KU, RESET, TRANSL )
2681 * Generates values for an M by N matrix A within the bandwidth
2682 * defined by KL and KU.
2683 * Stores the values in the array AA in the data structure required
2684 * by the routine, with unwanted elements set to rogue value.
2686 * TYPE is 'GE', 'GB', 'HE', 'HB', 'HP', 'TR', 'TB' OR 'TP'.
2688 * Auxiliary routine for test program for Level 2 Blas.
2690 * -- Written on 10-August-1987.
2691 * Richard Hanson, Sandia National Labs.
2692 * Jeremy Du Croz, NAG Central Office.
2696 PARAMETER ( ZERO = ( 0.0, 0.0 ), ONE = ( 1.0, 0.0 ) )
2698 PARAMETER ( ROGUE = ( -1.0E10, 1.0E10 ) )
2700 PARAMETER ( RZERO = 0.0 )
2702 PARAMETER ( RROGUE = -1.0E10 )
2703 * .. Scalar Arguments ..
2705 INTEGER KL, KU, LDA, M, N, NMAX
2707 CHARACTER*1 DIAG, UPLO
2709 * .. Array Arguments ..
2710 COMPLEX A( NMAX, * ), AA( * )
2711 * .. Local Scalars ..
2712 INTEGER I, I1, I2, I3, IBEG, IEND, IOFF, J, JJ, KK
2713 LOGICAL GEN, LOWER, SYM, TRI, UNIT, UPPER
2714 * .. External Functions ..
2717 * .. Intrinsic Functions ..
2718 INTRINSIC CMPLX, CONJG, MAX, MIN, REAL
2719 * .. Executable Statements ..
2720 GEN = TYPE( 1: 1 ).EQ.'G'
2721 SYM = TYPE( 1: 1 ).EQ.'H'
2722 TRI = TYPE( 1: 1 ).EQ.'T'
2723 UPPER = ( SYM.OR.TRI ).AND.UPLO.EQ.'U'
2724 LOWER = ( SYM.OR.TRI ).AND.UPLO.EQ.'L'
2725 UNIT = TRI.AND.DIAG.EQ.'U'
2727 * Generate data in array A.
2731 IF( GEN.OR.( UPPER.AND.I.LE.J ).OR.( LOWER.AND.I.GE.J ) )
2733 IF( ( I.LE.J.AND.J - I.LE.KU ).OR.
2734 $ ( I.GE.J.AND.I - J.LE.KL ) )THEN
2735 A( I, J ) = CBEG( RESET ) + TRANSL
2741 A( J, I ) = CONJG( A( I, J ) )
2749 $ A( J, J ) = CMPLX( REAL( A( J, J ) ), RZERO )
2751 $ A( J, J ) = A( J, J ) + ONE
2756 * Store elements in array AS in data structure required by routine.
2758 IF( TYPE.EQ.'GE' )THEN
2761 AA( I + ( J - 1 )*LDA ) = A( I, J )
2763 DO 40 I = M + 1, LDA
2764 AA( I + ( J - 1 )*LDA ) = ROGUE
2767 ELSE IF( TYPE.EQ.'GB' )THEN
2769 DO 60 I1 = 1, KU + 1 - J
2770 AA( I1 + ( J - 1 )*LDA ) = ROGUE
2772 DO 70 I2 = I1, MIN( KL + KU + 1, KU + 1 + M - J )
2773 AA( I2 + ( J - 1 )*LDA ) = A( I2 + J - KU - 1, J )
2776 AA( I3 + ( J - 1 )*LDA ) = ROGUE
2779 ELSE IF( TYPE.EQ.'HE'.OR.TYPE.EQ.'TR' )THEN
2796 DO 100 I = 1, IBEG - 1
2797 AA( I + ( J - 1 )*LDA ) = ROGUE
2799 DO 110 I = IBEG, IEND
2800 AA( I + ( J - 1 )*LDA ) = A( I, J )
2802 DO 120 I = IEND + 1, LDA
2803 AA( I + ( J - 1 )*LDA ) = ROGUE
2806 JJ = J + ( J - 1 )*LDA
2807 AA( JJ ) = CMPLX( REAL( AA( JJ ) ), RROGUE )
2810 ELSE IF( TYPE.EQ.'HB'.OR.TYPE.EQ.'TB' )THEN
2814 IBEG = MAX( 1, KL + 2 - J )
2827 IEND = MIN( KL + 1, 1 + M - J )
2829 DO 140 I = 1, IBEG - 1
2830 AA( I + ( J - 1 )*LDA ) = ROGUE
2832 DO 150 I = IBEG, IEND
2833 AA( I + ( J - 1 )*LDA ) = A( I + J - KK, J )
2835 DO 160 I = IEND + 1, LDA
2836 AA( I + ( J - 1 )*LDA ) = ROGUE
2839 JJ = KK + ( J - 1 )*LDA
2840 AA( JJ ) = CMPLX( REAL( AA( JJ ) ), RROGUE )
2843 ELSE IF( TYPE.EQ.'HP'.OR.TYPE.EQ.'TP' )THEN
2853 DO 180 I = IBEG, IEND
2855 AA( IOFF ) = A( I, J )
2858 $ AA( IOFF ) = ROGUE
2860 $ AA( IOFF ) = CMPLX( REAL( AA( IOFF ) ), RROGUE )
2870 SUBROUTINE CMVCH( TRANS, M, N, ALPHA, A, NMAX, X, INCX, BETA, Y,
2871 $ INCY, YT, G, YY, EPS, ERR, FATAL, NOUT, MV )
2873 * Checks the results of the computational tests.
2875 * Auxiliary routine for test program for Level 2 Blas.
2877 * -- Written on 10-August-1987.
2878 * Richard Hanson, Sandia National Labs.
2879 * Jeremy Du Croz, NAG Central Office.
2883 PARAMETER ( ZERO = ( 0.0, 0.0 ) )
2885 PARAMETER ( RZERO = 0.0, RONE = 1.0 )
2886 * .. Scalar Arguments ..
2889 INTEGER INCX, INCY, M, N, NMAX, NOUT
2892 * .. Array Arguments ..
2893 COMPLEX A( NMAX, * ), X( * ), Y( * ), YT( * ), YY( * )
2895 * .. Local Scalars ..
2898 INTEGER I, INCXL, INCYL, IY, J, JX, KX, KY, ML, NL
2900 * .. Intrinsic Functions ..
2901 INTRINSIC ABS, AIMAG, CONJG, MAX, REAL, SQRT
2902 * .. Statement Functions ..
2904 * .. Statement Function definitions ..
2905 ABS1( C ) = ABS( REAL( C ) ) + ABS( AIMAG( C ) )
2906 * .. Executable Statements ..
2908 CTRAN = TRANS.EQ.'C'
2909 IF( TRAN.OR.CTRAN )THEN
2931 * Compute expected result in YT using data in A, X and Y.
2932 * Compute gauges in G.
2941 YT( IY ) = YT( IY ) + A( J, I )*X( JX )
2942 G( IY ) = G( IY ) + ABS1( A( J, I ) )*ABS1( X( JX ) )
2945 ELSE IF( CTRAN )THEN
2947 YT( IY ) = YT( IY ) + CONJG( A( J, I ) )*X( JX )
2948 G( IY ) = G( IY ) + ABS1( A( J, I ) )*ABS1( X( JX ) )
2953 YT( IY ) = YT( IY ) + A( I, J )*X( JX )
2954 G( IY ) = G( IY ) + ABS1( A( I, J ) )*ABS1( X( JX ) )
2958 YT( IY ) = ALPHA*YT( IY ) + BETA*Y( IY )
2959 G( IY ) = ABS1( ALPHA )*G( IY ) + ABS1( BETA )*ABS1( Y( IY ) )
2963 * Compute the error ratio for this result.
2967 ERRI = ABS( YT( I ) - YY( 1 + ( I - 1 )*ABS( INCY ) ) )/EPS
2968 IF( G( I ).NE.RZERO )
2969 $ ERRI = ERRI/G( I )
2970 ERR = MAX( ERR, ERRI )
2971 IF( ERR*SQRT( EPS ).GE.RONE )
2974 * If the loop completes, all results are at least half accurate.
2977 * Report fatal error.
2980 WRITE( NOUT, FMT = 9999 )
2983 WRITE( NOUT, FMT = 9998 )I, YT( I ),
2984 $ YY( 1 + ( I - 1 )*ABS( INCY ) )
2986 WRITE( NOUT, FMT = 9998 )I,
2987 $ YY( 1 + ( I - 1 )*ABS( INCY ) ), YT( I )
2994 9999 FORMAT( ' ******* FATAL ERROR - COMPUTED RESULT IS LESS THAN HAL',
2995 $ 'F ACCURATE *******', /' EXPECTED RE',
2996 $ 'SULT COMPUTED RESULT' )
2997 9998 FORMAT( 1X, I7, 2( ' (', G15.6, ',', G15.6, ')' ) )
3002 LOGICAL FUNCTION LCE( RI, RJ, LR )
3004 * Tests if two arrays are identical.
3006 * Auxiliary routine for test program for Level 2 Blas.
3008 * -- Written on 10-August-1987.
3009 * Richard Hanson, Sandia National Labs.
3010 * Jeremy Du Croz, NAG Central Office.
3012 * .. Scalar Arguments ..
3014 * .. Array Arguments ..
3015 COMPLEX RI( * ), RJ( * )
3016 * .. Local Scalars ..
3018 * .. Executable Statements ..
3020 IF( RI( I ).NE.RJ( I ) )
3032 LOGICAL FUNCTION LCERES( TYPE, UPLO, M, N, AA, AS, LDA )
3034 * Tests if selected elements in two arrays are equal.
3036 * TYPE is 'GE', 'HE' or 'HP'.
3038 * Auxiliary routine for test program for Level 2 Blas.
3040 * -- Written on 10-August-1987.
3041 * Richard Hanson, Sandia National Labs.
3042 * Jeremy Du Croz, NAG Central Office.
3044 * .. Scalar Arguments ..
3048 * .. Array Arguments ..
3049 COMPLEX AA( LDA, * ), AS( LDA, * )
3050 * .. Local Scalars ..
3051 INTEGER I, IBEG, IEND, J
3053 * .. Executable Statements ..
3055 IF( TYPE.EQ.'GE' )THEN
3057 DO 10 I = M + 1, LDA
3058 IF( AA( I, J ).NE.AS( I, J ) )
3062 ELSE IF( TYPE.EQ.'HE' )THEN
3071 DO 30 I = 1, IBEG - 1
3072 IF( AA( I, J ).NE.AS( I, J ) )
3075 DO 40 I = IEND + 1, LDA
3076 IF( AA( I, J ).NE.AS( I, J ) )
3092 COMPLEX FUNCTION CBEG( RESET )
3094 * Generates complex numbers as pairs of random numbers uniformly
3095 * distributed between -0.5 and 0.5.
3097 * Auxiliary routine for test program for Level 2 Blas.
3099 * -- Written on 10-August-1987.
3100 * Richard Hanson, Sandia National Labs.
3101 * Jeremy Du Croz, NAG Central Office.
3103 * .. Scalar Arguments ..
3105 * .. Local Scalars ..
3106 INTEGER I, IC, J, MI, MJ
3107 * .. Save statement ..
3108 SAVE I, IC, J, MI, MJ
3109 * .. Intrinsic Functions ..
3111 * .. Executable Statements ..
3113 * Initialize local variables.
3122 * The sequence of values of I or J is bounded between 1 and 999.
3123 * If initial I or J = 1,2,3,6,7 or 9, the period will be 50.
3124 * If initial I or J = 4 or 8, the period will be 25.
3125 * If initial I or J = 5, the period will be 10.
3126 * IC is used to break up the period by skipping 1 value of I or J
3132 I = I - 1000*( I/1000 )
3133 J = J - 1000*( J/1000 )
3138 CBEG = CMPLX( ( I - 500 )/1001.0, ( J - 500 )/1001.0 )
3144 REAL FUNCTION SDIFF( X, Y )
3146 * Auxiliary routine for test program for Level 2 Blas.
3148 * -- Written on 10-August-1987.
3149 * Richard Hanson, Sandia National Labs.
3151 * .. Scalar Arguments ..
3153 * .. Executable Statements ..
3160 SUBROUTINE CHKXER( SRNAMT, INFOT, NOUT, LERR, OK )
3162 * Tests whether XERBLA has detected an error when it should.
3164 * Auxiliary routine for test program for Level 2 Blas.
3166 * -- Written on 10-August-1987.
3167 * Richard Hanson, Sandia National Labs.
3168 * Jeremy Du Croz, NAG Central Office.
3170 * .. Scalar Arguments ..
3174 * .. Executable Statements ..
3176 WRITE( NOUT, FMT = 9999 )INFOT, SRNAMT
3182 9999 FORMAT( ' ***** ILLEGAL VALUE OF PARAMETER NUMBER ', I2, ' NOT D',
3183 $ 'ETECTED BY ', A6, ' *****' )
3188 SUBROUTINE XERBLA( SRNAME, INFO )
3190 * This is a special version of XERBLA to be used only as part of
3191 * the test program for testing error exits from the Level 2 BLAS
3194 * XERBLA is an error handler for the Level 2 BLAS routines.
3196 * It is called by the Level 2 BLAS routines if an input parameter is
3199 * Auxiliary routine for test program for Level 2 Blas.
3201 * -- Written on 10-August-1987.
3202 * Richard Hanson, Sandia National Labs.
3203 * Jeremy Du Croz, NAG Central Office.
3205 * .. Scalar Arguments ..
3208 * .. Scalars in Common ..
3212 * .. Common blocks ..
3213 COMMON /INFOC/INFOT, NOUT, OK, LERR
3214 COMMON /SRNAMC/SRNAMT
3215 * .. Executable Statements ..
3217 IF( INFO.NE.INFOT )THEN
3218 IF( INFOT.NE.0 )THEN
3219 WRITE( NOUT, FMT = 9999 )INFO, INFOT
3221 WRITE( NOUT, FMT = 9997 )INFO
3225 IF( SRNAME.NE.SRNAMT )THEN
3226 WRITE( NOUT, FMT = 9998 )SRNAME, SRNAMT
3231 9999 FORMAT( ' ******* XERBLA WAS CALLED WITH INFO = ', I6, ' INSTEAD',
3232 $ ' OF ', I2, ' *******' )
3233 9998 FORMAT( ' ******* XERBLA WAS CALLED WITH SRNAME = ', A6, ' INSTE',
3234 $ 'AD OF ', A6, ' *******' )
3235 9997 FORMAT( ' ******* XERBLA WAS CALLED WITH INFO = ', I6,