133 SUBROUTINE zqrt02( M, N, K, A, AF, Q, R, LDA, TAU, WORK, LWORK,
141 INTEGER K, LDA, LWORK, M, N
144 DOUBLE PRECISION RESULT( * ), RWORK( * )
145 COMPLEX*16 A( LDA, * ), AF( LDA, * ), Q( LDA, * ),
146 $ r( lda, * ), tau( * ), work( lwork )
152 DOUBLE PRECISION ZERO, ONE
153 parameter( zero = 0.0d+0, one = 1.0d+0 )
155 parameter( rogue = ( -1.0d+10, -1.0d+10 ) )
159 DOUBLE PRECISION ANORM, EPS, RESID
162 DOUBLE PRECISION DLAMCH, ZLANGE, ZLANSY
163 EXTERNAL dlamch, zlange, zlansy
169 INTRINSIC dble, dcmplx, max
175 COMMON / srnamc / srnamt
179 eps = dlamch(
'Epsilon' )
183 CALL zlaset(
'Full', m, n, rogue, rogue, q, lda )
184 CALL zlacpy(
'Lower', m-1, k, af( 2, 1 ), lda, q( 2, 1 ), lda )
189 CALL zungqr( m, n, k, q, lda, tau, work, lwork, info )
193 CALL zlaset(
'Full', n, k, dcmplx( zero ), dcmplx( zero ), r,
195 CALL zlacpy(
'Upper', n, k, af, lda, r, lda )
199 CALL zgemm(
'Conjugate transpose',
'No transpose', n, k, m,
200 $ dcmplx( -one ), q, lda, a, lda, dcmplx( one ), r,
205 anorm = zlange(
'1', m, k, a, lda, rwork )
206 resid = zlange(
'1', n, k, r, lda, rwork )
207 IF( anorm.GT.zero )
THEN
208 result( 1 ) = ( ( resid / dble( max( 1, m ) ) ) / anorm ) / eps
215 CALL zlaset(
'Full', n, n, dcmplx( zero ), dcmplx( one ), r, lda )
216 CALL zherk(
'Upper',
'Conjugate transpose', n, m, -one, q, lda,
221 resid = zlansy(
'1',
'Upper', n, r, lda, rwork )
223 result( 2 ) = ( resid / dble( max( 1, m ) ) ) / eps
subroutine zgemm(transa, transb, m, n, k, alpha, a, lda, b, ldb, beta, c, ldc)
ZGEMM
subroutine zherk(uplo, trans, n, k, alpha, a, lda, beta, c, ldc)
ZHERK
subroutine zlacpy(uplo, m, n, a, lda, b, ldb)
ZLACPY copies all or part of one two-dimensional array to another.
subroutine zlaset(uplo, m, n, alpha, beta, a, lda)
ZLASET initializes the off-diagonal elements and the diagonal elements of a matrix to given values.
subroutine zungqr(m, n, k, a, lda, tau, work, lwork, info)
ZUNGQR
subroutine zqrt02(m, n, k, a, af, q, r, lda, tau, work, lwork, rwork, result)
ZQRT02