226 $ HOUS2, LHOUS2, WORK, LWORK, INFO )
236 INTEGER N, LDA, LWORK, LHOUS2, INFO
239 DOUBLE PRECISION D( * ), E( * )
240 COMPLEX*16 A( LDA, * ), TAU( * ),
241 $ hous2( * ), work( * )
247 LOGICAL LQUERY, UPPER, WANTQ
248 INTEGER KD, IB, LWMIN, LHMIN, LWRK, LDAB, WPOS, ABPOS
256 EXTERNAL lsame, ilaenv2stage
263 wantq = lsame( vect,
'V' )
264 upper = lsame( uplo,
'U' )
265 lquery = ( lwork.EQ.-1 ) .OR. ( lhous2.EQ.-1 )
269 kd = ilaenv2stage( 1,
'ZHETRD_2STAGE', vect, n, -1, -1,
271 ib = ilaenv2stage( 2,
'ZHETRD_2STAGE', vect, n, kd, -1,
277 lhmin = ilaenv2stage( 3,
'ZHETRD_2STAGE', vect, n, kd, ib,
279 lwmin = ilaenv2stage( 4,
'ZHETRD_2STAGE', vect, n, kd, ib,
283 IF( .NOT.lsame( vect,
'N' ) )
THEN
285 ELSE IF( .NOT.upper .AND. .NOT.lsame( uplo,
'L' ) )
THEN
287 ELSE IF( n.LT.0 )
THEN
289 ELSE IF( lda.LT.max( 1, n ) )
THEN
291 ELSE IF( lhous2.LT.lhmin .AND. .NOT.lquery )
THEN
293 ELSE IF( lwork.LT.lwmin .AND. .NOT.lquery )
THEN
303 CALL xerbla(
'ZHETRD_2STAGE', -info )
305 ELSE IF( lquery )
THEN
321 wpos = abpos + ldab*n
322 CALL zhetrd_he2hb( uplo, n, kd, a, lda, work( abpos ), ldab,
323 $ tau, work( wpos ), lwrk, info )
325 CALL xerbla(
'ZHETRD_HE2HB', -info )
329 $ work( abpos ), ldab, d, e,
330 $ hous2, lhous2, work( wpos ), lwrk, info )
332 CALL xerbla(
'ZHETRD_HB2ST', -info )
subroutine zhetrd_2stage(vect, uplo, n, a, lda, d, e, tau, hous2, lhous2, work, lwork, info)
ZHETRD_2STAGE
subroutine zhetrd_hb2st(stage1, vect, uplo, n, kd, ab, ldab, d, e, hous, lhous, work, lwork, info)
ZHETRD_HB2ST reduces a complex Hermitian band matrix A to real symmetric tridiagonal form T
subroutine zhetrd_he2hb(uplo, n, kd, a, lda, ab, ldab, tau, work, lwork, info)
ZHETRD_HE2HB