;;; Compiled by f2cl version 2.0 beta Date: 2007/05/04 17:29:50 ;;; Using Lisp CMU Common Lisp Snapshot 2007-05 (19D) ;;; ;;; Options: ((:prune-labels nil) (:auto-save t) (:relaxed-array-decls t) ;;; (:coerce-assigns :as-needed) (:array-type ':simple-array) ;;; (:array-slicing nil) (:declare-common nil) ;;; (:float-format double-float)) (in-package :slatec) (let ((naif 0) (naig 0) (x3sml 0.0) (xmax 0.0) (aifcs (make-array 13 :element-type 'double-float :initial-contents '(-0.03797135849667 0.05919188853726364 9.862928057727998e-4 6.848843819076567e-6 2.5942025962194713e-8 6.176612774081375e-11 1.0092454172466118e-13 1.2014792511179938e-16 1.0882945588716992e-19 7.751377219668488e-23 4.4548112037175636e-26 2.1092845231692343e-29 8.370173591074134e-33))) (aigcs (make-array 13 :element-type 'double-float :initial-contents '(0.018152365581161272 0.021572563166010757 2.567835698748325e-4 1.4265214119792405e-6 4.572114920018043e-9 9.52517084356471e-12 1.3925634605771398e-14 1.5070999142762378e-17 1.2559148312567778e-20 8.306307377082133e-24 4.465753849371857e-27 1.9900855034518868e-30 7.4702885256533335e-34))) (first$ nil)) (declare (type f2cl-lib:logical first$) (type (simple-array double-float (13)) aigcs aifcs) (type (double-float) xmax x3sml) (type (integer) naig naif)) (setq first$ f2cl-lib:%true%) (defun dai (x) (declare (type (double-float) x)) (prog ((theta 0.0) (xm 0.0) (z 0.0) (xmaxt 0.0) (dai 0.0)) (declare (type (double-float) dai xmaxt z xm theta)) (cond (first$ (setf naif (initds aifcs 13 (* 0.1f0 (f2cl-lib:freal (f2cl-lib:d1mach 3))))) (setf naig (initds aigcs 13 (* 0.1f0 (f2cl-lib:freal (f2cl-lib:d1mach 3))))) (setf x3sml (expt (f2cl-lib:d1mach 3) 0.3334)) (setf xmaxt (expt (* -1.5 (f2cl-lib:flog (f2cl-lib:d1mach 1))) 0.6667)) (setf xmax (- (+ xmaxt (/ (* (- xmaxt) (f2cl-lib:flog xmaxt)) (+ (* 4.0 (f2cl-lib:fsqrt xmaxt)) 1.0))) 0.01)))) (setf first$ f2cl-lib:%false%) (if (>= x -1.0) (go label20)) (multiple-value-bind (var-0 var-1 var-2) (d9aimp x xm theta) (declare (ignore var-0)) (setf xm var-1) (setf theta var-2)) (setf dai (* xm (cos theta))) (go end_label) label20 (if (> x 1.0) (go label30)) (setf z 0.0) (if (> (abs x) x3sml) (setf z (expt x 3))) (setf dai (+ 0.375 (- (dcsevl z aifcs naif) (* x (+ 0.25 (dcsevl z aigcs naig)))))) (go end_label) label30 (if (> x xmax) (go label40)) (setf dai (* (daie x) (exp (/ (* -2.0 x (f2cl-lib:fsqrt x)) 3.0)))) (go end_label) label40 (setf dai 0.0) (xermsg "SLATEC" "DAI" "X SO BIG AI UNDERFLOWS" 1 1) (go end_label) end_label (return (values dai nil))))) (in-package #-gcl #:cl-user #+gcl "CL-USER") #+#.(cl:if (cl:find-package '#:f2cl) '(and) '(or)) (eval-when (:load-toplevel :compile-toplevel :execute) (setf (gethash 'fortran-to-lisp::dai fortran-to-lisp::*f2cl-function-info*) (fortran-to-lisp::make-f2cl-finfo :arg-types '((double-float)) :return-values '(nil) :calls '(fortran-to-lisp::xermsg fortran-to-lisp::daie fortran-to-lisp::dcsevl fortran-to-lisp::d9aimp fortran-to-lisp::initds fortran-to-lisp::d1mach))))