1 SUBROUTINE dchkgb( DOTYPE, NM, MVAL, NN, NVAL, NNB, NBVAL, NNS,
2 $ nsval, thresh, tsterr, a, la, afac, lafac, b,
3 $ x, xact, work, rwork, iwork, nout )
11 INTEGER la, lafac, nm, nn, nnb, nns, nout
12 DOUBLE PRECISION thresh
16 INTEGER iwork( * ), mval( * ), nbval( * ), nsval( * ),
18 DOUBLE PRECISION a( * ), afac( * ), b( * ), rwork( * ),
19 $ work( * ), x( * ), xact( * )
104 DOUBLE PRECISION one, zero
105 parameter( one = 1.0d+0, zero = 0.0d+0 )
106 INTEGER ntypes, ntests
107 parameter( ntypes = 8, ntests = 7 )
109 parameter( nbw = 4, ntran = 3 )
112 LOGICAL trfcon, zerot
113 CHARACTER dist, norm,
trans, type, xtype
115 INTEGER i, i1, i2, ikl, iku, im, imat, in, inb, info,
116 $ ioff, irhs, itran, izero, j, k, kl, koff, ku,
117 $ lda, ldafac, ldb, m, mode, n, nb, nerrs, nfail,
118 $ nimat, nkl, nku, nrhs, nrun
119 DOUBLE PRECISION ainvnm, anorm, anormi, anormo, cndnum, rcond,
120 $ rcondc, rcondi, rcondo
123 CHARACTER transs( ntran )
124 INTEGER iseed( 4 ), iseedy( 4 ), klval( nbw ),
126 DOUBLE PRECISION result( ntests )
129 DOUBLE PRECISION dget06, dlangb, dlange
130 EXTERNAL dget06, dlangb, dlange
147 common / infoc / infot, nunit, ok, lerr
148 common / srnamc / srnamt
151 DATA iseedy / 1988, 1989, 1990, 1991 / ,
152 $ transs /
'N',
'T',
'C' /
158 path( 1: 1 ) =
'Double precision'
164 iseed( i ) = iseedy( i )
170 $ CALL
derrge( path, nout )
186 klval( 2 ) = m + ( m+1 ) / 4
190 klval( 3 ) = ( 3*m-1 ) / 4
191 klval( 4 ) = ( m+1 ) / 4
201 kuval( 2 ) = n + ( n+1 ) / 4
205 kuval( 3 ) = ( 3*n-1 ) / 4
206 kuval( 4 ) = ( n+1 ) / 4
217 IF( m.LE.0 .OR. n.LE.0 )
239 ldafac = 2*kl + ku + 1
240 IF( ( lda*n ).GT.la .OR. ( ldafac*n ).GT.lafac )
THEN
241 IF( nfail.EQ.0 .AND. nerrs.EQ.0 )
242 $ CALL
alahd( nout, path )
243 IF( n*( kl+ku+1 ).GT.la )
THEN
244 WRITE( nout, fmt = 9999 )la, m, n, kl, ku,
248 IF( n*( 2*kl+ku+1 ).GT.lafac )
THEN
249 WRITE( nout, fmt = 9998 )lafac, m, n, kl, ku,
256 DO 120 imat = 1, nimat
260 IF( .NOT.dotype( imat ) )
266 zerot = imat.GE.2 .AND. imat.LE.4
267 IF( zerot .AND. n.LT.imat-1 )
270 IF( .NOT.zerot .OR. .NOT.dotype( 1 ) )
THEN
275 CALL
dlatb4( path, imat, m, n, type, kl, ku,
276 $ anorm, mode, cndnum, dist )
278 koff =
max( 1, ku+2-n )
279 DO 20 i = 1, koff - 1
283 CALL
dlatms( m, n, dist, iseed, type, rwork,
284 $ mode, cndnum, anorm, kl, ku,
'Z',
285 $ a( koff ), lda, work, info )
290 CALL
alaerh( path,
'DLATMS', info, 0,
' ', m,
291 $ n, kl, ku, -1, imat, nfail,
295 ELSE IF( izero.GT.0 )
THEN
300 CALL dcopy( i2-i1+1, b, 1, a( ioff+i1 ), 1 )
310 ELSE IF( imat.EQ.3 )
THEN
313 izero =
min( m, n ) / 2 + 1
315 ioff = ( izero-1 )*lda
320 i1 =
max( 1, ku+2-izero )
321 i2 =
min( kl+ku+1, ku+1+( m-izero ) )
322 CALL dcopy( i2-i1+1, a( ioff+i1 ), 1, b, 1 )
329 DO 40 i =
max( 1, ku+2-j ),
330 $
min( kl+ku+1, ku+1+( m-j ) )
353 IF( m.GT.0 .AND. n.GT.0 )
354 $ CALL dlacpy(
'Full', kl+ku+1, n, a, lda,
355 $ afac( kl+1 ), ldafac )
357 CALL dgbtrf( m, n, kl, ku, afac, ldafac, iwork,
363 $ CALL
alaerh( path,
'DGBTRF', info, izero,
364 $
' ', m, n, kl, ku, nb, imat,
365 $ nfail, nerrs, nout )
372 CALL
dgbt01( m, n, kl, ku, a, lda, afac, ldafac,
373 $ iwork, work, result( 1 ) )
378 IF( result( 1 ).GE.thresh )
THEN
379 IF( nfail.EQ.0 .AND. nerrs.EQ.0 )
380 $ CALL
alahd( nout, path )
381 WRITE( nout, fmt = 9997 )m, n, kl, ku, nb,
382 $ imat, 1, result( 1 )
390 IF( inb.GT.1 .OR. m.NE.n )
393 anormo = dlangb(
'O', n, kl, ku, a, lda, rwork )
394 anormi = dlangb(
'I', n, kl, ku, a, lda, rwork )
402 CALL dlaset(
'Full', n, n, zero, one, work,
405 CALL dgbtrs(
'No transpose', n, kl, ku, n,
406 $ afac, ldafac, iwork, work, ldb,
411 ainvnm = dlange(
'O', n, n, work, ldb,
413 IF( anormo.LE.zero .OR. ainvnm.LE.zero )
THEN
416 rcondo = ( one / anormo ) / ainvnm
422 ainvnm = dlange(
'I', n, n, work, ldb,
424 IF( anormi.LE.zero .OR. ainvnm.LE.zero )
THEN
427 rcondi = ( one / anormi ) / ainvnm
447 DO 70 itran = 1, ntran
448 trans = transs( itran )
449 IF( itran.EQ.1 )
THEN
462 $ n, kl, ku, nrhs, a, lda,
463 $ xact, ldb, b, ldb, iseed,
466 CALL dlacpy(
'Full', n, nrhs, b, ldb, x,
470 CALL dgbtrs(
trans, n, kl, ku, nrhs, afac,
471 $ ldafac, iwork, x, ldb, info )
476 $ CALL
alaerh( path,
'DGBTRS', info, 0,
477 $
trans, n, n, kl, ku, -1,
478 $ imat, nfail, nerrs, nout )
480 CALL dlacpy(
'Full', n, nrhs, b, ldb,
483 $ lda, x, ldb, work, ldb,
490 CALL
dget04( n, nrhs, x, ldb, xact, ldb,
491 $ rcondc, result( 3 ) )
498 CALL dgbrfs(
trans, n, kl, ku, nrhs, a,
499 $ lda, afac, ldafac, iwork, b,
500 $ ldb, x, ldb, rwork,
501 $ rwork( nrhs+1 ), work,
502 $ iwork( n+1 ), info )
507 $ CALL
alaerh( path,
'DGBRFS', info, 0,
508 $
trans, n, n, kl, ku, nrhs,
509 $ imat, nfail, nerrs, nout )
511 CALL
dget04( n, nrhs, x, ldb, xact, ldb,
512 $ rcondc, result( 4 ) )
514 $ lda, b, ldb, x, ldb, xact,
515 $ ldb, rwork, rwork( nrhs+1 ),
518 IF( result( k ).GE.thresh )
THEN
519 IF( nfail.EQ.0 .AND. nerrs.EQ.0 )
520 $ CALL
alahd( nout, path )
521 WRITE( nout, fmt = 9996 )
trans, n,
522 $ kl, ku, nrhs, imat, k,
536 IF( itran.EQ.1 )
THEN
546 CALL dgbcon( norm, n, kl, ku, afac, ldafac,
547 $ iwork, anorm, rcond, work,
548 $ iwork( n+1 ), info )
553 $ CALL
alaerh( path,
'DGBCON', info, 0,
554 $ norm, n, n, kl, ku, -1, imat,
555 $ nfail, nerrs, nout )
557 result( 7 ) =
dget06( rcond, rcondc )
562 IF( result( 7 ).GE.thresh )
THEN
563 IF( nfail.EQ.0 .AND. nerrs.EQ.0 )
564 $ CALL
alahd( nout, path )
565 WRITE( nout, fmt = 9995 )norm, n, kl, ku,
566 $ imat, 7, result( 7 )
581 CALL
alasum( path, nout, nfail, nrun, nerrs )
583 9999
format(
' *** In DCHKGB, LA=', i5,
' is too small for M=', i5,
584 $
', N=', i5,
', KL=', i4,
', KU=', i4,
585 $ /
' ==> Increase LA to at least ', i5 )
586 9998
format(
' *** In DCHKGB, LAFAC=', i5,
' is too small for M=', i5,
587 $
', N=', i5,
', KL=', i4,
', KU=', i4,
588 $ /
' ==> Increase LAFAC to at least ', i5 )
589 9997
format(
' M =', i5,
', N =', i5,
', KL=', i5,
', KU=', i5,
590 $
', NB =', i4,
', type ', i1,
', test(', i1,
')=', g12.5 )
591 9996
format(
' TRANS=''', a1,
''', N=', i5,
', KL=', i5,
', KU=', i5,
592 $
', NRHS=', i3,
', type ', i1,
', test(', i1,
')=', g12.5 )
593 9995
format(
' NORM =''', a1,
''', N=', i5,
', KL=', i5,
', KU=', i5,
594 $
',', 10x,
' type ', i1,
', test(', i1,
')=', g12.5 )