74 SUBROUTINE zlqt04(M,N,NB,RESULT)
85 DOUBLE PRECISION RESULT(6)
91 COMPLEX*16,
ALLOCATABLE :: AF(:,:), Q(:,:),
92 $ L(:,:), RWORK(:), WORK( : ), T(:,:),
93 $ CF(:,:), DF(:,:), A(:,:), C(:,:), D(:,:)
98 parameter( zero = 0.0)
99 parameter( one = (1.0,0.0), czero=(0.0,0.0) )
102 INTEGER INFO, J, K, LL, LWORK, LDT
103 DOUBLE PRECISION ANORM, EPS, RESID, CNORM, DNORM
109 DOUBLE PRECISION DLAMCH
110 DOUBLE PRECISION ZLANGE, ZLANSY
112 EXTERNAL dlamch, zlange, zlansy, lsame
118 DATA iseed / 1988, 1989, 1990, 1991 /
120 eps = dlamch(
'Epsilon' )
123 lwork = max(2,ll)*max(2,ll)*nb
127 ALLOCATE ( a(m,n), af(m,n), q(n,n), l(ll,n), rwork(ll),
128 $ work(lwork), t(nb,n), c(m,n), cf(m,n),
135 CALL zlarnv( 2, iseed, m, a( 1, j ) )
137 CALL zlacpy(
'Full', m, n, a, m, af, m )
141 CALL zgelqt( m, n, nb, af, m, t, ldt, work, info )
145 CALL zlaset(
'Full', n, n, czero, one, q, n )
146 CALL zgemlqt(
'R',
'N', n, n, k, nb, af, m, t, ldt, q, n,
151 CALL zlaset(
'Full', ll, n, czero, czero, l, ll )
152 CALL zlacpy(
'Lower', m, n, af, m, l, ll )
156 CALL zgemm(
'N',
'C', m, n, n, -one, a, m, q, n, one, l, ll )
157 anorm = zlange(
'1', m, n, a, m, rwork )
158 resid = zlange(
'1', m, n, l, ll, rwork )
159 IF( anorm.GT.zero )
THEN
160 result( 1 ) = resid / (eps*max(1,m)*anorm)
167 CALL zlaset(
'Full', n, n, czero, one, l, ll )
168 CALL zherk(
'U',
'C', n, n, dreal(-one), q, n, dreal(one), l, ll)
169 resid = zlansy(
'1',
'Upper', n, l, ll, rwork )
170 result( 2 ) = resid / (eps*max(1,n))
175 CALL zlarnv( 2, iseed, n, d( 1, j ) )
177 dnorm = zlange(
'1', n, m, d, n, rwork)
178 CALL zlacpy(
'Full', n, m, d, n, df, n )
182 CALL zgemlqt(
'L',
'N', n, m, k, nb, af, m, t, nb, df, n,
187 CALL zgemm(
'N',
'N', n, m, n, -one, q, n, d, n, one, df, n )
188 resid = zlange(
'1', n, m, df, n, rwork )
189 IF( dnorm.GT.zero )
THEN
190 result( 3 ) = resid / (eps*max(1,m)*dnorm)
197 CALL zlacpy(
'Full', n, m, d, n, df, n )
201 CALL zgemlqt(
'L',
'C', n, m, k, nb, af, m, t, nb, df, n,
206 CALL zgemm(
'C',
'N', n, m, n, -one, q, n, d, n, one, df, n )
207 resid = zlange(
'1', n, m, df, n, rwork )
208 IF( dnorm.GT.zero )
THEN
209 result( 4 ) = resid / (eps*max(1,m)*dnorm)
217 CALL zlarnv( 2, iseed, m, c( 1, j ) )
219 cnorm = zlange(
'1', m, n, c, m, rwork)
220 CALL zlacpy(
'Full', m, n, c, m, cf, m )
224 CALL zgemlqt(
'R',
'N', m, n, k, nb, af, m, t, nb, cf, m,
229 CALL zgemm(
'N',
'N', m, n, n, -one, c, m, q, n, one, cf, m )
230 resid = zlange(
'1', n, m, df, n, rwork )
231 IF( cnorm.GT.zero )
THEN
232 result( 5 ) = resid / (eps*max(1,m)*dnorm)
239 CALL zlacpy(
'Full', m, n, c, m, cf, m )
243 CALL zgemlqt(
'R',
'C', m, n, k, nb, af, m, t, nb, cf, m,
248 CALL zgemm(
'N',
'C', m, n, n, -one, c, m, q, n, one, cf, m )
249 resid = zlange(
'1', m, n, cf, m, rwork )
250 IF( cnorm.GT.zero )
THEN
251 result( 6 ) = resid / (eps*max(1,m)*dnorm)
258 DEALLOCATE ( a, af, q, l, rwork, work, t, c, d, cf, df)