Go to the documentation of this file.00001
00002 SUBROUTINE DGAMLM (XMIN, XMAX)
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 DOUBLE PRECISION XMIN, XMAX, ALNBIG, ALNSML, XLN, XOLD, D1MACH
00033
00034 ALNSML = LOG(D1MACH(1))
00035 XMIN = -ALNSML
00036 DO 10 I=1,10
00037 XOLD = XMIN
00038 XLN = LOG(XMIN)
00039 XMIN = XMIN - XMIN*((XMIN+0.5D0)*XLN - XMIN - 0.2258D0 + ALNSML)
00040 1 / (XMIN*XLN+0.5D0)
00041 IF (ABS(XMIN-XOLD).LT.0.005D0) GO TO 20
00042 10 CONTINUE
00043 CALL XERMSG ('SLATEC', 'DGAMLM', 'UNABLE TO FIND XMIN', 1, 2)
00044
00045 20 XMIN = -XMIN + 0.01D0
00046
00047 ALNBIG = LOG (D1MACH(2))
00048 XMAX = ALNBIG
00049 DO 30 I=1,10
00050 XOLD = XMAX
00051 XLN = LOG(XMAX)
00052 XMAX = XMAX - XMAX*((XMAX-0.5D0)*XLN - XMAX + 0.9189D0 - ALNBIG)
00053 1 / (XMAX*XLN-0.5D0)
00054 IF (ABS(XMAX-XOLD).LT.0.005D0) GO TO 40
00055 30 CONTINUE
00056 CALL XERMSG ('SLATEC', 'DGAMLM', 'UNABLE TO FIND XMAX', 2, 2)
00057
00058 40 XMAX = XMAX - 0.01D0
00059 XMIN = MAX (XMIN, -XMAX+1.D0)
00060
00061 RETURN
00062 END