124 SUBROUTINE drqt01( M, N, A, AF, Q, R, LDA, TAU, WORK, LWORK,
132 INTEGER LDA, LWORK, M, N
135 DOUBLE PRECISION A( LDA, * ), AF( LDA, * ), Q( LDA, * ),
136 $ r( lda, * ), result( * ), rwork( * ), tau( * ),
143 DOUBLE PRECISION ZERO, ONE
144 parameter( zero = 0.0d+0, one = 1.0d+0 )
145 DOUBLE PRECISION ROGUE
146 parameter( rogue = -1.0d+10 )
150 DOUBLE PRECISION ANORM, EPS, RESID
153 DOUBLE PRECISION DLAMCH, DLANGE, DLANSY
154 EXTERNAL dlamch, dlange, dlansy
160 INTRINSIC dble, max, min
166 COMMON / srnamc / srnamt
171 eps = dlamch(
'Epsilon' )
175 CALL dlacpy(
'Full', m, n, a, lda, af, lda )
180 CALL dgerqf( m, n, af, lda, tau, work, lwork, info )
184 CALL dlaset(
'Full', n, n, rogue, rogue, q, lda )
186 IF( m.GT.0 .AND. m.LT.n )
187 $
CALL dlacpy(
'Full', m, n-m, af, lda, q( n-m+1, 1 ), lda )
189 $
CALL dlacpy(
'Lower', m-1, m-1, af( 2, n-m+1 ), lda,
190 $ q( n-m+2, n-m+1 ), lda )
193 $
CALL dlacpy(
'Lower', n-1, n-1, af( m-n+2, 1 ), lda,
200 CALL dorgrq( n, n, minmn, q, lda, tau, work, lwork, info )
204 CALL dlaset(
'Full', m, n, zero, zero, r, lda )
207 $
CALL dlacpy(
'Upper', m, m, af( 1, n-m+1 ), lda,
208 $ r( 1, n-m+1 ), lda )
210 IF( m.GT.n .AND. n.GT.0 )
211 $
CALL dlacpy(
'Full', m-n, n, af, lda, r, lda )
213 $
CALL dlacpy(
'Upper', n, n, af( m-n+1, 1 ), lda,
214 $ r( m-n+1, 1 ), lda )
219 CALL dgemm(
'No transpose',
'Transpose', m, n, n, -one, a, lda, q,
224 anorm = dlange(
'1', m, n, a, lda, rwork )
225 resid = dlange(
'1', m, n, r, lda, rwork )
226 IF( anorm.GT.zero )
THEN
227 result( 1 ) = ( ( resid / dble( max( 1, n ) ) ) / anorm ) / eps
234 CALL dlaset(
'Full', n, n, zero, one, r, lda )
235 CALL dsyrk(
'Upper',
'No transpose', n, n, -one, q, lda, one, r,
240 resid = dlansy(
'1',
'Upper', n, r, lda, rwork )
242 result( 2 ) = ( resid / dble( max( 1, n ) ) ) / eps
subroutine drqt01(m, n, a, af, q, r, lda, tau, work, lwork, rwork, result)
DRQT01
subroutine dgemm(transa, transb, m, n, k, alpha, a, lda, b, ldb, beta, c, ldc)
DGEMM
subroutine dgerqf(m, n, a, lda, tau, work, lwork, info)
DGERQF
subroutine dsyrk(uplo, trans, n, k, alpha, a, lda, beta, c, ldc)
DSYRK
subroutine dlacpy(uplo, m, n, a, lda, b, ldb)
DLACPY copies all or part of one two-dimensional array to another.
subroutine dlaset(uplo, m, n, alpha, beta, a, lda)
DLASET initializes the off-diagonal elements and the diagonal elements of a matrix to given values.
subroutine dorgrq(m, n, k, a, lda, tau, work, lwork, info)
DORGRQ