142 SUBROUTINE strtrs( UPLO, TRANS, DIAG, N, NRHS, A, LDA, B, LDB,
150 CHARACTER DIAG, TRANS, UPLO
151 INTEGER INFO, LDA, LDB, N, NRHS
154 REAL A( LDA, * ), B( LDB, * )
161 parameter( zero = 0.0e+0, one = 1.0e+0 )
181 nounit = lsame( diag,
'N' )
182 IF( .NOT.lsame( uplo,
'U' ) .AND.
183 $ .NOT.lsame( uplo,
'L' ) )
THEN
185 ELSE IF( .NOT.lsame( trans,
'N' ) .AND. .NOT.
186 $ lsame( trans,
'T' ) .AND.
187 $ .NOT.lsame( trans,
'C' ) )
THEN
189 ELSE IF( .NOT.nounit .AND. .NOT.lsame( diag,
'U' ) )
THEN
191 ELSE IF( n.LT.0 )
THEN
193 ELSE IF( nrhs.LT.0 )
THEN
195 ELSE IF( lda.LT.max( 1, n ) )
THEN
197 ELSE IF( ldb.LT.max( 1, n ) )
THEN
201 CALL xerbla(
'STRTRS', -info )
214 IF( a( info, info ).EQ.zero )
222 CALL strsm(
'Left', uplo, trans, diag, n, nrhs, one, a, lda, b,
subroutine strsm(side, uplo, transa, diag, m, n, alpha, a, lda, b, ldb)
STRSM
subroutine strtrs(uplo, trans, diag, n, nrhs, a, lda, b, ldb, info)
STRTRS