mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2025-01-04 07:53:38 +01:00
86 lines
2.6 KiB
FortranFixed
86 lines
2.6 KiB
FortranFixed
|
*DECK DXRED
|
||
|
SUBROUTINE DXRED (X, IX, IERROR)
|
||
|
C***BEGIN PROLOGUE DXRED
|
||
|
C***PURPOSE To provide double-precision floating-point arithmetic
|
||
|
C with an extended exponent range.
|
||
|
C***LIBRARY SLATEC
|
||
|
C***CATEGORY A3D
|
||
|
C***TYPE DOUBLE PRECISION (XRED-S, DXRED-D)
|
||
|
C***KEYWORDS EXTENDED-RANGE DOUBLE-PRECISION ARITHMETIC
|
||
|
C***AUTHOR Lozier, Daniel W., (National Bureau of Standards)
|
||
|
C Smith, John M., (NBS and George Mason University)
|
||
|
C***DESCRIPTION
|
||
|
C DOUBLE PRECISION X
|
||
|
C INTEGER IX
|
||
|
C
|
||
|
C IF
|
||
|
C RADIX**(-2L) .LE. (ABS(X),IX) .LE. RADIX**(2L)
|
||
|
C THEN DXRED TRANSFORMS (X,IX) SO THAT IX=0.
|
||
|
C IF (X,IX) IS OUTSIDE THE ABOVE RANGE,
|
||
|
C THEN DXRED TAKES NO ACTION.
|
||
|
C THIS SUBROUTINE IS USEFUL IF THE
|
||
|
C RESULTS OF EXTENDED-RANGE CALCULATIONS
|
||
|
C ARE TO BE USED IN SUBSEQUENT ORDINARY
|
||
|
C DOUBLE-PRECISION CALCULATIONS.
|
||
|
C
|
||
|
C***SEE ALSO DXSET
|
||
|
C***REFERENCES (NONE)
|
||
|
C***ROUTINES CALLED (NONE)
|
||
|
C***COMMON BLOCKS DXBLK2
|
||
|
C***REVISION HISTORY (YYMMDD)
|
||
|
C 820712 DATE WRITTEN
|
||
|
C 881020 Revised to meet SLATEC CML recommendations. (DWL and JMS)
|
||
|
C 901019 Revisions to prologue. (DWL and WRB)
|
||
|
C 901106 Changed all specific intrinsics to generic. (WRB)
|
||
|
C Corrected order of sections in prologue and added TYPE
|
||
|
C section. (WRB)
|
||
|
C 920127 Revised PURPOSE section of prologue. (DWL)
|
||
|
C***END PROLOGUE DXRED
|
||
|
DOUBLE PRECISION X
|
||
|
INTEGER IX
|
||
|
DOUBLE PRECISION RADIX, RADIXL, RAD2L, DLG10R, XA
|
||
|
INTEGER L, L2, KMAX
|
||
|
COMMON /DXBLK2/ RADIX, RADIXL, RAD2L, DLG10R, L, L2, KMAX
|
||
|
SAVE /DXBLK2/
|
||
|
C
|
||
|
C***FIRST EXECUTABLE STATEMENT DXRED
|
||
|
IERROR=0
|
||
|
IF (X.EQ.0.0D0) GO TO 90
|
||
|
XA = ABS(X)
|
||
|
IF (IX.EQ.0) GO TO 70
|
||
|
IXA = ABS(IX)
|
||
|
IXA1 = IXA/L2
|
||
|
IXA2 = MOD(IXA,L2)
|
||
|
IF (IX.GT.0) GO TO 40
|
||
|
10 CONTINUE
|
||
|
IF (XA.GT.1.0D0) GO TO 20
|
||
|
XA = XA*RAD2L
|
||
|
IXA1 = IXA1 + 1
|
||
|
GO TO 10
|
||
|
20 XA = XA/RADIX**IXA2
|
||
|
IF (IXA1.EQ.0) GO TO 70
|
||
|
DO 30 I=1,IXA1
|
||
|
IF (XA.LT.1.0D0) GO TO 100
|
||
|
XA = XA/RAD2L
|
||
|
30 CONTINUE
|
||
|
GO TO 70
|
||
|
C
|
||
|
40 CONTINUE
|
||
|
IF (XA.LT.1.0D0) GO TO 50
|
||
|
XA = XA/RAD2L
|
||
|
IXA1 = IXA1 + 1
|
||
|
GO TO 40
|
||
|
50 XA = XA*RADIX**IXA2
|
||
|
IF (IXA1.EQ.0) GO TO 70
|
||
|
DO 60 I=1,IXA1
|
||
|
IF (XA.GT.1.0D0) GO TO 100
|
||
|
XA = XA*RAD2L
|
||
|
60 CONTINUE
|
||
|
70 IF (XA.GT.RAD2L) GO TO 100
|
||
|
IF (XA.GT.1.0D0) GO TO 80
|
||
|
IF (RAD2L*XA.LT.1.0D0) GO TO 100
|
||
|
80 X = SIGN(XA,X)
|
||
|
90 IX = 0
|
||
|
100 RETURN
|
||
|
END
|