122 SUBROUTINE zsyt01_aa( UPLO, N, A, LDA, AFAC, LDAFAC, IPIV, C,
123 $ LDC, RWORK, RESID )
131 INTEGER LDA, LDAFAC, LDC, N
132 DOUBLE PRECISION RESID
136 COMPLEX*16 A( LDA, * ), ( LDAFAC, * ), C( LDC, * )
137 DOUBLE PRECISION RWORK( * )
143 DOUBLE PRECISION ZERO, ONE
144 parameter( zero = 0.0d+0, one = 1.0d+0 )
145 COMPLEX*16 CZERO, CONE
146 parameter( czero = 0.0e+0, cone = 1.0e+0 )
150 DOUBLE PRECISION , EPS
154 DOUBLE PRECISION DLAMCH, ZLANSY
155 EXTERNAL lsame, dlamch, zlansy
174 eps = dlamch(
'Epsilon' )
175 anorm = zlansy(
'1', uplo, n, a, lda, rwork )
179 CALL zlaset(
'Full', n, n, czero, czero, c, ldc )
182 IF( lsame( uplo,
'U' ) )
THEN
183 CALL zlacpy(
'F', 1, n-1, afac( 1, 2 ), ldafac+1, c( 1, 2 ),
185 CALL zlacpy(
'F', 1, n-1, afac( 1, 2 ), ldafac+1, c( 2, 1 ),
188 CALL zlacpy(
'F', 1, n-1, afac( 2, 1 ), ldafac+1, c( 1, 2 ),
190 CALL zlacpy(
'F', 1, n-1, afac( 2, 1 ), ldafac+1, c( 2, 1 ),
196 IF( lsame( uplo,
'U' ) )
THEN
197 CALL ztrmm(
'Left', uplo,
'Transpose',
'Unit', n-1, n,
198 $ cone, afac( 1, 2 ), ldafac, c( 2, 1 ), ldc )
200 CALL ztrmm(
'Left', uplo,
'No transpose',
'Unit', n-1, n,
201 $ cone, afac( 2, 1 ), ldafac, c( 2, 1 ), ldc )
206 IF( lsame( uplo,
'U' ) )
THEN
207 CALL ztrmm(
'Right', uplo,
'No transpose',
'Unit', n, n-1,
210 CALL ztrmm(
'Right', uplo,
'Transpose',
'Unit', n
211 $ cone, afac( 2, 1 ), ldafac, c( 1, 2 ), ldc )
220 $
CALL zswap( n, c( j, 1 ), ldc, c( i, 1 ), ldc )
225 $
CALL zswap( n, c( 1, j ), 1, c( 1, i ), 1 )
231 IF( lsame( uplo,
'U' ) )
THEN
234 c( i, j ) = c( i, j ) - a( i, j )
240 c( i, j ) = c( i, j ) - a( i, j )
247 resid = zlansy(
'1', uplo, n, c, ldc, rwork )
249 IF( anorm.LE.zero )
THEN
253 resid = ( ( resid / dble( n ) ) / anorm ) / eps
subroutine ztrmm(side, uplo, transa, diag, m, n, alpha, a, lda, b, ldb)
ZTRMM