297 SUBROUTINE zhbgvx( JOBZ, RANGE, UPLO, N, KA, KB, AB, LDAB, BB,
298 $ LDBB, Q, LDQ, VL, VU, IL, IU, ABSTOL, M, W, Z,
299 $ LDZ, WORK, RWORK, IWORK, IFAIL, INFO )
306 CHARACTER JOBZ, RANGE, UPLO
307 INTEGER IL, INFO, IU, KA, KB, LDAB, LDBB, LDQ, LDZ, M,
309 DOUBLE PRECISION ABSTOL, VL, VU
312 INTEGER IFAIL( * ), IWORK( * )
313 DOUBLE PRECISION RWORK( * ), W( * )
314 COMPLEX*16 AB( LDAB, * ), BB( LDBB, * ), Q( LDQ, * ),
315 $ work( * ), z( ldz, * )
321 DOUBLE PRECISION ZERO
322 PARAMETER ( ZERO = 0.0d+0 )
323 COMPLEX*16 CZERO, CONE
324 parameter( czero = ( 0.0d+0, 0.0d+0 ),
325 $ cone = ( 1.0d+0, 0.0d+0 ) )
328 LOGICAL ALLEIG, INDEIG, TEST, UPPER, VALEIG, WANTZ
329 CHARACTER ORDER, VECT
330 INTEGER I, IINFO, INDD, INDE, INDEE, INDIBL, INDISP,
331 $ indiwk, indrwk, indwrk, itmp1, j, jj, nsplit
332 DOUBLE PRECISION TMP1
350 wantz = lsame( jobz,
'V' )
351 upper = lsame( uplo,
'U' )
352 alleig = lsame( range,
'A' )
353 valeig = lsame( range,
'V' )
354 indeig = lsame( range,
'I' )
357 IF( .NOT.( wantz .OR. lsame( jobz,
'N' ) ) )
THEN
359 ELSE IF( .NOT.( alleig .OR. valeig .OR. indeig ) )
THEN
361 ELSE IF( .NOT.( upper .OR. lsame( uplo,
'L' ) ) )
THEN
363 ELSE IF( n.LT.0 )
THEN
365 ELSE IF( ka.LT.0 )
THEN
367 ELSE IF( kb.LT.0 .OR. kb.GT.ka )
THEN
369 ELSE IF( ldab.LT.ka+1 )
THEN
371 ELSE IF( ldbb.LT.kb+1 )
THEN
373 ELSE IF( ldq.LT.1 .OR. ( wantz .AND. ldq.LT.n ) )
THEN
377 IF( n.GT.0 .AND. vu.LE.vl )
379 ELSE IF( indeig )
THEN
380 IF( il.LT.1 .OR. il.GT.
max( 1, n ) )
THEN
382 ELSE IF ( iu.LT.
min( n, il ) .OR. iu.GT.n )
THEN
388 IF( ldz.LT.1 .OR. ( wantz .AND. ldz.LT.n ) )
THEN
394 CALL xerbla(
'ZHBGVX', -info )
406 CALL zpbstf( uplo, n, kb, bb, ldbb, info )
414 CALL zhbgst( jobz, uplo, n, ka, kb, ab, ldab, bb, ldbb, q, ldq,
415 $ work, rwork, iinfo )
429 CALL ZHBTRD( VECT, UPLO, N, KA, AB, LDAB, RWORK( INDD ),
430 $ RWORK( INDE ), Q, LDQ, WORK( INDWRK ), IINFO )
438.EQ..AND..EQ.
IF( IL1 IUN ) THEN
442.OR..AND..LE.
IF( ( ALLEIG TEST ) ( ABSTOLZERO ) ) THEN
443 CALL DCOPY( N, RWORK( INDD ), 1, W, 1 )
445 CALL DCOPY( N-1, RWORK( INDE ), 1, RWORK( INDEE ), 1 )
446.NOT.
IF( WANTZ ) THEN
447 CALL DSTERF( N, W, RWORK( INDEE ), INFO )
449 CALL ZLACPY( 'a
', N, N, Q, LDQ, Z, LDZ )
450 CALL ZSTEQR( JOBZ, N, W, RWORK( INDEE ), Z, LDZ,
451 $ RWORK( INDRWK ), INFO )
476 CALL DSTEBZ( RANGE, ORDER, N, VL, VU, IL, IU, ABSTOL,
477 $ RWORK( INDD ), RWORK( INDE ), M, NSPLIT, W,
478 $ IWORK( INDIBL ), IWORK( INDISP ), RWORK( INDRWK ),
479 $ IWORK( INDIWK ), INFO )
482 CALL ZSTEIN( N, RWORK( INDD ), RWORK( INDE ), M, W,
483 $ IWORK( INDIBL ), IWORK( INDISP ), Z, LDZ,
484 $ RWORK( INDRWK ), IWORK( INDIWK ), IFAIL, INFO )
490 CALL ZCOPY( N, Z( 1, J ), 1, WORK( 1 ), 1 )
491 CALL ZGEMV( 'n
', N, N, CONE, Q, LDQ, WORK, 1, CZERO,
506.LT.
IF( W( JJ )TMP1 ) THEN
513 ITMP1 = IWORK( INDIBL+I-1 )
515 IWORK( INDIBL+I-1 ) = IWORK( INDIBL+J-1 )
517 IWORK( INDIBL+J-1 ) = ITMP1
518 CALL ZSWAP( N, Z( 1, I ), 1, Z( 1, J ), 1 )
521 IFAIL( I ) = IFAIL( J )
subroutine dstebz(range, order, n, vl, vu, il, iu, abstol, d, e, m, nsplit, w, iblock, isplit, work, iwork, info)
DSTEBZ
subroutine dsterf(n, d, e, info)
DSTERF
subroutine xerbla(srname, info)
XERBLA
subroutine zlacpy(uplo, m, n, a, lda, b, ldb)
ZLACPY copies all or part of one two-dimensional array to another.
subroutine zhbgst(vect, uplo, n, ka, kb, ab, ldab, bb, ldbb, x, ldx, work, rwork, info)
ZHBGST
subroutine zstein(n, d, e, m, w, iblock, isplit, z, ldz, work, iwork, ifail, info)
ZSTEIN
subroutine zpbstf(uplo, n, kd, ab, ldab, info)
ZPBSTF
subroutine zsteqr(compz, n, d, e, z, ldz, work, info)
ZSTEQR
subroutine zhbtrd(vect, uplo, n, kd, ab, ldab, d, e, q, ldq, work, info)
ZHBTRD
subroutine zhbgvx(jobz, range, uplo, n, ka, kb, ab, ldab, bb, ldbb, q, ldq, vl, vu, il, iu, abstol, m, w, z, ldz, work, rwork, iwork, ifail, info)
ZHBGVX
subroutine zswap(n, zx, incx, zy, incy)
ZSWAP
subroutine zcopy(n, zx, incx, zy, incy)
ZCOPY
subroutine zgemv(trans, m, n, alpha, a, lda, x, incx, beta, y, incy)
ZGEMV
subroutine dcopy(n, dx, incx, dy, incy)
DCOPY