erf.f 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. *DECK ERF
  2. FUNCTION ERF (X)
  3. C***BEGIN PROLOGUE ERF
  4. C***PURPOSE Compute the error function.
  5. C***LIBRARY SLATEC (FNLIB)
  6. C***CATEGORY C8A, L5A1E
  7. C***TYPE SINGLE PRECISION (ERF-S, DERF-D)
  8. C***KEYWORDS ERF, ERROR FUNCTION, FNLIB, SPECIAL FUNCTIONS
  9. C***AUTHOR Fullerton, W., (LANL)
  10. C***DESCRIPTION
  11. C
  12. C ERF(X) calculates the single precision error function for
  13. C single precision argument X.
  14. C
  15. C Series for ERF on the interval 0. to 1.00000D+00
  16. C with weighted error 7.10E-18
  17. C log weighted error 17.15
  18. C significant figures required 16.31
  19. C decimal places required 17.71
  20. C
  21. C***REFERENCES (NONE)
  22. C***ROUTINES CALLED CSEVL, ERFC, INITS, R1MACH
  23. C***REVISION HISTORY (YYMMDD)
  24. C 770401 DATE WRITTEN
  25. C 890531 Changed all specific intrinsics to generic. (WRB)
  26. C 890531 REVISION DATE from Version 3.2
  27. C 891214 Prologue converted to Version 4.0 format. (BAB)
  28. C 900727 Added EXTERNAL statement. (WRB)
  29. C 920618 Removed space from variable name. (RWC, WRB)
  30. C***END PROLOGUE ERF
  31. DIMENSION ERFCS(13)
  32. LOGICAL FIRST
  33. EXTERNAL ERFC
  34. SAVE ERFCS, SQRTPI, NTERF, XBIG, SQEPS, FIRST
  35. DATA ERFCS( 1) / -.0490461212 34691808E0 /
  36. DATA ERFCS( 2) / -.1422612051 0371364E0 /
  37. DATA ERFCS( 3) / .0100355821 87599796E0 /
  38. DATA ERFCS( 4) / -.0005768764 69976748E0 /
  39. DATA ERFCS( 5) / .0000274199 31252196E0 /
  40. DATA ERFCS( 6) / -.0000011043 17550734E0 /
  41. DATA ERFCS( 7) / .0000000384 88755420E0 /
  42. DATA ERFCS( 8) / -.0000000011 80858253E0 /
  43. DATA ERFCS( 9) / .0000000000 32334215E0 /
  44. DATA ERFCS(10) / -.0000000000 00799101E0 /
  45. DATA ERFCS(11) / .0000000000 00017990E0 /
  46. DATA ERFCS(12) / -.0000000000 00000371E0 /
  47. DATA ERFCS(13) / .0000000000 00000007E0 /
  48. DATA SQRTPI /1.772453850 9055160E0/
  49. DATA FIRST /.TRUE./
  50. C***FIRST EXECUTABLE STATEMENT ERF
  51. IF (FIRST) THEN
  52. NTERF = INITS (ERFCS, 13, 0.1*R1MACH(3))
  53. XBIG = SQRT(-LOG(SQRTPI*R1MACH(3)))
  54. SQEPS = SQRT(2.0*R1MACH(3))
  55. ENDIF
  56. FIRST = .FALSE.
  57. C
  58. Y = ABS(X)
  59. IF (Y.GT.1.) GO TO 20
  60. C
  61. C ERF(X) = 1. - ERFC(X) FOR -1. .LE. X .LE. 1.
  62. C
  63. IF (Y.LE.SQEPS) ERF = 2.0*X/SQRTPI
  64. IF (Y.GT.SQEPS) ERF = X*(1.0 + CSEVL(2.*X**2-1., ERFCS, NTERF))
  65. RETURN
  66. C
  67. C ERF(X) = 1. - ERFC(X) FOR ABS(X) .GT. 1.
  68. C
  69. 20 IF (Y.LE.XBIG) ERF = SIGN (1.0-ERFC(Y), X)
  70. IF (Y.GT.XBIG) ERF = SIGN (1.0, X)
  71. C
  72. RETURN
  73. END