2 subroutine auto(rk,zk,tk,nk,nstep,ngrid,
5 * ntipe, necon, wecon )
12 integer ngrid,nk,nstep
13 real*8 tk(*),rk(*),zk(*), wecon(*)
15 real*8 rk1(*),zk1(*),rk2(*),zk2(*)
16 real*8 rk3(*),zk3(*),rk4(*),zk4(*)
18 integer ntipe(*), necon(*)
21 c...input initial
data
23 write(fname,
'(a,a)') path(1:kname),
'data.dat'
24 open(1,file=fname,form=
'formatted')
46 write(fname,
'(a,a)') path(1:kname),
'data_d.wr'
47 open(1,file=fname,form=
'formatted')
49 write(1,*) icont,ni,nj,nctrl
50 write(1,*) rmin,rmax,zmin,zmax,alp,qcen,
51 * rx10,zx10,rx20,zx20,rm0,zm0
62 write(fname,
'(a,a)') path(1:kname),
'limpnt.dat'
63 open(1,file=fname,form=
'formatted')
67 read(1,*) rblm(i),zblm(i)
71 write(fname,
'(a,a)') path(1:kname),
'limpnt_d.wr'
72 open(1,file=fname,form=
'formatted')
76 write(1,*) rblm(i),zblm(i)
90 * rk3,zk3,rk4,zk4,ntipe, necon, wecon)
113 c...input initial
data
116 write(fname,
'(a,a)') path(1:kname),
'data_d.wr'
117 open(1,file=fname,form=
'formatted')
119 read(1,*) icont,ni,nj,nctrl
120 read(1,*) rmin,rmax,zmin,zmax,alp,qcen,
121 * rx10,zx10,rx20,zx20,rm0,zm0
134 write(fname,
'(a,a)') path(1:kname),
'limpnt_d.wr'
135 open(1,file=fname,form=
'formatted')
139 read(1,*) rblm(i),zblm(i)
148 subroutine eq_0(pcequi,psitok,ncequi,nstep,ngrid,
149 * alf0, alf1, alf2, bet0, bet1, bet2,
150 * betpol, betplx, zli3,
152 * ftok, tokout, psicen, pscout,
153 * nursb,psi_bnd,alp_b,rax,zax,n_ctrl,b_0,r_0 )
160 common /comomg/ omega,sigma
162 common /comhel/ helinp, helout
164 integer isol,ngrid,nstep,ngav1
165 real*8 pcequi(*),psitok(*)
167 real*8 alf0,alf1,alf2,bet0,bet1,bet2
168 real*8 betpol,zli3,ftok,psicen,tokout,pscout
179 c-----------------------------------------------------------------
187 c
if( nstep.eq.0 .AnD. ngrid.eq.0 )
then
199 ccc+
if(nstep.gt.0) go to 6789
201 c...input initial
data
207 if(nstep.gt.0) icont=1
209 c -----------------------
212 c -----------------------
214 write(fname,
'(a,a)') path(1:kname),
'itpr.dat'
215 open(1,file=fname,form=
'formatted')
254 call
extfil(pcequi,ncequi)
260 call taburs(ien,coin,nursb)
291 if(nflag.eq.0) call
psiful
310 subroutine eq( pcequi, psicon, ncequi, nstep, ngrid,
311 * alf0, alf1, alf2, bet0, bet1, bet2,
312 * betpol, betplx, zli3,
314 * ftok, tokout, psicen, pscout,
315 * nursb,psi_bnd,alp_b,rax,zax )
322 common /comomg/ omega,sigma
324 common /comhel/ helinp, helout
329 integer isol,ngrid,ncequi,nstep,ngav1
331 real*8 alf0,alf1,alf2,bet0,bet1,bet2
332 real*8 betpol,zli3,ftok,psicen,tokout,pscout
333 real*8 psicon(*),pcequi(*)
346 write(fname,
'(a,a)') path(1:kname),
'itpr.dat'
347 open(1,file=fname,form=
'formatted')
367 c------------------------------------------------
390 call
extfil(pcequi,ncequi)
396 call taburs(ien,coin,nursb)
416 if(nstep.eq.0 .AND. nflag.eq.0)
then
426 if(nflag.eq.0) call
psiful
446 if(iter.eq.iterbf .or. nstep.gt.0)
then
449 call
shab(il,jl,icelm,jcelm)
455 ccc
if(iter.eq.2) call
wrd
467 if(erru.lt.eps .OR. itin.ge.nitin)
then
493 call
shab(il,jl,icelm,jcelm)
496 elseif(ich.eq.1)
then
499 if(erru.lt.epsin .OR. itin.ge.nitin)
then
517 call
shab(il,jl,icelm,jcelm)
520 elseif(ich.eq.2)
then
523 if(erru.lt.epsin .OR. itin.ge.nitin)
then
532 dcrdr=(clr-clr0)/ddrl
533 dczdr=(clz-clz0)/ddrl
535 dcrdz=(clr1-clr0)/ddzl
536 dczdz=(clz1-clz0)/ddzl
538 det=dcrdr*dczdz-dczdr*dcrdz
540 delrl= (clz0*dcrdz-clr0*dczdz)/det
541 delzl= (clr0*dczdr-clz0*dcrdr)/det
543 dll=dsqrt(delrl**2 + delzl**2)
545 dllim=0.25d0*dr(imax)
547 if(dll .gt. dllim)
then
554 if(nstp.gt.10) nstp=10
562 call
shab(il,jl,icelm,jcelm)
569 call
right0(il,jl,icelm,jcelm,ngav1)
583 call
shab(il,jl,icelm,jcelm)
598 write(*,*)
'limit number of ext. iterations is exeeded'
599 write(*,*)
'itl = ',itl,
' Nitl = ',nitl
603 if( ngav1.eq.4 .OR. ngav1.eq.5 )
then
606 call
qst(qcen,cnor,b0ax,r0ax)
611 call
right0(il,jl,icelm,jcelm,ngav1)
620 if(ngav1.eq.1 .OR. ngav1.eq.3 .OR. ngav1.eq.5)
then
624 zcoin = betplx / betpol
625 c
write(6,*)
'betplx/betpol',zcoin
626 zcoin = (1.d0/zcoin-1.d0)*tok/(cnor*f_cur)+1.d0
628 coin = (coin-1.d0)*0.33d0+1.d0
629 call taburs( 1,coin,nursb)
637 crz=dabs(clr*rm*rm/(um-up))+dabs(clz*(zm-zx0)/(um-up))
639 if(erru.le.epsin .AND. crz.lt.epscrz .AND. itl.ge.0
640 * .AND. ich.eq.0) go to 1111
645 if(erru.le.eps.and.kpr.eq.1)
then
646 write(*,
'("iter erru rm zm ", i4,6(1pe12.5))'),
649 write(*,
'("ich clr clz ", i4,6(1pe12.5))'),
655 if(iter.le.nrun) go to 1000
672 c call
adapol(alf0,alf1,alf2,bet0,bet1,bet2)
676 coment call
qst(qcen,cnor,b0ax,r0ax)
705 call
extfil(pcequi,ncequi)
716 c...
if(nglev.eq.1)
return
745 write(*,*)
'..................................................'
746 write(*,*)
'Convergence of free bound. equilibrium iterations:'
747 write(*,*)
' iter = ',iter,
' nrun = ',nrun
748 write(*,*)
' itl = ',itl ,
' Nitl = ',nitl
749 write(*,*)
' erru = ',erru
750 write(*,*)
' crz = ',crz
756 subroutine eq_ax( pcequi, psicon, ncequi, nstep,ngrid,
757 * alf0, alf1, alf2, bet0, bet1, bet2,
758 * betpol, betplx, zli3,
760 * ftok,tokout,psicen,pscout,
762 * psi_bnd,alp_b,rax,zax,isymm )
768 common /comomg/ omega,sigma
769 common /comhel/ helinp, helout
772 integer isol,ngrid,nk,nstep,ngav1
773 real*8 psicon(*),pcequi(*)
774 real*8 alf0,alf1,alf2,bet0,bet1,bet2
775 real*8 betpol,zli3,ftok,psicen,tokout,pscout
776 real timeb, timee,t_start, t_finish
777 c------------------------------------------------------------------
779 if(nstep.gt.0) icont=1
781 c -----------------------
785 c -----------------------
805 c------------------------------------------------
841 call
shab(il,jl,icelm,jcelm)
842 c------------------------------------------------------------------
843 if( ngav1.eq.4 .OR. ngav1.eq.5 )
then
845 call
qst(qcen,cnor,b0ax,r0ax)
847 c------------------------------------------------------------------
849 call
right0(il,jl,icelm,jcelm,ngav1)
853 c
write(*,*)
'erru',erru
872 if( ngav1.eq.1 .OR. ngav1.eq.3 .OR. ngav1.eq.5 )
then
875 zcoin = betplx / betpol
876 c
write(*,*)
'betplx/betpol',zcoin
877 zcoin = (1.d0/zcoin-1.d0)*tok/(cnor*f_cur)+1.d0
880 coin = (coin-1.d0)*0.33d0+1.d0
882 call taburs( 1,coin,nursb)
898 if(erru.le.eps0)
then
906 coment call
qst(qcen,cnor,b0ax,r0ax)
923 subroutine shab(il,jl,icelm,jcelm)
932 if( rl.ge.r(i) .AND. rl.lt.r(i+1) ) go to 11
940 if( zl.ge.z(j) .AND. zl.lt.z(j+1) ) go to 21
957 ddl=dsqrt( (rl-ri)**2 + (zl-zj)**2 )
1004 ue(i,j)=ue(2*i-1,2*j-1)
1006 if(nstep.eq.0) go to 110
1008 ui(i,j)=ui(2*i-1,2*j-1)
1016 binadg(ibs,ib)=binadg(2*ibs-1,2*ib-1)+binadg(2*ibs,2*ib-1)
1026 include
'double.inc'
1028 include
'comblc.inc'
1036 ui(2*i-1,2*j-1)=ui(i,j)
1043 ui(i,j)=(ui(i,j-1)*dz(j-1)+ui(i,j+1)*dz(j))/(dz(j-1)+dz(j))
1050 ui(i,j)=(ui(i-1,j)*dr(i-1)+ui(i+1,j)*dr(i))/(dr(i-1)+dr(i))
1060 include
'double.inc'
1063 include
'comblc.inc'
1065 real*8 xs(nshp),ys(nshp),
fun(nshp),dp(5)
1067 if(ip.le.2 .OR. ip.gt.ni2 .OR.
1068 + jp.le.2 .OR. jp.gt.nj2)
return
1084 if(i.eq.ip .AND. j.eq.jp) go to 210
1108 u(i,j)=upij + dp(1)*(ri-rpi) + dp(2)*(zj-zpj)
1109 + + 0.5*dp(3)*(ri-rpi)*(ri-rpi)
1110 + + dp(4)*(ri-rpi)*(zj-zpj)
1111 + + 0.5*dp(5)*(zj-zpj)*(zj-zpj)
1122 include
'double.inc'
1124 include
'comblc.inc'
1132 u(i,j)=ui(i,j)+ue(i,j)+clz*z(j)+clr*r(i)*r(i)
1134 delu=dabs(u(i,j)-uold)
1135 del_um=dabs(um-up)+1.d-9
1136 erru=dmax1(delu/del_um,erru)
1140 c
write(6,*)
'erru',erru
1141 c
write(6,*)
'-------'
1148 subroutine tab_buil(alf0, alf1, alf2, bet0, bet1, bet2)
1150 include
'double.inc'
1151 parameter(ntabp=500)
1152 real*8 psi(ntabp),q(ntabp),dp(ntabp),df(ntabp)
1154 write(fname,
'(a,a)') path(1:kname),
'eoh2.dat'
1155 open(1,file=fname,form=
'formatted')
1159 read(1,*) psi(i),q(i),dp(i)
1163 dp(i)=alf0*dp(i)/dpnor
1164 zpsi=1.d0-psi(i)/psi(ntab)
1170 write(fname,
'(a,a)') path(1:kname),
'tabppf.dat'
1171 open(1,file=fname,form=
'formatted')
1175 write(1,*) psi(i),dp(i),df(i)
1179 write(fname,
'(a,a)') path(1:kname),
'tab_q.dat'
1180 open(1,file=fname,form=
'formatted')
1182 write(1,*) ntab, (0)
1184 write(1,*) psi(i),q(i)
1192 include
'double.inc'
1194 real*8 ps(np),q(np),
p(np),f(np)
1198 write(fname,
'(a,a)') path(1:kname),
'tabpfq.dat'
1199 open(1,file=fname,form=
'formatted')
1203 read(1,*) ps(i),q(i),
p(i),f(i)
1208 write(fname,
'(a,a)') path(1:kname),
'tabppf.dat'
1209 open(1,file=fname,form=
'formatted')
1213 write(1,*) ps(i),
p(i),f(i)
1217 write(fname,
'(a,a)') path(1:kname),
'tab_q.dat'
1218 open(1,file=fname,form=
'formatted')
1222 write(1,*) ps(i),q(i)
1241 write(fname,
'(a,a)') path(1:kname),
'tab_q.dat'
1242 open(1,file=fname,form=
'formatted')
1246 read(1,*) ps(i),q(i)
1272 if( q(i) .lt. qzv )
then
1280 write(fname,
'(a,a)') path(1:kname),
'tab_q.dat'
1281 open(1,file=fname,form=
'formatted')
1285 write(1,*) ps(i),q(i)
1296 include
'double.inc'
1298 include
'comblc.inc'
1307 usym=0.5d0*(uup+udown)
1318 include
'double.inc'
1320 include
'comblc.inc'
subroutine exfmat(rk, zk, tk, nk,
subroutine solve(isol, wdm)
subroutine get_par(psi_bnd)
subroutine eq(pcequi, psicon, ncequi, nstep, ngrid,
subroutine right0(ill, jll, icelm, jcelm, ngav1)
subroutine tab_buil(alf0, alf1, alf2, bet0, bet1, bet2)
subroutine cfr_mat(rk, zk, tk, nk,
subroutine auto(rk, zk, tk, nk, nstep, ngrid,
subroutine deriv5(X, Y, F, M, N, U)
subroutine eq_ax(pcequi, psicon, ncequi, nstep, ngrid,
subroutine shab(il, jl, icelm, jcelm)
subroutine inter2(ip, jp)
real(r8) function p(a, x, xr, xs, yr, ys, psi, psir, F_dia)
subroutine extfil(pcequi, ncequi)
subroutine ext_fil(pcequi, ncequi)
subroutine qst(qcen, cnor, b0ax, r0ax)
subroutine eq_0(pcequi, psitok, ncequi, nstep, ngrid,
subroutine psi_fil(psicon, ncequi)