146 REAL FUNCTION SLA_SYRCOND( UPLO, N, A, LDA, AF, LDAF, IPIV, CMODE,
147 $ C, INFO, WORK, IWORK )
156 INTEGER n, lda, ldaf, info, cmode
159 INTEGER iwork( * ), ipiv( * )
160 REAL a( lda, * ), af( ldaf, * ), work( * ), c( * )
168 REAL ainvnm, smlnum, tmp
192 ELSE IF( lda.LT.max( 1, n ) )
THEN
194 ELSE IF( ldaf.LT.max( 1, n ) )
THEN
198 CALL xerbla(
'SLA_SYRCOND', -info )
206 IF (
lsame( uplo,
'U' ) ) up = .true.
214 IF ( cmode .EQ. 1 )
THEN
216 tmp = tmp + abs( a( j, i ) * c( j ) )
219 tmp = tmp + abs( a( i, j ) * c( j ) )
221 ELSE IF ( cmode .EQ. 0 )
THEN
223 tmp = tmp + abs( a( j, i ) )
226 tmp = tmp + abs( a( i, j ) )
230 tmp = tmp + abs( a( j, i ) / c( j ) )
233 tmp = tmp + abs( a( i, j ) / c( j ) )
241 IF ( cmode .EQ. 1 )
THEN
243 tmp = tmp + abs( a( i, j ) * c( j ) )
246 tmp = tmp + abs( a( j, i ) * c( j ) )
248 ELSE IF ( cmode .EQ. 0 )
THEN
250 tmp = tmp + abs( a( i, j ) )
253 tmp = tmp + abs( a( j, i ) )
257 tmp = tmp + abs( a( i, j) / c( j ) )
260 tmp = tmp + abs( a( j, i) / c( j ) )
269 smlnum =
slamch(
'Safe minimum' )
275 CALL slacn2( n, work( n+1 ), work, iwork, ainvnm, kase, isave )
282 work( i ) = work( i ) * work( 2*n+i )
286 CALL ssytrs(
'U', n, 1, af, ldaf, ipiv, work, n, info )
288 CALL ssytrs(
'L', n, 1, af, ldaf, ipiv, work, n, info )
293 IF ( cmode .EQ. 1 )
THEN
295 work( i ) = work( i ) / c( i )
297 ELSE IF ( cmode .EQ. -1 )
THEN
299 work( i ) = work( i ) * c( i )
306 IF ( cmode .EQ. 1 )
THEN
308 work( i ) = work( i ) / c( i )
310 ELSE IF ( cmode .EQ. -1 )
THEN
312 work( i ) = work( i ) * c( i )
317 CALL ssytrs(
'U', n, 1, af, ldaf, ipiv, work, n, info )
319 CALL ssytrs(
'L', n, 1, af, ldaf, ipiv, work, n, info )
325 work( i ) = work( i ) * work( 2*n+i )
334 IF( ainvnm .NE. 0.0 )