      FUNCTION BESI0(X)
C***BEGIN PROLOGUE  BESI0
C***DATE WRITTEN   770401   (YYMMDD)
C***REVISION DATE  820801   (YYMMDD)
C***CATEGORY NO.  C10B1
C***KEYWORDS  BESSEL FUNCTION,FIRST KIND,HYPERBOLIC BESSEL FUNCTION,
C             MODIFIED BESSEL FUNCTION,ORDER ZERO 
C***AUTHOR  FULLERTON, W., (LANL)
C***PURPOSE  Computes the hyperbolic Bessel function of the first kind
C            of order zero
C***DESCRIPTION
C
C BESI0(X) computes the modified (hyperbolic) Bessel function
C of the first kind of order zero and real argument X.
C
C Series for BI0        on the interval  0.          to  9.00000D+00
C                                        with weighted error   2.46E-18
C                                         log weighted error  17.61
C                               significant figures required  17.90
C                                    decimal places required  18.15
C***REFERENCES  (NONE)
C***ROUTINES CALLED  BESI0E,CSEVL,INITS,R1MACH,XERROR
C***END PROLOGUE  BESI0
      DIMENSION BI0CS(12)
      DATA BI0 CS( 1) /   -.0766054725 2839144951E0 /
      DATA BI0 CS( 2) /   1.9273379539 93808270E0 /
      DATA BI0 CS( 3) /    .2282644586 920301339E0 /
      DATA BI0 CS( 4) /    .0130489146 6707290428E0 /
      DATA BI0 CS( 5) /    .0004344270 9008164874E0 /
      DATA BI0 CS( 6) /    .0000094226 5768600193E0 /
      DATA BI0 CS( 7) /    .0000001434 0062895106E0 /
      DATA BI0 CS( 8) /    .0000000016 1384906966E0 /
      DATA BI0 CS( 9) /    .0000000000 1396650044E0 /
      DATA BI0 CS(10) /    .0000000000 0009579451E0 /
      DATA BI0 CS(11) /    .0000000000 0000053339E0 /
      DATA BI0 CS(12) /    .0000000000 0000000245E0 /
      DATA NTI0, XSML, XMAX / 0, 0., 0. /
C***FIRST EXECUTABLE STATEMENT  BESI0
      IF (NTI0.NE.0) GO TO 10 
      NTI0 = INITS (BI0CS, 12, 0.1*R1MACH(3))
      XSML = SQRT (4.0*R1MACH(3))
      XMAX = ALOG (R1MACH(2)) 
C
 10   Y = ABS(X)
      IF (Y.GT.3.0) GO TO 20
C
      BESI0 = 1.0
      IF (Y.GT.XSML) BESI0 = 2.75 + CSEVL (Y*Y/4.5-1.0, BI0CS, NTI0)
      RETURN
C
 20   IF (Y.GT.XMAX) CALL XERROR ( 'BESI0   ABS(X) SO BIG I0 OVERFLOWS',
     1  34, 1, 2)
C
      BESI0 = EXP(Y) * BESI0E(X)
C
      RETURN
      END 
      FUNCTION BESI0E(X)
C***BEGIN PROLOGUE  BESI0E
C***DATE WRITTEN   770701   (YYMMDD)
C***REVISION DATE  820801   (YYMMDD)
C***CATEGORY NO.  C10B1
C***KEYWORDS  BESSEL FUNCTION,EXPONENTIALLY SCALED,FIRST KIND,
C             HYPERBOLIC BESSEL FUNCTION,MODIFIED BESSEL FUNCTION,
C             ORDER ZERO
C***AUTHOR  FULLERTON, W., (LANL)
C***PURPOSE  Computes the exponentially scaled hyperbolic Bessel
C            function of the first kind of order zero.
C***DESCRIPTION
C
C BESI0E(X) calculates the exponentially scaled modified (hyperbolic) 
C Bessel function of the first kind of order zero for real argument X;
C i.e., EXP(-ABS(X))*I0(X). 
C
C
C Series for BI0        on the interval  0.          to  9.00000D+00
C                                        with weighted error   2.46E-18
C                                         log weighted error  17.61
C                               significant figures required  17.90
C                                    decimal places required  18.15
C
C
C Series for AI0        on the interval  1.25000D-01 to  3.33333D-01
C                                        with weighted error   7.87E-17
C                                         log weighted error  16.10
C                               significant figures required  14.69
C                                    decimal places required  16.76
C
C
C Series for AI02       on the interval  0.          to  1.25000D-01
C                                        with weighted error   3.79E-17
C                                         log weighted error  16.42
C                               significant figures required  14.86
C                                    decimal places required  17.09
C***REFERENCES  (NONE)
C***ROUTINES CALLED  CSEVL,INITS,R1MACH 
C***END PROLOGUE  BESI0E
      DIMENSION BI0CS(12), AI0CS(21), AI02CS(22)
      DATA BI0 CS( 1) /   -.0766054725 2839144951E0 /
      DATA BI0 CS( 2) /   1.9273379539 93808270E0 /
      DATA BI0 CS( 3) /    .2282644586 920301339E0 /
      DATA BI0 CS( 4) /    .0130489146 6707290428E0 /
      DATA BI0 CS( 5) /    .0004344270 9008164874E0 /
      DATA BI0 CS( 6) /    .0000094226 5768600193E0 /
      DATA BI0 CS( 7) /    .0000001434 0062895106E0 /
      DATA BI0 CS( 8) /    .0000000016 1384906966E0 /
      DATA BI0 CS( 9) /    .0000000000 1396650044E0 /
      DATA BI0 CS(10) /    .0000000000 0009579451E0 /
      DATA BI0 CS(11) /    .0000000000 0000053339E0 /
      DATA BI0 CS(12) /    .0000000000 0000000245E0 /
      DATA AI0 CS( 1) /    .0757599449 4023796E0 /
      DATA AI0 CS( 2) /    .0075913808 1082334E0 /
      DATA AI0 CS( 3) /    .0004153131 3389237E0 /
      DATA AI0 CS( 4) /    .0000107007 6463439E0 /
      DATA AI0 CS( 5) /   -.0000079011 7997921E0 /
      DATA AI0 CS( 6) /   -.0000007826 1435014E0 /
      DATA AI0 CS( 7) /    .0000002783 8499429E0 /
      DATA AI0 CS( 8) /    .0000000082 5247260E0 /
      DATA AI0 CS( 9) /   -.0000000120 4463945E0 /
      DATA AI0 CS(10) /    .0000000015 5964859E0 /
      DATA AI0 CS(11) /    .0000000002 2925563E0 /
      DATA AI0 CS(12) /   -.0000000001 1916228E0 /
      DATA AI0 CS(13) /    .0000000000 1757854E0 /
      DATA AI0 CS(14) /    .0000000000 0112822E0 /
      DATA AI0 CS(15) /   -.0000000000 0114684E0 /
      DATA AI0 CS(16) /    .0000000000 0027155E0 /
      DATA AI0 CS(17) /   -.0000000000 0002415E0 /
      DATA AI0 CS(18) /   -.0000000000 0000608E0 /
      DATA AI0 CS(19) /    .0000000000 0000314E0 /
      DATA AI0 CS(20) /   -.0000000000 0000071E0 /
      DATA AI0 CS(21) /    .0000000000 0000007E0 /
      DATA AI02CS( 1) /    .0544904110 1410882E0 /
      DATA AI02CS( 2) /    .0033691164 7825569E0 /
      DATA AI02CS( 3) /    .0000688975 8346918E0 /
      DATA AI02CS( 4) /    .0000028913 7052082E0 /
      DATA AI02CS( 5) /    .0000002048 9185893E0 /
      DATA AI02CS( 6) /    .0000000226 6668991E0 /
      DATA AI02CS( 7) /    .0000000033 9623203E0 /
      DATA AI02CS( 8) /    .0000000004 9406022E0 /
      DATA AI02CS( 9) /    .0000000000 1188914E0 /
      DATA AI02CS(10) /   -.0000000000 3149915E0 /
      DATA AI02CS(11) /   -.0000000000 1321580E0 /
      DATA AI02CS(12) /   -.0000000000 0179419E0 /
      DATA AI02CS(13) /    .0000000000 0071801E0 /
      DATA AI02CS(14) /    .0000000000 0038529E0 /
      DATA AI02CS(15) /    .0000000000 0001539E0 /
      DATA AI02CS(16) /   -.0000000000 0004151E0 /
      DATA AI02CS(17) /   -.0000000000 0000954E0 /
      DATA AI02CS(18) /    .0000000000 0000382E0 /
      DATA AI02CS(19) /    .0000000000 0000176E0 /
      DATA AI02CS(20) /   -.0000000000 0000034E0 /
      DATA AI02CS(21) /   -.0000000000 0000027E0 /
      DATA AI02CS(22) /    .0000000000 0000003E0 /
      DATA NTI0, NTAI0, NTAI02, XSML / 3*0, 0. /
C***FIRST EXECUTABLE STATEMENT  BESI0E
      IF (NTI0.NE.0) GO TO 10 
      NTI0 = INITS (BI0CS, 12, 0.1*R1MACH(3))
      NTAI0 = INITS (AI0CS, 21, 0.1*R1MACH(3))
      NTAI02 = INITS (AI02CS, 22, 0.1*R1MACH(3))
      XSML = SQRT (4.0*R1MACH(3))
C
 10   Y = ABS(X)
      IF (Y.GT.3.0) GO TO 20
C
      BESI0E = 1.0
      IF (Y.GT.XSML) BESI0E = EXP(-Y) * ( 2.75 +
     1  CSEVL (Y*Y/4.5-1.0, BI0CS, NTI0) )
      RETURN
C
 20   IF (Y.LE.8.) BESI0E = (.375 + CSEVL ((48./Y-11.)/5., AI0CS, NTAI0)
     1  ) / SQRT(Y) 
      IF (Y.GT.8.) BESI0E = (.375 + CSEVL (16./Y-1., AI02CS, NTAI02)) 
     1  / SQRT(Y)
C
      RETURN
      END 
