5 SUBROUTINE dmatd(NEQ,X,Y,YPRIME,DELTA,CJ,H,IER,EWT,E,
6 * WM,IWM,RES,IRES,UROUND,JACD,RPAR,IPAR)
64 IMPLICIT DOUBLE PRECISION(a-h,o-z)
65 dimension y(*),yprime(*),delta(*),ewt(*),e(*)
66 dimension wm(*),iwm(*), rpar(*),ipar(*)
69 parameter(lml=1, lmu=2, lmtype=4, lnre=12, lnpd=22, llciwp=30)
74 GO TO (100,200,300,400,500),mtype
82 CALL jacd(x,y,yprime,wm,cj,rpar,ipar)
92 del=squr*
max(abs(y(i)),abs(h*yprime(i)),
94 del=sign(del,h*yprime(i))
99 yprime(i)=yprime(i)+cj*del
100 iwm(lnre)=iwm(lnre)+1
101 CALL res(x,y,yprime,cj,e,ires,rpar,ipar)
102 IF (ires .LT. 0)
RETURN
105 220 wm(nrow+l)=(e(l)-delta(l))*delinv
114 230
CALL dgetrf( neq, neq, wm, neq, iwm(lipvt), ier)
128 CALL jacd(x,y,yprime,wm,cj,rpar,ipar)
129 meband=2*iwm(lml)+iwm(lmu)+1
135 500 mband=iwm(lml)+iwm(lmu)+1
137 meband=mband+iwm(lml)
148 wm(ipsave+k)=yprime(n)
149 del=squr*
max(abs(y(n)),abs(h*yprime(n)),
151 del=sign(del,h*yprime(n))
154 510 yprime(n)=yprime(n)+cj*del
155 iwm(lnre)=iwm(lnre)+1
156 CALL res(x,y,yprime,cj,e,ires,rpar,ipar)
157 IF (ires .LT. 0)
RETURN
161 yprime(n)=wm(ipsave+k)
162 del=squr*
max(abs(y(n)),abs(h*yprime(n)),
164 del=sign(del,h*yprime(n))
167 i1=max0(1,(n-iwm(lmu)))
168 i2=min0(neq,(n+iwm(lml)))
171 520 wm(ii+i)=(e(i)-delta(i))*delinv
178 550
CALL dgbtrf(neq, neq, iwm(lml), iwm(lmu), wm, meband,
charNDArray max(char d, const charNDArray &m)
subroutine dmatd(NEQ, X, Y, YPRIME, DELTA, CJ, H, IER, EWT, E, WM, IWM, RES, IRES, UROUND, JACD, RPAR, IPAR)