180 SUBROUTINE zhprfs( UPLO, N, NRHS, AP, AFP, IPIV, B, LDB, X, LDX,
181 $ ferr, berr, work, rwork, info )
190 INTEGER INFO, LDB, LDX, N, NRHS
194 DOUBLE PRECISION BERR( * ), FERR( * ), RWORK( * )
195 COMPLEX*16 AFP( * ), AP( * ), B( ldb, * ), WORK( * ),
203 parameter ( itmax = 5 )
204 DOUBLE PRECISION ZERO
205 parameter ( zero = 0.0d+0 )
207 parameter ( one = ( 1.0d+0, 0.0d+0 ) )
209 parameter ( two = 2.0d+0 )
210 DOUBLE PRECISION THREE
211 parameter ( three = 3.0d+0 )
215 INTEGER COUNT, I, IK, J, K, KASE, KK, NZ
216 DOUBLE PRECISION EPS, LSTRES, S, SAFE1, SAFE2, SAFMIN, XK
226 INTRINSIC abs, dble, dimag, max
230 DOUBLE PRECISION DLAMCH
231 EXTERNAL lsame, dlamch
234 DOUBLE PRECISION CABS1
237 cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
244 upper = lsame( uplo,
'U' )
245 IF( .NOT.upper .AND. .NOT.lsame( uplo,
'L' ) )
THEN
247 ELSE IF( n.LT.0 )
THEN
249 ELSE IF( nrhs.LT.0 )
THEN
251 ELSE IF( ldb.LT.max( 1, n ) )
THEN
253 ELSE IF( ldx.LT.max( 1, n ) )
THEN
257 CALL xerbla(
'ZHPRFS', -info )
263 IF( n.EQ.0 .OR. nrhs.EQ.0 )
THEN
274 eps = dlamch(
'Epsilon' )
275 safmin = dlamch(
'Safe minimum' )
291 CALL zcopy( n, b( 1, j ), 1, work, 1 )
292 CALL zhpmv( uplo, n, -one, ap, x( 1, j ), 1, one, work, 1 )
304 rwork( i ) = cabs1( b( i, j ) )
313 xk = cabs1( x( k, j ) )
316 rwork( i ) = rwork( i ) + cabs1( ap( ik ) )*xk
317 s = s + cabs1( ap( ik ) )*cabs1( x( i, j ) )
320 rwork( k ) = rwork( k ) + abs( dble( ap( kk+k-1 ) ) )*
327 xk = cabs1( x( k, j ) )
328 rwork( k ) = rwork( k ) + abs( dble( ap( kk ) ) )*xk
331 rwork( i ) = rwork( i ) + cabs1( ap( ik ) )*xk
332 s = s + cabs1( ap( ik ) )*cabs1( x( i, j ) )
335 rwork( k ) = rwork( k ) + s
341 IF( rwork( i ).GT.safe2 )
THEN
342 s = max( s, cabs1( work( i ) ) / rwork( i ) )
344 s = max( s, ( cabs1( work( i ) )+safe1 ) /
345 $ ( rwork( i )+safe1 ) )
356 IF( berr( j ).GT.eps .AND. two*berr( j ).LE.lstres .AND.
357 $ count.LE.itmax )
THEN
361 CALL zhptrs( uplo, n, 1, afp, ipiv, work, n, info )
362 CALL zaxpy( n, one, work, 1, x( 1, j ), 1 )
391 IF( rwork( i ).GT.safe2 )
THEN
392 rwork( i ) = cabs1( work( i ) ) + nz*eps*rwork( i )
394 rwork( i ) = cabs1( work( i ) ) + nz*eps*rwork( i ) +
401 CALL zlacn2( n, work( n+1 ), work, ferr( j ), kase, isave )
407 CALL zhptrs( uplo, n, 1, afp, ipiv, work, n, info )
409 work( i ) = rwork( i )*work( i )
411 ELSE IF( kase.EQ.2 )
THEN
416 work( i ) = rwork( i )*work( i )
418 CALL zhptrs( uplo, n, 1, afp, ipiv, work, n, info )
427 lstres = max( lstres, cabs1( x( i, j ) ) )
430 $ ferr( j ) = ferr( j ) / lstres
subroutine zhptrs(UPLO, N, NRHS, AP, IPIV, B, LDB, INFO)
ZHPTRS
subroutine zhprfs(UPLO, N, NRHS, AP, AFP, IPIV, B, LDB, X, LDX, FERR, BERR, WORK, RWORK, INFO)
ZHPRFS
subroutine zcopy(N, ZX, INCX, ZY, INCY)
ZCOPY
subroutine xerbla(SRNAME, INFO)
XERBLA
subroutine zlacn2(N, V, X, EST, KASE, ISAVE)
ZLACN2 estimates the 1-norm of a square matrix, using reverse communication for evaluating matrix-vec...
subroutine zhpmv(UPLO, N, ALPHA, AP, X, INCX, BETA, Y, INCY)
ZHPMV
subroutine zaxpy(N, ZA, ZX, INCX, ZY, INCY)
ZAXPY