170 SUBROUTINE ztpqrt2( M, N, L, A, LDA, B, LDB, T, LDT, INFO )
177 INTEGER INFO, LDA, LDB, LDT, N, M, L
180 COMPLEX*16 A( LDA, * ), B( LDB, * ), T( LDT, * )
187 parameter( one = (1.0,0.0), zero = (0.0,0.0) )
190 INTEGER I, J, P, MP, NP
206 ELSE IF( n.LT.0 )
THEN
208 ELSE IF( l.LT.0 .OR. l.GT.min(m,n) )
THEN
210 ELSE IF( lda.LT.max( 1, n ) )
THEN
212 ELSE IF( ldb.LT.max( 1, m ) )
THEN
214 ELSE IF( ldt.LT.max( 1, n ) )
THEN
218 CALL xerbla(
'ZTPQRT2', -info )
224 IF( n.EQ.0 .OR. m.EQ.0 )
RETURN
231 CALL zlarfg( p+1, a( i, i ), b( 1, i ), 1, t( i, 1 ) )
237 t( j, n ) = conjg(a( i, i+j ))
239 CALL zgemv(
'C', p, n-i, one, b( 1, i+1 ), ldb,
240 $ b( 1, i ), 1, one, t( 1, n ), 1 )
244 alpha = -conjg(t( i, 1 ))
246 a( i, i+j ) = a( i, i+j ) + alpha*conjg(t( j, n ))
248 CALL zgerc( p, n-i, alpha, b( 1, i ), 1,
249 $ t( 1, n ), 1, b( 1, i+1 ), ldb )
269 t( j, i ) = alpha*b( m-l+j, i )
271 CALL ztrmv(
'U',
'C',
'N', p, b( mp, 1 ), ldb,
276 CALL zgemv(
'C', l, i-1-p, alpha, b( mp, np ), ldb,
277 $ b( mp, i ), 1, zero, t( np, i ), 1 )
281 CALL zgemv(
'C', m-l, i-1, alpha, b, ldb, b( 1, i ), 1,
282 $ one, t( 1, i ), 1 )
286 CALL ztrmv(
'U',
'N',
'N', i-1, t, ldt, t( 1, i ), 1 )
290 t( i, i ) = t( i, 1 )
subroutine zgemv(trans, m, n, alpha, a, lda, x, incx, beta, y, incy)
ZGEMV
subroutine ztpqrt2(m, n, l, a, lda, b, ldb, t, ldt, info)
ZTPQRT2 computes a QR factorization of a real or complex "triangular-pentagonal" matrix,...