174 SUBROUTINE ctplqt( M, N, L, MB, A, LDA, B, LDB, T, LDT, WORK,
183 INTEGER INFO, LDA, LDB, LDT, N, M, L, MB
186 COMPLEX A( LDA, * ), B( LDB, * ), T( LDT, * ), WORK( * )
193 INTEGER I, IB, LB, NB, IINFO
205 ELSE IF( n.LT.0 )
THEN
207 ELSE IF( l.LT.0 .OR. (l.GT.min(m,n) .AND. min(m,n).GE.0))
THEN
209 ELSE IF( mb.LT.1 .OR. (mb.GT.m .AND. m.GT.0))
THEN
211 ELSE IF( lda.LT.max( 1, m ) )
THEN
213 ELSE IF( ldb.LT.max( 1, m ) )
THEN
215 ELSE IF( ldt.LT.mb )
THEN
219 CALL xerbla(
'CTPLQT', -info )
225 IF( m.EQ.0 .OR. n.EQ.0 )
RETURN
231 ib = min( m-i+1, mb )
232 nb = min( n-l+i+ib-1, n )
239 CALL ctplqt2( ib, nb, lb, a(i,i), lda, b( i, 1 ), ldb,
240 $ t(1, i ), ldt, iinfo )
245 CALL ctprfb(
'R',
'N',
'F',
'R', m-i-ib+1, nb, ib, lb,
246 $ b( i, 1 ), ldb, t( 1, i ), ldt,
247 $ a( i+ib, i ), lda, b( i+ib, 1 ), ldb,