;;; 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 ':array) ;;; (:array-slicing t) (:declare-common nil) ;;; (:float-format double-float)) (in-package :slatec) (defun dqawo (f a b omega integr epsabs epsrel result abserr neval ier leniw maxp1 lenw last$ iwork work) (declare (type (array double-float (*)) work) (type (array f2cl-lib:integer4 (*)) iwork) (type (f2cl-lib:integer4) last$ lenw maxp1 leniw ier neval integr) (type (double-float) abserr result epsrel epsabs omega b a)) (f2cl-lib:with-multi-array-data ((iwork f2cl-lib:integer4 iwork-%data% iwork-%offset%) (work double-float work-%data% work-%offset%)) (prog ((limit 0) (lvl 0) (l1 0) (l2 0) (l3 0) (l4 0) (momcom 0)) (declare (type (f2cl-lib:integer4) momcom l4 l3 l2 l1 lvl limit)) (setf ier 6) (setf neval 0) (setf last$ 0) (setf result 0.0) (setf abserr 0.0) (if (or (< leniw 2) (< maxp1 1) (< lenw (f2cl-lib:int-add (f2cl-lib:int-mul leniw 2) (f2cl-lib:int-mul maxp1 25)))) (go label10)) (setf limit (the f2cl-lib:integer4 (truncate leniw 2))) (setf l1 (f2cl-lib:int-add limit 1)) (setf l2 (f2cl-lib:int-add limit l1)) (setf l3 (f2cl-lib:int-add limit l2)) (setf l4 (f2cl-lib:int-add limit l3)) (multiple-value-bind (var-0 var-1 var-2 var-3 var-4 var-5 var-6 var-7 var-8 var-9 var-10 var-11 var-12 var-13 var-14 var-15 var-16 var-17 var-18 var-19 var-20 var-21 var-22) (dqawoe f a b omega integr epsabs epsrel limit 1 maxp1 result abserr neval ier last$ (f2cl-lib:array-slice work double-float (1) ((1 *))) (f2cl-lib:array-slice work double-float (l1) ((1 *))) (f2cl-lib:array-slice work double-float (l2) ((1 *))) (f2cl-lib:array-slice work double-float (l3) ((1 *))) (f2cl-lib:array-slice iwork f2cl-lib:integer4 (1) ((1 *))) (f2cl-lib:array-slice iwork f2cl-lib:integer4 (l1) ((1 *))) momcom (f2cl-lib:array-slice work double-float (l4) ((1 *)))) (declare (ignore var-0 var-1 var-2 var-3 var-5 var-6 var-7 var-8 var-9 var-15 var-16 var-17 var-18 var-19 var-20 var-22)) (setf integr var-4) (setf result var-10) (setf abserr var-11) (setf neval var-12) (setf ier var-13) (setf last$ var-14) (setf momcom var-21)) (setf lvl 0) label10 (if (= ier 6) (setf lvl 0)) (if (/= ier 0) (xermsg "SLATEC" "DQAWO" "ABNORMAL RETURN" ier lvl)) (go end_label) end_label (return (values nil nil nil nil integr nil nil result abserr neval ier nil nil nil last$ nil 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::dqawo fortran-to-lisp::*f2cl-function-info*) (fortran-to-lisp::make-f2cl-finfo :arg-types '(t (double-float) (double-float) (double-float) (fortran-to-lisp::integer4) (double-float) (double-float) (double-float) (double-float) (fortran-to-lisp::integer4) (fortran-to-lisp::integer4) (fortran-to-lisp::integer4) (fortran-to-lisp::integer4) (fortran-to-lisp::integer4) (fortran-to-lisp::integer4) (array fortran-to-lisp::integer4 (*)) (array double-float (*))) :return-values '(nil nil nil nil fortran-to-lisp::integr nil nil fortran-to-lisp::result fortran-to-lisp::abserr fortran-to-lisp::neval fortran-to-lisp::ier nil nil nil fortran-to-lisp::last$ nil nil) :calls '(fortran-to-lisp::xermsg fortran-to-lisp::dqawoe))))