OpenRadioss 2025.1.11
OpenRadioss project
Loading...
Searching...
No Matches
sdrvsy_rook.f
Go to the documentation of this file.
1*> \brief \b SDRVSY_ROOK
2*
3* =========== DOCUMENTATION ===========
4*
5* Online html documentation available at
6* http://www.netlib.org/lapack/explore-html/
7*
8* Definition:
9* ===========
10*
11* SUBROUTINE SDRVSY_ROOK( DOTYPE, NN, NVAL, NRHS, THRESH, TSTERR,
12* $ NMAX, A, AFAC, AINV, B, X, XACT, WORK,
13* $ RWORK, IWORK, NOUT )
14*
15* .. Scalar Arguments ..
16* LOGICAL TSTERR
17* INTEGER NMAX, NN, NOUT, NRHS
18* REAL THRESH
19* ..
20* .. Array Arguments ..
21* LOGICAL DOTYPE( * )
22* INTEGER IWORK( * ), NVAL( * )
23* REAL A( * ), AFAC( * ), AINV( * ), B( * ),
24* $ RWORK( * ), WORK( * ), X( * ), XACT( * )
25* ..
26*
27*
28*> \par Purpose:
29* =============
30*>
31*> \verbatim
32*>
33*> SDRVSY_ROOK tests the driver routines SSYSV_ROOK.
34*> \endverbatim
35*
36* Arguments:
37* ==========
38*
39*> \param[in] DOTYPE
40*> \verbatim
41*> DOTYPE is LOGICAL array, dimension (NTYPES)
42*> The matrix types to be used for testing. Matrices of type j
43*> (for 1 <= j <= NTYPES) are used for testing if DOTYPE(j) =
44*> .TRUE.; if DOTYPE(j) = .FALSE., then type j is not used.
45*> \endverbatim
46*>
47*> \param[in] NN
48*> \verbatim
49*> NN is INTEGER
50*> The number of values of N contained in the vector NVAL.
51*> \endverbatim
52*>
53*> \param[in] NVAL
54*> \verbatim
55*> NVAL is INTEGER array, dimension (NN)
56*> The values of the matrix dimension N.
57*> \endverbatim
58*>
59*> \param[in] NRHS
60*> \verbatim
61*> NRHS is INTEGER
62*> The number of right hand side vectors to be generated for
63*> each linear system.
64*> \endverbatim
65*>
66*> \param[in] THRESH
67*> \verbatim
68*> THRESH is DOUBLE PRECISION
69*> The threshold value for the test ratios. A result is
70*> included in the output file if RESULT >= THRESH. To have
71*> every test ratio printed, use THRESH = 0.
72*> \endverbatim
73*>
74*> \param[in] TSTERR
75*> \verbatim
76*> TSTERR is LOGICAL
77*> Flag that indicates whether error exits are to be tested.
78*> \endverbatim
79*>
80*> \param[in] NMAX
81*> \verbatim
82*> NMAX is INTEGER
83*> The maximum value permitted for N, used in dimensioning the
84*> work arrays.
85*> \endverbatim
86*>
87*> \param[out] A
88*> \verbatim
89*> A is REAL array, dimension (NMAX*NMAX)
90*> \endverbatim
91*>
92*> \param[out] AFAC
93*> \verbatim
94*> AFAC is REAL array, dimension (NMAX*NMAX)
95*> \endverbatim
96*>
97*> \param[out] AINV
98*> \verbatim
99*> AINV is REAL array, dimension (NMAX*NMAX)
100*> \endverbatim
101*>
102*> \param[out] B
103*> \verbatim
104*> B is REAL array, dimension (NMAX*NRHS)
105*> \endverbatim
106*>
107*> \param[out] X
108*> \verbatim
109*> X is REAL array, dimension (NMAX*NRHS)
110*> \endverbatim
111*>
112*> \param[out] XACT
113*> \verbatim
114*> XACT is REAL array, dimension (NMAX*NRHS)
115*> \endverbatim
116*>
117*> \param[out] WORK
118*> \verbatim
119*> WORK is REAL array, dimension
120*> (NMAX*max(2,NRHS))
121*> \endverbatim
122*>
123*> \param[out] RWORK
124*> \verbatim
125*> RWORK is REAL array, dimension (NMAX+2*NRHS)
126*> \endverbatim
127*>
128*> \param[out] IWORK
129*> \verbatim
130*> IWORK is INTEGER array, dimension (2*NMAX)
131*> \endverbatim
132*>
133*> \param[in] NOUT
134*> \verbatim
135*> NOUT is INTEGER
136*> The unit number for output.
137*> \endverbatim
138*
139* Authors:
140* ========
141*
142*> \author Univ. of Tennessee
143*> \author Univ. of California Berkeley
144*> \author Univ. of Colorado Denver
145*> \author NAG Ltd.
146*
147*> \ingroup double_lin
148*
149* =====================================================================
150 SUBROUTINE sdrvsy_rook( DOTYPE, NN, NVAL, NRHS, THRESH, TSTERR,
151 $ NMAX, A, AFAC, AINV, B, X, XACT, WORK,
152 $ RWORK, IWORK, NOUT )
153*
154* -- LAPACK test routine --
155* -- LAPACK is a software package provided by Univ. of Tennessee, --
156* -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..--
157*
158* .. Scalar Arguments ..
159 LOGICAL TSTERR
160 INTEGER NMAX, NN, NOUT, NRHS
161 REAL THRESH
162* ..
163* .. Array Arguments ..
164 LOGICAL DOTYPE( * )
165 INTEGER IWORK( * ), NVAL( * )
166 REAL A( * ), AFAC( * ), AINV( * ), B( * ),
167 $ rwork( * ), work( * ), x( * ), xact( * )
168* ..
169*
170* =====================================================================
171*
172* .. Parameters ..
173 REAL ONE, ZERO
174 PARAMETER ( ONE = 1.0e+0, zero = 0.0e+0 )
175 INTEGER NTYPES, NTESTS
176 parameter( ntypes = 10, ntests = 3 )
177 INTEGER NFACT
178 parameter( nfact = 2 )
179* ..
180* .. Local Scalars ..
181 LOGICAL ZEROT
182 CHARACTER DIST, FACT, TYPE, UPLO, XTYPE
183 CHARACTER*3 PATH, MATPATH
184 INTEGER I, I1, I2, IFACT, IMAT, IN, INFO, IOFF, IUPLO,
185 $ izero, j, k, kl, ku, lda, lwork, mode, n,
186 $ nb, nbmin, nerrs, nfail, nimat, nrun, nt
187 REAL AINVNM, ANORM, CNDNUM, RCONDC
188* ..
189* .. Local Arrays ..
190 CHARACTER FACTS( NFACT ), UPLOS( 2 )
191 INTEGER ISEED( 4 ), ISEEDY( 4 )
192 REAL RESULT( NTESTS )
193* ..
194* .. External Functions ..
195 REAL SLANSY
196 EXTERNAL SLANSY
197* ..
198* .. External Subroutines ..
199 EXTERNAL aladhd, alaerh, alasvm, serrvx, sget04, slacpy,
202 $ ssytri_rook,
203 $ xlaenv
204* ..
205* .. Scalars in Common ..
206 LOGICAL LERR, OK
207 CHARACTER*32 SRNAMT
208 INTEGER INFOT, NUNIT
209* ..
210* .. Common blocks ..
211 COMMON / infoc / infot, nunit, ok, lerr
212 COMMON / srnamc / srnamt
213* ..
214* .. Intrinsic Functions ..
215 INTRINSIC max, min
216* ..
217* .. Data statements ..
218 DATA iseedy / 1988, 1989, 1990, 1991 /
219 DATA uplos / 'u', 'l' / , FACTS / 'f', 'n' /
220* ..
221* .. Executable Statements ..
222*
223* Initialize constants and the random number seed.
224*
225* Test path
226*
227 PATH( 1: 1 ) = 'single precision'
228 PATH( 2: 3 ) = 'sr'
229*
230* Path to generate matrices
231*
232 MATPATH( 1: 1 ) = 'single precision'
233 MATPATH( 2: 3 ) = 'sy'
234*
235 NRUN = 0
236 NFAIL = 0
237 NERRS = 0
238 DO 10 I = 1, 4
239 ISEED( I ) = ISEEDY( I )
240 10 CONTINUE
241 LWORK = MAX( 2*NMAX, NMAX*NRHS )
242*
243* Test the error exits
244*
245 IF( TSTERR )
246 $ CALL SERRVX( PATH, NOUT )
247 INFOT = 0
248*
249* Set the block size and minimum block size for which the block
250* routine should be used, which will be later returned by ILAENV.
251*
252 NB = 1
253 NBMIN = 2
254 CALL XLAENV( 1, NB )
255 CALL XLAENV( 2, NBMIN )
256*
257* Do for each value of N in NVAL
258*
259 DO 180 IN = 1, NN
260 N = NVAL( IN )
261 LDA = MAX( N, 1 )
262 XTYPE = 'n'
263 NIMAT = NTYPES
264.LE. IF( N0 )
265 $ NIMAT = 1
266*
267 DO 170 IMAT = 1, NIMAT
268*
269* Do the tests only if DOTYPE( IMAT ) is true.
270*
271.NOT. IF( DOTYPE( IMAT ) )
272 $ GO TO 170
273*
274* Skip types 3, 4, 5, or 6 if the matrix size is too small.
275*
276.GE..AND..LE. ZEROT = IMAT3 IMAT6
277.AND..LT. IF( ZEROT NIMAT-2 )
278 $ GO TO 170
279*
280* Do first for UPLO = 'U', then for UPLO = 'L'
281*
282 DO 160 IUPLO = 1, 2
283 UPLO = UPLOS( IUPLO )
284*
285* Begin generate the test matrix A.
286*
287* Set up parameters with SLATB4 for the matrix generator
288* based on the type of matrix to be generated.
289*
290 CALL SLATB4( MATPATH, IMAT, N, N, TYPE, KL, KU, ANORM,
291 $ MODE, CNDNUM, DIST )
292*
293* Generate a matrix with SLATMS.
294*
295 SRNAMT = 'slatms'
296 CALL SLATMS( N, N, DIST, ISEED, TYPE, RWORK, MODE,
297 $ CNDNUM, ANORM, KL, KU, UPLO, A, LDA, WORK,
298 $ INFO )
299*
300* Check error code from SLATMS and handle error.
301*
302.NE. IF( INFO0 ) THEN
303 CALL ALAERH( PATH, 'slatms', INFO, 0, UPLO, N, N, -1,
304 $ -1, -1, IMAT, NFAIL, NERRS, NOUT )
305*
306* Skip all tests for this generated matrix
307*
308 GO TO 160
309 END IF
310*
311* For types 3-6, zero one or more rows and columns of the
312* matrix to test that INFO is returned correctly.
313*
314 IF( ZEROT ) THEN
315.EQ. IF( IMAT3 ) THEN
316 IZERO = 1
317.EQ. ELSE IF( IMAT4 ) THEN
318 IZERO = N
319 ELSE
320 IZERO = N / 2 + 1
321 END IF
322*
323.LT. IF( IMAT6 ) THEN
324*
325* Set row and column IZERO to zero.
326*
327.EQ. IF( IUPLO1 ) THEN
328 IOFF = ( IZERO-1 )*LDA
329 DO 20 I = 1, IZERO - 1
330 A( IOFF+I ) = ZERO
331 20 CONTINUE
332 IOFF = IOFF + IZERO
333 DO 30 I = IZERO, N
334 A( IOFF ) = ZERO
335 IOFF = IOFF + LDA
336 30 CONTINUE
337 ELSE
338 IOFF = IZERO
339 DO 40 I = 1, IZERO - 1
340 A( IOFF ) = ZERO
341 IOFF = IOFF + LDA
342 40 CONTINUE
343 IOFF = IOFF - IZERO
344 DO 50 I = IZERO, N
345 A( IOFF+I ) = ZERO
346 50 CONTINUE
347 END IF
348 ELSE
349 IOFF = 0
350.EQ. IF( IUPLO1 ) THEN
351*
352* Set the first IZERO rows and columns to zero.
353*
354 DO 70 J = 1, N
355 I2 = MIN( J, IZERO )
356 DO 60 I = 1, I2
357 A( IOFF+I ) = ZERO
358 60 CONTINUE
359 IOFF = IOFF + LDA
360 70 CONTINUE
361 ELSE
362*
363* Set the last IZERO rows and columns to zero.
364*
365 DO 90 J = 1, N
366 I1 = MAX( J, IZERO )
367 DO 80 I = I1, N
368 A( IOFF+I ) = ZERO
369 80 CONTINUE
370 IOFF = IOFF + LDA
371 90 CONTINUE
372 END IF
373 END IF
374 ELSE
375 IZERO = 0
376 END IF
377*
378* End generate the test matrix A.
379*
380 DO 150 IFACT = 1, NFACT
381*
382* Do first for FACT = 'F', then for other values.
383*
384 FACT = FACTS( IFACT )
385*
386* Compute the condition number for comparison with
387* the value returned by DSYSVX_ROOK.
388*
389 IF( ZEROT ) THEN
390.EQ. IF( IFACT1 )
391 $ GO TO 150
392 RCONDC = ZERO
393*
394.EQ. ELSE IF( IFACT1 ) THEN
395*
396* Compute the 1-norm of A.
397*
398 ANORM = SLANSY( '1', UPLO, N, A, LDA, RWORK )
399*
400* Factor the matrix A.
401*
402 CALL SLACPY( UPLO, N, N, A, LDA, AFAC, LDA )
403 CALL SSYTRF_ROOK( UPLO, N, AFAC, LDA, IWORK, WORK,
404 $ LWORK, INFO )
405*
406* Compute inv(A) and take its norm.
407*
408 CALL SLACPY( UPLO, N, N, AFAC, LDA, AINV, LDA )
409 LWORK = (N+NB+1)*(NB+3)
410 CALL SSYTRI_ROOK( UPLO, N, AINV, LDA, IWORK,
411 $ WORK, INFO )
412 AINVNM = SLANSY( '1', UPLO, N, AINV, LDA, RWORK )
413*
414* Compute the 1-norm condition number of A.
415*
416.LE..OR..LE. IF( ANORMZERO AINVNMZERO ) THEN
417 RCONDC = ONE
418 ELSE
419 RCONDC = ( ONE / ANORM ) / AINVNM
420 END IF
421 END IF
422*
423* Form an exact solution and set the right hand side.
424*
425 SRNAMT = 'slarhs'
426 CALL SLARHS( MATPATH, XTYPE, UPLO, ' ', N, N, KL, KU,
427 $ NRHS, A, LDA, XACT, LDA, B, LDA, ISEED,
428 $ INFO )
429 XTYPE = 'c'
430*
431* --- Test SSYSV_ROOK ---
432*
433.EQ. IF( IFACT2 ) THEN
434 CALL SLACPY( UPLO, N, N, A, LDA, AFAC, LDA )
435 CALL SLACPY( 'full', N, NRHS, B, LDA, X, LDA )
436*
437* Factor the matrix and solve the system using
438* SSYSV_ROOK.
439*
440 SRNAMT = 'ssysv_rook'
441 CALL SSYSV_ROOK( UPLO, N, NRHS, AFAC, LDA, IWORK,
442 $ X, LDA, WORK, LWORK, INFO )
443*
444* Adjust the expected value of INFO to account for
445* pivoting.
446*
447 K = IZERO
448.GT. IF( K0 ) THEN
449 100 CONTINUE
450.LT. IF( IWORK( K )0 ) THEN
451.NE. IF( IWORK( K )-K ) THEN
452 K = -IWORK( K )
453 GO TO 100
454 END IF
455.NE. ELSE IF( IWORK( K )K ) THEN
456 K = IWORK( K )
457 GO TO 100
458 END IF
459 END IF
460*
461* Check error code from SSYSV_ROOK and handle error.
462*
463.NE. IF( INFOK ) THEN
464 CALL ALAERH( PATH, 'ssysv_rook', INFO, K, UPLO,
465 $ N, N, -1, -1, NRHS, IMAT, NFAIL,
466 $ NERRS, NOUT )
467 GO TO 120
468.NE. ELSE IF( INFO0 ) THEN
469 GO TO 120
470 END IF
471*
472*+ TEST 1 Reconstruct matrix from factors and compute
473* residual.
474*
475 CALL SSYT01_ROOK( UPLO, N, A, LDA, AFAC, LDA,
476 $ IWORK, AINV, LDA, RWORK,
477 $ RESULT( 1 ) )
478*
479*+ TEST 2 Compute residual of the computed solution.
480*
481 CALL SLACPY( 'full', N, NRHS, B, LDA, WORK, LDA )
482 CALL SPOT02( UPLO, N, NRHS, A, LDA, X, LDA, WORK,
483 $ LDA, RWORK, RESULT( 2 ) )
484*
485*+ TEST 3
486* Check solution from generated exact solution.
487*
488 CALL SGET04( N, NRHS, X, LDA, XACT, LDA, RCONDC,
489 $ RESULT( 3 ) )
490 NT = 3
491*
492* Print information about the tests that did not pass
493* the threshold.
494*
495 DO 110 K = 1, NT
496.GE. IF( RESULT( K )THRESH ) THEN
497.EQ..AND..EQ. IF( NFAIL0 NERRS0 )
498 $ CALL ALADHD( NOUT, PATH )
499 WRITE( NOUT, FMT = 9999 )'ssysv_rook', UPLO,
500 $ N, IMAT, K, RESULT( K )
501 NFAIL = NFAIL + 1
502 END IF
503 110 CONTINUE
504 NRUN = NRUN + NT
505 120 CONTINUE
506 END IF
507*
508 150 CONTINUE
509*
510 160 CONTINUE
511 170 CONTINUE
512 180 CONTINUE
513*
514* Print a summary of the results.
515*
516 CALL ALASVM( PATH, NOUT, NFAIL, NRUN, NERRS )
517*
518 9999 FORMAT( 1X, A, ', uplo=''', A1, ''', n =', I5, ', type ', I2,
519 $ ', test ', I2, ', ratio =', G12.5 )
520 RETURN
521*
522* End of SDRVSY_ROOK
523*
524 END
subroutine slaset(uplo, m, n, alpha, beta, a, lda)
SLASET initializes the off-diagonal elements and the diagonal elements of a matrix to given values.
Definition slaset.f:110
subroutine slacpy(uplo, m, n, a, lda, b, ldb)
SLACPY copies all or part of one two-dimensional array to another.
Definition slacpy.f:103
subroutine xlaenv(ispec, nvalue)
XLAENV
Definition xlaenv.f:81
subroutine alasvm(type, nout, nfail, nrun, nerrs)
ALASVM
Definition alasvm.f:73
subroutine aladhd(iounit, path)
ALADHD
Definition aladhd.f:90
subroutine alaerh(path, subnam, info, infoe, opts, m, n, kl, ku, n5, imat, nfail, nerrs, nout)
ALAERH
Definition alaerh.f:147
subroutine sdrvsy_rook(dotype, nn, nval, nrhs, thresh, tsterr, nmax, a, afac, ainv, b, x, xact, work, rwork, iwork, nout)
SDRVSY_ROOK
subroutine ssytrf_rook(uplo, n, a, lda, ipiv, work, lwork, info)
SSYTRF_ROOK
subroutine ssytri_rook(uplo, n, a, lda, ipiv, work, info)
SSYTRI_ROOK
subroutine ssysv_rook(uplo, n, nrhs, a, lda, ipiv, b, ldb, work, lwork, info)
SSYSV_ROOK computes the solution to system of linear equations A * X = B for SY matrices
Definition ssysv_rook.f:204
subroutine slatms(m, n, dist, iseed, sym, d, mode, cond, dmax, kl, ku, pack, a, lda, work, info)
SLATMS
Definition slatms.f:321
subroutine slarhs(path, xtype, uplo, trans, m, n, kl, ku, nrhs, a, lda, x, ldx, b, ldb, iseed, info)
SLARHS
Definition slarhs.f:205
subroutine spot02(uplo, n, nrhs, a, lda, x, ldx, b, ldb, rwork, resid)
SPOT02
Definition spot02.f:127
subroutine serrvx(path, nunit)
SERRVX
Definition serrvx.f:55
subroutine spot05(uplo, n, nrhs, a, lda, b, ldb, x, ldx, xact, ldxact, ferr, berr, reslts)
SPOT05
Definition spot05.f:164
subroutine ssyt01_rook(uplo, n, a, lda, afac, ldafac, ipiv, c, ldc, rwork, resid)
SSYT01_ROOK
subroutine sget04(n, nrhs, x, ldx, xact, ldxact, rcond, resid)
SGET04
Definition sget04.f:102
subroutine slatb4(path, imat, m, n, type, kl, ku, anorm, mode, cndnum, dist)
SLATB4
Definition slatb4.f:120
#define min(a, b)
Definition macros.h:20
#define max(a, b)
Definition macros.h:21