;;; 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) (defun initds (os nos eta) (declare (type (single-float) eta) (type (integer) nos) (type (simple-array double-float (*)) os)) (prog ((initds 0) (i 0) (ii 0) (err 0.0f0)) (declare (type (single-float) err) (type (integer) ii i initds)) (if (< nos 1) (xermsg "SLATEC" "INITDS" "Number of coefficients is less than 1" 2 1)) (setf err 0.0f0) (f2cl-lib:fdo (ii 1 (f2cl-lib:int-add ii 1)) ((> ii nos) nil) (tagbody (setf i (f2cl-lib:int-sub (f2cl-lib:int-add nos 1) ii)) (setf err (+ err (abs (f2cl-lib:freal (f2cl-lib:fref os (i) ((1 *))))))) (if (> err eta) (go label20)) label10)) label20 (if (= i nos) (xermsg "SLATEC" "INITDS" "Chebyshev series too short for specified accuracy" 1 1)) (setf initds i) (go end_label) end_label (return (values initds nil 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::initds fortran-to-lisp::*f2cl-function-info*) (fortran-to-lisp::make-f2cl-finfo :arg-types '((simple-array double-float (*)) (integer) (single-float)) :return-values '(nil nil nil) :calls '(fortran-to-lisp::xermsg))))