195 SUBROUTINE cgees( JOBVS, SORT, SELECT, N, A, LDA, SDIM, W, VS,
196 $ LDVS, WORK, LWORK, RWORK, BWORK, INFO )
203 CHARACTER JOBVS, SORT
204 INTEGER INFO, LDA, LDVS, LWORK, N, SDIM
209 COMPLEX A( LDA, * ), VS( LDVS, * ), W( * ), WORK( * )
220 parameter( zero = 0.0e0, one = 1.0e0 )
223 LOGICAL LQUERY, SCALEA, WANTST, WANTVS
224 INTEGER HSWORK, I, IBAL, ICOND, IERR, IEVAL, IHI, ILO,
225 $ itau, iwrk, maxwrk, minwrk
226 REAL ANRM, BIGNUM, CSCALE, EPS, S, SEP, SMLNUM
239 EXTERNAL lsame, ilaenv, clange, slamch
249 lquery = ( lwork.EQ.-1 )
250 wantvs = lsame( jobvs,
'V' )
251 wantst = lsame( sort,
'S' )
252 IF( ( .NOT.wantvs ) .AND. ( .NOT.lsame( jobvs,
'N' ) ) )
THEN
254 ELSE IF( ( .NOT.wantst ) .AND. ( .NOT.lsame( sort,
'N' ) ) )
THEN
256 ELSE IF( n.LT.0 )
THEN
258 ELSE IF( lda.LT.
max( 1, n ) )
THEN
260 ELSE IF( ldvs.LT.1 .OR. ( wantvs .AND. ldvs.LT.n ) )
THEN
280 maxwrk = n + n*ilaenv( 1,
'CGEHRD',
' ', n, 1, n, 0 )
285 hswork = real( work( 1 ) )
287 IF( .NOT.wantvs )
THEN
288 maxwrk =
max( maxwrk, hswork )
290 maxwrk =
max( maxwrk, n + ( n - 1 )*ilaenv( 1,
'CUNGHR',
291 $
' ', n, 1, n, -1 ) )
292 maxwrk =
max( maxwrk, hswork )
297 IF( lwork.LT.minwrk .AND. .NOT.lquery )
THEN
303 CALL xerbla(
'CGEES ', -info )
305 ELSE IF( lquery )
THEN
319 smlnum = slamch(
'S' )
320 bignum = one / smlnum
321 CALL slabad( smlnum, bignum )
322 smlnum = sqrt( smlnum ) / eps
323 bignum = one / smlnum
327 anrm = clange(
'M', n, n, a, lda, dum )
329 IF( anrm.GT.zero .AND. anrm.LT.smlnum )
THEN
332 ELSE IF( anrm.GT.bignum )
THEN
337 $
CALL clascl(
'G', 0, 0, anrm, cscale, n, n, a, lda, ierr )
344 CALL cgebal(
'P', n, a, lda, ilo, ihi, rwork( ibal ), ierr )
352 CALL cgehrd( n, ilo, ihi, a, lda, work( itau ), work( iwrk ),
353 $ lwork-iwrk+1, ierr )
359 CALL clacpy(
'L', n, n, a, lda, vs, ldvs )
365 CALL cunghr( n, ilo, ihi, vs, ldvs, work( itau ), work( iwrk ),
366 $ lwork-iwrk+1, ierr )
376 CALL chseqr(
'S', jobvs, n, ilo, ihi, a, lda, w, vs, ldvs,
377 $ work( iwrk ), lwork-iwrk+1, ieval )
383 IF( wantst .AND. info.EQ.0 )
THEN
385 $
CALL clascl(
'G', 0, 0, cscale, anrm, n, 1, w, n, ierr )
387 bwork( i ) =
SELECT( w( i ) )
394 CALL ctrsen(
'N', jobvs, bwork, n, a, lda, vs, ldvs, w, sdim,
395 $ s, sep, work( iwrk ), lwork-iwrk+1, icond )
404 CALL cgebak( 'p
', 'r
', N, ILO, IHI, RWORK( IBAL ), N, VS, LDVS,
412 CALL CLASCL( 'u
', 0, 0, CSCALE, ANRM, N, N, A, LDA, IERR )
413 CALL CCOPY( N, A, LDA+1, W, 1 )
subroutine cgees(jobvs, sort, select, n, a, lda, sdim, w, vs, ldvs, work, lwork, rwork, bwork, info)
CGEES computes the eigenvalues, the Schur form, and, optionally, the matrix of Schur vectors for GE m...