1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
|
subroutine srcma (rsav, isav, job)
c-----------------------------------------------------------------------
c this routine saves or restores (depending on job) the contents of
c the common blocks ls0001, lsa001, and eh0001, which are used
c internally by one or more odepack solvers.
c
c rsav = real array of length 240 or more.
c isav = integer array of length 50 or more.
c job = flag indicating to save or restore the common blocks..
c job = 1 if common is to be saved (written to rsav/isav)
c job = 2 if common is to be restored (read from rsav/isav)
c a call with job = 2 presumes a prior call with job = 1.
c-----------------------------------------------------------------------
integer isav, job
integer ieh, ils, ilsa
integer i, lenrls, lenils, lenrla, lenila
double precision rsav
double precision rls, rlsa
dimension rsav(1), isav(1)
common /ls0001/ rls(218), ils(39)
common /lsa001/ rlsa(22), ilsa(9)
common /eh0001/ ieh(2)
data lenrls/218/, lenils/39/, lenrla/22/, lenila/9/
c
if (job .eq. 2) go to 100
do 10 i = 1,lenrls
10 rsav(i) = rls(i)
do 15 i = 1,lenrla
15 rsav(lenrls+i) = rlsa(i)
c
do 20 i = 1,lenils
20 isav(i) = ils(i)
do 25 i = 1,lenila
25 isav(lenils+i) = ilsa(i)
c
isav(lenils+lenila+1) = ieh(1)
isav(lenils+lenila+2) = ieh(2)
return
c
100 continue
do 110 i = 1,lenrls
110 rls(i) = rsav(i)
do 115 i = 1,lenrla
115 rlsa(i) = rsav(lenrls+i)
c
do 120 i = 1,lenils
120 ils(i) = isav(i)
do 125 i = 1,lenila
125 ilsa(i) = isav(lenils+i)
c
ieh(1) = isav(lenils+lenila+1)
ieh(2) = isav(lenils+lenila+2)
return
c----------------------- end of subroutine srcma -----------------------
end
|