home *** CD-ROM | disk | FTP | other *** search
/ Frostbyte's 1980s DOS Shareware Collection / floppyshareware.zip / floppyshareware / DOOG / PCSSP1.ZIP / AGLGQUAD.ZIP / QA10.FOR < prev    next >
Text File  |  1985-11-29  |  2KB  |  62 lines

  1. C
  2. C     ..................................................................
  3. C
  4. C        SUBROUTINE QA10
  5. C
  6. C        PURPOSE
  7. C           TO COMPUTE INTEGRAL(EXP(-X)*FCT(X)/SQRT(X), SUMMED OVER X
  8. C                               FROM 0 TO INFINITY).
  9. C
  10. C        USAGE
  11. C           CALL QA10 (FCT,Y)
  12. C           PARAMETER FCT REQUIRES AN EXTERNAL STATEMENT
  13. C
  14. C        DESCRIPTION OF PARAMETERS
  15. C           FCT    - THE NAME OF AN EXTERNAL FUNCTION SUBPROGRAM USED.
  16. C           Y      - THE RESULTING INTEGRAL VALUE.
  17. C
  18. C        REMARKS
  19. C           NONE
  20. C
  21. C        SUBROUTINES AND FUNCTION SUBPROGRAMS REQUIRED
  22. C           THE EXTERNAL FUNCTION SUBPROGRAM FCT(X) MUST BE FURNISHED
  23. C           BY THE USER.
  24. C
  25. C        METHOD
  26. C           EVALUATION IS DONE BY MEANS OF 10-POINT GENERALIZED GAUSS-
  27. C           LAGUERRE QUADRATURE FORMULA, WHICH INTEGRATES EXACTLY,
  28. C           WHENEVER FCT(X) IS A POLYNOMIAL UP TO DEGREE 19.
  29. C           FOR REFERENCE, SEE
  30. C           CONCUS/CASSATT/JAEHNIG/MELBY, TABLES FOR THE EVALUATION OF
  31. C           INTEGRAL(X**BETA*EXP(-X)*F(X), SUMMED OVER X FROM 0 TO
  32. C           INFINITY) BY GAUSS-LAGUERRE QUADRATURE, MTAC, VOL.17,
  33. C           ISS.83 (1963), PP.245-256.
  34. C
  35. C     ..................................................................
  36. C
  37.       SUBROUTINE QA10(FCT,Y)
  38. C
  39. C
  40.       X=29.02495
  41.       Y=.4458787E-12*FCT(X)
  42.       X=21.19389
  43.       Y=Y+.8798682E-9*FCT(X)
  44.       X=15.56116
  45.       Y=Y+.2172139E-6*FCT(X)
  46.       X=11.20813
  47.       Y=Y+.1560511E-4*FCT(X)
  48.       X=7.777439
  49.       Y=Y+.0004566773*FCT(X)
  50.       X=5.084908
  51.       Y=Y+.006487547*FCT(X)
  52.       X=3.022513
  53.       Y=Y+.04962104*FCT(X)
  54.       X=1.522944
  55.       Y=Y+.2180344*FCT(X)
  56.       X=.5438675
  57.       Y=Y+.5733510*FCT(X)
  58.       X=.06019206
  59.       Y=Y+.9244873*FCT(X)
  60.       RETURN
  61.       END
  62.