144 SUBROUTINE ctbtrs( UPLO, TRANS, DIAG, N, KD, NRHS, AB, LDAB, B,
152 CHARACTER DIAG, TRANS, UPLO
153 INTEGER INFO, KD, LDAB, LDB, N, NRHS
156 COMPLEX AB( LDAB, * ), B( LDB, * )
163 parameter( zero = ( 0.0e+0, 0.0e+0 ) )
166 LOGICAL NOUNIT, UPPER
184 nounit = lsame( diag,
'N' )
185 upper = lsame( uplo,
'U' )
186 IF( .NOT.upper .AND. .NOT.lsame( uplo,
'L' ) )
THEN
188 ELSE IF( .NOT.lsame( trans,
'N' ) .AND. .NOT.
189 $ lsame( trans,
'T' ) .AND. .NOT.lsame( trans,
'C' ) )
THEN
191 ELSE IF( .NOT.nounit .AND. .NOT.lsame( diag,
'U' ) )
THEN
193 ELSE IF( n.LT.0 )
THEN
195 ELSE IF( kd.LT.0 )
THEN
197 ELSE IF( nrhs.LT.0 )
THEN
199 ELSE IF( ldab.LT.kd+1 )
THEN
201 ELSE IF( ldb.LT.max( 1, n ) )
THEN
205 CALL xerbla(
'CTBTRS', -info )
219 IF( ab( kd+1, info ).EQ.zero )
224 IF( ab( 1, info ).EQ.zero )
234 CALL ctbsv( uplo, trans, diag, n, kd, ab, ldab, b( 1, j ), 1 )
subroutine xerbla(srname, info)
subroutine ctbsv(uplo, trans, diag, n, k, a, lda, x, incx)
CTBSV
subroutine ctbtrs(uplo, trans, diag, n, kd, nrhs, ab, ldab, b, ldb, info)
CTBTRS