| @@ -30,17 +30,14 @@ | |||||
| *> \author Univ. of Colorado Denver | *> \author Univ. of Colorado Denver | ||||
| *> \author NAG Ltd. | *> \author NAG Ltd. | ||||
| * | * | ||||
| *> \date April 2012 | |||||
| * | |||||
| *> \ingroup complex_blas_testing | *> \ingroup complex_blas_testing | ||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| PROGRAM CBLAT1 | PROGRAM CBLAT1 | ||||
| * | * | ||||
| * -- Reference BLAS test routine (version 3.7.0) -- | |||||
| * -- Reference BLAS test routine -- | |||||
| * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | ||||
| * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | ||||
| * April 2012 | |||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| * | * | ||||
| @@ -86,6 +83,9 @@ | |||||
| * | * | ||||
| 99999 FORMAT (' Complex BLAS Test Program Results',/1X) | 99999 FORMAT (' Complex BLAS Test Program Results',/1X) | ||||
| 99998 FORMAT (' ----- PASS -----') | 99998 FORMAT (' ----- PASS -----') | ||||
| * | |||||
| * End of CBLAT1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE HEADER | SUBROUTINE HEADER | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -114,11 +114,15 @@ | |||||
| RETURN | RETURN | ||||
| * | * | ||||
| 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | ||||
| * | |||||
| * End of HEADER | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK1(SFAC) | SUBROUTINE CHECK1(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| INTEGER NOUT | INTEGER NOUT | ||||
| PARAMETER (NOUT=6) | |||||
| REAL THRESH | |||||
| PARAMETER (NOUT=6, THRESH=10.0E0) | |||||
| * .. Scalar Arguments .. | * .. Scalar Arguments .. | ||||
| REAL SFAC | REAL SFAC | ||||
| * .. Scalars in Common .. | * .. Scalars in Common .. | ||||
| @@ -127,18 +131,18 @@ | |||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| COMPLEX CA | COMPLEX CA | ||||
| REAL SA | REAL SA | ||||
| INTEGER I, J, LEN, NP1 | |||||
| INTEGER I, IX, J, LEN, NP1 | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| COMPLEX CTRUE5(8,5,2), CTRUE6(8,5,2), CV(8,5,2), CX(8), | |||||
| + MWPCS(5), MWPCT(5) | |||||
| COMPLEX CTRUE5(8,5,2), CTRUE6(8,5,2), CV(8,5,2), CVR(8), | |||||
| + CX(8), CXR(15), MWPCS(5), MWPCT(5) | |||||
| REAL STRUE2(5), STRUE4(5) | REAL STRUE2(5), STRUE4(5) | ||||
| INTEGER ITRUE3(5) | |||||
| INTEGER ITRUE3(5), ITRUEC(5) | |||||
| * .. External Functions .. | * .. External Functions .. | ||||
| REAL SCASUM, SCNRM2 | REAL SCASUM, SCNRM2 | ||||
| INTEGER ICAMAX | INTEGER ICAMAX | ||||
| EXTERNAL SCASUM, SCNRM2, ICAMAX | EXTERNAL SCASUM, SCNRM2, ICAMAX | ||||
| * .. External Subroutines .. | * .. External Subroutines .. | ||||
| EXTERNAL CSCAL, CSSCAL, CTEST, ITEST1, STEST1 | |||||
| EXTERNAL CB1NRM2, CSCAL, CSSCAL, CTEST, ITEST1, STEST1 | |||||
| * .. Intrinsic Functions .. | * .. Intrinsic Functions .. | ||||
| INTRINSIC MAX | INTRINSIC MAX | ||||
| * .. Common blocks .. | * .. Common blocks .. | ||||
| @@ -173,6 +177,9 @@ | |||||
| + (7.0E0,2.0E0), (0.3E0,0.1E0), (5.0E0,8.0E0), | + (7.0E0,2.0E0), (0.3E0,0.1E0), (5.0E0,8.0E0), | ||||
| + (0.5E0,0.0E0), (6.0E0,9.0E0), (0.0E0,0.5E0), | + (0.5E0,0.0E0), (6.0E0,9.0E0), (0.0E0,0.5E0), | ||||
| + (8.0E0,3.0E0), (0.0E0,0.2E0), (9.0E0,4.0E0)/ | + (8.0E0,3.0E0), (0.0E0,0.2E0), (9.0E0,4.0E0)/ | ||||
| DATA CVR/(8.0E0,8.0E0), (-7.0E0,-7.0E0), | |||||
| + (9.0E0,9.0E0), (5.0E0,5.0E0), (9.0E0,9.0E0), | |||||
| + (8.0E0,8.0E0), (7.0E0,7.0E0), (7.0E0,7.0E0)/ | |||||
| DATA STRUE2/0.0E0, 0.5E0, 0.6E0, 0.7E0, 0.8E0/ | DATA STRUE2/0.0E0, 0.5E0, 0.6E0, 0.7E0, 0.8E0/ | ||||
| DATA STRUE4/0.0E0, 0.7E0, 1.0E0, 1.3E0, 1.6E0/ | DATA STRUE4/0.0E0, 0.7E0, 1.0E0, 1.3E0, 1.6E0/ | ||||
| DATA ((CTRUE5(I,J,1),I=1,8),J=1,5)/(0.1E0,0.1E0), | DATA ((CTRUE5(I,J,1),I=1,8),J=1,5)/(0.1E0,0.1E0), | ||||
| @@ -238,6 +245,7 @@ | |||||
| + (0.15E0,0.00E0), (6.0E0,9.0E0), (0.00E0,0.15E0), | + (0.15E0,0.00E0), (6.0E0,9.0E0), (0.00E0,0.15E0), | ||||
| + (8.0E0,3.0E0), (0.00E0,0.06E0), (9.0E0,4.0E0)/ | + (8.0E0,3.0E0), (0.00E0,0.06E0), (9.0E0,4.0E0)/ | ||||
| DATA ITRUE3/0, 1, 2, 2, 2/ | DATA ITRUE3/0, 1, 2, 2, 2/ | ||||
| DATA ITRUEC/0, 1, 1, 1, 1/ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| DO 60 INCX = 1, 2 | DO 60 INCX = 1, 2 | ||||
| DO 40 NP1 = 1, 5 | DO 40 NP1 = 1, 5 | ||||
| @@ -249,6 +257,10 @@ | |||||
| 20 CONTINUE | 20 CONTINUE | ||||
| IF (ICASE.EQ.6) THEN | IF (ICASE.EQ.6) THEN | ||||
| * .. SCNRM2 .. | * .. SCNRM2 .. | ||||
| * Test scaling when some entries are tiny or huge | |||||
| CALL CB1NRM2(N,(INCX-2)*2,THRESH) | |||||
| CALL CB1NRM2(N,INCX,THRESH) | |||||
| * Test with hardcoded mid range entries | |||||
| CALL STEST1(SCNRM2(N,CX,INCX),STRUE2(NP1),STRUE2(NP1), | CALL STEST1(SCNRM2(N,CX,INCX),STRUE2(NP1),STRUE2(NP1), | ||||
| + SFAC) | + SFAC) | ||||
| ELSE IF (ICASE.EQ.7) THEN | ELSE IF (ICASE.EQ.7) THEN | ||||
| @@ -268,12 +280,25 @@ | |||||
| ELSE IF (ICASE.EQ.10) THEN | ELSE IF (ICASE.EQ.10) THEN | ||||
| * .. ICAMAX .. | * .. ICAMAX .. | ||||
| CALL ITEST1(ICAMAX(N,CX,INCX),ITRUE3(NP1)) | CALL ITEST1(ICAMAX(N,CX,INCX),ITRUE3(NP1)) | ||||
| DO 160 I = 1, LEN | |||||
| CX(I) = (42.0E0,43.0E0) | |||||
| 160 CONTINUE | |||||
| CALL ITEST1(ICAMAX(N,CX,INCX),ITRUEC(NP1)) | |||||
| ELSE | ELSE | ||||
| WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | ||||
| STOP | STOP | ||||
| END IF | END IF | ||||
| * | * | ||||
| 40 CONTINUE | 40 CONTINUE | ||||
| IF (ICASE.EQ.10) THEN | |||||
| N = 8 | |||||
| IX = 1 | |||||
| DO 180 I = 1, N | |||||
| CXR(IX) = CVR(I) | |||||
| IX = IX + INCX | |||||
| 180 CONTINUE | |||||
| CALL ITEST1(ICAMAX(N,CXR,INCX),3) | |||||
| END IF | |||||
| 60 CONTINUE | 60 CONTINUE | ||||
| * | * | ||||
| INCX = 1 | INCX = 1 | ||||
| @@ -315,6 +340,9 @@ | |||||
| CALL CTEST(5,CX,MWPCT,MWPCS,SFAC) | CALL CTEST(5,CX,MWPCT,MWPCS,SFAC) | ||||
| END IF | END IF | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK2(SFAC) | SUBROUTINE CHECK2(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -327,11 +355,13 @@ | |||||
| LOGICAL PASS | LOGICAL PASS | ||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| COMPLEX CA | COMPLEX CA | ||||
| INTEGER I, J, KI, KN, KSIZE, LENX, LENY, MX, MY | |||||
| INTEGER I, J, KI, KN, KSIZE, LENX, LENY, LINCX, LINCY, | |||||
| + MX, MY | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| COMPLEX CDOT(1), CSIZE1(4), CSIZE2(7,2), CSIZE3(14), | COMPLEX CDOT(1), CSIZE1(4), CSIZE2(7,2), CSIZE3(14), | ||||
| + CT10X(7,4,4), CT10Y(7,4,4), CT6(4,4), CT7(4,4), | + CT10X(7,4,4), CT10Y(7,4,4), CT6(4,4), CT7(4,4), | ||||
| + CT8(7,4,4), CX(7), CX1(7), CY(7), CY1(7) | |||||
| + CT8(7,4,4), CTY0(1), CX(7), CX0(1), CX1(7), | |||||
| + CY(7), CY0(1), CY1(7) | |||||
| INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | ||||
| * .. External Functions .. | * .. External Functions .. | ||||
| COMPLEX CDOTC, CDOTU | COMPLEX CDOTC, CDOTU | ||||
| @@ -546,6 +576,23 @@ | |||||
| * .. CCOPY .. | * .. CCOPY .. | ||||
| CALL CCOPY(N,CX,INCX,CY,INCY) | CALL CCOPY(N,CX,INCX,CY,INCY) | ||||
| CALL CTEST(LENY,CY,CT10Y(1,KN,KI),CSIZE3,1.0E0) | CALL CTEST(LENY,CY,CT10Y(1,KN,KI),CSIZE3,1.0E0) | ||||
| IF (KI.EQ.1) THEN | |||||
| CX0(1) = (42.0E0,43.0E0) | |||||
| CY0(1) = (44.0E0,45.0E0) | |||||
| IF (N.EQ.0) THEN | |||||
| CTY0(1) = CY0(1) | |||||
| ELSE | |||||
| CTY0(1) = CX0(1) | |||||
| END IF | |||||
| LINCX = INCX | |||||
| INCX = 0 | |||||
| LINCY = INCY | |||||
| INCY = 0 | |||||
| CALL CCOPY(N,CX0,INCX,CY0,INCY) | |||||
| CALL CTEST(1,CY0,CTY0,CSIZE3,1.0E0) | |||||
| INCX = LINCX | |||||
| INCY = LINCY | |||||
| END IF | |||||
| ELSE IF (ICASE.EQ.5) THEN | ELSE IF (ICASE.EQ.5) THEN | ||||
| * .. CSWAP .. | * .. CSWAP .. | ||||
| CALL CSWAP(N,CX,INCX,CY,INCY) | CALL CSWAP(N,CX,INCX,CY,INCY) | ||||
| @@ -559,6 +606,9 @@ | |||||
| 40 CONTINUE | 40 CONTINUE | ||||
| 60 CONTINUE | 60 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK2 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * ********************************* STEST ************************** | * ********************************* STEST ************************** | ||||
| @@ -615,6 +665,9 @@ | |||||
| + ' COMP(I) TRUE(I) DIFFERENCE', | + ' COMP(I) TRUE(I) DIFFERENCE', | ||||
| + ' SIZE(I)',/1X) | + ' SIZE(I)',/1X) | ||||
| 99997 FORMAT (1X,I4,I3,3I5,I3,2E36.8,2E12.4) | 99997 FORMAT (1X,I4,I3,3I5,I3,2E36.8,2E12.4) | ||||
| * | |||||
| * End of STEST | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | ||||
| * ************************* STEST1 ***************************** | * ************************* STEST1 ***************************** | ||||
| @@ -640,6 +693,9 @@ | |||||
| CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * | * | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of STEST1 | |||||
| * | |||||
| END | END | ||||
| REAL FUNCTION SDIFF(SA,SB) | REAL FUNCTION SDIFF(SA,SB) | ||||
| * ********************************* SDIFF ************************** | * ********************************* SDIFF ************************** | ||||
| @@ -650,6 +706,9 @@ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| SDIFF = SA - SB | SDIFF = SA - SB | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of SDIFF | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CTEST(LEN,CCOMP,CTRUE,CSIZE,SFAC) | SUBROUTINE CTEST(LEN,CCOMP,CTRUE,CSIZE,SFAC) | ||||
| * **************************** CTEST ***************************** | * **************************** CTEST ***************************** | ||||
| @@ -681,6 +740,9 @@ | |||||
| * | * | ||||
| CALL STEST(2*LEN,SCOMP,STRUE,SSIZE,SFAC) | CALL STEST(2*LEN,SCOMP,STRUE,SSIZE,SFAC) | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CTEST | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE ITEST1(ICOMP,ITRUE) | SUBROUTINE ITEST1(ICOMP,ITRUE) | ||||
| * ********************************* ITEST1 ************************* | * ********************************* ITEST1 ************************* | ||||
| @@ -721,4 +783,232 @@ | |||||
| + ' COMP TRUE DIFFERENCE', | + ' COMP TRUE DIFFERENCE', | ||||
| + /1X) | + /1X) | ||||
| 99997 FORMAT (1X,I4,I3,3I5,2I36,I12) | 99997 FORMAT (1X,I4,I3,3I5,2I36,I12) | ||||
| * | |||||
| * End of ITEST1 | |||||
| * | |||||
| END | |||||
| SUBROUTINE CB1NRM2(N,INCX,THRESH) | |||||
| * Compare NRM2 with a reference computation using combinations | |||||
| * of the following values: | |||||
| * | |||||
| * 0, very small, small, ulp, 1, 1/ulp, big, very big, infinity, NaN | |||||
| * | |||||
| * one of these values is used to initialize x(1) and x(2:N) is | |||||
| * filled with random values from [-1,1] scaled by another of | |||||
| * these values. | |||||
| * | |||||
| * This routine is adapted from the test suite provided by | |||||
| * Anderson E. (2017) | |||||
| * Algorithm 978: Safe Scaling in the Level 1 BLAS | |||||
| * ACM Trans Math Softw 44:1--28 | |||||
| * https://doi.org/10.1145/3061665 | |||||
| * | |||||
| * .. Scalar Arguments .. | |||||
| INTEGER INCX, N | |||||
| REAL THRESH | |||||
| * | |||||
| * ===================================================================== | |||||
| * .. Parameters .. | |||||
| INTEGER NMAX, NOUT, NV | |||||
| PARAMETER (NMAX=20, NOUT=6, NV=10) | |||||
| REAL HALF, ONE, THREE, TWO, ZERO | |||||
| PARAMETER (HALF=0.5E+0, ONE=1.0E+0, TWO= 2.0E+0, | |||||
| & THREE=3.0E+0, ZERO=0.0E+0) | |||||
| * .. External Functions .. | |||||
| REAL SCNRM2 | |||||
| EXTERNAL SCNRM2 | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC AIMAG, ABS, CMPLX, MAX, MIN, REAL, SQRT | |||||
| * .. Model parameters .. | |||||
| REAL BIGNUM, SAFMAX, SAFMIN, SMLNUM, ULP | |||||
| PARAMETER (BIGNUM=0.1014120480E+32, | |||||
| & SAFMAX=0.8507059173E+38, | |||||
| & SAFMIN=0.1175494351E-37, | |||||
| & SMLNUM=0.9860761315E-31, | |||||
| & ULP=0.1192092896E-06) | |||||
| * .. Local Scalars .. | |||||
| COMPLEX ROGUE | |||||
| REAL SNRM, TRAT, V0, V1, WORKSSQ, Y1, Y2, | |||||
| & YMAX, YMIN, YNRM, ZNRM | |||||
| INTEGER I, IV, IW, IX, KS | |||||
| LOGICAL FIRST | |||||
| * .. Local Arrays .. | |||||
| COMPLEX X(NMAX), Z(NMAX) | |||||
| REAL VALUES(NV), WORK(NMAX) | |||||
| * .. Executable Statements .. | |||||
| VALUES(1) = ZERO | |||||
| VALUES(2) = TWO*SAFMIN | |||||
| VALUES(3) = SMLNUM | |||||
| VALUES(4) = ULP | |||||
| VALUES(5) = ONE | |||||
| VALUES(6) = ONE / ULP | |||||
| VALUES(7) = BIGNUM | |||||
| VALUES(8) = SAFMAX | |||||
| VALUES(9) = SXVALS(V0,2) | |||||
| VALUES(10) = SXVALS(V0,3) | |||||
| ROGUE = CMPLX(1234.5678E+0,-1234.5678E+0) | |||||
| FIRST = .TRUE. | |||||
| * | |||||
| * Check that the arrays are large enough | |||||
| * | |||||
| IF (N*ABS(INCX).GT.NMAX) THEN | |||||
| WRITE (NOUT,99) "SCNRM2", NMAX, INCX, N, N*ABS(INCX) | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Zero-sized inputs are tested in STEST1. | |||||
| IF (N.LE.0) THEN | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Generate 2*(N-1) values in (-1,1). | |||||
| * | |||||
| KS = 2*(N-1) | |||||
| DO I = 1, KS | |||||
| CALL RANDOM_NUMBER(WORK(I)) | |||||
| WORK(I) = ONE - TWO*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Compute the sum of squares of the random values | |||||
| * by an unscaled algorithm. | |||||
| * | |||||
| WORKSSQ = ZERO | |||||
| DO I = 1, KS | |||||
| WORKSSQ = WORKSSQ + WORK(I)*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Construct the test vector with one known value | |||||
| * and the rest from the random work array multiplied | |||||
| * by a scaling factor. | |||||
| * | |||||
| DO IV = 1, NV | |||||
| V0 = VALUES(IV) | |||||
| IF (ABS(V0).GT.ONE) THEN | |||||
| V0 = V0*HALF*HALF | |||||
| END IF | |||||
| Z(1) = CMPLX(V0,-THREE*V0) | |||||
| DO IW = 1, NV | |||||
| V1 = VALUES(IW) | |||||
| IF (ABS(V1).GT.ONE) THEN | |||||
| V1 = (V1*HALF) / SQRT(REAL(KS+1)) | |||||
| END IF | |||||
| DO I = 1, N-1 | |||||
| Z(I+1) = CMPLX(V1*WORK(2*I-1),V1*WORK(2*I)) | |||||
| END DO | |||||
| * | |||||
| * Compute the expected value of the 2-norm | |||||
| * | |||||
| Y1 = ABS(V0) * SQRT(10.0E0) | |||||
| IF (N.GT.1) THEN | |||||
| Y2 = ABS(V1)*SQRT(WORKSSQ) | |||||
| ELSE | |||||
| Y2 = ZERO | |||||
| END IF | |||||
| YMIN = MIN(Y1, Y2) | |||||
| YMAX = MAX(Y1, Y2) | |||||
| * | |||||
| * Expected value is NaN if either is NaN. The test | |||||
| * for YMIN == YMAX avoids further computation if both | |||||
| * are infinity. | |||||
| * | |||||
| IF ((Y1.NE.Y1).OR.(Y2.NE.Y2)) THEN | |||||
| * add to propagate NaN | |||||
| YNRM = Y1 + Y2 | |||||
| ELSE IF (YMIN == YMAX) THEN | |||||
| YNRM = SQRT(TWO)*YMAX | |||||
| ELSE IF (YMAX == ZERO) THEN | |||||
| YNRM = ZERO | |||||
| ELSE | |||||
| YNRM = YMAX*SQRT(ONE + (YMIN / YMAX)**2) | |||||
| END IF | |||||
| * | |||||
| * Fill the input array to SCNRM2 with steps of incx | |||||
| * | |||||
| DO I = 1, N | |||||
| X(I) = ROGUE | |||||
| END DO | |||||
| IX = 1 | |||||
| IF (INCX.LT.0) IX = 1 - (N-1)*INCX | |||||
| DO I = 1, N | |||||
| X(IX) = Z(I) | |||||
| IX = IX + INCX | |||||
| END DO | |||||
| * | |||||
| * Call SCNRM2 to compute the 2-norm | |||||
| * | |||||
| SNRM = SCNRM2(N,X,INCX) | |||||
| * | |||||
| * Compare SNRM and ZNRM. Roundoff error grows like O(n) | |||||
| * in this implementation so we scale the test ratio accordingly. | |||||
| * | |||||
| IF (INCX.EQ.0) THEN | |||||
| Y1 = ABS(REAL(X(1))) | |||||
| Y2 = ABS(AIMAG(X(1))) | |||||
| YMIN = MIN(Y1, Y2) | |||||
| YMAX = MAX(Y1, Y2) | |||||
| IF ((Y1.NE.Y1).OR.(Y2.NE.Y2)) THEN | |||||
| * add to propagate NaN | |||||
| ZNRM = Y1 + Y2 | |||||
| ELSE IF (YMIN == YMAX) THEN | |||||
| ZNRM = SQRT(TWO)*YMAX | |||||
| ELSE IF (YMAX == ZERO) THEN | |||||
| ZNRM = ZERO | |||||
| ELSE | |||||
| ZNRM = YMAX * SQRT(ONE + (YMIN / YMAX)**2) | |||||
| END IF | |||||
| ZNRM = SQRT(REAL(n)) * ZNRM | |||||
| ELSE | |||||
| ZNRM = YNRM | |||||
| END IF | |||||
| * | |||||
| * The tests for NaN rely on the compiler not being overly | |||||
| * aggressive and removing the statements altogether. | |||||
| IF ((SNRM.NE.SNRM).OR.(ZNRM.NE.ZNRM)) THEN | |||||
| IF ((SNRM.NE.SNRM).NEQV.(ZNRM.NE.ZNRM)) THEN | |||||
| TRAT = ONE / ULP | |||||
| ELSE | |||||
| TRAT = ZERO | |||||
| END IF | |||||
| ELSE IF (ZNRM == ZERO) THEN | |||||
| TRAT = SNRM / ULP | |||||
| ELSE | |||||
| TRAT = (ABS(SNRM-ZNRM) / ZNRM) / (TWO*REAL(N)*ULP) | |||||
| END IF | |||||
| IF ((TRAT.NE.TRAT).OR.(TRAT.GE.THRESH)) THEN | |||||
| IF (FIRST) THEN | |||||
| FIRST = .FALSE. | |||||
| WRITE(NOUT,99999) | |||||
| END IF | |||||
| WRITE (NOUT,98) "SCNRM2", N, INCX, IV, IW, TRAT | |||||
| END IF | |||||
| END DO | |||||
| END DO | |||||
| 99999 FORMAT (' FAIL') | |||||
| 99 FORMAT ( ' Not enough space to test ', A6, ': NMAX = ',I6, | |||||
| + ', INCX = ',I6,/,' N = ',I6,', must be at least ',I6 ) | |||||
| 98 FORMAT( 1X, A6, ': N=', I6,', INCX=', I4, ', IV=', I2, ', IW=', | |||||
| + I2, ', test=', E15.8 ) | |||||
| RETURN | |||||
| CONTAINS | |||||
| REAL FUNCTION SXVALS(XX,K) | |||||
| * .. Scalar Arguments .. | |||||
| REAL XX | |||||
| INTEGER K | |||||
| * .. Local Scalars .. | |||||
| REAL X, Y, YY, Z | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC HUGE | |||||
| * .. Executable Statements .. | |||||
| Y = HUGE(XX) | |||||
| Z = YY | |||||
| IF (K.EQ.1) THEN | |||||
| X = -Z | |||||
| ELSE IF (K.EQ.2) THEN | |||||
| X = Z | |||||
| ELSE IF (K.EQ.3) THEN | |||||
| X = Z / Z | |||||
| END IF | |||||
| SXVALS = X | |||||
| RETURN | |||||
| END | |||||
| END | END | ||||
| @@ -30,17 +30,14 @@ | |||||
| *> \author Univ. of Colorado Denver | *> \author Univ. of Colorado Denver | ||||
| *> \author NAG Ltd. | *> \author NAG Ltd. | ||||
| * | * | ||||
| *> \date April 2012 | |||||
| * | |||||
| *> \ingroup double_blas_testing | *> \ingroup double_blas_testing | ||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| PROGRAM DBLAT1 | PROGRAM DBLAT1 | ||||
| * | * | ||||
| * -- Reference BLAS test routine (version 3.8.0) -- | |||||
| * -- Reference BLAS test routine -- | |||||
| * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | ||||
| * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | ||||
| * April 2012 | |||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| * | * | ||||
| @@ -91,6 +88,9 @@ | |||||
| * | * | ||||
| 99999 FORMAT (' Real BLAS Test Program Results',/1X) | 99999 FORMAT (' Real BLAS Test Program Results',/1X) | ||||
| 99998 FORMAT (' ----- PASS -----') | 99998 FORMAT (' ----- PASS -----') | ||||
| * | |||||
| * End of DBLAT1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE HEADER | SUBROUTINE HEADER | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -122,6 +122,9 @@ | |||||
| RETURN | RETURN | ||||
| * | * | ||||
| 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | ||||
| * | |||||
| * End of HEADER | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK0(SFAC) | SUBROUTINE CHECK0(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -238,28 +241,33 @@ | |||||
| END IF | END IF | ||||
| 20 CONTINUE | 20 CONTINUE | ||||
| 40 RETURN | 40 RETURN | ||||
| * | |||||
| * End of CHECK0 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK1(SFAC) | SUBROUTINE CHECK1(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| DOUBLE PRECISION THRESH | |||||
| INTEGER NOUT | INTEGER NOUT | ||||
| PARAMETER (NOUT=6) | |||||
| PARAMETER (NOUT=6, THRESH=10.0D0) | |||||
| * .. Scalar Arguments .. | * .. Scalar Arguments .. | ||||
| DOUBLE PRECISION SFAC | DOUBLE PRECISION SFAC | ||||
| * .. Scalars in Common .. | * .. Scalars in Common .. | ||||
| INTEGER ICASE, INCX, INCY, N | INTEGER ICASE, INCX, INCY, N | ||||
| LOGICAL PASS | LOGICAL PASS | ||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| INTEGER I, LEN, NP1 | |||||
| INTEGER I, IX, LEN, NP1 | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| DOUBLE PRECISION DTRUE1(5), DTRUE3(5), DTRUE5(8,5,2), DV(8,5,2), | DOUBLE PRECISION DTRUE1(5), DTRUE3(5), DTRUE5(8,5,2), DV(8,5,2), | ||||
| + SA(10), STEMP(1), STRUE(8), SX(8) | |||||
| INTEGER ITRUE2(5) | |||||
| + DVR(8), SA(10), STEMP(1), STRUE(8), SX(8), | |||||
| + SXR(15) | |||||
| INTEGER ITRUE2(5), ITRUEC(5) | |||||
| * .. External Functions .. | * .. External Functions .. | ||||
| DOUBLE PRECISION DASUM, DNRM2 | DOUBLE PRECISION DASUM, DNRM2 | ||||
| INTEGER IDAMAX | INTEGER IDAMAX | ||||
| EXTERNAL DASUM, DNRM2, IDAMAX | EXTERNAL DASUM, DNRM2, IDAMAX | ||||
| * .. External Subroutines .. | * .. External Subroutines .. | ||||
| EXTERNAL ITEST1, DSCAL, STEST, STEST1 | |||||
| EXTERNAL ITEST1, DB1NRM2, DSCAL, STEST, STEST1 | |||||
| * .. Intrinsic Functions .. | * .. Intrinsic Functions .. | ||||
| INTRINSIC MAX | INTRINSIC MAX | ||||
| * .. Common blocks .. | * .. Common blocks .. | ||||
| @@ -280,6 +288,8 @@ | |||||
| + 0.2D0, 3.0D0, -0.6D0, 5.0D0, 0.3D0, 2.0D0, | + 0.2D0, 3.0D0, -0.6D0, 5.0D0, 0.3D0, 2.0D0, | ||||
| + 2.0D0, 2.0D0, 0.1D0, 4.0D0, -0.3D0, 6.0D0, | + 2.0D0, 2.0D0, 0.1D0, 4.0D0, -0.3D0, 6.0D0, | ||||
| + -0.5D0, 7.0D0, -0.1D0, 3.0D0/ | + -0.5D0, 7.0D0, -0.1D0, 3.0D0/ | ||||
| DATA DVR/8.0D0, -7.0D0, 9.0D0, 5.0D0, 9.0D0, 8.0D0, | |||||
| + 7.0D0, 7.0D0/ | |||||
| DATA DTRUE1/0.0D0, 0.3D0, 0.5D0, 0.7D0, 0.6D0/ | DATA DTRUE1/0.0D0, 0.3D0, 0.5D0, 0.7D0, 0.6D0/ | ||||
| DATA DTRUE3/0.0D0, 0.3D0, 0.7D0, 1.1D0, 1.0D0/ | DATA DTRUE3/0.0D0, 0.3D0, 0.7D0, 1.1D0, 1.0D0/ | ||||
| DATA DTRUE5/0.10D0, 2.0D0, 2.0D0, 2.0D0, 2.0D0, | DATA DTRUE5/0.10D0, 2.0D0, 2.0D0, 2.0D0, 2.0D0, | ||||
| @@ -297,6 +307,7 @@ | |||||
| + 0.03D0, 4.0D0, -0.09D0, 6.0D0, -0.15D0, 7.0D0, | + 0.03D0, 4.0D0, -0.09D0, 6.0D0, -0.15D0, 7.0D0, | ||||
| + -0.03D0, 3.0D0/ | + -0.03D0, 3.0D0/ | ||||
| DATA ITRUE2/0, 1, 2, 2, 3/ | DATA ITRUE2/0, 1, 2, 2, 3/ | ||||
| DATA ITRUEC/0, 1, 1, 1, 1/ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| DO 80 INCX = 1, 2 | DO 80 INCX = 1, 2 | ||||
| DO 60 NP1 = 1, 5 | DO 60 NP1 = 1, 5 | ||||
| @@ -309,6 +320,10 @@ | |||||
| * | * | ||||
| IF (ICASE.EQ.7) THEN | IF (ICASE.EQ.7) THEN | ||||
| * .. DNRM2 .. | * .. DNRM2 .. | ||||
| * Test scaling when some entries are tiny or huge | |||||
| CALL DB1NRM2(N,(INCX-2)*2,THRESH) | |||||
| CALL DB1NRM2(N,INCX,THRESH) | |||||
| * Test with hardcoded mid range entries | |||||
| STEMP(1) = DTRUE1(NP1) | STEMP(1) = DTRUE1(NP1) | ||||
| CALL STEST1(DNRM2(N,SX,INCX),STEMP(1),STEMP,SFAC) | CALL STEST1(DNRM2(N,SX,INCX),STEMP(1),STEMP,SFAC) | ||||
| ELSE IF (ICASE.EQ.8) THEN | ELSE IF (ICASE.EQ.8) THEN | ||||
| @@ -325,13 +340,29 @@ | |||||
| ELSE IF (ICASE.EQ.10) THEN | ELSE IF (ICASE.EQ.10) THEN | ||||
| * .. IDAMAX .. | * .. IDAMAX .. | ||||
| CALL ITEST1(IDAMAX(N,SX,INCX),ITRUE2(NP1)) | CALL ITEST1(IDAMAX(N,SX,INCX),ITRUE2(NP1)) | ||||
| DO 100 I = 1, LEN | |||||
| SX(I) = 42.0D0 | |||||
| 100 CONTINUE | |||||
| CALL ITEST1(IDAMAX(N,SX,INCX),ITRUEC(NP1)) | |||||
| ELSE | ELSE | ||||
| WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | ||||
| STOP | STOP | ||||
| END IF | END IF | ||||
| 60 CONTINUE | 60 CONTINUE | ||||
| IF (ICASE.EQ.10) THEN | |||||
| N = 8 | |||||
| IX = 1 | |||||
| DO 120 I = 1, N | |||||
| SXR(IX) = DVR(I) | |||||
| IX = IX + INCX | |||||
| 120 CONTINUE | |||||
| CALL ITEST1(IDAMAX(N,SXR,INCX),3) | |||||
| END IF | |||||
| 80 CONTINUE | 80 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK2(SFAC) | SUBROUTINE CHECK2(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -345,7 +376,7 @@ | |||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| DOUBLE PRECISION SA | DOUBLE PRECISION SA | ||||
| INTEGER I, J, KI, KN, KNI, KPAR, KSIZE, LENX, LENY, | INTEGER I, J, KI, KN, KNI, KPAR, KSIZE, LENX, LENY, | ||||
| $ MX, MY | |||||
| $ LINCX, LINCY, MX, MY | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| DOUBLE PRECISION DT10X(7,4,4), DT10Y(7,4,4), DT7(4,4), | DOUBLE PRECISION DT10X(7,4,4), DT10Y(7,4,4), DT7(4,4), | ||||
| $ DT8(7,4,4), DX1(7), | $ DT8(7,4,4), DX1(7), | ||||
| @@ -354,7 +385,8 @@ | |||||
| $ DPAR(5,4), DT19X(7,4,16),DT19XA(7,4,4), | $ DPAR(5,4), DT19X(7,4,16),DT19XA(7,4,4), | ||||
| $ DT19XB(7,4,4), DT19XC(7,4,4),DT19XD(7,4,4), | $ DT19XB(7,4,4), DT19XC(7,4,4),DT19XD(7,4,4), | ||||
| $ DT19Y(7,4,16), DT19YA(7,4,4),DT19YB(7,4,4), | $ DT19Y(7,4,16), DT19YA(7,4,4),DT19YB(7,4,4), | ||||
| $ DT19YC(7,4,4), DT19YD(7,4,4), DTEMP(5) | |||||
| $ DT19YC(7,4,4), DT19YD(7,4,4), DTEMP(5), | |||||
| $ STY0(1), SX0(1), SY0(1) | |||||
| INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | ||||
| * .. External Functions .. | * .. External Functions .. | ||||
| DOUBLE PRECISION DDOT, DSDOT | DOUBLE PRECISION DDOT, DSDOT | ||||
| @@ -628,6 +660,23 @@ | |||||
| 60 CONTINUE | 60 CONTINUE | ||||
| CALL DCOPY(N,SX,INCX,SY,INCY) | CALL DCOPY(N,SX,INCX,SY,INCY) | ||||
| CALL STEST(LENY,SY,STY,SSIZE2(1,1),1.0D0) | CALL STEST(LENY,SY,STY,SSIZE2(1,1),1.0D0) | ||||
| IF (KI.EQ.1) THEN | |||||
| SX0(1) = 42.0D0 | |||||
| SY0(1) = 43.0D0 | |||||
| IF (N.EQ.0) THEN | |||||
| STY0(1) = SY0(1) | |||||
| ELSE | |||||
| STY0(1) = SX0(1) | |||||
| END IF | |||||
| LINCX = INCX | |||||
| INCX = 0 | |||||
| LINCY = INCY | |||||
| INCY = 0 | |||||
| CALL DCOPY(N,SX0,INCX,SY0,INCY) | |||||
| CALL STEST(1,SY0,STY0,SSIZE2(1,1),1.0D0) | |||||
| INCX = LINCX | |||||
| INCY = LINCY | |||||
| END IF | |||||
| ELSE IF (ICASE.EQ.6) THEN | ELSE IF (ICASE.EQ.6) THEN | ||||
| * .. DSWAP .. | * .. DSWAP .. | ||||
| CALL DSWAP(N,SX,INCX,SY,INCY) | CALL DSWAP(N,SX,INCX,SY,INCY) | ||||
| @@ -677,6 +726,9 @@ | |||||
| 100 CONTINUE | 100 CONTINUE | ||||
| 120 CONTINUE | 120 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK2 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK3(SFAC) | SUBROUTINE CHECK3(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -883,6 +935,9 @@ | |||||
| CALL STEST(5,COPYY,MWPSTY,MWPSTY,SFAC) | CALL STEST(5,COPYY,MWPSTY,MWPSTY,SFAC) | ||||
| 200 CONTINUE | 200 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK3 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * ********************************* STEST ************************** | * ********************************* STEST ************************** | ||||
| @@ -939,6 +994,9 @@ | |||||
| + ' COMP(I) TRUE(I) DIFFERENCE', | + ' COMP(I) TRUE(I) DIFFERENCE', | ||||
| + ' SIZE(I)',/1X) | + ' SIZE(I)',/1X) | ||||
| 99997 FORMAT (1X,I4,I3,2I5,I3,2D36.8,2D12.4) | 99997 FORMAT (1X,I4,I3,2I5,I3,2D36.8,2D12.4) | ||||
| * | |||||
| * End of STEST | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE TESTDSDOT(SCOMP,STRUE,SSIZE,SFAC) | SUBROUTINE TESTDSDOT(SCOMP,STRUE,SSIZE,SFAC) | ||||
| * ********************************* STEST ************************** | * ********************************* STEST ************************** | ||||
| @@ -987,6 +1045,9 @@ | |||||
| + ' COMP(I) TRUE(I) DIFFERENCE', | + ' COMP(I) TRUE(I) DIFFERENCE', | ||||
| + ' SIZE(I)',/1X) | + ' SIZE(I)',/1X) | ||||
| 99997 FORMAT (1X,I4,I3,1I5,I3,2E36.8,2E12.4) | 99997 FORMAT (1X,I4,I3,1I5,I3,2E36.8,2E12.4) | ||||
| * | |||||
| * End of TESTDSDOT | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | ||||
| * ************************* STEST1 ***************************** | * ************************* STEST1 ***************************** | ||||
| @@ -1012,6 +1073,9 @@ | |||||
| CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * | * | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of STEST1 | |||||
| * | |||||
| END | END | ||||
| DOUBLE PRECISION FUNCTION SDIFF(SA,SB) | DOUBLE PRECISION FUNCTION SDIFF(SA,SB) | ||||
| * ********************************* SDIFF ************************** | * ********************************* SDIFF ************************** | ||||
| @@ -1022,6 +1086,9 @@ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| SDIFF = SA - SB | SDIFF = SA - SB | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of SDIFF | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE ITEST1(ICOMP,ITRUE) | SUBROUTINE ITEST1(ICOMP,ITRUE) | ||||
| * ********************************* ITEST1 ************************* | * ********************************* ITEST1 ************************* | ||||
| @@ -1063,4 +1130,217 @@ | |||||
| + ' COMP TRUE DIFFERENCE', | + ' COMP TRUE DIFFERENCE', | ||||
| + /1X) | + /1X) | ||||
| 99997 FORMAT (1X,I4,I3,2I5,2I36,I12) | 99997 FORMAT (1X,I4,I3,2I5,2I36,I12) | ||||
| * | |||||
| * End of ITEST1 | |||||
| * | |||||
| END | |||||
| SUBROUTINE DB1NRM2(N,INCX,THRESH) | |||||
| * Compare NRM2 with a reference computation using combinations | |||||
| * of the following values: | |||||
| * | |||||
| * 0, very small, small, ulp, 1, 1/ulp, big, very big, infinity, NaN | |||||
| * | |||||
| * one of these values is used to initialize x(1) and x(2:N) is | |||||
| * filled with random values from [-1,1] scaled by another of | |||||
| * these values. | |||||
| * | |||||
| * This routine is adapted from the test suite provided by | |||||
| * Anderson E. (2017) | |||||
| * Algorithm 978: Safe Scaling in the Level 1 BLAS | |||||
| * ACM Trans Math Softw 44:1--28 | |||||
| * https://doi.org/10.1145/3061665 | |||||
| * | |||||
| * .. Scalar Arguments .. | |||||
| INTEGER INCX, N | |||||
| DOUBLE PRECISION THRESH | |||||
| * | |||||
| * ===================================================================== | |||||
| * .. Parameters .. | |||||
| INTEGER NMAX, NOUT, NV | |||||
| PARAMETER (NMAX=20, NOUT=6, NV=10) | |||||
| DOUBLE PRECISION HALF, ONE, TWO, ZERO | |||||
| PARAMETER (HALF=0.5D+0, ONE=1.0D+0, TWO= 2.0D+0, | |||||
| & ZERO=0.0D+0) | |||||
| * .. External Functions .. | |||||
| DOUBLE PRECISION DNRM2 | |||||
| EXTERNAL DNRM2 | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC ABS, DBLE, MAX, MIN, SQRT | |||||
| * .. Model parameters .. | |||||
| DOUBLE PRECISION BIGNUM, SAFMAX, SAFMIN, SMLNUM, ULP | |||||
| PARAMETER (BIGNUM=0.99792015476735990583D+292, | |||||
| & SAFMAX=0.44942328371557897693D+308, | |||||
| & SAFMIN=0.22250738585072013831D-307, | |||||
| & SMLNUM=0.10020841800044863890D-291, | |||||
| & ULP=0.22204460492503130808D-015) | |||||
| * .. Local Scalars .. | |||||
| DOUBLE PRECISION ROGUE, SNRM, TRAT, V0, V1, WORKSSQ, Y1, Y2, | |||||
| & YMAX, YMIN, YNRM, ZNRM | |||||
| INTEGER I, IV, IW, IX | |||||
| LOGICAL FIRST | |||||
| * .. Local Arrays .. | |||||
| DOUBLE PRECISION VALUES(NV), WORK(NMAX), X(NMAX), Z(NMAX) | |||||
| * .. Executable Statements .. | |||||
| VALUES(1) = ZERO | |||||
| VALUES(2) = TWO*SAFMIN | |||||
| VALUES(3) = SMLNUM | |||||
| VALUES(4) = ULP | |||||
| VALUES(5) = ONE | |||||
| VALUES(6) = ONE / ULP | |||||
| VALUES(7) = BIGNUM | |||||
| VALUES(8) = SAFMAX | |||||
| VALUES(9) = DXVALS(V0,2) | |||||
| VALUES(10) = DXVALS(V0,3) | |||||
| ROGUE = -1234.5678D+0 | |||||
| FIRST = .TRUE. | |||||
| * | |||||
| * Check that the arrays are large enough | |||||
| * | |||||
| IF (N*ABS(INCX).GT.NMAX) THEN | |||||
| WRITE (NOUT,99) "DNRM2", NMAX, INCX, N, N*ABS(INCX) | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Zero-sized inputs are tested in STEST1. | |||||
| IF (N.LE.0) THEN | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Generate (N-1) values in (-1,1). | |||||
| * | |||||
| DO I = 2, N | |||||
| CALL RANDOM_NUMBER(WORK(I)) | |||||
| WORK(I) = ONE - TWO*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Compute the sum of squares of the random values | |||||
| * by an unscaled algorithm. | |||||
| * | |||||
| WORKSSQ = ZERO | |||||
| DO I = 2, N | |||||
| WORKSSQ = WORKSSQ + WORK(I)*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Construct the test vector with one known value | |||||
| * and the rest from the random work array multiplied | |||||
| * by a scaling factor. | |||||
| * | |||||
| DO IV = 1, NV | |||||
| V0 = VALUES(IV) | |||||
| IF (ABS(V0).GT.ONE) THEN | |||||
| V0 = V0*HALF | |||||
| END IF | |||||
| Z(1) = V0 | |||||
| DO IW = 1, NV | |||||
| V1 = VALUES(IW) | |||||
| IF (ABS(V1).GT.ONE) THEN | |||||
| V1 = (V1*HALF) / SQRT(DBLE(N)) | |||||
| END IF | |||||
| DO I = 2, N | |||||
| Z(I) = V1*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Compute the expected value of the 2-norm | |||||
| * | |||||
| Y1 = ABS(V0) | |||||
| IF (N.GT.1) THEN | |||||
| Y2 = ABS(V1)*SQRT(WORKSSQ) | |||||
| ELSE | |||||
| Y2 = ZERO | |||||
| END IF | |||||
| YMIN = MIN(Y1, Y2) | |||||
| YMAX = MAX(Y1, Y2) | |||||
| * | |||||
| * Expected value is NaN if either is NaN. The test | |||||
| * for YMIN == YMAX avoids further computation if both | |||||
| * are infinity. | |||||
| * | |||||
| IF ((Y1.NE.Y1).OR.(Y2.NE.Y2)) THEN | |||||
| * Add to propagate NaN | |||||
| YNRM = Y1 + Y2 | |||||
| ELSE IF (YMAX == ZERO) THEN | |||||
| YNRM = ZERO | |||||
| ELSE IF (YMIN == YMAX) THEN | |||||
| YNRM = SQRT(TWO)*YMAX | |||||
| ELSE | |||||
| YNRM = YMAX*SQRT(ONE + (YMIN / YMAX)**2) | |||||
| END IF | |||||
| * | |||||
| * Fill the input array to DNRM2 with steps of incx | |||||
| * | |||||
| DO I = 1, N | |||||
| X(I) = ROGUE | |||||
| END DO | |||||
| IX = 1 | |||||
| IF (INCX.LT.0) IX = 1 - (N-1)*INCX | |||||
| DO I = 1, N | |||||
| X(IX) = Z(I) | |||||
| IX = IX + INCX | |||||
| END DO | |||||
| * | |||||
| * Call DNRM2 to compute the 2-norm | |||||
| * | |||||
| SNRM = DNRM2(N,X,INCX) | |||||
| * | |||||
| * Compare SNRM and ZNRM. Roundoff error grows like O(n) | |||||
| * in this implementation so we scale the test ratio accordingly. | |||||
| * | |||||
| IF (INCX.EQ.0) THEN | |||||
| ZNRM = SQRT(DBLE(N))*ABS(X(1)) | |||||
| ELSE | |||||
| ZNRM = YNRM | |||||
| END IF | |||||
| * | |||||
| * The tests for NaN rely on the compiler not being overly | |||||
| * aggressive and removing the statements altogether. | |||||
| IF ((SNRM.NE.SNRM).OR.(ZNRM.NE.ZNRM)) THEN | |||||
| IF ((SNRM.NE.SNRM).NEQV.(ZNRM.NE.ZNRM)) THEN | |||||
| TRAT = ONE / ULP | |||||
| ELSE | |||||
| TRAT = ZERO | |||||
| END IF | |||||
| ELSE IF (SNRM == ZNRM) THEN | |||||
| TRAT = ZERO | |||||
| ELSE IF (ZNRM == ZERO) THEN | |||||
| TRAT = SNRM / ULP | |||||
| ELSE | |||||
| TRAT = (ABS(SNRM-ZNRM) / ZNRM) / (DBLE(N)*ULP) | |||||
| END IF | |||||
| IF ((TRAT.NE.TRAT).OR.(TRAT.GE.THRESH)) THEN | |||||
| IF (FIRST) THEN | |||||
| FIRST = .FALSE. | |||||
| WRITE(NOUT,99999) | |||||
| END IF | |||||
| WRITE (NOUT,98) "DNRM2", N, INCX, IV, IW, TRAT | |||||
| END IF | |||||
| END DO | |||||
| END DO | |||||
| 99999 FORMAT (' FAIL') | |||||
| 99 FORMAT ( ' Not enough space to test ', A6, ': NMAX = ',I6, | |||||
| + ', INCX = ',I6,/,' N = ',I6,', must be at least ',I6 ) | |||||
| 98 FORMAT( 1X, A6, ': N=', I6,', INCX=', I4, ', IV=', I2, ', IW=', | |||||
| + I2, ', test=', E15.8 ) | |||||
| RETURN | |||||
| CONTAINS | |||||
| DOUBLE PRECISION FUNCTION DXVALS(XX,K) | |||||
| * .. Scalar Arguments .. | |||||
| DOUBLE PRECISION XX | |||||
| INTEGER K | |||||
| * .. Local Scalars .. | |||||
| DOUBLE PRECISION X, Y, YY, Z | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC HUGE | |||||
| * .. Executable Statements .. | |||||
| Y = HUGE(XX) | |||||
| Z = YY | |||||
| IF (K.EQ.1) THEN | |||||
| X = -Z | |||||
| ELSE IF (K.EQ.2) THEN | |||||
| X = Z | |||||
| ELSE IF (K.EQ.3) THEN | |||||
| X = Z / Z | |||||
| END IF | |||||
| DXVALS = X | |||||
| RETURN | |||||
| END | |||||
| END | END | ||||
| @@ -30,17 +30,14 @@ | |||||
| *> \author Univ. of Colorado Denver | *> \author Univ. of Colorado Denver | ||||
| *> \author NAG Ltd. | *> \author NAG Ltd. | ||||
| * | * | ||||
| *> \date April 2012 | |||||
| * | |||||
| *> \ingroup single_blas_testing | *> \ingroup single_blas_testing | ||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| PROGRAM SBLAT1 | PROGRAM SBLAT1 | ||||
| * | * | ||||
| * -- Reference BLAS test routine (version 3.8.0) -- | |||||
| * -- Reference BLAS test routine -- | |||||
| * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | ||||
| * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | ||||
| * April 2012 | |||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| * | * | ||||
| @@ -91,6 +88,9 @@ | |||||
| * | * | ||||
| 99999 FORMAT (' Real BLAS Test Program Results',/1X) | 99999 FORMAT (' Real BLAS Test Program Results',/1X) | ||||
| 99998 FORMAT (' ----- PASS -----') | 99998 FORMAT (' ----- PASS -----') | ||||
| * | |||||
| * End of SBLAT1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE HEADER | SUBROUTINE HEADER | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -122,6 +122,9 @@ | |||||
| RETURN | RETURN | ||||
| * | * | ||||
| 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | ||||
| * | |||||
| * End of HEADER | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK0(SFAC) | SUBROUTINE CHECK0(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -238,28 +241,33 @@ | |||||
| END IF | END IF | ||||
| 20 CONTINUE | 20 CONTINUE | ||||
| 40 RETURN | 40 RETURN | ||||
| * | |||||
| * End of CHECK0 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK1(SFAC) | SUBROUTINE CHECK1(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| INTEGER NOUT | INTEGER NOUT | ||||
| PARAMETER (NOUT=6) | |||||
| REAL THRESH | |||||
| PARAMETER (NOUT=6, THRESH=10.0E0) | |||||
| * .. Scalar Arguments .. | * .. Scalar Arguments .. | ||||
| REAL SFAC | REAL SFAC | ||||
| * .. Scalars in Common .. | * .. Scalars in Common .. | ||||
| INTEGER ICASE, INCX, INCY, N | INTEGER ICASE, INCX, INCY, N | ||||
| LOGICAL PASS | LOGICAL PASS | ||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| INTEGER I, LEN, NP1 | |||||
| INTEGER I, IX, LEN, NP1 | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| REAL DTRUE1(5), DTRUE3(5), DTRUE5(8,5,2), DV(8,5,2), | REAL DTRUE1(5), DTRUE3(5), DTRUE5(8,5,2), DV(8,5,2), | ||||
| + SA(10), STEMP(1), STRUE(8), SX(8) | |||||
| INTEGER ITRUE2(5) | |||||
| + DVR(8), SA(10), STEMP(1), STRUE(8), SX(8), | |||||
| + SXR(15) | |||||
| INTEGER ITRUE2(5), ITRUEC(5) | |||||
| * .. External Functions .. | * .. External Functions .. | ||||
| REAL SASUM, SNRM2 | REAL SASUM, SNRM2 | ||||
| INTEGER ISAMAX | INTEGER ISAMAX | ||||
| EXTERNAL SASUM, SNRM2, ISAMAX | EXTERNAL SASUM, SNRM2, ISAMAX | ||||
| * .. External Subroutines .. | * .. External Subroutines .. | ||||
| EXTERNAL ITEST1, SSCAL, STEST, STEST1 | |||||
| EXTERNAL ITEST1, SB1NRM2, SSCAL, STEST, STEST1 | |||||
| * .. Intrinsic Functions .. | * .. Intrinsic Functions .. | ||||
| INTRINSIC MAX | INTRINSIC MAX | ||||
| * .. Common blocks .. | * .. Common blocks .. | ||||
| @@ -280,6 +288,8 @@ | |||||
| + 0.2E0, 3.0E0, -0.6E0, 5.0E0, 0.3E0, 2.0E0, | + 0.2E0, 3.0E0, -0.6E0, 5.0E0, 0.3E0, 2.0E0, | ||||
| + 2.0E0, 2.0E0, 0.1E0, 4.0E0, -0.3E0, 6.0E0, | + 2.0E0, 2.0E0, 0.1E0, 4.0E0, -0.3E0, 6.0E0, | ||||
| + -0.5E0, 7.0E0, -0.1E0, 3.0E0/ | + -0.5E0, 7.0E0, -0.1E0, 3.0E0/ | ||||
| DATA DVR/8.0E0, -7.0E0, 9.0E0, 5.0E0, 9.0E0, 8.0E0, | |||||
| + 7.0E0, 7.0E0/ | |||||
| DATA DTRUE1/0.0E0, 0.3E0, 0.5E0, 0.7E0, 0.6E0/ | DATA DTRUE1/0.0E0, 0.3E0, 0.5E0, 0.7E0, 0.6E0/ | ||||
| DATA DTRUE3/0.0E0, 0.3E0, 0.7E0, 1.1E0, 1.0E0/ | DATA DTRUE3/0.0E0, 0.3E0, 0.7E0, 1.1E0, 1.0E0/ | ||||
| DATA DTRUE5/0.10E0, 2.0E0, 2.0E0, 2.0E0, 2.0E0, | DATA DTRUE5/0.10E0, 2.0E0, 2.0E0, 2.0E0, 2.0E0, | ||||
| @@ -297,6 +307,7 @@ | |||||
| + 0.03E0, 4.0E0, -0.09E0, 6.0E0, -0.15E0, 7.0E0, | + 0.03E0, 4.0E0, -0.09E0, 6.0E0, -0.15E0, 7.0E0, | ||||
| + -0.03E0, 3.0E0/ | + -0.03E0, 3.0E0/ | ||||
| DATA ITRUE2/0, 1, 2, 2, 3/ | DATA ITRUE2/0, 1, 2, 2, 3/ | ||||
| DATA ITRUEC/0, 1, 1, 1, 1/ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| DO 80 INCX = 1, 2 | DO 80 INCX = 1, 2 | ||||
| DO 60 NP1 = 1, 5 | DO 60 NP1 = 1, 5 | ||||
| @@ -309,6 +320,10 @@ | |||||
| * | * | ||||
| IF (ICASE.EQ.7) THEN | IF (ICASE.EQ.7) THEN | ||||
| * .. SNRM2 .. | * .. SNRM2 .. | ||||
| * Test scaling when some entries are tiny or huge | |||||
| CALL SB1NRM2(N,(INCX-2)*2,THRESH) | |||||
| CALL SB1NRM2(N,INCX,THRESH) | |||||
| * Test with hardcoded mid range entries | |||||
| STEMP(1) = DTRUE1(NP1) | STEMP(1) = DTRUE1(NP1) | ||||
| CALL STEST1(SNRM2(N,SX,INCX),STEMP(1),STEMP,SFAC) | CALL STEST1(SNRM2(N,SX,INCX),STEMP(1),STEMP,SFAC) | ||||
| ELSE IF (ICASE.EQ.8) THEN | ELSE IF (ICASE.EQ.8) THEN | ||||
| @@ -325,13 +340,29 @@ | |||||
| ELSE IF (ICASE.EQ.10) THEN | ELSE IF (ICASE.EQ.10) THEN | ||||
| * .. ISAMAX .. | * .. ISAMAX .. | ||||
| CALL ITEST1(ISAMAX(N,SX,INCX),ITRUE2(NP1)) | CALL ITEST1(ISAMAX(N,SX,INCX),ITRUE2(NP1)) | ||||
| DO 100 I = 1, LEN | |||||
| SX(I) = 42.0E0 | |||||
| 100 CONTINUE | |||||
| CALL ITEST1(ISAMAX(N,SX,INCX),ITRUEC(NP1)) | |||||
| ELSE | ELSE | ||||
| WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | ||||
| STOP | STOP | ||||
| END IF | END IF | ||||
| 60 CONTINUE | 60 CONTINUE | ||||
| IF (ICASE.EQ.10) THEN | |||||
| N = 8 | |||||
| IX = 1 | |||||
| DO 120 I = 1, N | |||||
| SXR(IX) = DVR(I) | |||||
| IX = IX + INCX | |||||
| 120 CONTINUE | |||||
| CALL ITEST1(ISAMAX(N,SXR,INCX),3) | |||||
| END IF | |||||
| 80 CONTINUE | 80 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK2(SFAC) | SUBROUTINE CHECK2(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -345,7 +376,7 @@ | |||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| REAL SA | REAL SA | ||||
| INTEGER I, J, KI, KN, KNI, KPAR, KSIZE, LENX, LENY, | INTEGER I, J, KI, KN, KNI, KPAR, KSIZE, LENX, LENY, | ||||
| $ MX, MY | |||||
| $ LINCX, LINCY, MX, MY | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| REAL DT10X(7,4,4), DT10Y(7,4,4), DT7(4,4), | REAL DT10X(7,4,4), DT10Y(7,4,4), DT7(4,4), | ||||
| $ DT8(7,4,4), DX1(7), | $ DT8(7,4,4), DX1(7), | ||||
| @@ -355,7 +386,7 @@ | |||||
| $ DT19XB(7,4,4), DT19XC(7,4,4),DT19XD(7,4,4), | $ DT19XB(7,4,4), DT19XC(7,4,4),DT19XD(7,4,4), | ||||
| $ DT19Y(7,4,16), DT19YA(7,4,4),DT19YB(7,4,4), | $ DT19Y(7,4,16), DT19YA(7,4,4),DT19YB(7,4,4), | ||||
| $ DT19YC(7,4,4), DT19YD(7,4,4), DTEMP(5), | $ DT19YC(7,4,4), DT19YD(7,4,4), DTEMP(5), | ||||
| $ ST7B(4,4) | |||||
| $ ST7B(4,4), STY0(1), SX0(1), SY0(1) | |||||
| INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | ||||
| * .. External Functions .. | * .. External Functions .. | ||||
| REAL SDOT, SDSDOT | REAL SDOT, SDSDOT | ||||
| @@ -631,6 +662,23 @@ | |||||
| 60 CONTINUE | 60 CONTINUE | ||||
| CALL SCOPY(N,SX,INCX,SY,INCY) | CALL SCOPY(N,SX,INCX,SY,INCY) | ||||
| CALL STEST(LENY,SY,STY,SSIZE2(1,1),1.0E0) | CALL STEST(LENY,SY,STY,SSIZE2(1,1),1.0E0) | ||||
| IF (KI.EQ.1) THEN | |||||
| SX0(1) = 42.0E0 | |||||
| SY0(1) = 43.0E0 | |||||
| IF (N.EQ.0) THEN | |||||
| STY0(1) = SY0(1) | |||||
| ELSE | |||||
| STY0(1) = SX0(1) | |||||
| END IF | |||||
| LINCX = INCX | |||||
| INCX = 0 | |||||
| LINCY = INCY | |||||
| INCY = 0 | |||||
| CALL SCOPY(N,SX0,INCX,SY0,INCY) | |||||
| CALL STEST(1,SY0,STY0,SSIZE2(1,1),1.0E0) | |||||
| INCX = LINCX | |||||
| INCY = LINCY | |||||
| END IF | |||||
| ELSE IF (ICASE.EQ.6) THEN | ELSE IF (ICASE.EQ.6) THEN | ||||
| * .. SSWAP .. | * .. SSWAP .. | ||||
| CALL SSWAP(N,SX,INCX,SY,INCY) | CALL SSWAP(N,SX,INCX,SY,INCY) | ||||
| @@ -680,6 +728,9 @@ | |||||
| 100 CONTINUE | 100 CONTINUE | ||||
| 120 CONTINUE | 120 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK2 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK3(SFAC) | SUBROUTINE CHECK3(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -886,6 +937,9 @@ | |||||
| CALL STEST(5,COPYY,MWPSTY,MWPSTY,SFAC) | CALL STEST(5,COPYY,MWPSTY,MWPSTY,SFAC) | ||||
| 200 CONTINUE | 200 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK3 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * ********************************* STEST ************************** | * ********************************* STEST ************************** | ||||
| @@ -942,6 +996,9 @@ | |||||
| + ' COMP(I) TRUE(I) DIFFERENCE', | + ' COMP(I) TRUE(I) DIFFERENCE', | ||||
| + ' SIZE(I)',/1X) | + ' SIZE(I)',/1X) | ||||
| 99997 FORMAT (1X,I4,I3,2I5,I3,2E36.8,2E12.4) | 99997 FORMAT (1X,I4,I3,2I5,I3,2E36.8,2E12.4) | ||||
| * | |||||
| * End of STEST | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | ||||
| * ************************* STEST1 ***************************** | * ************************* STEST1 ***************************** | ||||
| @@ -967,6 +1024,9 @@ | |||||
| CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * | * | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of STEST1 | |||||
| * | |||||
| END | END | ||||
| REAL FUNCTION SDIFF(SA,SB) | REAL FUNCTION SDIFF(SA,SB) | ||||
| * ********************************* SDIFF ************************** | * ********************************* SDIFF ************************** | ||||
| @@ -977,6 +1037,9 @@ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| SDIFF = SA - SB | SDIFF = SA - SB | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of SDIFF | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE ITEST1(ICOMP,ITRUE) | SUBROUTINE ITEST1(ICOMP,ITRUE) | ||||
| * ********************************* ITEST1 ************************* | * ********************************* ITEST1 ************************* | ||||
| @@ -1018,4 +1081,218 @@ | |||||
| + ' COMP TRUE DIFFERENCE', | + ' COMP TRUE DIFFERENCE', | ||||
| + /1X) | + /1X) | ||||
| 99997 FORMAT (1X,I4,I3,2I5,2I36,I12) | 99997 FORMAT (1X,I4,I3,2I5,2I36,I12) | ||||
| * | |||||
| * End of ITEST1 | |||||
| * | |||||
| END | |||||
| SUBROUTINE SB1NRM2(N,INCX,THRESH) | |||||
| * Compare NRM2 with a reference computation using combinations | |||||
| * of the following values: | |||||
| * | |||||
| * 0, very small, small, ulp, 1, 1/ulp, big, very big, infinity, NaN | |||||
| * | |||||
| * one of these values is used to initialize x(1) and x(2:N) is | |||||
| * filled with random values from [-1,1] scaled by another of | |||||
| * these values. | |||||
| * | |||||
| * This routine is adapted from the test suite provided by | |||||
| * Anderson E. (2017) | |||||
| * Algorithm 978: Safe Scaling in the Level 1 BLAS | |||||
| * ACM Trans Math Softw 44:1--28 | |||||
| * https://doi.org/10.1145/3061665 | |||||
| * | |||||
| IMPLICIT NONE | |||||
| * .. Scalar Arguments .. | |||||
| INTEGER INCX, N | |||||
| REAL THRESH | |||||
| * | |||||
| * ===================================================================== | |||||
| * .. Parameters .. | |||||
| INTEGER NMAX, NOUT, NV | |||||
| PARAMETER (NMAX=20, NOUT=6, NV=10) | |||||
| REAL HALF, ONE, TWO, ZERO | |||||
| PARAMETER (HALF=0.5E+0, ONE=1.0E+0, TWO= 2.0E+0, | |||||
| & ZERO=0.0E+0) | |||||
| * .. External Functions .. | |||||
| REAL SNRM2 | |||||
| EXTERNAL SNRM2 | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC ABS, MAX, MIN, REAL, SQRT | |||||
| * .. Model parameters .. | |||||
| REAL BIGNUM, SAFMAX, SAFMIN, SMLNUM, ULP | |||||
| PARAMETER (BIGNUM=0.1014120480E+32, | |||||
| & SAFMAX=0.8507059173E+38, | |||||
| & SAFMIN=0.1175494351E-37, | |||||
| & SMLNUM=0.9860761315E-31, | |||||
| & ULP=0.1192092896E-06) | |||||
| * .. Local Scalars .. | |||||
| REAL ROGUE, SNRM, TRAT, V0, V1, WORKSSQ, Y1, Y2, | |||||
| & YMAX, YMIN, YNRM, ZNRM | |||||
| INTEGER I, IV, IW, IX | |||||
| LOGICAL FIRST | |||||
| * .. Local Arrays .. | |||||
| REAL VALUES(NV), WORK(NMAX), X(NMAX), Z(NMAX) | |||||
| * .. Executable Statements .. | |||||
| VALUES(1) = ZERO | |||||
| VALUES(2) = TWO*SAFMIN | |||||
| VALUES(3) = SMLNUM | |||||
| VALUES(4) = ULP | |||||
| VALUES(5) = ONE | |||||
| VALUES(6) = ONE / ULP | |||||
| VALUES(7) = BIGNUM | |||||
| VALUES(8) = SAFMAX | |||||
| VALUES(9) = SXVALS(V0,2) | |||||
| VALUES(10) = SXVALS(V0,3) | |||||
| ROGUE = -1234.5678E+0 | |||||
| FIRST = .TRUE. | |||||
| * | |||||
| * Check that the arrays are large enough | |||||
| * | |||||
| IF (N*ABS(INCX).GT.NMAX) THEN | |||||
| WRITE (NOUT,99) "SNRM2", NMAX, INCX, N, N*ABS(INCX) | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Zero-sized inputs are tested in STEST1. | |||||
| IF (N.LE.0) THEN | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Generate (N-1) values in (-1,1). | |||||
| * | |||||
| DO I = 2, N | |||||
| CALL RANDOM_NUMBER(WORK(I)) | |||||
| WORK(I) = ONE - TWO*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Compute the sum of squares of the random values | |||||
| * by an unscaled algorithm. | |||||
| * | |||||
| WORKSSQ = ZERO | |||||
| DO I = 2, N | |||||
| WORKSSQ = WORKSSQ + WORK(I)*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Construct the test vector with one known value | |||||
| * and the rest from the random work array multiplied | |||||
| * by a scaling factor. | |||||
| * | |||||
| DO IV = 1, NV | |||||
| V0 = VALUES(IV) | |||||
| IF (ABS(V0).GT.ONE) THEN | |||||
| V0 = V0*HALF | |||||
| END IF | |||||
| Z(1) = V0 | |||||
| DO IW = 1, NV | |||||
| V1 = VALUES(IW) | |||||
| IF (ABS(V1).GT.ONE) THEN | |||||
| V1 = (V1*HALF) / SQRT(REAL(N)) | |||||
| END IF | |||||
| DO I = 2, N | |||||
| Z(I) = V1*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Compute the expected value of the 2-norm | |||||
| * | |||||
| Y1 = ABS(V0) | |||||
| IF (N.GT.1) THEN | |||||
| Y2 = ABS(V1)*SQRT(WORKSSQ) | |||||
| ELSE | |||||
| Y2 = ZERO | |||||
| END IF | |||||
| YMIN = MIN(Y1, Y2) | |||||
| YMAX = MAX(Y1, Y2) | |||||
| * | |||||
| * Expected value is NaN if either is NaN. The test | |||||
| * for YMIN == YMAX avoids further computation if both | |||||
| * are infinity. | |||||
| * | |||||
| IF ((Y1.NE.Y1).OR.(Y2.NE.Y2)) THEN | |||||
| * add to propagate NaN | |||||
| YNRM = Y1 + Y2 | |||||
| ELSE IF (YMIN == YMAX) THEN | |||||
| YNRM = SQRT(TWO)*YMAX | |||||
| ELSE IF (YMAX == ZERO) THEN | |||||
| YNRM = ZERO | |||||
| ELSE | |||||
| YNRM = YMAX*SQRT(ONE + (YMIN / YMAX)**2) | |||||
| END IF | |||||
| * | |||||
| * Fill the input array to SNRM2 with steps of incx | |||||
| * | |||||
| DO I = 1, N | |||||
| X(I) = ROGUE | |||||
| END DO | |||||
| IX = 1 | |||||
| IF (INCX.LT.0) IX = 1 - (N-1)*INCX | |||||
| DO I = 1, N | |||||
| X(IX) = Z(I) | |||||
| IX = IX + INCX | |||||
| END DO | |||||
| * | |||||
| * Call SNRM2 to compute the 2-norm | |||||
| * | |||||
| SNRM = SNRM2(N,X,INCX) | |||||
| * | |||||
| * Compare SNRM and ZNRM. Roundoff error grows like O(n) | |||||
| * in this implementation so we scale the test ratio accordingly. | |||||
| * | |||||
| IF (INCX.EQ.0) THEN | |||||
| ZNRM = SQRT(REAL(N))*ABS(X(1)) | |||||
| ELSE | |||||
| ZNRM = YNRM | |||||
| END IF | |||||
| * | |||||
| * The tests for NaN rely on the compiler not being overly | |||||
| * aggressive and removing the statements altogether. | |||||
| IF ((SNRM.NE.SNRM).OR.(ZNRM.NE.ZNRM)) THEN | |||||
| IF ((SNRM.NE.SNRM).NEQV.(ZNRM.NE.ZNRM)) THEN | |||||
| TRAT = ONE / ULP | |||||
| ELSE | |||||
| TRAT = ZERO | |||||
| END IF | |||||
| ELSE IF (SNRM == ZNRM) THEN | |||||
| TRAT = ZERO | |||||
| ELSE IF (ZNRM == ZERO) THEN | |||||
| TRAT = SNRM / ULP | |||||
| ELSE | |||||
| TRAT = (ABS(SNRM-ZNRM) / ZNRM) / (REAL(N)*ULP) | |||||
| END IF | |||||
| IF ((TRAT.NE.TRAT).OR.(TRAT.GE.THRESH)) THEN | |||||
| IF (FIRST) THEN | |||||
| FIRST = .FALSE. | |||||
| WRITE(NOUT,99999) | |||||
| END IF | |||||
| WRITE (NOUT,98) "SNRM2", N, INCX, IV, IW, TRAT | |||||
| END IF | |||||
| END DO | |||||
| END DO | |||||
| 99999 FORMAT (' FAIL') | |||||
| 99 FORMAT ( ' Not enough space to test ', A6, ': NMAX = ',I6, | |||||
| + ', INCX = ',I6,/,' N = ',I6,', must be at least ',I6 ) | |||||
| 98 FORMAT( 1X, A6, ': N=', I6,', INCX=', I4, ', IV=', I2, ', IW=', | |||||
| + I2, ', test=', E15.8 ) | |||||
| RETURN | |||||
| CONTAINS | |||||
| REAL FUNCTION SXVALS(XX,K) | |||||
| * .. Scalar Arguments .. | |||||
| REAL XX | |||||
| INTEGER K | |||||
| * .. Local Scalars .. | |||||
| REAL X, Y, YY, Z | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC HUGE | |||||
| * .. Executable Statements .. | |||||
| Y = HUGE(XX) | |||||
| Z = YY | |||||
| IF (K.EQ.1) THEN | |||||
| X = -Z | |||||
| ELSE IF (K.EQ.2) THEN | |||||
| X = Z | |||||
| ELSE IF (K.EQ.3) THEN | |||||
| X = Z / Z | |||||
| END IF | |||||
| SXVALS = X | |||||
| RETURN | |||||
| END | |||||
| END | END | ||||
| @@ -30,17 +30,14 @@ | |||||
| *> \author Univ. of Colorado Denver | *> \author Univ. of Colorado Denver | ||||
| *> \author NAG Ltd. | *> \author NAG Ltd. | ||||
| * | * | ||||
| *> \date April 2012 | |||||
| * | |||||
| *> \ingroup complex16_blas_testing | *> \ingroup complex16_blas_testing | ||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| PROGRAM ZBLAT1 | PROGRAM ZBLAT1 | ||||
| * | * | ||||
| * -- Reference BLAS test routine (version 3.7.0) -- | |||||
| * -- Reference BLAS test routine -- | |||||
| * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | * -- Reference BLAS is a software package provided by Univ. of Tennessee, -- | ||||
| * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | * -- Univ. of California Berkeley, Univ. of Colorado Denver and NAG Ltd..-- | ||||
| * April 2012 | |||||
| * | * | ||||
| * ===================================================================== | * ===================================================================== | ||||
| * | * | ||||
| @@ -86,6 +83,9 @@ | |||||
| * | * | ||||
| 99999 FORMAT (' Complex BLAS Test Program Results',/1X) | 99999 FORMAT (' Complex BLAS Test Program Results',/1X) | ||||
| 99998 FORMAT (' ----- PASS -----') | 99998 FORMAT (' ----- PASS -----') | ||||
| * | |||||
| * End of ZBLAT1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE HEADER | SUBROUTINE HEADER | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -114,11 +114,15 @@ | |||||
| RETURN | RETURN | ||||
| * | * | ||||
| 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | 99999 FORMAT (/' Test of subprogram number',I3,12X,A6) | ||||
| * | |||||
| * End of HEADER | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK1(SFAC) | SUBROUTINE CHECK1(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| INTEGER NOUT | INTEGER NOUT | ||||
| PARAMETER (NOUT=6) | |||||
| DOUBLE PRECISION THRESH | |||||
| PARAMETER (NOUT=6, THRESH=10.0D0) | |||||
| * .. Scalar Arguments .. | * .. Scalar Arguments .. | ||||
| DOUBLE PRECISION SFAC | DOUBLE PRECISION SFAC | ||||
| * .. Scalars in Common .. | * .. Scalars in Common .. | ||||
| @@ -127,18 +131,18 @@ | |||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| COMPLEX*16 CA | COMPLEX*16 CA | ||||
| DOUBLE PRECISION SA | DOUBLE PRECISION SA | ||||
| INTEGER I, J, LEN, NP1 | |||||
| INTEGER I, IX, J, LEN, NP1 | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| COMPLEX*16 CTRUE5(8,5,2), CTRUE6(8,5,2), CV(8,5,2), CX(8), | |||||
| + MWPCS(5), MWPCT(5) | |||||
| COMPLEX*16 CTRUE5(8,5,2), CTRUE6(8,5,2), CV(8,5,2), CVR(8), | |||||
| + CX(8), CXR(15), MWPCS(5), MWPCT(5) | |||||
| DOUBLE PRECISION STRUE2(5), STRUE4(5) | DOUBLE PRECISION STRUE2(5), STRUE4(5) | ||||
| INTEGER ITRUE3(5) | |||||
| INTEGER ITRUE3(5), ITRUEC(5) | |||||
| * .. External Functions .. | * .. External Functions .. | ||||
| DOUBLE PRECISION DZASUM, DZNRM2 | DOUBLE PRECISION DZASUM, DZNRM2 | ||||
| INTEGER IZAMAX | INTEGER IZAMAX | ||||
| EXTERNAL DZASUM, DZNRM2, IZAMAX | EXTERNAL DZASUM, DZNRM2, IZAMAX | ||||
| * .. External Subroutines .. | * .. External Subroutines .. | ||||
| EXTERNAL ZSCAL, ZDSCAL, CTEST, ITEST1, STEST1 | |||||
| EXTERNAL ZB1NRM2, ZSCAL, ZDSCAL, CTEST, ITEST1, STEST1 | |||||
| * .. Intrinsic Functions .. | * .. Intrinsic Functions .. | ||||
| INTRINSIC MAX | INTRINSIC MAX | ||||
| * .. Common blocks .. | * .. Common blocks .. | ||||
| @@ -173,6 +177,9 @@ | |||||
| + (7.0D0,2.0D0), (0.3D0,0.1D0), (5.0D0,8.0D0), | + (7.0D0,2.0D0), (0.3D0,0.1D0), (5.0D0,8.0D0), | ||||
| + (0.5D0,0.0D0), (6.0D0,9.0D0), (0.0D0,0.5D0), | + (0.5D0,0.0D0), (6.0D0,9.0D0), (0.0D0,0.5D0), | ||||
| + (8.0D0,3.0D0), (0.0D0,0.2D0), (9.0D0,4.0D0)/ | + (8.0D0,3.0D0), (0.0D0,0.2D0), (9.0D0,4.0D0)/ | ||||
| DATA CVR/(8.0D0,8.0D0), (-7.0D0,-7.0D0), | |||||
| + (9.0D0,9.0D0), (5.0D0,5.0D0), (9.0D0,9.0D0), | |||||
| + (8.0D0,8.0D0), (7.0D0,7.0D0), (7.0D0,7.0D0)/ | |||||
| DATA STRUE2/0.0D0, 0.5D0, 0.6D0, 0.7D0, 0.8D0/ | DATA STRUE2/0.0D0, 0.5D0, 0.6D0, 0.7D0, 0.8D0/ | ||||
| DATA STRUE4/0.0D0, 0.7D0, 1.0D0, 1.3D0, 1.6D0/ | DATA STRUE4/0.0D0, 0.7D0, 1.0D0, 1.3D0, 1.6D0/ | ||||
| DATA ((CTRUE5(I,J,1),I=1,8),J=1,5)/(0.1D0,0.1D0), | DATA ((CTRUE5(I,J,1),I=1,8),J=1,5)/(0.1D0,0.1D0), | ||||
| @@ -238,6 +245,7 @@ | |||||
| + (0.15D0,0.00D0), (6.0D0,9.0D0), (0.00D0,0.15D0), | + (0.15D0,0.00D0), (6.0D0,9.0D0), (0.00D0,0.15D0), | ||||
| + (8.0D0,3.0D0), (0.00D0,0.06D0), (9.0D0,4.0D0)/ | + (8.0D0,3.0D0), (0.00D0,0.06D0), (9.0D0,4.0D0)/ | ||||
| DATA ITRUE3/0, 1, 2, 2, 2/ | DATA ITRUE3/0, 1, 2, 2, 2/ | ||||
| DATA ITRUEC/0, 1, 1, 1, 1/ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| DO 60 INCX = 1, 2 | DO 60 INCX = 1, 2 | ||||
| DO 40 NP1 = 1, 5 | DO 40 NP1 = 1, 5 | ||||
| @@ -249,6 +257,10 @@ | |||||
| 20 CONTINUE | 20 CONTINUE | ||||
| IF (ICASE.EQ.6) THEN | IF (ICASE.EQ.6) THEN | ||||
| * .. DZNRM2 .. | * .. DZNRM2 .. | ||||
| * Test scaling when some entries are tiny or huge | |||||
| CALL ZB1NRM2(N,(INCX-2)*2,THRESH) | |||||
| CALL ZB1NRM2(N,INCX,THRESH) | |||||
| * Test with hardcoded mid range entries | |||||
| CALL STEST1(DZNRM2(N,CX,INCX),STRUE2(NP1),STRUE2(NP1), | CALL STEST1(DZNRM2(N,CX,INCX),STRUE2(NP1),STRUE2(NP1), | ||||
| + SFAC) | + SFAC) | ||||
| ELSE IF (ICASE.EQ.7) THEN | ELSE IF (ICASE.EQ.7) THEN | ||||
| @@ -268,12 +280,25 @@ | |||||
| ELSE IF (ICASE.EQ.10) THEN | ELSE IF (ICASE.EQ.10) THEN | ||||
| * .. IZAMAX .. | * .. IZAMAX .. | ||||
| CALL ITEST1(IZAMAX(N,CX,INCX),ITRUE3(NP1)) | CALL ITEST1(IZAMAX(N,CX,INCX),ITRUE3(NP1)) | ||||
| DO 160 I = 1, LEN | |||||
| CX(I) = (42.0D0,43.0D0) | |||||
| 160 CONTINUE | |||||
| CALL ITEST1(IZAMAX(N,CX,INCX),ITRUEC(NP1)) | |||||
| ELSE | ELSE | ||||
| WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | WRITE (NOUT,*) ' Shouldn''t be here in CHECK1' | ||||
| STOP | STOP | ||||
| END IF | END IF | ||||
| * | * | ||||
| 40 CONTINUE | 40 CONTINUE | ||||
| IF (ICASE.EQ.10) THEN | |||||
| N = 8 | |||||
| IX = 1 | |||||
| DO 180 I = 1, N | |||||
| CXR(IX) = CVR(I) | |||||
| IX = IX + INCX | |||||
| 180 CONTINUE | |||||
| CALL ITEST1(IZAMAX(N,CXR,INCX),3) | |||||
| END IF | |||||
| 60 CONTINUE | 60 CONTINUE | ||||
| * | * | ||||
| INCX = 1 | INCX = 1 | ||||
| @@ -315,6 +340,9 @@ | |||||
| CALL CTEST(5,CX,MWPCT,MWPCS,SFAC) | CALL CTEST(5,CX,MWPCT,MWPCS,SFAC) | ||||
| END IF | END IF | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK1 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CHECK2(SFAC) | SUBROUTINE CHECK2(SFAC) | ||||
| * .. Parameters .. | * .. Parameters .. | ||||
| @@ -327,11 +355,13 @@ | |||||
| LOGICAL PASS | LOGICAL PASS | ||||
| * .. Local Scalars .. | * .. Local Scalars .. | ||||
| COMPLEX*16 CA | COMPLEX*16 CA | ||||
| INTEGER I, J, KI, KN, KSIZE, LENX, LENY, MX, MY | |||||
| INTEGER I, J, KI, KN, KSIZE, LENX, LENY, LINCX, LINCY, | |||||
| + MX, MY | |||||
| * .. Local Arrays .. | * .. Local Arrays .. | ||||
| COMPLEX*16 CDOT(1), CSIZE1(4), CSIZE2(7,2), CSIZE3(14), | COMPLEX*16 CDOT(1), CSIZE1(4), CSIZE2(7,2), CSIZE3(14), | ||||
| + CT10X(7,4,4), CT10Y(7,4,4), CT6(4,4), CT7(4,4), | + CT10X(7,4,4), CT10Y(7,4,4), CT6(4,4), CT7(4,4), | ||||
| + CT8(7,4,4), CX(7), CX1(7), CY(7), CY1(7) | |||||
| + CT8(7,4,4), CTY0(1), CX(7), CX0(1), CX1(7), | |||||
| + CY(7), CY0(1), CY1(7) | |||||
| INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | INTEGER INCXS(4), INCYS(4), LENS(4,2), NS(4) | ||||
| * .. External Functions .. | * .. External Functions .. | ||||
| COMPLEX*16 ZDOTC, ZDOTU | COMPLEX*16 ZDOTC, ZDOTU | ||||
| @@ -546,6 +576,23 @@ | |||||
| * .. ZCOPY .. | * .. ZCOPY .. | ||||
| CALL ZCOPY(N,CX,INCX,CY,INCY) | CALL ZCOPY(N,CX,INCX,CY,INCY) | ||||
| CALL CTEST(LENY,CY,CT10Y(1,KN,KI),CSIZE3,1.0D0) | CALL CTEST(LENY,CY,CT10Y(1,KN,KI),CSIZE3,1.0D0) | ||||
| IF (KI.EQ.1) THEN | |||||
| CX0(1) = (42.0D0,43.0D0) | |||||
| CY0(1) = (44.0D0,45.0D0) | |||||
| IF (N.EQ.0) THEN | |||||
| CTY0(1) = CY0(1) | |||||
| ELSE | |||||
| CTY0(1) = CX0(1) | |||||
| END IF | |||||
| LINCX = INCX | |||||
| INCX = 0 | |||||
| LINCY = INCY | |||||
| INCY = 0 | |||||
| CALL ZCOPY(N,CX0,INCX,CY0,INCY) | |||||
| CALL CTEST(1,CY0,CTY0,CSIZE3,1.0D0) | |||||
| INCX = LINCX | |||||
| INCY = LINCY | |||||
| END IF | |||||
| ELSE IF (ICASE.EQ.5) THEN | ELSE IF (ICASE.EQ.5) THEN | ||||
| * .. ZSWAP .. | * .. ZSWAP .. | ||||
| CALL ZSWAP(N,CX,INCX,CY,INCY) | CALL ZSWAP(N,CX,INCX,CY,INCY) | ||||
| @@ -559,6 +606,9 @@ | |||||
| 40 CONTINUE | 40 CONTINUE | ||||
| 60 CONTINUE | 60 CONTINUE | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CHECK2 | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | SUBROUTINE STEST(LEN,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * ********************************* STEST ************************** | * ********************************* STEST ************************** | ||||
| @@ -615,6 +665,9 @@ | |||||
| + ' COMP(I) TRUE(I) DIFFERENCE', | + ' COMP(I) TRUE(I) DIFFERENCE', | ||||
| + ' SIZE(I)',/1X) | + ' SIZE(I)',/1X) | ||||
| 99997 FORMAT (1X,I4,I3,3I5,I3,2D36.8,2D12.4) | 99997 FORMAT (1X,I4,I3,3I5,I3,2D36.8,2D12.4) | ||||
| * | |||||
| * End of STEST | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | SUBROUTINE STEST1(SCOMP1,STRUE1,SSIZE,SFAC) | ||||
| * ************************* STEST1 ***************************** | * ************************* STEST1 ***************************** | ||||
| @@ -640,6 +693,9 @@ | |||||
| CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | CALL STEST(1,SCOMP,STRUE,SSIZE,SFAC) | ||||
| * | * | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of STEST1 | |||||
| * | |||||
| END | END | ||||
| DOUBLE PRECISION FUNCTION SDIFF(SA,SB) | DOUBLE PRECISION FUNCTION SDIFF(SA,SB) | ||||
| * ********************************* SDIFF ************************** | * ********************************* SDIFF ************************** | ||||
| @@ -650,6 +706,9 @@ | |||||
| * .. Executable Statements .. | * .. Executable Statements .. | ||||
| SDIFF = SA - SB | SDIFF = SA - SB | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of SDIFF | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE CTEST(LEN,CCOMP,CTRUE,CSIZE,SFAC) | SUBROUTINE CTEST(LEN,CCOMP,CTRUE,CSIZE,SFAC) | ||||
| * **************************** CTEST ***************************** | * **************************** CTEST ***************************** | ||||
| @@ -681,6 +740,9 @@ | |||||
| * | * | ||||
| CALL STEST(2*LEN,SCOMP,STRUE,SSIZE,SFAC) | CALL STEST(2*LEN,SCOMP,STRUE,SSIZE,SFAC) | ||||
| RETURN | RETURN | ||||
| * | |||||
| * End of CTEST | |||||
| * | |||||
| END | END | ||||
| SUBROUTINE ITEST1(ICOMP,ITRUE) | SUBROUTINE ITEST1(ICOMP,ITRUE) | ||||
| * ********************************* ITEST1 ************************* | * ********************************* ITEST1 ************************* | ||||
| @@ -721,4 +783,232 @@ | |||||
| + ' COMP TRUE DIFFERENCE', | + ' COMP TRUE DIFFERENCE', | ||||
| + /1X) | + /1X) | ||||
| 99997 FORMAT (1X,I4,I3,3I5,2I36,I12) | 99997 FORMAT (1X,I4,I3,3I5,2I36,I12) | ||||
| * | |||||
| * End of ITEST1 | |||||
| * | |||||
| END | |||||
| SUBROUTINE ZB1NRM2(N,INCX,THRESH) | |||||
| * Compare NRM2 with a reference computation using combinations | |||||
| * of the following values: | |||||
| * | |||||
| * 0, very small, small, ulp, 1, 1/ulp, big, very big, infinity, NaN | |||||
| * | |||||
| * one of these values is used to initialize x(1) and x(2:N) is | |||||
| * filled with random values from [-1,1] scaled by another of | |||||
| * these values. | |||||
| * | |||||
| * This routine is adapted from the test suite provided by | |||||
| * Anderson E. (2017) | |||||
| * Algorithm 978: Safe Scaling in the Level 1 BLAS | |||||
| * ACM Trans Math Softw 44:1--28 | |||||
| * https://doi.org/10.1145/3061665 | |||||
| * | |||||
| * .. Scalar Arguments .. | |||||
| INTEGER INCX, N | |||||
| DOUBLE PRECISION THRESH | |||||
| * | |||||
| * ===================================================================== | |||||
| * .. Parameters .. | |||||
| INTEGER NMAX, NOUT, NV | |||||
| PARAMETER (NMAX=20, NOUT=6, NV=10) | |||||
| DOUBLE PRECISION HALF, ONE, THREE, TWO, ZERO | |||||
| PARAMETER (HALF=0.5D+0, ONE=1.0D+0, TWO= 2.0D+0, | |||||
| & THREE=3.0D+0, ZERO=0.0D+0) | |||||
| * .. External Functions .. | |||||
| DOUBLE PRECISION DZNRM2 | |||||
| EXTERNAL DZNRM2 | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC AIMAG, ABS, DCMPLX, DBLE, MAX, MIN, SQRT | |||||
| * .. Model parameters .. | |||||
| DOUBLE PRECISION BIGNUM, SAFMAX, SAFMIN, SMLNUM, ULP | |||||
| PARAMETER (BIGNUM=0.99792015476735990583D+292, | |||||
| & SAFMAX=0.44942328371557897693D+308, | |||||
| & SAFMIN=0.22250738585072013831D-307, | |||||
| & SMLNUM=0.10020841800044863890D-291, | |||||
| & ULP=0.22204460492503130808D-015) | |||||
| * .. Local Scalars .. | |||||
| COMPLEX*16 ROGUE | |||||
| DOUBLE PRECISION SNRM, TRAT, V0, V1, WORKSSQ, Y1, Y2, | |||||
| & YMAX, YMIN, YNRM, ZNRM | |||||
| INTEGER I, IV, IW, IX, KS | |||||
| LOGICAL FIRST | |||||
| * .. Local Arrays .. | |||||
| COMPLEX*16 X(NMAX), Z(NMAX) | |||||
| DOUBLE PRECISION VALUES(NV), WORK(NMAX) | |||||
| * .. Executable Statements .. | |||||
| VALUES(1) = ZERO | |||||
| VALUES(2) = TWO*SAFMIN | |||||
| VALUES(3) = SMLNUM | |||||
| VALUES(4) = ULP | |||||
| VALUES(5) = ONE | |||||
| VALUES(6) = ONE / ULP | |||||
| VALUES(7) = BIGNUM | |||||
| VALUES(8) = SAFMAX | |||||
| VALUES(9) = DXVALS(V0,2) | |||||
| VALUES(10) = DXVALS(V0,3) | |||||
| ROGUE = DCMPLX(1234.5678D+0,-1234.5678D+0) | |||||
| FIRST = .TRUE. | |||||
| * | |||||
| * Check that the arrays are large enough | |||||
| * | |||||
| IF (N*ABS(INCX).GT.NMAX) THEN | |||||
| WRITE (NOUT,99) "DZNRM2", NMAX, INCX, N, N*ABS(INCX) | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Zero-sized inputs are tested in STEST1. | |||||
| IF (N.LE.0) THEN | |||||
| RETURN | |||||
| END IF | |||||
| * | |||||
| * Generate 2*(N-1) values in (-1,1). | |||||
| * | |||||
| KS = 2*(N-1) | |||||
| DO I = 1, KS | |||||
| CALL RANDOM_NUMBER(WORK(I)) | |||||
| WORK(I) = ONE - TWO*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Compute the sum of squares of the random values | |||||
| * by an unscaled algorithm. | |||||
| * | |||||
| WORKSSQ = ZERO | |||||
| DO I = 1, KS | |||||
| WORKSSQ = WORKSSQ + WORK(I)*WORK(I) | |||||
| END DO | |||||
| * | |||||
| * Construct the test vector with one known value | |||||
| * and the rest from the random work array multiplied | |||||
| * by a scaling factor. | |||||
| * | |||||
| DO IV = 1, NV | |||||
| V0 = VALUES(IV) | |||||
| IF (ABS(V0).GT.ONE) THEN | |||||
| V0 = V0*HALF*HALF | |||||
| END IF | |||||
| Z(1) = DCMPLX(V0,-THREE*V0) | |||||
| DO IW = 1, NV | |||||
| V1 = VALUES(IW) | |||||
| IF (ABS(V1).GT.ONE) THEN | |||||
| V1 = (V1*HALF) / SQRT(DBLE(KS+1)) | |||||
| END IF | |||||
| DO I = 1, N-1 | |||||
| Z(I+1) = DCMPLX(V1*WORK(2*I-1),V1*WORK(2*I)) | |||||
| END DO | |||||
| * | |||||
| * Compute the expected value of the 2-norm | |||||
| * | |||||
| Y1 = ABS(V0) * SQRT(10.0D0) | |||||
| IF (N.GT.1) THEN | |||||
| Y2 = ABS(V1)*SQRT(WORKSSQ) | |||||
| ELSE | |||||
| Y2 = ZERO | |||||
| END IF | |||||
| YMIN = MIN(Y1, Y2) | |||||
| YMAX = MAX(Y1, Y2) | |||||
| * | |||||
| * Expected value is NaN if either is NaN. The test | |||||
| * for YMIN == YMAX avoids further computation if both | |||||
| * are infinity. | |||||
| * | |||||
| IF ((Y1.NE.Y1).OR.(Y2.NE.Y2)) THEN | |||||
| * add to propagate NaN | |||||
| YNRM = Y1 + Y2 | |||||
| ELSE IF (YMIN == YMAX) THEN | |||||
| YNRM = SQRT(TWO)*YMAX | |||||
| ELSE IF (YMAX == ZERO) THEN | |||||
| YNRM = ZERO | |||||
| ELSE | |||||
| YNRM = YMAX*SQRT(ONE + (YMIN / YMAX)**2) | |||||
| END IF | |||||
| * | |||||
| * Fill the input array to DZNRM2 with steps of incx | |||||
| * | |||||
| DO I = 1, N | |||||
| X(I) = ROGUE | |||||
| END DO | |||||
| IX = 1 | |||||
| IF (INCX.LT.0) IX = 1 - (N-1)*INCX | |||||
| DO I = 1, N | |||||
| X(IX) = Z(I) | |||||
| IX = IX + INCX | |||||
| END DO | |||||
| * | |||||
| * Call DZNRM2 to compute the 2-norm | |||||
| * | |||||
| SNRM = DZNRM2(N,X,INCX) | |||||
| * | |||||
| * Compare SNRM and ZNRM. Roundoff error grows like O(n) | |||||
| * in this implementation so we scale the test ratio accordingly. | |||||
| * | |||||
| IF (INCX.EQ.0) THEN | |||||
| Y1 = ABS(DBLE(X(1))) | |||||
| Y2 = ABS(AIMAG(X(1))) | |||||
| YMIN = MIN(Y1, Y2) | |||||
| YMAX = MAX(Y1, Y2) | |||||
| IF ((Y1.NE.Y1).OR.(Y2.NE.Y2)) THEN | |||||
| * add to propagate NaN | |||||
| ZNRM = Y1 + Y2 | |||||
| ELSE IF (YMIN == YMAX) THEN | |||||
| ZNRM = SQRT(TWO)*YMAX | |||||
| ELSE IF (YMAX == ZERO) THEN | |||||
| ZNRM = ZERO | |||||
| ELSE | |||||
| ZNRM = YMAX * SQRT(ONE + (YMIN / YMAX)**2) | |||||
| END IF | |||||
| ZNRM = SQRT(DBLE(n)) * ZNRM | |||||
| ELSE | |||||
| ZNRM = YNRM | |||||
| END IF | |||||
| * | |||||
| * The tests for NaN rely on the compiler not being overly | |||||
| * aggressive and removing the statements altogether. | |||||
| IF ((SNRM.NE.SNRM).OR.(ZNRM.NE.ZNRM)) THEN | |||||
| IF ((SNRM.NE.SNRM).NEQV.(ZNRM.NE.ZNRM)) THEN | |||||
| TRAT = ONE / ULP | |||||
| ELSE | |||||
| TRAT = ZERO | |||||
| END IF | |||||
| ELSE IF (ZNRM == ZERO) THEN | |||||
| TRAT = SNRM / ULP | |||||
| ELSE | |||||
| TRAT = (ABS(SNRM-ZNRM) / ZNRM) / (TWO*DBLE(N)*ULP) | |||||
| END IF | |||||
| IF ((TRAT.NE.TRAT).OR.(TRAT.GE.THRESH)) THEN | |||||
| IF (FIRST) THEN | |||||
| FIRST = .FALSE. | |||||
| WRITE(NOUT,99999) | |||||
| END IF | |||||
| WRITE (NOUT,98) "DZNRM2", N, INCX, IV, IW, TRAT | |||||
| END IF | |||||
| END DO | |||||
| END DO | |||||
| 99999 FORMAT (' FAIL') | |||||
| 99 FORMAT ( ' Not enough space to test ', A6, ': NMAX = ',I6, | |||||
| + ', INCX = ',I6,/,' N = ',I6,', must be at least ',I6 ) | |||||
| 98 FORMAT( 1X, A6, ': N=', I6,', INCX=', I4, ', IV=', I2, ', IW=', | |||||
| + I2, ', test=', E15.8 ) | |||||
| RETURN | |||||
| CONTAINS | |||||
| DOUBLE PRECISION FUNCTION DXVALS(XX,K) | |||||
| * .. Scalar Arguments .. | |||||
| DOUBLE PRECISION XX | |||||
| INTEGER K | |||||
| * .. Local Scalars .. | |||||
| DOUBLE PRECISION X, Y, YY, Z | |||||
| * .. Intrinsic Functions .. | |||||
| INTRINSIC HUGE | |||||
| * .. Executable Statements .. | |||||
| Y = HUGE(XX) | |||||
| Z = YY | |||||
| IF (K.EQ.1) THEN | |||||
| X = -Z | |||||
| ELSE IF (K.EQ.2) THEN | |||||
| X = Z | |||||
| ELSE IF (K.EQ.3) THEN | |||||
| X = Z / Z | |||||
| END IF | |||||
| DXVALS = X | |||||
| RETURN | |||||
| END | |||||
| END | END | ||||