You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
120 lines
3.4 KiB
120 lines
3.4 KiB
2 years ago
|
*> \brief zminMax tests the robustness and precision of the double-valued intrinsic operators MIN and MAX
|
||
|
*
|
||
|
* =========== DOCUMENTATION ===========
|
||
|
*
|
||
|
* Online html documentation available at
|
||
|
* http://www.netlib.org/lapack/explore-html/
|
||
|
*
|
||
|
* Authors:
|
||
|
* ========
|
||
|
*
|
||
|
*> \author Weslley S. Pereira, University of Colorado Denver, U.S.
|
||
|
*
|
||
|
*> \verbatim
|
||
|
*>
|
||
|
*> Tests with pairs of numbers (x,y):
|
||
|
*> Inf inputs where x < y:
|
||
|
*> (1) (-Inf, 0)
|
||
|
*> (2) ( 0 , Inf)
|
||
|
*> (3) (-Inf, Inf)
|
||
|
*> Inf inputs where x > y:
|
||
|
*> (4) ( 0 ,-Inf)
|
||
|
*> (5) ( Inf, 0)
|
||
|
*> (6) ( Inf,-Inf)
|
||
|
*> NaN inputs to test NaN propagation:
|
||
|
*> (7) ( 0 , NaN)
|
||
|
*> (8) ( NaN, 0)
|
||
|
*> The program tests MIN(x,y) and MAX(x,y) for every pair
|
||
|
*>
|
||
|
*> \endverbatim
|
||
|
*
|
||
|
*> \ingroup auxOTHERauxiliary
|
||
|
*
|
||
|
* =====================================================================
|
||
|
program zmul
|
||
|
*
|
||
|
* -- LAPACK test routine --
|
||
|
* Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd..
|
||
|
|
||
|
* ..
|
||
|
* .. Parameters ..
|
||
|
integer n
|
||
|
parameter ( n = 8 )
|
||
|
double precision zero
|
||
|
parameter ( zero = 0.0d0 )
|
||
|
* ..
|
||
|
* .. Local Variables ..
|
||
|
integer i, nFailingTests, nTests
|
||
|
double precision aInf, aNaN, OV, R, X(n), Y(n)
|
||
|
*
|
||
|
* .. Intrinsic Functions ..
|
||
|
intrinsic HUGE, MIN, MAX
|
||
|
|
||
|
*
|
||
|
* .. Initialize error counts ..
|
||
|
nFailingTests = 0
|
||
|
nTests = 0
|
||
|
*
|
||
|
* .. Inf and NaN entries ..
|
||
|
OV = HUGE(0.0d0)
|
||
|
aInf = OV * 2
|
||
|
aNaN = aInf / aInf
|
||
|
X = (/ -aInf, zero, -aInf, zero, aInf, aInf, zero, aNaN /)
|
||
|
Y = (/ zero, aInf, aInf, -aInf, zero, -aInf, aNaN, zero /)
|
||
|
|
||
|
*
|
||
|
* .. Tests ..
|
||
|
*
|
||
|
do 10 i = 1, 3
|
||
|
nTests = nTests + 2
|
||
|
R = MIN( X(i), Y(i) )
|
||
|
if( R .ne. X(i) ) then
|
||
|
nFailingTests = nFailingTests + 1
|
||
|
WRITE( *, FMT = 9998 ) 'i',i, 'MIN', X(i), Y(i), R
|
||
|
endif
|
||
|
R = MAX( X(i), Y(i) )
|
||
|
if( R .ne. Y(i) ) then
|
||
|
nFailingTests = nFailingTests + 1
|
||
|
WRITE( *, FMT = 9998 ) 'i',i, 'MAX', X(i), Y(i), R
|
||
|
endif
|
||
|
10 continue
|
||
|
do 20 i = 4, 6
|
||
|
nTests = nTests + 2
|
||
|
R = MIN( X(i), Y(i) )
|
||
|
if( R .ne. Y(i) ) then
|
||
|
nFailingTests = nFailingTests + 1
|
||
|
WRITE( *, FMT = 9998 ) 'i',i, 'MIN', X(i), Y(i), R
|
||
|
endif
|
||
|
R = MAX( X(i), Y(i) )
|
||
|
if( R .ne. X(i) ) then
|
||
|
nFailingTests = nFailingTests + 1
|
||
|
WRITE( *, FMT = 9998 ) 'i',i, 'MAX', X(i), Y(i), R
|
||
|
endif
|
||
|
20 continue
|
||
|
do 30 i = 7, 8
|
||
|
nTests = nTests + 2
|
||
|
R = MIN( X(i), Y(i) )
|
||
|
if( R .eq. R ) then
|
||
|
nFailingTests = nFailingTests + 1
|
||
|
WRITE( *, FMT = 9998 ) 'i',i, 'MIN', X(i), Y(i), R
|
||
|
endif
|
||
|
R = MAX( X(i), Y(i) )
|
||
|
if( R .eq. R ) then
|
||
|
nFailingTests = nFailingTests + 1
|
||
|
WRITE( *, FMT = 9998 ) 'i',i, 'MAX', X(i), Y(i), R
|
||
|
endif
|
||
|
30 continue
|
||
|
*
|
||
|
if( nFailingTests .gt. 0 ) then
|
||
|
print *, "# ", nTests-nFailingTests, " tests out of ", nTests,
|
||
|
$ " pass for intrinsic MIN and MAX,", nFailingTests," fail."
|
||
|
else
|
||
|
print *, "# All tests pass for intrinsic MIN and MAX."
|
||
|
endif
|
||
|
*
|
||
|
* .. Formats ..
|
||
|
9998 FORMAT( '[',A1,I1, '] ', A3, '(', F5.0, ',', F5.0, ') = ', F5.0 )
|
||
|
*
|
||
|
* End of zmul
|
||
|
*
|
||
|
END
|