3 * keyctr,igdf,nstep,platok, psax,i_betp,betplx,
4 * rax,zax, rxpnt,zxpnt, psbo, psdel,
5 * rk,zk,nk, pcequi,ncequi, psitok,
9 * necon,wecon,ntipe , nflag, errarr)
18 include
'compol_add.inc'
19 c -----------------------------
21 real*8 rk(*),zk(*),psitok(*),wecon(*)
22 real*8 rloop(*),zloop(*),rprob(*),zprob(*)
26 integer ntipe(*),necon(*)
27 integer nk,nloop,nprob,nstep,keyctr
29 real*8 alf0,alf1,alf2,bet0,bet1,bet2
30 dimension alm(4,4),blm(4),xlm(4),iwrk(4)
31 real time_beg,time_end,time_b,time_e,dtim1,dtim2,dtim3
54 rolim=ro(iplas,jrolim)
74 call
f_bndmat(rk,zk,nk,rloop,zloop,nloop,rprob,zprob,nprob)
115 if(iter.gt.4) call
skbetp(betplx,betpol)
134 write(*,*)
'artfil ',clr,clz
135 write(*,*)
'psiax,psim',psiax,psim
143 if(ngav.eq.0 .AND. igdf.eq.2)
then
154 write(*,*)
'erro=',erro
158 cab=abs(clr)+abs(clz)
160 if(ngav/10*10.eq.ngav)
then
165 elseif(ngav.eq.1)
then
167 errpsm=abs((psiax-psim)/psipla)
168 errpsb=abs((psip-psibon)/psipla)
169 fvv=sqrt(f(iplas)**2+fpv)
173 elseif(ngav.eq.2)
then
175 errpsm=abs((psiax-psim)/psipla)
176 errpsb=abs((psip-psibon)/psipla)
178 fvv=sqrt(f(iplas)**2+fpv)
179 errfpv=abs((fvac-fvv)/(f(1)-f(iplas)))
186 if(erro.lt.epsro .OR. itin.gt.itrmax)
then
188 if(ich.ne.0) go to 2000
191 write(*,*)
'itin',itin
193 write(*,*)
'errpsm',errpsm
194 write(*,*)
'errpsb',errpsb
195 write(*,*)
'errfpv',errfpv
197 if( (cab.lt.epscrz) .AND.
198 * (errpsm.lt.epspsm) .AND.
199 * (errfpv.lt.epsfpv) ) go to 3000
201 if( itout.gt.nitmax ) go to 3000
226 drm=0.101*(ro(2,1)-ro(1,1))
237 elseif(ich.eq.1)
then
256 elseif(ich.eq.2 .AND. ngav/10*10.eq.ngav)
then
267 det=dcrdr*dczdz-dczdr*dcrdz
269 delr= (cz0*dcrdz-cr0*dczdz)/det
270 delz= (cr0*dczdr-cz0*dcrdr)/det
273 dell=sqrt(delr**2+delz**2)
274 if(dell.gt.drm*10.d0)
then
275 nshift=dell/(drm*10.d0)
277 delr=drm*10.d0*delr/dell
278 delz=drm*10.d0*delz/dell
280 if(nshift.gt.10) nshift=10
336 elseif(ich.eq.2 .AND. ngav.gt.0)
then
355 elseif(ich.eq.3 .AnD. ngav.eq.1)
then
369 dcrdro=(cr3-cr0)/drolim
370 dczdro=(cz3-cz0)/drolim
371 dpmdro=(pm3-pm0)/drolim
400 call
ge(3,4,alm,blm,xlm,iwrk)
424 elseif(ich.eq.3 .AnD. ngav.gt.1)
then
436 dfpv=(f(1)**2-fvac**2)*1.d-3
444 elseif(ich.eq.4)
then
461 dcrdro=(cr3-cr0)/drolim
462 dczdro=(cz3-cz0)/drolim
463 dpmdro=(pm3-pm0)/drolim
464 dfvdro=(fv3-fv0)/drolim
507 call
ge(4,4,alm,blm,xlm,iwrk)
541 if(itout.gt.nitmax) nflag=1
581 write(*,*)
'iter itout',iter,itout
583 c----------------------------------------------------------
587 call
flux_r(psitok,ncequi)
613 * keyctr,igdf,nstep,platok, psax,i_betp,betplx,
614 * rax,zax, rxpnt,zxpnt, psbo, psdel,
615 * rk,zk,nk, pcequi,ncequi, psitok,
616 * rloop,zloop,nloop, rprob,zprob,nprob,
617 * zli3,betpol,betful,
618 * necon,wecon,ntipe , nflag, errarr)
626 include
'compol_add.inc'
627 c -----------------------------
629 real*8 rk(*),zk(*),psitok(*),wecon(*)
631 real*8 rloop(*),zloop(*),rprob(*),zprob(*)
634 integer ntipe(*),necon(*)
635 integer nk,nstep,keyctr
637 real*8 alf0,alf1,alf2,bet0,bet1,bet2
638 real time_beg,time_end,time_b,time_e,dtim1,dtim2,dtim3
666 if(nstep.ne.nstepo)
then
671 call
f_bndmat(rk,zk,nk,rloop,zloop,nloop,rprob,zprob,nprob)
683 write(*,*)
'iter=',iter,itin
705 if(iter.gt.4) call
skbetp(betplx,betpol)
713 c
write(*,*)
'solve(g)'
719 c
write(*,*)
'solve(psii)'
728 c
write(*,*)
'psiful '
730 if(ngav.le.0 .AND. igdf.eq.2)
then
738 call
flux_r(psitok,ncequi)
744 elseif(ngav.eq.1)
then
746 errpsm=abs((psiax-psim)/psipla)
753 c
write(*,*)
'itin',itin
754 c
write(*,*)
'errpsm',errpsm
759 c
write(*,*)
'iter, itout ==', iter, itout
760 c----------------------------------------------------------
subroutine eqa_ax(dt, time,
subroutine flux_r(psitok, ncequi)
subroutine f_remesh(erro)
subroutine skbetp(betplx, betpol)
subroutine bt_pol(betpol)
subroutine f_ext_fil(pcequi, ncequi)
subroutine ge(N, NZ, A, X, Y, IP)
subroutine f_bndmat(rk, zk, nk, rlop, zlop, nlop, rprob, zprob, nprob)
subroutine f_solve(isol, wdm)