174 SUBROUTINE cungtsqr( M, N, MB, NB, A, LDA, T, LDT, WORK, LWORK,
184 INTEGER INFO, LDA, LDT, LWORK, M, N, MB, NB
187 COMPLEX A( LDA, * ), T( LDT, * ), WORK( * )
194 parameter( cone = ( 1.0e+0, 0.0e+0 ),
195 $ czero = ( 0.0e+0, 0.0e+0 ) )
199 INTEGER IINFO, LDC, LWORKOPT, LC, LW, NBLOCAL, J
205 INTRINSIC cmplx, max, min
215 ELSE IF( n.LT.0 .OR. m.LT.n )
THEN
217 ELSE IF( mb.LE.n )
THEN
219 ELSE IF( nb.LT.1 )
THEN
221 ELSE IF( lda.LT.max( 1, m ) )
THEN
223 ELSE IF( ldt.LT.max( 1, min( nb, n ) ) )
THEN
231 IF( lwork.LT.2 .AND. (.NOT.lquery) )
THEN
237 nblocal = min( nb, n )
249 IF( ( lwork.LT.max( 1, lworkopt ) ).AND.(.NOT.lquery) )
THEN
259 CALL xerbla(
'CUNGTSQR', -info )
261 ELSE IF ( lquery )
THEN
262 work( 1 ) = cmplx( lworkopt )
268 IF( min( m, n ).EQ.0 )
THEN
269 work( 1 ) = cmplx( lworkopt )
284 CALL claset(
'F', m, n, czero, cone, work, ldc )
291 CALL clamtsqr(
'L',
'N', m, n, n, mb, nblocal, a, lda, t, ldt,
292 $ work, ldc, work( lc+1 ), lw, iinfo )
299 CALL ccopy( m, work( (j-1)*ldc + 1 ), 1, a( 1, j ), 1 )
302 work( 1 ) = cmplx( lworkopt )