125 SUBROUTINE chet01_aa( UPLO, N, A, LDA, AFAC, LDAFAC, IPIV, C,
126 $ LDC, RWORK, RESID )
135 INTEGER LDA, LDAFAC, LDC, N
141 COMPLEX A( LDA, * ), AFAC( LDAFAC, * ), C( LDC, * )
148 parameter( czero = ( 0.0e+0, 0.0e+0 ),
149 $ cone = ( 1.0e+0, 0.0e+0 ) )
151 parameter( zero = 0.0e+0, one = 1.0e+0 )
160 EXTERNAL lsame, slamch, clanhe
179 eps = slamch(
'Epsilon' )
180 anorm = clanhe(
'1', uplo, n, a, lda, rwork )
184 CALL claset(
'Full', n, n, czero, czero, c, ldc )
185 CALL clacpy(
'F', 1, n, afac( 1, 1 ), ldafac+1, c( 1, 1 ), ldc+1 )
187 IF( lsame( uplo,
'U' ) )
THEN
188 CALL clacpy(
'F', 1, n-1, afac( 1, 2 ), ldafac+1, c( 1, 2 ),
190 CALL clacpy(
'F', 1, n-1, afac( 1, 2 ), ldafac+1, c( 2, 1 ),
192 CALL clacgv( n-1, c( 2, 1 ), ldc+1 )
194 CALL clacpy(
'F', 1, n-1, afac( 2, 1 ), ldafac+1, c( 1, 2 ),
196 CALL clacpy(
'F', 1, n-1, afac( 2, 1 ), ldafac+1, c( 2, 1 ),
198 CALL clacgv( n-1, c( 1, 2 ), ldc+1 )
203 IF( lsame( uplo,
'U' ) )
THEN
204 CALL ctrmm(
'Left', uplo,
'Conjugate transpose',
'Unit',
205 $ n-1, n, cone, afac( 1, 2 ), ldafac, c( 2, 1 ),
208 CALL ctrmm(
'Left', uplo,
'No transpose',
'Unit', n-1, n,
209 $ cone, afac( 2, 1 ), ldafac, c( 2, 1 ), ldc )
214 IF( lsame( uplo,
'U' ) )
THEN
215 CALL ctrmm(
'Right', uplo,
'No transpose',
'Unit', n, n-1,
216 $ cone, afac( 1, 2 ), ldafac, c( 1, 2 ), ldc )
218 CALL ctrmm(
'Right', uplo,
'Conjugate transpose',
'Unit', n,
219 $ n-1, cone, afac( 2, 1 ), ldafac, c( 1, 2 ),
229 $
CALL cswap( n, c( j, 1 ), ldc, c( i, 1 ), ldc )
234 $
CALL cswap( n, c( 1, j ), 1, c( 1, i ), 1 )
240 IF( lsame( uplo,
'U' ) )
THEN
243 c( i, j ) = c( i, j ) - a( i, j )
249 c( i, j ) = c( i, j ) - a( i, j )
256 resid = clanhe(
'1', uplo, n, c, ldc, rwork )
258 IF( anorm.LE.zero )
THEN
262 resid = ( ( resid / dble( n ) ) / anorm ) / eps