home *** CD-ROM | disk | FTP | other *** search
/ Enter 2004 January / enter-2004-01.iso / files / maxima-5.9.0.exe / {app} / share / maxima / 5.9.0 / src / numerical / slatec / dbesk1.lisp < prev    next >
Encoding:
Text File  |  2003-02-09  |  3.3 KB  |  77 lines

  1. ;;; Compiled by f2cl version 2.0 beta 2002-05-06
  2. ;;; 
  3. ;;; Options: ((:prune-labels nil) (:auto-save t) (:relaxed-array-decls t)
  4. ;;;           (:coerce-assigns :as-needed) (:array-type ':simple-array)
  5. ;;;           (:array-slicing nil) (:declare-common nil)
  6. ;;;           (:float-format double-float))
  7.  
  8. (in-package "SLATEC")
  9.  
  10.  
  11. (let ((ntk1 0)
  12.       (xmin 0.0)
  13.       (xsml 0.0)
  14.       (xmax 0.0)
  15.       (bk1cs (make-array 16 :element-type 'double-float))
  16.       (first nil))
  17.   (declare (type f2cl-lib:logical first)
  18.            (type (simple-array double-float (16)) bk1cs)
  19.            (type double-float xmax xsml xmin)
  20.            (type f2cl-lib:integer4 ntk1))
  21.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (1) ((1 16))) 0.025300227338947774)
  22.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (2) ((1 16))) -0.3531559607765449)
  23.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (3) ((1 16))) -0.12261118082265715)
  24.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (4) ((1 16))) -0.006975723859639864)
  25.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (5) ((1 16))) -1.7302889575130517e-4)
  26.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (6) ((1 16))) -2.4334061415659683e-6)
  27.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (7) ((1 16))) -2.2133876307347258e-8)
  28.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (8) ((1 16))) -1.4114883926335278e-10)
  29.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (9) ((1 16))) -6.666901694199329e-13)
  30.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (10) ((1 16))) -2.427449850519366e-15)
  31.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (11) ((1 16))) -7.023863479386289e-18)
  32.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (12) ((1 16))) -1.6543275155100995e-20)
  33.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (13) ((1 16))) -3.23383474599445e-23)
  34.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (14) ((1 16))) -5.331275052926527e-26)
  35.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (15) ((1 16))) -7.513040716215722e-29)
  36.   (f2cl-lib:fset (f2cl-lib:fref bk1cs (16) ((1 16))) -9.155085717654189e-32)
  37.   (setq first f2cl-lib:%true%)
  38.   (defun dbesk1 (x)
  39.     (declare (type double-float x))
  40.     (prog ((xmaxt 0.0) (y 0.0) (dbesk1 0.0))
  41.       (declare (type double-float dbesk1 y xmaxt))
  42.       (cond
  43.        (first
  44.         (setf ntk1
  45.                 (initds bk1cs 16
  46.                  (* 0.1f0 (f2cl-lib:freal (f2cl-lib:d1mach 3)))))
  47.         (setf xmin
  48.                 (exp
  49.                  (+
  50.                   (max (f2cl-lib:flog (f2cl-lib:d1mach 1))
  51.                        (- (f2cl-lib:flog (f2cl-lib:d1mach 2))))
  52.                   0.01)))
  53.         (setf xsml (f2cl-lib:fsqrt (* 4.0 (f2cl-lib:d1mach 3))))
  54.         (setf xmaxt (- (f2cl-lib:flog (f2cl-lib:d1mach 1))))
  55.         (setf xmax
  56.                 (+ xmaxt
  57.                    (/ (* -0.5 xmaxt (f2cl-lib:flog xmaxt)) (+ xmaxt 0.5))))))
  58.       (setf first f2cl-lib:%false%)
  59.       (if (<= x 0.0) (xermsg "SLATEC" "DBESK1" "X IS ZERO OR NEGATIVE" 2 2))
  60.       (if (> x 2.0) (go label20))
  61.       (if (< x xmin) (xermsg "SLATEC" "DBESK1" "X SO SMALL K1 OVERFLOWS" 3 2))
  62.       (setf y 0.0)
  63.       (if (> x xsml) (setf y (* x x)))
  64.       (setf dbesk1
  65.               (+ (* (f2cl-lib:flog (* 0.5 x)) (dbesi1 x))
  66.                  (/ (+ 0.75 (dcsevl (- (* 0.5 y) 1.0) bk1cs ntk1)) x)))
  67.       (go end_label)
  68.      label20
  69.       (setf dbesk1 0.0)
  70.       (if (> x xmax) (xermsg "SLATEC" "DBESK1" "X SO BIG K1 UNDERFLOWS" 1 1))
  71.       (if (> x xmax) (go end_label))
  72.       (setf dbesk1 (* (exp (- x)) (dbsk1e x)))
  73.       (go end_label)
  74.      end_label
  75.       (return (values dbesk1 nil)))))
  76.  
  77.