326 SUBROUTINE zggesx( JOBVSL, JOBVSR, SORT, SELCTG, SENSE, N, A, LDA,
327 $ B, LDB, SDIM, ALPHA, BETA, VSL, LDVSL, VSR,
328 $ LDVSR, RCONDE, RCONDV, WORK, LWORK, RWORK,
329 $ IWORK, LIWORK, BWORK, INFO )
336 CHARACTER JOBVSL, JOBVSR, SENSE, SORT
337 INTEGER INFO, LDA, LDB, LDVSL, LDVSR, LIWORK, LWORK, N,
343 DOUBLE PRECISION RCONDE( 2 ), RCONDV( 2 ), RWORK( * )
344 COMPLEX*16 A( LDA, * ), ALPHA( * ), B( LDB, * ),
345 $ beta( * ), vsl( ldvsl, * ), vsr( ldvsr, * ),
356 DOUBLE PRECISION ZERO, ONE
358 COMPLEX*16 CZERO, CONE
359 parameter( czero = ( 0.0d+0, 0.0d+0
360 $ cone = ( 1.0d+0, 0.0d+0 ) )
363 LOGICAL CURSL, ILASCL, ILBSCL, ILVSL, ILVSR, ,
364 $ LQUERY, WANTSB, WANTSE, WANTSN, WANTST, WANTSV
365 INTEGER I, ICOLS, IERR, IHI, IJOB, IJOBVL, IJOBVR,
366 $ ileft, ilo, iright, irows, irwrk, itau, iwrk,
367 $ liwmin, lwrk, maxwrk
372 DOUBLE PRECISION DIF( 2 )
382DOUBLE PRECISION DLAMCH,
383 EXTERNAL lsame, ilaenv, dlamch,
zlange
392 IF( lsame( jobvsl
'N' ) )
THEN
395 ELSE IF( lsame( jobvsl,
'V' ) )
THEN
403 IF( lsame( jobvsr,
'N' ) )
THEN
406 ELSE IF( lsame( jobvsr,
'V' ) )
THEN
414 wantst = lsame( sort,
'S' )
415 wantsn = lsame( sense,
'N' )
416 wantse = lsame( sense,
'E' )
417 wantsv = lsame( sense,
'V' )
419 lquery = ( lwork.EQ.-1 .OR. liwork.EQ.-1 )
422 ELSE IF( wantse )
THEN
424 ELSE IF( wantsv )
THEN
426 ELSE IF( wantsb )
THEN
433 IF( ijobvl.LE.0 )
THEN
435 ELSE IF( ijobvr.LE.0 )
THEN
437 ELSE IF( ( .NOT.wantst ) .AND. ( .NOT.lsame( sort,
'N' ) ) )
THEN
439 ELSE IF( .NOT.( wantsn .OR. wantse .OR. wantsv .OR. wantsb ) .OR.
440 $ ( .NOT.wantst .AND. .NOT.wantsn ) )
THEN
442 ELSE IF( n.LT.0 )
THEN
444 ELSE IF( lda.LT.
max( 1, n ) )
THEN
446 ELSE IF( ldb.LT.
max( 1, n ) )
THEN
448 ELSE IF( ldvsl.LT.1 .OR. ( ilvsl .AND. ldvsl.LT.n ) )
THEN
450 ELSE IF( ldvsr.LT.1 .OR. ( ilvsr .AND. ldvsr.LT.n ) )
THEN
464 maxwrk = n*(1 + ilaenv( 1,
'ZGEQRF',
' ', n, 1, n, 0 ) )
465 maxwrk =
max( maxwrk, n*( 1 +
466 $
'ZUNMQR'' ', n, 1, n, -1 ) ) )
468 maxwrk =
max( maxwrk, n*( 1 +
469 $ ilaenv( 1,
'ZUNGQR',
' ', n, 1, n, -1 ) ) )
473 $ lwrk =
max( lwrk, n*n/2 )
480 IF( wantsn .OR. n.EQ.0 )
THEN
487 IF( lwork.LT.minwrk .AND. .NOT.lquery )
THEN
489 ELSE IF( liwork.LT.liwmin .AND. .NOT.lquery)
THEN
495 CALL xerbla(
'ZGGESX', -info )
497 ELSE IF (lquery)
THEN
511 smlnum = dlamch(
'S' )
512 bignum = one / smlnum
513 CALL dlabad( smlnum, bignum )
514 smlnum = sqrt( smlnum ) / eps
515 bignum = one / smlnum
519 anrm =
zlange(
'M', n, n, a, lda, rwork )
521 IF( anrm.GT.zero .AND. anrm.LT.smlnum )
THEN
524 ELSE IF( anrm.GT.bignum )
THEN
529 $
CALL zlascl(
'G', 0, 0, anrm, anrmto, n, n, a, lda, ierr )
533 bnrm =
zlange(
'M', n, n, b, ldb, rwork )
535 IF( bnrm.GT.zero .AND. bnrm.LT.smlnum )
THEN
538 ELSE IF( bnrm.GT.bignum )
THEN
543 $
CALL zlascl(
'G', 0, 0, bnrm, bnrmto, n, n, b, ldb, ierr )
551 CALL zggbal(
'P', n, a, lda, b, ldb, ilo, ihi, rwork( ileft ),
552 $ rwork( iright ), rwork( irwrk ), ierr )
557 irows = ihi + 1 - ilo
561 CALL zgeqrf( irows, icols, b( ilo, ilo ), ldb, work( itau ),
562 $ work( iwrk ), lwork+1-iwrk, ierr )
567 CALL zunmqr(
'L', 'c
', IROWS, ICOLS, IROWS, B( ILO, ILO ), LDB,
568 $ WORK( ITAU ), A( ILO, ILO ), LDA, WORK( IWRK ),
569 $ LWORK+1-IWRK, IERR )
575 CALL ZLASET( 'full
', N, N, CZERO, CONE, VSL, LDVSL )
576.GT.
IF( IROWS1 ) THEN
577 CALL ZLACPY( 'l
', IROWS-1, IROWS-1, B( ILO+1, ILO ), LDB,
578 $ VSL( ILO+1, ILO ), LDVSL )
580 CALL ZUNGQR( IROWS, IROWS, IROWS, VSL( ILO, ILO ), LDVSL,
581 $ WORK( ITAU ), WORK( IWRK ), LWORK+1-IWRK, IERR )
587 $ CALL ZLASET( 'full
', N, N, CZERO, CONE, VSR, LDVSR )
592 CALL ZGGHRD( JOBVSL, JOBVSR, N, ILO, IHI, A, LDA, B, LDB, VSL,
593 $ LDVSL, VSR, LDVSR, IERR )
602 CALL ZHGEQZ( 's
', JOBVSL, JOBVSR, N, ILO, IHI, A, LDA, B, LDB,
603 $ ALPHA, BETA, VSL, LDVSL, VSR, LDVSR, WORK( IWRK ),
604 $ LWORK+1-IWRK, RWORK( IRWRK ), IERR )
606.GT..AND..LE.
IF( IERR0 IERRN ) THEN
608.GT..AND..LE.
ELSE IF( IERRN IERR2*N ) THEN
624 $ CALL ZLASCL( 'g
', 0, 0, ANRMTO, ANRM, N, 1, ALPHA, N, IERR )
626 $ CALL ZLASCL( 'g
', 0, 0, BNRMTO, BNRM, N, 1, BETA, N, IERR )
631 BWORK( I ) = SELCTG( ALPHA( I ), BETA( I ) )
639 CALL ZTGSEN( IJOB, ILVSL, ILVSR, BWORK, N, A, LDA, B, LDB,
640 $ ALPHA, BETA, VSL, LDVSL, VSR, LDVSR, SDIM, PL, PR,
641 $ DIF, WORK( IWRK ), LWORK-IWRK+1, IWORK, LIWORK,
645 $ MAXWRK = MAX( MAXWRK, 2*SDIM*( N-SDIM ) )
646.EQ.
IF( IERR-21 ) THEN
652.EQ..OR..EQ.
IF( IJOB1 IJOB4 ) THEN
656.EQ..OR..EQ.
IF( IJOB2 IJOB4 ) THEN
657 RCONDV( 1 ) = DIF( 1 )
658 RCONDV( 2 ) = DIF( 2 )
670 $ CALL ZGGBAK( 'p',
'L', n, ilo, ihi, rwork( ileft ),
671 $ rwork( iright ), n, vsl, ldvsl, ierr )
674 $
CALL zggbak(
'P',
'R', n, ilo, ihi, rwork( ileft ),
675 $ rwork( iright ), n, vsr, ldvsr, ierr )
680 CALL zlascl(
'U', 0, 0, anrmto, anrm, n, n, a, lda, ierr )
681 CALL zlascl(
'G', 0, 0, anrmto, anrm, n, 1, alpha, n, ierr )
685 CALL zlascl(
'U', 0, 0, bnrmto, bnrm, n, n, b, ldb, ierr )
686 CALL zlascl(
'G', 0, 0, bnrmto, bnrm, n, 1, beta, n, ierr )
696 cursl = selctg( alpha( i ), beta( i ) )
699 IF( cursl .AND. .NOT.lastsl )
subroutine zggesx(jobvsl, jobvsr, sort, selctg, sense, n, a, lda, b, ldb, sdim, alpha, beta, vsl, ldvsl, vsr, ldvsr, rconde, rcondv, work, lwork, rwork, iwork, liwork, bwork, info)
ZGGESX computes the eigenvalues, the Schur form, and, optionally, the matrix of Schur vectors for GE ...
subroutine ztgsen(ijob, wantq, wantz, select, n, a, lda, b, ldb, alpha, beta, q, ldq, z, ldz, m, pl, pr, dif, work, lwork, iwork, liwork, info)
ZTGSEN