127 SUBROUTINE ctrexc( COMPQ, N, T, LDT, Q, LDQ, IFST, ILST, INFO )
136 INTEGER IFST, ILST, INFO, LDQ, LDT, N
139 COMPLEX Q( ldq, * ), T( ldt, * )
146 INTEGER K, M1, M2, M3
148 COMPLEX SN, T11, T22, TEMP
165 wantq = lsame( compq,
'V' )
166 IF( .NOT.lsame( compq,
'N' ) .AND. .NOT.wantq )
THEN 168 ELSE IF( n.LT.0 )
THEN 170 ELSE IF( ldt.LT.max( 1, n ) )
THEN 172 ELSE IF( ldq.LT.1 .OR. ( wantq .AND. ldq.LT.max( 1, n ) ) )
THEN 174 ELSE IF(( ifst.LT.1 .OR. ifst.GT.n ).AND.( n.GT.0 ))
THEN 176 ELSE IF(( ilst.LT.1 .OR. ilst.GT.n ).AND.( n.GT.0 ))
THEN 180 CALL xerbla(
'CTREXC', -info )
186 IF( n.LE.1 .OR. ifst.EQ.ilst )
189 IF( ifst.LT.ilst )
THEN 205 DO 10 k = ifst + m1, ilst + m2, m3
214 CALL clartg( t( k, k+1 ), t22-t11, cs, sn, temp )
219 $
CALL crot( n-k-1, t( k, k+2 ), ldt, t( k+1, k+2 ), ldt, cs,
221 CALL crot( k-1, t( 1, k ), 1, t( 1, k+1 ), 1, cs, conjg( sn ) )
230 CALL crot( n, q( 1, k ), 1, q( 1, k+1 ), 1, cs,
subroutine crot(N, CX, INCX, CY, INCY, C, S)
CROT applies a plane rotation with real cosine and complex sine to a pair of complex vectors...
subroutine clartg(F, G, CS, SN, R)
CLARTG generates a plane rotation with real cosine and complex sine.
subroutine xerbla(SRNAME, INFO)
XERBLA
subroutine ctrexc(COMPQ, N, T, LDT, Q, LDQ, IFST, ILST, INFO)
CTREXC