1 ;;; Compiled by f2cl version:
2 ;;; ("f2cl1.l,v 95098eb54f13 2013/04/01 00:45:16 toy $"
3 ;;; "f2cl2.l,v 95098eb54f13 2013/04/01 00:45:16 toy $"
4 ;;; "f2cl3.l,v 96616d88fb7e 2008/02/22 22:19:34 rtoy $"
5 ;;; "f2cl4.l,v 96616d88fb7e 2008/02/22 22:19:34 rtoy $"
6 ;;; "f2cl5.l,v 95098eb54f13 2013/04/01 00:45:16 toy $"
7 ;;; "f2cl6.l,v 1d5cbacbb977 2008/08/24 00:56:27 rtoy $"
8 ;;; "macros.l,v 1409c1352feb 2013/03/24 20:44:50 toy $")
10 ;;; Using Lisp CMU Common Lisp snapshot-2013-11 (20E Unicode)
12 ;;; Options: ((:prune-labels nil) (:auto-save t) (:relaxed-array-decls t)
13 ;;; (:coerce-assigns :as-needed) (:array-type ':array)
14 ;;; (:array-slicing t) (:declare-common nil)
15 ;;; (:float-format single-float))
17 (in-package "ODEPACK")
22 :element-type
'f2cl-lib
:integer4
23 :initial-contents
'(12 5)))
27 (declare (type (array f2cl-lib
:integer4
(2)) mord
)
28 (type (f2cl-lib:integer4
) mxstp0 mxhnl0 lenrat
))
30 (res adda jac neq y ydoti t$ tout itol rtol atol itask istate iopt
31 rwork lrw iwork liw mf
)
32 (declare (type (f2cl-lib:integer4
) mf liw lrw iopt istate itask itol
)
33 (type (double-float) tout t$
)
34 (type (array double-float
(*)) rwork atol rtol ydoti y
)
35 (type (array f2cl-lib
:integer4
(*)) iwork neq
))
37 (symbol-macrolet ((ccmax
38 (aref (dls001-part-0 *dls001-common-block
*) 209))
39 (h (aref (dls001-part-0 *dls001-common-block
*) 211))
40 (hmin (aref (dls001-part-0 *dls001-common-block
*) 212))
41 (hmxi (aref (dls001-part-0 *dls001-common-block
*) 213))
42 (hu (aref (dls001-part-0 *dls001-common-block
*) 214))
43 (tn (aref (dls001-part-0 *dls001-common-block
*) 216))
45 (aref (dls001-part-0 *dls001-common-block
*) 217))
46 (init (aref (dls001-part-1 *dls001-common-block
*) 0))
47 (mxstep (aref (dls001-part-1 *dls001-common-block
*) 1))
48 (mxhnil (aref (dls001-part-1 *dls001-common-block
*) 2))
49 (nhnil (aref (dls001-part-1 *dls001-common-block
*) 3))
50 (nslast (aref (dls001-part-1 *dls001-common-block
*) 4))
51 (nyh (aref (dls001-part-1 *dls001-common-block
*) 5))
53 (aref (dls001-part-1 *dls001-common-block
*) 16))
54 (kflag (aref (dls001-part-1 *dls001-common-block
*) 17))
55 (l (aref (dls001-part-1 *dls001-common-block
*) 18))
56 (lyh (aref (dls001-part-1 *dls001-common-block
*) 19))
57 (lewt (aref (dls001-part-1 *dls001-common-block
*) 20))
58 (lacor (aref (dls001-part-1 *dls001-common-block
*) 21))
59 (lsavf (aref (dls001-part-1 *dls001-common-block
*) 22))
60 (lwm (aref (dls001-part-1 *dls001-common-block
*) 23))
61 (meth (aref (dls001-part-1 *dls001-common-block
*) 25))
62 (miter (aref (dls001-part-1 *dls001-common-block
*) 26))
64 (aref (dls001-part-1 *dls001-common-block
*) 27))
66 (aref (dls001-part-1 *dls001-common-block
*) 28))
67 (msbp (aref (dls001-part-1 *dls001-common-block
*) 29))
68 (mxncf (aref (dls001-part-1 *dls001-common-block
*) 30))
69 (n (aref (dls001-part-1 *dls001-common-block
*) 31))
70 (nq (aref (dls001-part-1 *dls001-common-block
*) 32))
71 (nst (aref (dls001-part-1 *dls001-common-block
*) 33))
72 (nfe (aref (dls001-part-1 *dls001-common-block
*) 34))
73 (nje (aref (dls001-part-1 *dls001-common-block
*) 35))
74 (nqu (aref (dls001-part-1 *dls001-common-block
*) 36))
75 (istatc (aref (dlss01-part-1 *dlss01-common-block
*) 2))
76 (iys (aref (dlss01-part-1 *dlss01-common-block
*) 3))
77 (ipian (aref (dlss01-part-1 *dlss01-common-block
*) 8))
78 (ipjan (aref (dlss01-part-1 *dlss01-common-block
*) 9))
79 (lenyh (aref (dlss01-part-1 *dlss01-common-block
*) 18))
81 (aref (dlss01-part-1 *dlss01-common-block
*) 19))
82 (lenwk (aref (dlss01-part-1 *dlss01-common-block
*) 20))
83 (lrat (aref (dlss01-part-1 *dlss01-common-block
*) 22))
84 (lrest (aref (dlss01-part-1 *dlss01-common-block
*) 23))
85 (lwmin (aref (dlss01-part-1 *dlss01-common-block
*) 24))
86 (moss (aref (dlss01-part-1 *dlss01-common-block
*) 25))
87 (ngp (aref (dlss01-part-1 *dlss01-common-block
*) 28))
88 (nlu (aref (dlss01-part-1 *dlss01-common-block
*) 29))
89 (nnz (aref (dlss01-part-1 *dlss01-common-block
*) 30))
90 (nzl (aref (dlss01-part-1 *dlss01-common-block
*) 32))
91 (nzu (aref (dlss01-part-1 *dlss01-common-block
*) 33)))
92 (f2cl-lib:with-multi-array-data
93 ((neq f2cl-lib
:integer4 neq-%data% neq-%offset%
)
94 (iwork f2cl-lib
:integer4 iwork-%data% iwork-%offset%
)
95 (y double-float y-%data% y-%offset%
)
96 (ydoti double-float ydoti-%data% ydoti-%offset%
)
97 (rtol double-float rtol-%data% rtol-%offset%
)
98 (atol double-float atol-%data% atol-%offset%
)
99 (rwork double-float rwork-%data% rwork-%offset%
))
100 (prog ((ncolm 0) (mf1 0) (lyhn 0) (lyhd 0) (lyd0 0) (lwtem 0)
101 (lrtem 0) (ljc 0) (lja 0) (lic 0) (lia 0) (lenrw 0) (leniw 0)
102 (lenyht 0) (kgo 0) (j 0) (ires 0) (irem 0) (ipgo 0) (ipflag 0)
103 (imxer 0) (imul 0) (imax 0) (iflag 0) (igo 0) (ier 0) (i2 0)
104 (i1 0) (i 0) (w0 0.0d0
) (sum 0.0d0
) (size 0.0d0
) (tp 0.0d0
)
105 (tolsf 0.0d0
) (tol 0.0d0
) (tnext 0.0d0
) (tdist 0.0d0
)
106 (tcrit 0.0d0
) (rtoli 0.0d0
) (rh 0.0d0
) (hmx 0.0d0
)
107 (hmax 0.0d0
) (h0 0.0d0
) (ewti 0.0d0
) (big 0.0d0
) (ayi 0.0d0
)
108 (atoli 0.0d0
) (ihit nil
)
111 :element-type
'character
112 :initial-element
#\
)))
113 (declare (type (string 60) msg
)
114 (type f2cl-lib
:logical ihit
)
115 (type (double-float) atoli ayi big ewti h0 hmax hmx rh
116 rtoli tcrit tdist tnext tol tolsf tp
118 (type (f2cl-lib:integer4
) i i1 i2 ier igo iflag imax imul
119 imxer ipflag ipgo irem ires j
120 kgo lenyht leniw lenrw lia lic
121 lja ljc lrtem lwtem lyd0 lyhd
123 (if (or (< istate
0) (> istate
3)) (go label601
))
124 (if (or (< itask
1) (> itask
5)) (go label602
))
125 (if (<= istate
1) (go label10
))
126 (if (= init
0) (go label603
))
127 (if (= istate
2) (go label200
))
131 (if (= tout t$
) (go end_label
))
133 (if (<= (f2cl-lib:fref neq-%data%
(1) ((1 *)) neq-%offset%
) 0)
135 (if (<= istate
1) (go label25
))
136 (if (> (f2cl-lib:fref neq-%data%
(1) ((1 *)) neq-%offset%
) n
)
139 (setf n
(f2cl-lib:fref neq-%data%
(1) ((1 *)) neq-%offset%
))
140 (if (or (< itol
1) (> itol
4)) (go label606
))
141 (if (or (< iopt
0) (> iopt
1)) (go label607
))
142 (setf moss
(the f2cl-lib
:integer4
(truncate mf
100)))
143 (setf mf1
(f2cl-lib:int-sub mf
(f2cl-lib:int-mul
100 moss
)))
144 (setf meth
(the f2cl-lib
:integer4
(truncate mf1
10)))
145 (setf miter
(f2cl-lib:int-sub mf1
(f2cl-lib:int-mul
10 meth
)))
146 (if (or (< moss
0) (> moss
4)) (go label608
))
147 (if (and (= miter
2) (= moss
1))
148 (setf moss
(f2cl-lib:int-add moss
1)))
149 (if (and (= miter
2) (= moss
3))
150 (setf moss
(f2cl-lib:int-add moss
1)))
151 (if (and (= miter
1) (= moss
2))
152 (setf moss
(f2cl-lib:int-sub moss
1)))
153 (if (and (= miter
1) (= moss
4))
154 (setf moss
(f2cl-lib:int-sub moss
1)))
155 (if (or (< meth
1) (> meth
2)) (go label608
))
156 (if (or (< miter
1) (> miter
2)) (go label608
))
157 (if (= iopt
1) (go label40
))
158 (setf maxord
(f2cl-lib:fref mord
(meth) ((1 2))))
161 (if (<= istate
1) (setf h0
0.0d0
))
167 (f2cl-lib:fref iwork-%data%
(5) ((1 liw
)) iwork-%offset%
))
168 (if (< maxord
0) (go label611
))
169 (if (= maxord
0) (setf maxord
100))
171 (min (the f2cl-lib
:integer4 maxord
)
172 (the f2cl-lib
:integer4
173 (f2cl-lib:fref mord
(meth) ((1 2))))))
175 (f2cl-lib:fref iwork-%data%
(6) ((1 liw
)) iwork-%offset%
))
176 (if (< mxstep
0) (go label612
))
177 (if (= mxstep
0) (setf mxstep mxstp0
))
179 (f2cl-lib:fref iwork-%data%
(7) ((1 liw
)) iwork-%offset%
))
180 (if (< mxhnil
0) (go label613
))
181 (if (= mxhnil
0) (setf mxhnil mxhnl0
))
182 (if (> istate
1) (go label50
))
183 (setf h0
(f2cl-lib:fref rwork-%data%
(5) ((1 lrw
)) rwork-%offset%
))
184 (if (< (* (- tout t$
) h0
) 0.0d0
) (go label614
))
187 (f2cl-lib:fref rwork-%data%
(6) ((1 lrw
)) rwork-%offset%
))
188 (if (< hmax
0.0d0
) (go label615
))
190 (if (> hmax
0.0d0
) (setf hmxi
(/ 1.0d0 hmax
)))
192 (f2cl-lib:fref rwork-%data%
(7) ((1 lrw
)) rwork-%offset%
))
193 (if (< hmin
0.0d0
) (go label616
))
195 (setf rtoli
(f2cl-lib:fref rtol-%data%
(1) ((1 *)) rtol-%offset%
))
196 (setf atoli
(f2cl-lib:fref atol-%data%
(1) ((1 *)) atol-%offset%
))
197 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
202 (f2cl-lib:fref rtol-%data%
206 (if (or (= itol
2) (= itol
4))
208 (f2cl-lib:fref atol-%data%
212 (if (< rtoli
0.0d0
) (go label619
))
213 (if (< atoli
0.0d0
) (go label620
))
216 (if (<= istate
1) (setf nyh n
))
219 (+ (f2cl-lib:int-mul
4 n
)
220 (the f2cl-lib
:integer4
(truncate (* 10 n
) lrat
)))))
223 (+ (f2cl-lib:int-mul
4 n
)
224 (the f2cl-lib
:integer4
(truncate (* 11 n
) lrat
)))))
225 (setf lenyh
(f2cl-lib:int-mul
(f2cl-lib:int-add maxord
1) nyh
))
226 (setf lrest
(f2cl-lib:int-add lenyh
(f2cl-lib:int-mul
3 n
)))
227 (setf lenrw
(f2cl-lib:int-add
20 lwmin lrest
))
228 (setf (f2cl-lib:fref iwork-%data%
(17) ((1 liw
)) iwork-%offset%
)
231 (if (and (/= moss
1) (/= moss
2))
232 (setf leniw
(f2cl-lib:int-add leniw n
1)))
233 (setf (f2cl-lib:fref iwork-%data%
(18) ((1 liw
)) iwork-%offset%
)
235 (if (> lenrw lrw
) (go label617
))
236 (if (> leniw liw
) (go label618
))
238 (if (and (/= moss
1) (/= moss
2))
241 (f2cl-lib:int-add leniw
242 (f2cl-lib:fref iwork-%data%
249 (setf (f2cl-lib:fref iwork-%data%
(18) ((1 liw
)) iwork-%offset%
)
251 (if (> leniw liw
) (go label618
))
252 (setf lja
(f2cl-lib:int-add lia n
1))
254 (min (the f2cl-lib
:integer4 lia
)
255 (the f2cl-lib
:integer4 liw
)))
257 (min (the f2cl-lib
:integer4 lja
)
258 (the f2cl-lib
:integer4 liw
)))
259 (setf lic
(f2cl-lib:int-add leniw
1))
260 (if (= moss
0) (setf leniw
(f2cl-lib:int-add leniw n
1)))
261 (setf (f2cl-lib:fref iwork-%data%
(18) ((1 liw
)) iwork-%offset%
)
263 (if (> leniw liw
) (go label618
))
267 (f2cl-lib:int-add leniw
268 (f2cl-lib:fref iwork-%data%
275 (setf (f2cl-lib:fref iwork-%data%
(18) ((1 liw
)) iwork-%offset%
)
277 (if (> leniw liw
) (go label618
))
278 (setf ljc
(f2cl-lib:int-add lic n
1))
280 (min (the f2cl-lib
:integer4 lic
)
281 (the f2cl-lib
:integer4 liw
)))
283 (min (the f2cl-lib
:integer4 ljc
)
284 (the f2cl-lib
:integer4 liw
)))
286 (if (<= istate
1) (setf nq istate
))
288 (min (the f2cl-lib
:integer4
(f2cl-lib:int-add nq
1))
289 (the f2cl-lib
:integer4
(f2cl-lib:int-add maxord
2))))
290 (setf lenyhm
(f2cl-lib:int-mul ncolm nyh
))
293 (if (= istate
3) (setf imul moss
))
294 (if (and (= istate
3) (= moss
3)) (setf imul
1))
295 (if (or (= moss
2) (= moss
4)) (setf imul
3))
296 (setf lrtem
(f2cl-lib:int-add lenyht
(f2cl-lib:int-mul imul n
)))
297 (setf lwtem
(f2cl-lib:int-sub lrw
20 lrtem
))
299 (setf lyhn
(f2cl-lib:int-add lwm lwtem
))
300 (setf lsavf
(f2cl-lib:int-add lyhn lenyht
))
301 (setf lewt
(f2cl-lib:int-add lsavf n
))
302 (setf lacor
(f2cl-lib:int-add lewt n
))
304 (if (<= istate
1) (go label100
))
305 (setf lyhd
(f2cl-lib:int-sub lyh lyhn
))
306 (setf imax
(f2cl-lib:int-add
(f2cl-lib:int-sub lyhn
1) lenyhm
))
309 (f2cl-lib:fdo
(i lyhn
(f2cl-lib:int-add i
1))
312 (setf j
(f2cl-lib:int-sub
(f2cl-lib:int-add imax lyhn
) i
))
314 (setf (f2cl-lib:fref rwork-%data%
318 (f2cl-lib:fref rwork-%data%
319 ((f2cl-lib:int-add j lyhd
))
324 (f2cl-lib:fdo
(i lyhn
(f2cl-lib:int-add i
1))
328 (setf (f2cl-lib:fref rwork-%data%
332 (f2cl-lib:fref rwork-%data%
333 ((f2cl-lib:int-add i lyhd
))
338 (setf (f2cl-lib:fref iwork-%data%
(22) ((1 liw
)) iwork-%offset%
)
340 (if (and (/= moss
2) (/= moss
4)) (go label85
))
341 (dewset n itol rtol atol
342 (f2cl-lib:array-slice rwork-%data%
347 (f2cl-lib:array-slice rwork-%data%
352 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
357 (f2cl-lib:fref rwork-%data%
358 ((f2cl-lib:int-sub
(f2cl-lib:int-add i lewt
)
365 (setf (f2cl-lib:fref rwork-%data%
367 (f2cl-lib:int-add i lewt
)
372 (f2cl-lib:fref rwork-%data%
374 (f2cl-lib:int-add i lewt
)
380 (min (the f2cl-lib
:integer4 lsavf
)
381 (the f2cl-lib
:integer4 lrw
)))
383 (min (the f2cl-lib
:integer4 lewt
)
384 (the f2cl-lib
:integer4 lrw
)))
386 (min (the f2cl-lib
:integer4 lacor
)
387 (the f2cl-lib
:integer4 lrw
)))
389 (var-0 var-1 var-2 var-3 var-4 var-5 var-6 var-7 var-8 var-9
391 (diprepi neq y ydoti rwork
392 (f2cl-lib:array-slice iwork-%data%
397 (f2cl-lib:array-slice iwork-%data%
402 (f2cl-lib:array-slice iwork-%data%
407 (f2cl-lib:array-slice iwork-%data%
413 (declare (ignore var-0 var-1 var-2 var-3 var-4 var-5 var-6 var-7
414 var-9 var-10 var-11
))
417 (f2cl-lib:int-add
(f2cl-lib:int-sub lwm
1) lenwk lrest
))
418 (setf (f2cl-lib:fref iwork-%data%
(17) ((1 liw
)) iwork-%offset%
)
421 (setf (f2cl-lib:fref iwork-%data%
427 (setf (f2cl-lib:fref iwork-%data%
432 (setf ipgo
(f2cl-lib:int-sub
1 ipflag
))
433 (f2cl-lib:computed-goto
434 (label90 label628 label629 label630 label631 label632 label633
438 (setf (f2cl-lib:fref iwork-%data%
(22) ((1 liw
)) iwork-%offset%
)
440 (setf lyd0
(f2cl-lib:int-add lyh n
))
441 (if (> lenrw lrw
) (go label617
))
443 (if (<= nq maxord
) (go label94
))
444 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
448 (setf (f2cl-lib:fref ydoti-%data%
(i) ((1 *)) ydoti-%offset%
)
449 (f2cl-lib:fref rwork-%data%
451 (f2cl-lib:int-add i lsavf
)
456 (if (= n nyh
) (go label200
))
457 (setf i1
(f2cl-lib:int-add lyh
(f2cl-lib:int-mul l nyh
)))
460 (f2cl-lib:int-add lyh
462 (f2cl-lib:int-add maxord
1)
465 (if (> i1 i2
) (go label200
))
466 (f2cl-lib:fdo
(i i1
(f2cl-lib:int-add i
1))
470 (setf (f2cl-lib:fref rwork-%data%
(i) ((1 lrw
)) rwork-%offset%
)
475 (setf (f2cl-lib:fref iwork-%data%
(22) ((1 liw
)) iwork-%offset%
)
485 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
489 (setf (f2cl-lib:fref rwork-%data%
491 (f2cl-lib:int-add i lyh
)
495 (f2cl-lib:fref y-%data%
(i) ((1 *)) y-%offset%
))))
496 (if (/= istate
1) (go label108
))
497 (setf lyd0
(f2cl-lib:int-add lyh nyh
))
498 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
502 (setf (f2cl-lib:fref rwork-%data%
504 (f2cl-lib:int-add i lyd0
)
508 (f2cl-lib:fref ydoti-%data%
513 (dewset n itol rtol atol
514 (f2cl-lib:array-slice rwork-%data%
519 (f2cl-lib:array-slice rwork-%data%
524 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
529 (f2cl-lib:fref rwork-%data%
530 ((f2cl-lib:int-sub
(f2cl-lib:int-add i lewt
)
537 (setf (f2cl-lib:fref rwork-%data%
539 (f2cl-lib:int-add i lewt
)
544 (f2cl-lib:fref rwork-%data%
546 (f2cl-lib:int-add i lewt
)
551 (min (the f2cl-lib
:integer4 lacor
)
552 (the f2cl-lib
:integer4 lrw
)))
554 (var-0 var-1 var-2 var-3 var-4 var-5 var-6 var-7 var-8 var-9
556 (diprepi neq y ydoti rwork
557 (f2cl-lib:array-slice iwork-%data%
562 (f2cl-lib:array-slice iwork-%data%
567 (f2cl-lib:array-slice iwork-%data%
572 (f2cl-lib:array-slice iwork-%data%
578 (declare (ignore var-0 var-1 var-2 var-3 var-4 var-5 var-6 var-7
579 var-9 var-10 var-11
))
582 (f2cl-lib:int-add
(f2cl-lib:int-sub lwm
1) lenwk lrest
))
583 (setf (f2cl-lib:fref iwork-%data%
(17) ((1 liw
)) iwork-%offset%
)
586 (setf (f2cl-lib:fref iwork-%data%
592 (setf (f2cl-lib:fref iwork-%data%
597 (setf ipgo
(f2cl-lib:int-sub
1 ipflag
))
598 (f2cl-lib:computed-goto
599 (label115 label628 label629 label630 label631 label632 label633
603 (setf (f2cl-lib:fref iwork-%data%
(22) ((1 liw
)) iwork-%offset%
)
605 (if (> lenrw lrw
) (go label617
))
606 (setf lyd0
(f2cl-lib:int-add lyh n
))
607 (if (/= istate
0) (go label120
))
609 (var-0 var-1 var-2 var-3 var-4 var-5 var-6 var-7 var-8 var-9
)
610 (dainvgs (aref neq
0) t$ y
611 (f2cl-lib:array-slice rwork-%data%
616 (f2cl-lib:array-slice rwork-%data%
621 (f2cl-lib:array-slice rwork-%data%
626 (f2cl-lib:array-slice rwork-%data%
632 (declare (ignore var-0 var-2 var-3 var-4 var-5 var-6 var-8
636 (setf nfe
(f2cl-lib:int-add nfe
1))
637 (setf igo
(f2cl-lib:int-add ier
1))
638 (f2cl-lib:computed-goto
(label120 label565 label560 label560
) igo
)
640 (if (and (/= itask
4) (/= itask
5)) (go label125
))
642 (f2cl-lib:fref rwork-%data%
(1) ((1 lrw
)) rwork-%offset%
))
643 (if (< (* (- tcrit tout
) (- tout t$
)) 0.0d0
) (go label625
))
644 (if (and (/= h0
0.0d0
) (> (* (- (+ t$ h0
) tcrit
) h0
) 0.0d0
))
645 (setf h0
(- tcrit t$
)))
647 (setf uround
(dumach))
649 (setf (f2cl-lib:fref rwork-%data%
(lwm) ((1 lrw
)) rwork-%offset%
)
650 (f2cl-lib:fsqrt uround
))
661 (if (/= h0
0.0d0
) (go label180
))
662 (setf tdist
(abs (- tout t$
)))
663 (setf w0
(max (abs t$
) (abs tout
)))
664 (if (< tdist
(* 2.0d0 uround w0
)) (go label622
))
665 (setf tol
(f2cl-lib:fref rtol-%data%
(1) ((1 *)) rtol-%offset%
))
666 (if (<= itol
2) (go label145
))
667 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
673 (f2cl-lib:fref rtol-%data%
678 (if (> tol
0.0d0
) (go label160
))
679 (setf atoli
(f2cl-lib:fref atol-%data%
(1) ((1 *)) atol-%offset%
))
680 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
683 (if (or (= itol
2) (= itol
4))
685 (f2cl-lib:fref atol-%data%
690 (abs (f2cl-lib:fref y-%data%
(i) ((1 *)) y-%offset%
)))
691 (if (/= ayi
0.0d0
) (setf tol
(max tol
(/ atoli ayi
))))
694 (setf tol
(max tol
(* 100.0d0 uround
)))
695 (setf tol
(min tol
0.001d0
))
698 (f2cl-lib:array-slice rwork-%data%
703 (f2cl-lib:array-slice rwork-%data%
708 (setf sum
(+ (/ 1.0d0
(* tol w0 w0
)) (* tol
(expt sum
2))))
709 (setf h0
(/ 1.0d0
(f2cl-lib:fsqrt sum
)))
710 (setf h0
(min h0 tdist
))
711 (setf h0
(f2cl-lib:sign h0
(- tout t$
)))
713 (setf rh
(* (abs h0
) hmxi
))
714 (if (> rh
1.0d0
) (setf h0
(/ h0 rh
)))
716 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
720 (setf (f2cl-lib:fref rwork-%data%
722 (f2cl-lib:int-add i lyd0
)
727 (f2cl-lib:fref rwork-%data%
729 (f2cl-lib:int-add i lyd0
)
736 (f2cl-lib:computed-goto
737 (label210 label250 label220 label230 label240
)
740 (if (< (* (- tn tout
) h
) 0.0d0
) (go label250
))
741 (multiple-value-bind (var-0 var-1 var-2 var-3 var-4 var-5
)
743 (f2cl-lib:array-slice rwork-%data%
749 (declare (ignore var-0 var-1 var-2 var-3 var-4
))
751 (if (/= iflag
0) (go label627
))
755 (setf tp
(- tn
(* hu
(+ 1.0d0
(* 100.0d0 uround
)))))
756 (if (> (* (- tp tout
) h
) 0.0d0
) (go label623
))
757 (if (< (* (- tn tout
) h
) 0.0d0
) (go label250
))
761 (f2cl-lib:fref rwork-%data%
(1) ((1 lrw
)) rwork-%offset%
))
762 (if (> (* (- tn tcrit
) h
) 0.0d0
) (go label624
))
763 (if (< (* (- tcrit tout
) h
) 0.0d0
) (go label625
))
764 (if (< (* (- tn tout
) h
) 0.0d0
) (go label245
))
765 (multiple-value-bind (var-0 var-1 var-2 var-3 var-4 var-5
)
767 (f2cl-lib:array-slice rwork-%data%
773 (declare (ignore var-0 var-1 var-2 var-3 var-4
))
775 (if (/= iflag
0) (go label627
))
780 (f2cl-lib:fref rwork-%data%
(1) ((1 lrw
)) rwork-%offset%
))
781 (if (> (* (- tn tcrit
) h
) 0.0d0
) (go label624
))
783 (setf hmx
(+ (abs tn
) (abs h
)))
784 (setf ihit
(<= (abs (- tn tcrit
)) (* 100.0d0 uround hmx
)))
785 (if ihit
(go label400
))
786 (setf tnext
(+ tn
(* h
(+ 1.0d0
(* 4.0d0 uround
)))))
787 (if (<= (* (- tnext tcrit
) h
) 0.0d0
) (go label250
))
788 (setf h
(* (- tcrit tn
) (- 1.0d0
(* 4.0d0 uround
))))
789 (if (= istate
2) (setf jstart -
2))
791 (if (>= (f2cl-lib:int-sub nst nslast
) mxstep
) (go label500
))
792 (dewset n itol rtol atol
793 (f2cl-lib:array-slice rwork-%data%
798 (f2cl-lib:array-slice rwork-%data%
803 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
808 (f2cl-lib:fref rwork-%data%
809 ((f2cl-lib:int-sub
(f2cl-lib:int-add i lewt
)
816 (setf (f2cl-lib:fref rwork-%data%
818 (f2cl-lib:int-add i lewt
)
823 (f2cl-lib:fref rwork-%data%
825 (f2cl-lib:int-add i lewt
)
833 (f2cl-lib:array-slice rwork-%data%
838 (f2cl-lib:array-slice rwork-%data%
843 (if (<= tolsf
1.0d0
) (go label280
))
844 (setf tolsf
(* tolsf
2.0d0
))
845 (if (= nst
0) (go label626
))
848 (if (/= (+ tn h
) tn
) (go label290
))
849 (setf nhnil
(f2cl-lib:int-add nhnil
1))
850 (if (> nhnil mxhnil
) (go label290
))
851 (f2cl-lib:f2cl-set-string msg
852 "DLSODIS- Warning..Internal T (=R1) and H (=R2) are"
854 (xerrwd msg
50 101 0 0 0 0 0 0.0d0
0.0d0
)
855 (f2cl-lib:f2cl-set-string msg
856 " such that in the machine, T + H = T on the next step "
858 (xerrwd msg
60 101 0 0 0 0 0 0.0d0
0.0d0
)
859 (f2cl-lib:f2cl-set-string msg
860 " (H = step size). Solver will continue anyway."
862 (xerrwd msg
50 101 0 0 0 0 2 tn h
)
863 (if (< nhnil mxhnil
) (go label290
))
864 (f2cl-lib:f2cl-set-string msg
865 "DLSODIS- Above warning has been issued I1 times. "
867 (xerrwd msg
50 102 0 0 0 0 0 0.0d0
0.0d0
)
868 (f2cl-lib:f2cl-set-string msg
869 " It will not be issued again for this problem."
871 (xerrwd msg
50 102 0 1 mxhnil
0 0 0.0d0
0.0d0
)
874 (var-0 var-1 var-2 var-3 var-4 var-5 var-6 var-7 var-8 var-9
875 var-10 var-11 var-12 var-13 var-14 var-15
)
877 (f2cl-lib:array-slice rwork-%data%
883 (f2cl-lib:array-slice rwork-%data%
888 (f2cl-lib:array-slice rwork-%data%
894 (f2cl-lib:array-slice rwork-%data%
899 (f2cl-lib:array-slice rwork-%data%
904 (f2cl-lib:array-slice rwork-%data%
909 (f2cl-lib:array-slice rwork-%data%
914 res adda jac
#'dprjis
#'dsolss
)
915 (declare (ignore var-0 var-1 var-2 var-4 var-5 var-6 var-7 var-8
916 var-9 var-10 var-11 var-12 var-13 var-14
919 (setf kgo
(f2cl-lib:int-sub
1 kflag
))
920 (f2cl-lib:computed-goto
921 (label300 label530 label540 label400 label550 label555
)
925 (f2cl-lib:computed-goto
926 (label310 label400 label330 label340 label350
)
929 (if (< (* (- tn tout
) h
) 0.0d0
) (go label250
))
930 (multiple-value-bind (var-0 var-1 var-2 var-3 var-4 var-5
)
932 (f2cl-lib:array-slice rwork-%data%
938 (declare (ignore var-0 var-1 var-2 var-3 var-4
))
943 (if (>= (* (- tn tout
) h
) 0.0d0
) (go label400
))
946 (if (< (* (- tn tout
) h
) 0.0d0
) (go label345
))
947 (multiple-value-bind (var-0 var-1 var-2 var-3 var-4 var-5
)
949 (f2cl-lib:array-slice rwork-%data%
955 (declare (ignore var-0 var-1 var-2 var-3 var-4
))
960 (setf hmx
(+ (abs tn
) (abs h
)))
961 (setf ihit
(<= (abs (- tn tcrit
)) (* 100.0d0 uround hmx
)))
962 (if ihit
(go label400
))
963 (setf tnext
(+ tn
(* h
(+ 1.0d0
(* 4.0d0 uround
)))))
964 (if (<= (* (- tnext tcrit
) h
) 0.0d0
) (go label250
))
965 (setf h
(* (- tcrit tn
) (- 1.0d0
(* 4.0d0 uround
))))
969 (setf hmx
(+ (abs tn
) (abs h
)))
970 (setf ihit
(<= (abs (- tn tcrit
)) (* 100.0d0 uround hmx
)))
972 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
976 (setf (f2cl-lib:fref y-%data%
(i) ((1 *)) y-%offset%
)
977 (f2cl-lib:fref rwork-%data%
979 (f2cl-lib:int-add i lyh
)
984 (if (and (/= itask
4) (/= itask
5)) (go label420
))
985 (if ihit
(setf t$ tcrit
))
988 (if (= kflag -
3) (setf istate
3))
989 (setf (f2cl-lib:fref rwork-%data%
(11) ((1 lrw
)) rwork-%offset%
)
991 (setf (f2cl-lib:fref rwork-%data%
(12) ((1 lrw
)) rwork-%offset%
) h
)
992 (setf (f2cl-lib:fref rwork-%data%
(13) ((1 lrw
)) rwork-%offset%
)
994 (setf (f2cl-lib:fref iwork-%data%
(11) ((1 liw
)) iwork-%offset%
)
996 (setf (f2cl-lib:fref iwork-%data%
(12) ((1 liw
)) iwork-%offset%
)
998 (setf (f2cl-lib:fref iwork-%data%
(13) ((1 liw
)) iwork-%offset%
)
1000 (setf (f2cl-lib:fref iwork-%data%
(14) ((1 liw
)) iwork-%offset%
)
1002 (setf (f2cl-lib:fref iwork-%data%
(15) ((1 liw
)) iwork-%offset%
)
1004 (setf (f2cl-lib:fref iwork-%data%
(19) ((1 liw
)) iwork-%offset%
)
1006 (setf (f2cl-lib:fref iwork-%data%
(20) ((1 liw
)) iwork-%offset%
)
1008 (setf (f2cl-lib:fref iwork-%data%
(21) ((1 liw
)) iwork-%offset%
)
1010 (setf (f2cl-lib:fref iwork-%data%
(25) ((1 liw
)) iwork-%offset%
)
1012 (setf (f2cl-lib:fref iwork-%data%
(26) ((1 liw
)) iwork-%offset%
)
1016 (f2cl-lib:f2cl-set-string msg
1017 "DLSODIS- At current T (=R1), MXSTEP (=I1) steps "
1019 (xerrwd msg
50 201 0 0 0 0 0 0.0d0
0.0d0
)
1020 (f2cl-lib:f2cl-set-string msg
1021 " taken on this call before reaching TOUT "
1023 (xerrwd msg
50 201 0 1 mxstep
0 1 tn
0.0d0
)
1028 (f2cl-lib:fref rwork-%data%
1029 ((f2cl-lib:int-sub
(f2cl-lib:int-add lewt i
)
1033 (f2cl-lib:f2cl-set-string msg
1034 "DLSODIS- At T (=R1), EWT(I1) has become R2 <= 0."
1036 (xerrwd msg
50 202 0 1 i
0 2 tn ewti
)
1040 (f2cl-lib:f2cl-set-string msg
1041 "DLSODIS- At T (=R1), too much accuracy requested "
1043 (xerrwd msg
50 203 0 0 0 0 0 0.0d0
0.0d0
)
1044 (f2cl-lib:f2cl-set-string msg
1045 " for precision of machine.. See TOLSF (=R2) "
1047 (xerrwd msg
50 203 0 0 0 0 2 tn tolsf
)
1048 (setf (f2cl-lib:fref rwork-%data%
(14) ((1 lrw
)) rwork-%offset%
)
1053 (f2cl-lib:f2cl-set-string msg
1054 "DLSODIS- At T (=R1) and step size H (=R2), the "
1056 (xerrwd msg
50 204 0 0 0 0 0 0.0d0
0.0d0
)
1057 (f2cl-lib:f2cl-set-string msg
1058 " error test failed repeatedly or with ABS(H) = HMIN "
1060 (xerrwd msg
60 204 0 0 0 0 2 tn h
)
1064 (f2cl-lib:f2cl-set-string msg
1065 "DLSODIS- At T (=R1) and step size H (=R2), the "
1067 (xerrwd msg
50 205 0 0 0 0 0 0.0d0
0.0d0
)
1068 (f2cl-lib:f2cl-set-string msg
1069 " corrector convergence failed repeatedly "
1071 (xerrwd msg
50 205 0 0 0 0 0 0.0d0
0.0d0
)
1072 (f2cl-lib:f2cl-set-string msg
1073 " or with ABS(H) = HMIN "
1075 (xerrwd msg
30 205 0 0 0 0 2 tn h
)
1079 (f2cl-lib:f2cl-set-string msg
1080 "DLSODIS- At T (=R1) residual routine returned "
1082 (xerrwd msg
50 206 0 0 0 0 0 0.0d0
0.0d0
)
1083 (f2cl-lib:f2cl-set-string msg
1084 " error IRES = 3 repeatedly."
1086 (xerrwd msg
30 206 1 0 0 0 0 tn
0.0d0
)
1090 (f2cl-lib:f2cl-set-string msg
1091 "DLSODIS- At T (=R1) and step size H (=R2), a fatal"
1093 (xerrwd msg
50 207 0 0 0 0 0 0.0d0
0.0d0
)
1094 (f2cl-lib:f2cl-set-string msg
1095 " error flag was returned by CDRV (by way of "
1097 (xerrwd msg
50 207 0 0 0 0 0 0.0d0
0.0d0
)
1098 (f2cl-lib:f2cl-set-string msg
1099 " Subroutine DPRJIS or DSOLSS) "
1101 (xerrwd msg
40 207 0 0 0 0 2 tn h
)
1105 (f2cl-lib:f2cl-set-string msg
1106 "DLSODIS- Attempt to initialize dy/dt failed because matrix A"
1108 (xerrwd msg
60 208 0 0 0 0 0 0.0d0
0.0d0
)
1109 (f2cl-lib:f2cl-set-string msg
1110 " was singular. CDRV returned zero pivot error flag. "
1112 (xerrwd msg
60 208 0 0 0 0 0 0.0d0
0.0d0
)
1113 (f2cl-lib:f2cl-set-string msg
1114 "DAINVGS set its error flag to IER = (I1)"
1116 (xerrwd msg
40 208 0 1 ier
0 0 0.0d0
0.0d0
)
1120 (f2cl-lib:f2cl-set-string msg
1121 "DLSODIS- Attempt to initialize dy/dt failed "
1123 (xerrwd msg
50 209 0 0 0 0 0 0.0d0
0.0d0
)
1124 (f2cl-lib:f2cl-set-string msg
1125 " because residual routine set its error flag "
1127 (xerrwd msg
50 209 0 0 0 0 0 0.0d0
0.0d0
)
1128 (f2cl-lib:f2cl-set-string msg
" to IRES = (I1)" (string 60))
1129 (xerrwd msg
20 209 0 1 ier
0 0 0.0d0
0.0d0
)
1135 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
1141 (f2cl-lib:fref rwork-%data%
1143 (f2cl-lib:int-add i lacor
)
1147 (f2cl-lib:fref rwork-%data%
1149 (f2cl-lib:int-add i lewt
)
1153 (if (>= big size
) (go label575
))
1157 (setf (f2cl-lib:fref iwork-%data%
(16) ((1 liw
)) iwork-%offset%
)
1160 (setf lyd0
(f2cl-lib:int-add lyh nyh
))
1161 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
1164 (setf (f2cl-lib:fref rwork-%data%
1166 (f2cl-lib:int-add i lsavf
)
1171 (f2cl-lib:fref rwork-%data%
1173 (f2cl-lib:int-add i lyd0
)
1179 (setf (f2cl-lib:fref y-%data%
(i) ((1 *)) y-%offset%
)
1180 (f2cl-lib:fref rwork-%data%
1182 (f2cl-lib:int-add i lyh
)
1187 (multiple-value-bind (var-0 var-1 var-2 var-3 var-4 var-5
)
1192 (f2cl-lib:array-slice rwork-%data%
1199 (declare (ignore var-0 var-2 var-3 var-4
))
1204 (setf nfe
(f2cl-lib:int-add nfe
1))
1205 (if (<= ires
1) (go label595
))
1206 (f2cl-lib:f2cl-set-string msg
1207 "DLSODIS- Residual routine set its flag IRES "
1209 (xerrwd msg
50 210 0 0 0 0 0 0.0d0
0.0d0
)
1210 (f2cl-lib:f2cl-set-string msg
1211 " to (I1) when called for final output. "
1213 (xerrwd msg
50 210 0 1 ires
0 0 0.0d0
0.0d0
)
1216 (f2cl-lib:fdo
(i 1 (f2cl-lib:int-add i
1))
1220 (setf (f2cl-lib:fref y-%data%
(i) ((1 *)) y-%offset%
)
1221 (f2cl-lib:fref rwork-%data%
1223 (f2cl-lib:int-add i lyh
)
1229 (setf (f2cl-lib:fref rwork-%data%
(11) ((1 lrw
)) rwork-%offset%
)
1231 (setf (f2cl-lib:fref rwork-%data%
(12) ((1 lrw
)) rwork-%offset%
) h
)
1232 (setf (f2cl-lib:fref rwork-%data%
(13) ((1 lrw
)) rwork-%offset%
)
1234 (setf (f2cl-lib:fref iwork-%data%
(11) ((1 liw
)) iwork-%offset%
)
1236 (setf (f2cl-lib:fref iwork-%data%
(12) ((1 liw
)) iwork-%offset%
)
1238 (setf (f2cl-lib:fref iwork-%data%
(13) ((1 liw
)) iwork-%offset%
)
1240 (setf (f2cl-lib:fref iwork-%data%
(14) ((1 liw
)) iwork-%offset%
)
1242 (setf (f2cl-lib:fref iwork-%data%
(15) ((1 liw
)) iwork-%offset%
)
1244 (setf (f2cl-lib:fref iwork-%data%
(19) ((1 liw
)) iwork-%offset%
)
1246 (setf (f2cl-lib:fref iwork-%data%
(20) ((1 liw
)) iwork-%offset%
)
1248 (setf (f2cl-lib:fref iwork-%data%
(21) ((1 liw
)) iwork-%offset%
)
1250 (setf (f2cl-lib:fref iwork-%data%
(25) ((1 liw
)) iwork-%offset%
)
1252 (setf (f2cl-lib:fref iwork-%data%
(26) ((1 liw
)) iwork-%offset%
)
1256 (f2cl-lib:f2cl-set-string msg
1257 "DLSODIS- ISTATE (=I1) illegal."
1259 (xerrwd msg
30 1 0 1 istate
0 0 0.0d0
0.0d0
)
1260 (if (< istate
0) (go label800
))
1263 (f2cl-lib:f2cl-set-string msg
1264 "DLSODIS- ITASK (=I1) illegal. "
1266 (xerrwd msg
30 2 0 1 itask
0 0 0.0d0
0.0d0
)
1269 (f2cl-lib:f2cl-set-string msg
1270 "DLSODIS-ISTATE > 1 but DLSODIS not initialized."
1272 (xerrwd msg
50 3 0 0 0 0 0 0.0d0
0.0d0
)
1275 (f2cl-lib:f2cl-set-string msg
1276 "DLSODIS- NEQ (=I1) < 1 "
1278 (xerrwd msg
30 4 0 1
1279 (f2cl-lib:fref neq-%data%
(1) ((1 *)) neq-%offset%
) 0 0 0.0d0
1283 (f2cl-lib:f2cl-set-string msg
1284 "DLSODIS- ISTATE = 3 and NEQ increased (I1 to I2). "
1286 (xerrwd msg
50 5 0 2 n
1287 (f2cl-lib:fref neq-%data%
(1) ((1 *)) neq-%offset%
) 0 0.0d0
0.0d0
)
1290 (f2cl-lib:f2cl-set-string msg
1291 "DLSODIS- ITOL (=I1) illegal. "
1293 (xerrwd msg
30 6 0 1 itol
0 0 0.0d0
0.0d0
)
1296 (f2cl-lib:f2cl-set-string msg
1297 "DLSODIS- IOPT (=I1) illegal. "
1299 (xerrwd msg
30 7 0 1 iopt
0 0 0.0d0
0.0d0
)
1302 (f2cl-lib:f2cl-set-string msg
1303 "DLSODIS- MF (=I1) illegal. "
1305 (xerrwd msg
30 8 0 1 mf
0 0 0.0d0
0.0d0
)
1308 (f2cl-lib:f2cl-set-string msg
1309 "DLSODIS- MAXORD (=I1) < 0 "
1311 (xerrwd msg
30 11 0 1 maxord
0 0 0.0d0
0.0d0
)
1314 (f2cl-lib:f2cl-set-string msg
1315 "DLSODIS- MXSTEP (=I1) < 0 "
1317 (xerrwd msg
30 12 0 1 mxstep
0 0 0.0d0
0.0d0
)
1320 (f2cl-lib:f2cl-set-string msg
1321 "DLSODIS- MXHNIL (=I1) < 0 "
1323 (xerrwd msg
30 13 0 1 mxhnil
0 0 0.0d0
0.0d0
)
1326 (f2cl-lib:f2cl-set-string msg
1327 "DLSODIS- TOUT (=R1) behind T (=R2) "
1329 (xerrwd msg
40 14 0 0 0 0 2 tout t$
)
1330 (f2cl-lib:f2cl-set-string msg
1331 " Integration direction is given by H0 (=R1) "
1333 (xerrwd msg
50 14 0 0 0 0 1 h0
0.0d0
)
1336 (f2cl-lib:f2cl-set-string msg
1337 "DLSODIS- HMAX (=R1) < 0.0 "
1339 (xerrwd msg
30 15 0 0 0 0 1 hmax
0.0d0
)
1342 (f2cl-lib:f2cl-set-string msg
1343 "DLSODIS- HMIN (=R1) < 0.0 "
1345 (xerrwd msg
30 16 0 0 0 0 1 hmin
0.0d0
)
1348 (f2cl-lib:f2cl-set-string msg
1349 "DLSODIS- RWORK length is insufficient to proceed. "
1351 (xerrwd msg
50 17 0 0 0 0 0 0.0d0
0.0d0
)
1352 (f2cl-lib:f2cl-set-string msg
1353 " Length needed is >= LENRW (=I1), exceeds LRW (=I2)"
1355 (xerrwd msg
60 17 0 2 lenrw lrw
0 0.0d0
0.0d0
)
1358 (f2cl-lib:f2cl-set-string msg
1359 "DLSODIS- IWORK length is insufficient to proceed. "
1361 (xerrwd msg
50 18 0 0 0 0 0 0.0d0
0.0d0
)
1362 (f2cl-lib:f2cl-set-string msg
1363 " Length needed is >= LENIW (=I1), exceeds LIW (=I2)"
1365 (xerrwd msg
60 18 0 2 leniw liw
0 0.0d0
0.0d0
)
1368 (f2cl-lib:f2cl-set-string msg
1369 "DLSODIS- RTOL(=I1) is R1 < 0.0 "
1371 (xerrwd msg
40 19 0 1 i
0 1 rtoli
0.0d0
)
1374 (f2cl-lib:f2cl-set-string msg
1375 "DLSODIS- ATOL(=I1) is R1 < 0.0 "
1377 (xerrwd msg
40 20 0 1 i
0 1 atoli
0.0d0
)
1381 (f2cl-lib:fref rwork-%data%
1382 ((f2cl-lib:int-sub
(f2cl-lib:int-add lewt i
)
1386 (f2cl-lib:f2cl-set-string msg
1387 "DLSODIS- EWT(I1) is R1 <= 0.0 "
1389 (xerrwd msg
40 21 0 1 i
0 1 ewti
0.0d0
)
1392 (f2cl-lib:f2cl-set-string msg
1393 "DLSODIS- TOUT(=R1) too close to T(=R2) to start integration."
1395 (xerrwd msg
60 22 0 0 0 0 2 tout t$
)
1398 (f2cl-lib:f2cl-set-string msg
1399 "DLSODIS- ITASK = I1 and TOUT (=R1) behind TCUR - HU (= R2) "
1401 (xerrwd msg
60 23 0 1 itask
0 2 tout tp
)
1404 (f2cl-lib:f2cl-set-string msg
1405 "DLSODIS- ITASK = 4 or 5 and TCRIT (=R1) behind TCUR (=R2) "
1407 (xerrwd msg
60 24 0 0 0 0 2 tcrit tn
)
1410 (f2cl-lib:f2cl-set-string msg
1411 "DLSODIS- ITASK = 4 or 5 and TCRIT (=R1) behind TOUT (=R2) "
1413 (xerrwd msg
60 25 0 0 0 0 2 tcrit tout
)
1416 (f2cl-lib:f2cl-set-string msg
1417 "DLSODIS- At start of problem, too much accuracy "
1419 (xerrwd msg
50 26 0 0 0 0 0 0.0d0
0.0d0
)
1420 (f2cl-lib:f2cl-set-string msg
1421 " requested for precision of machine.. See TOLSF (=R1) "
1423 (xerrwd msg
60 26 0 0 0 0 1 tolsf
0.0d0
)
1424 (setf (f2cl-lib:fref rwork-%data%
(14) ((1 lrw
)) rwork-%offset%
)
1428 (f2cl-lib:f2cl-set-string msg
1429 "DLSODIS- Trouble in DINTDY. ITASK = I1, TOUT = R1"
1431 (xerrwd msg
50 27 0 1 itask
0 1 tout
0.0d0
)
1434 (f2cl-lib:f2cl-set-string msg
1435 "DLSODIS- RWORK length insufficient (for Subroutine DPREPI). "
1437 (xerrwd msg
60 28 0 0 0 0 0 0.0d0
0.0d0
)
1438 (f2cl-lib:f2cl-set-string msg
1439 " Length needed is >= LENRW (=I1), exceeds LRW (=I2)"
1441 (xerrwd msg
60 28 0 2 lenrw lrw
0 0.0d0
0.0d0
)
1444 (f2cl-lib:f2cl-set-string msg
1445 "DLSODIS- RWORK length insufficient (for Subroutine JGROUP). "
1447 (xerrwd msg
60 29 0 0 0 0 0 0.0d0
0.0d0
)
1448 (f2cl-lib:f2cl-set-string msg
1449 " Length needed is >= LENRW (=I1), exceeds LRW (=I2)"
1451 (xerrwd msg
60 29 0 2 lenrw lrw
0 0.0d0
0.0d0
)
1454 (f2cl-lib:f2cl-set-string msg
1455 "DLSODIS- RWORK length insufficient (for Subroutine ODRV). "
1457 (xerrwd msg
60 30 0 0 0 0 0 0.0d0
0.0d0
)
1458 (f2cl-lib:f2cl-set-string msg
1459 " Length needed is >= LENRW (=I1), exceeds LRW (=I2)"
1461 (xerrwd msg
60 30 0 2 lenrw lrw
0 0.0d0
0.0d0
)
1464 (f2cl-lib:f2cl-set-string msg
1465 "DLSODIS- Error from ODRV in Yale Sparse Matrix Package. "
1467 (xerrwd msg
60 31 0 0 0 0 0 0.0d0
0.0d0
)
1468 (setf imul
(the f2cl-lib
:integer4
(truncate (- iys
1) n
)))
1469 (setf irem
(f2cl-lib:int-sub iys
(f2cl-lib:int-mul imul n
)))
1470 (f2cl-lib:f2cl-set-string msg
1471 " At T (=R1), ODRV returned error flag = I1*NEQ + I2. "
1473 (xerrwd msg
60 31 0 2 imul irem
1 tn
0.0d0
)
1476 (f2cl-lib:f2cl-set-string msg
1477 "DLSODIS- RWORK length insufficient (for Subroutine CDRV). "
1479 (xerrwd msg
60 32 0 0 0 0 0 0.0d0
0.0d0
)
1480 (f2cl-lib:f2cl-set-string msg
1481 " Length needed is >= LENRW (=I1), exceeds LRW (=I2)"
1483 (xerrwd msg
60 32 0 2 lenrw lrw
0 0.0d0
0.0d0
)
1486 (f2cl-lib:f2cl-set-string msg
1487 "DLSODIS- Error from CDRV in Yale Sparse Matrix Package. "
1489 (xerrwd msg
60 33 0 0 0 0 0 0.0d0
0.0d0
)
1490 (setf imul
(the f2cl-lib
:integer4
(truncate (- iys
1) n
)))
1491 (setf irem
(f2cl-lib:int-sub iys
(f2cl-lib:int-mul imul n
)))
1492 (f2cl-lib:f2cl-set-string msg
1493 " At T (=R1), CDRV returned error flag = I1*NEQ + I2. "
1495 (xerrwd msg
60 33 0 2 imul irem
1 tn
0.0d0
)
1498 (f2cl-lib:f2cl-set-string msg
1499 " Duplicate entry in sparsity structure descriptors. "
1501 (xerrwd msg
60 33 0 0 0 0 0 0.0d0
0.0d0
)))
1503 ((or (= imul
3) (= imul
6))
1504 (f2cl-lib:f2cl-set-string msg
1505 " Insufficient storage for NSFC (called by CDRV). "
1507 (xerrwd msg
60 33 0 0 0 0 0 0.0d0
0.0d0
)))
1510 (f2cl-lib:f2cl-set-string msg
1511 "DLSODIS- At T (=R1) residual routine (called by DPREPI) "
1513 (xerrwd msg
60 34 0 0 0 0 0 0.0d0
0.0d0
)
1514 (setf ier
(f2cl-lib:int-sub -
5 ipflag
))
1515 (f2cl-lib:f2cl-set-string msg
1516 " returned error IRES (=I1)"
1518 (xerrwd msg
30 34 0 1 ier
0 1 tn
0.0d0
)
1523 (f2cl-lib:f2cl-set-string msg
1524 "DLSODIS- Run aborted.. apparent infinite loop. "
1526 (xerrwd msg
50 303 2 0 0 0 0 0.0d0
0.0d0
)
1550 (in-package #-gcl
#:cl-user
#+gcl
"CL-USER")
1551 #+#.
(cl:if
(cl:find-package
'#:f2cl
) '(and) '(or))
1552 (eval-when (:load-toplevel
:compile-toplevel
:execute
)
1553 (setf (gethash 'fortran-to-lisp
::dlsodis
1554 fortran-to-lisp
::*f2cl-function-info
*)
1555 (fortran-to-lisp::make-f2cl-finfo
1556 :arg-types
'(t t t
(array fortran-to-lisp
::integer4
(*))
1557 (array double-float
(*)) (array double-float
(*))
1558 (double-float) (double-float)
1559 (fortran-to-lisp::integer4
) (array double-float
(*))
1560 (array double-float
(*)) (fortran-to-lisp::integer4
)
1561 (fortran-to-lisp::integer4
) (fortran-to-lisp::integer4
)
1562 (array double-float
(*)) (fortran-to-lisp::integer4
)
1563 (array fortran-to-lisp
::integer4
(*))
1564 (fortran-to-lisp::integer4
)
1565 (fortran-to-lisp::integer4
))
1566 :return-values
'(nil nil nil nil nil nil fortran-to-lisp
::t$ nil nil
1567 nil nil nil fortran-to-lisp
::istate nil nil nil nil
1569 :calls
'(fortran-to-lisp::dstodi fortran-to-lisp
::xerrwd
1570 fortran-to-lisp
::dintdy fortran-to-lisp
::dvnorm
1571 fortran-to-lisp
::dainvgs fortran-to-lisp
::diprepi
1572 fortran-to-lisp
::dewset
))))