3 SUBROUTINE sstepon( KLUCH, k_auto, nstep, dt, time,
4 * voltpf, d_pf_mat,d_tcam_mat,key_dmf )
8 c---------------------------------------------------------------
18 c-----------------------------------------------------------------------
23 common /comhel/ helinp, helout
30 common /comsta/ platok,eqdfn,i_bsh
32 common /com234/ betpol,tokout,psiout
33 common /com_cam/ camtok
35 common /key_for_pet/ key_fixbon
37 c-----------------------------------------------------------------------
39 dimension rc(nclim), zc(nclim), pc(nclim), psip(nclim),
40 * vc(nclim), hc(nclim)
42 dimension rc1(nclim), zc1(nclim), rc2(nclim), zc2(nclim),
43 * rc3(nclim), zc3(nclim), rc4(nclim), zc4(nclim)
45 INTEGER necon(nilim), ntype(nclim)
46 dimension wecon(nilim)
48 common/comst0/ res(njlim), volk(njlim), volkp1(njlim)
50 common/comst1/ pjk(njlim),pjkp1(njlim),pjkp(njlim),pjkd(njlim)
52 common/comloo/ rloop(nloopp),zloop(nloopp),
53 & rprob(nprobp),zprob(nprobp),fiprob(nprobp),nloop,nprob
54 common/comst2/ psk(njlim), pskp1(njlim),pskp(njlim),pskm1(njlim)
57 c***********************************************************************
59 dimension psiplb(nstep_p),psiexb(nstep_p),psimag(nstep_p),
62 c***********************************************************************
68 c***********************************************************************
88 bbb = 1.d0 / (2.d0*pi)
113 IF( kluch .NE. 0 ) go to 1111
129 c--------------------------------------------------------------------
133 c=============================================
138 c-----------------------------------------------------------------
139 c --- input of
"BASIC" equlibrium
parameters from file
"durs.dat"
143 if(k_auto.eq.0) go to 2005
146 if(kastr.eq.1) go to 1150
148 write(fname,
'(a,a)') path(1:kname),
'durs.dat'
186 if(i_eqdsk.eq.1)
then
188 call
tab_efit(tokf,psax,eqdfn,rax,zax,b0,r0)
195 write(fname,
'(a,a)') path(1:kname),
'durs_d.dat'
196 open(1,file=fname,form=
'formatted')
198 write(1,*) n_tht,n_psi,igdf,nurs,keyctr,i_eqdsk,i_betp
199 write(1,*) epsro,betplx,tokf,psax,b0,r0,rax,zax
200 write(1,*) alf0,alf1,alf2,bet0,bet1,bet2
206 c***********************************************************************
207 c--- input of positions of
"PF_PROBE" points:
209 CALL
propnt( nout, nter, ninfw, ngra1,
210 * npro, rprob, zprob, fiprob )
211 c***********************************************************************
212 c--- input of positions of
"FL_LOOP" points:
214 CALL
loopnt( nout, nter, ninfw, ngra1,
215 * nloop, rloop, zloop )
216 c***********************************************************************
219 c***********************************************************************
220 c--- input
parameters of pfc system and passiv conductors
222 CALL
conduc( nc, ncequi, ncpfc, nfw, nbp, nvv,
223 * rc,zc, pc, vc,hc, ntype,
224 * rc1,zc1, rc2,zc2, rc3,zc3, rc4,zc4,
227 * nout, nter, ninfw, ngra1 )
232 c***********************************************************************
233 c--- definition induct. and selfinduct.
matrix
234 c--- for
"EDDY" conductors:
"PPIND" from
COMMON /ppidps/
237 CALL
l_matr( nout, nter, nc, ncpfc,
238 * ntype, rc, zc, vc, hc,
241 c-----------------------------------------------------------------------
242 c --- initial condition(currents) for circuit equations
246 IF( l.LE.nequi )
THEN
250 pjk(l) = pc(ncpfc+l-nequi)
257 write(fname,
'(a,a)') path(1:kname),
'currents.wr'
258 open(1,file=fname,form=
'formatted')
260 write(1,*) nequi,ncequi
261 write(1,*)(pjk(j),j=1,ncequi)
264 write(fname,
'(a,a)') path(1:kname),
'res_mat.wr'
265 open(1,file=fname,form=
'formatted')
267 write(1,*) (res(j),j=1,ncequi)
271 c..... toroidal currents of passive conductor structures
276 c********************************************************************
282 cccc include
'printb.inc'
289 call
wrcoil(nc,ncpfc,rc,zc,pc,necon,wecon)
293 call
auto(rc,zc,pc,nc,nstep,ngrid,
296 * ntype, necon, wecon )
318 if(kastr.eq.0 .AnD. i_eqdsk.eq.0)
then
319 write(fname,
'(a,a)') path(1:kname),
'inpol.dat'
320 open(1,file=fname,form=
'formatted')
329 write(fname,
'(a,a)') path(1:kname),
'durs_d.dat'
330 open(1,file=fname,form=
'formatted')
332 read(1,*) n_tht,n_psi,igdf,nurs,keyctr,i_eqdsk,i_betp
333 read(1,*) epsro,betplx,tokf,psax,b0,r0,rax,zax
334 read(1,*) alf0,alf1,alf2,bet0,bet1,bet2
345 call
rd_prob( nprob, rprob, zprob, fiprob )
347 call
rd_loop( nloop, rloop, zloop )
350 write(fname,
'(a,a)') path(1:kname),
'currents.wr'
351 open(1,file=fname,form=
'formatted')
353 read(1,*) nequi,ncequi
354 read(1,*)(pjk(j),j=1,ncequi)
357 write(fname,
'(a,a)') path(1:kname),
'res_mat.wr'
358 open(1,file=fname,form=
'formatted')
360 read(1,*) (res(j),j=1,ncequi)
382 cccc voltage for
zero time-level
385 volk(i) = voltpf(i)*bbb
400 call
eqb( alf0,alf1,alf2, bet0,bet1,bet2, alw0,alw1,alw2,
402 * ngav, k_step, platok, rax,zax, b0,r0, psax, igdf,
403 * n_tht, n_psi, epsro, nurs, i_eqdsk,i_bsh,
419 call
eq_0( pjk,psip,ncequi,kstep,ngrid,
420 * alf0,alf1,alf2,bet0,bet1,bet2,
421 * betpol,betplx,zli3,
423 * ftok, tokout, psiax, psiout,
424 * nursb,psi_bnd,alp_b,rax,zax,n_ctrl,b0,r0 )
428 call
eq( pjk, psk, ncequi, kstep, ngrid,
429 * alf0, alf1, alf2, bet0, bet1, bet2,
430 * betpol, betplx, zli3,
432 * ftok, tokout, psiax, psiout,
433 * nursb,psi_bnd,alp_b,rax,zax )
441 CALL
eq_par( z0cen, alp, alpnew, qcen, nctrl, numlim, up,
443 c***********************************************************************
450 c ---------------------
453 c ---------------------
462 c-----------------------------------------------------------------------
463 c --- definition of input
parameters from
"basic" equilibrium
470 c ----------------------------------------------------------------------
471 c for psi_axis value time scenario(for ngav1=2 or 3)
478 c***********************************************************************
481 psidel = psiout - psibou
483 cccc include
'printa.inc'
485 c***********************************************************************
486 c--- printing and writing of numbers and positions of limiter points:
489 c***********************************************************************
490 c***********************************************************************
491 c--------------------- writing in the disk files -----------------------
493 c-----------------------------------------------------------------------
500 c***********************************************************************
501 cccc
OPEN (nout, file=
'EVOL1.PRT', form=
'FORMATTED')
503 c ---
If we need to compute the
"basic" equilibrium only -> kstop=0
505 IF( kstop.EQ.0 )
THEN
508 c***********************************************************************
521 call
eqb( alf0,alf1,alf2, bet0,bet1,bet2, alw0,alw1,alw2,
523 * keyctr, kstep, platok, rax,zax, b0,r0, psax, igdf,
524 * n_tht, n_psi, epsro, nurs, i_eqdsk,i_bsh,
534 psi0_bnd=pspl_av+psex_av
546 cccc
WRITE(nout,*)
' NEW TIME-LEVEL K = KSTEP =', kstep
560 psi0_bnd=pspl_av+psex_av
573 c********************************************************************
574 c definition of
"KEYPRI" -
PARAMETER for printing
583 c====================================================================
584 c definition of input equil.
parameters: betplx, psiax, ftok, helinp
586 IF(ngav1.EQ.0 .OR. ngav1.EQ.2 .OR. ngav1.EQ.4)
588 IF( ngav1.EQ.0 .OR. ngav1.EQ.1 )
THEN
592 IF( ngav1.EQ.2 .OR. ngav1.EQ.3 )
THEN
596 IF( ngav1.EQ.4 .OR. ngav1.EQ.5 )
THEN
601 c***********************************************************************
602 c computing of
"VOLKP1" voltage for circuit equation
603 c for new time level kstep
607 volkp1(i) = voltpf(i)*bbb
612 c-----------------------------------------------------------------------
613 cccc include
'printb.inc'
614 c***********************************************************************
622 psi0_bnd=pspl_av+psex_av
623 psi0_ax=pspl_av+psex_av+psax
633 if(keyctr.eq.0) n_dmf=1
638 if(kpr.eq.1)print *,
' it_dfm==',it_dmf
641 call
eqb( alf0,alf1,alf2, bet0,bet1,bet2, alw0,alw1,alw2,
643 * keyctr, kstep, platok, rax,zax, b0,r0, psax, igdf,
644 * n_tht, n_psi, epsro, nurs, i_eqdsk,i_bsh,
648 c print *,
' psax keyctr platok=',psax,keyctr,platok
662 IF( kstep.EQ.1 )
THEN
674 CALL
evslv( nles, nreg, tstep, tstep, sigm,
675 * ncequi, volk, volkp1, res,
676 * psk, pskp1, pjk, pjkp1, pjkp,
677 * nout, nter, keypri, ereve )
681 c***********************************************************************
684 c----------------------------------------------------------------
685 c the initial approximation for the
case of closed-
loop evolution
690 c----------------------------------------------------------------
697 CALL
evslv( nles, nreg, tstepr, tstep, sigm,
698 * ncequi, volk, volkp1, res,
699 * pskm1, psk, pjk, pjkp1, pjkp,
700 * nout, nter, keypri, ereve )
704 c***********************************************************************
706 CALL
eq_ax( pjkp1, pskp1, ncequi, kstep, ngrid,
707 * alf0, alf1, alf2, bet0, bet1, bet2,
708 * betpol, betplx, zli3,
710 * ftok, tokout, psiax, psiout,
712 * psi_bnd,alp_b,rax,zax,0 )
727 CALL
eq_par( z0cen, alp, alpnew, qcen, nctrl, numlim, up,
730 c***********************************************************************
731 c --- start of the iteration
loop
732 c***********************************************************************
746 CALL
evslv( nles, nreg, tstep, tstep, sigm,
747 * ncequi, volk, volkp1, res,
748 * psk, pskp1, pjk, pjkp1, pjkp,
749 * nout, nter, keypri, ereve )
754 CALL
differ( pjkp, pjkp1, ncequi, errcu1, errcu2,
755 * curmax, curmin, nout, nter )
761 pjkp1(l) = sgmcur*pjkp1(l) + (1.0d0 - sgmcur)*pjkp(l)
763 c-----------------------------------------------------------------------
765 CALL
eq_ax( pjkp1, pskp1, ncequi, kstep, ngrid,
766 * alf0, alf1, alf2, bet0, bet1, bet2,
767 * betpol, betplx, zli3,
769 * ftok, tokout, psiax, psiout,
771 * psi_bnd,alp_b,rax,zax,0 )
773 write(*,*)
'stepon:EQ_AX done, erru=',erps
786 CALL
eq_par( z0cen, alp, alpnew, qcen, nctrl, numlim, up,
791 IF(ngav1.EQ.2 .OR. ngav1.EQ.3) ftok = tokout
792 IF(ngav1.EQ.4 .OR. ngav1.EQ.5) ftok = tokout
829 c ----- control of
EXIT from iteration
loop ------
833 c a_print(3) = delaxr
834 c a_print(4) = delzma
835 c a_print(5) = delzmb
837 c apr =
'KNEL ERPS DELAXR DELZst DELZit'
838 c call
out42(n_pr,a_print,num,apr)
840 c 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000
841 write(*,*)
'stepon:erru',erps
844 IF( erps .LT. enels )
THEN
849 IF( knel .GE. knels )
THEN
851 write(*,*)
'spider,sstepon: no covergence '
852 write(*,*) .GE.
'KNEL KNELS ',knel,knels
859 c 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000
865 diftok=dabs(platok-ztok)/(dabs(platok-ztok_n)+1.d-8)
866 difpsi=dabs(psax-zpsim)/(dabs(psax-zpsim_n)+1.d-8)
869 c print *,
' platok ztok=',platok,ztok
870 c print *,
' psax zpsim=',psax,zpsim
872 c diftok=dabs(platok-ztok)/(dabs(platok)+1.d-4)
873 c difpsi=dabs(psax-zpsim)/(dabs(psax)+1.d-4)
882 if(diftok.lt.5.0d-3 .AnD. it_dmf.gt.0)
then
884 call
eqb( alf0,alf1,alf2, bet0,bet1,bet2, alw0,alw1,alw2,
886 * keyctr, kstep, platok, rax,zax, b0,r0, psax, igdf,
887 * n_tht, n_psi, epsro, nurs, i_eqdsk,i_bsh,
907 c --- printing of iteration
loop accuracy
909 c
IF( keypri.EQ.1 )
THEN
910 c
WRITE(nout,*)
'_______________________________________'
911 c
WRITE(nout,1915) kstep, knel, timev
912 c
WRITE(nout,*)
'ERPS =', erps
913 c
WRITE(nout,*)
'ERRCU1 =', errcu1,
' ERRCU2 =', errcu2
914 c...
WRITE(nout,*)
'CURMAX =', curmax,
' CURMIN =', curmin
915 c
WRITE(nout,*)
'ERRPS1 =', errps1,
' ERRPS2 =', errps2
916 c...
WRITE(nout,*)
'PSIMAX =', psimax,
' PSIMIN =', psimin
917 c
WRITE(nout,*)
'DELPS1 =', delps1,
' DELPS2 =', delps2
918 c...
WRITE(nout,*)
'DELMAX =', delmax,
' DELMIN =', delmin
919 c
WRITE(nout,*)
'DELAXA =', delaxa,
' DELAXR =', delaxr
922 c***********************************************************************
923 c poloidal mag. field companents bp_r, bp_z and
924 c poloidal mag. field projection on direction fipro
925 c compute for given
"PF_PROBE" points:
927 c CALL
bp_prob( nout, nter, keypri,
928 c * npro, rpro, zpro, fipro,
929 c * brpro2, bzpro2, bpcom2 )
930 c***********************************************************************
931 c compute full poloidal
flux in given
"loop" points
933 c CALL
fl_loo( nout, nter, keypri,
934 c * nloo, rloo, zloo,
936 c***********************************************************************
938 c..... toroidal currents in passive conductor structures
943 c-----------------------------------------------------------------------
947 psidel = psiout - psibou
951 cccc include
'printa.inc'
953 c***********************************************************************
954 c--- time level
parameters are written in disk files
957 c***********************************************************************
977 pfcur1(l) = pfcur2(l)
983 d_pf_mat(i) = pjkp1(i)*1.0d6
988 d_tcam_mat(i-nequi) = pjkp1(i)*1.0d6
989 camtok=camtok+pjkp1(i)
1000 c***********************************************************************
1001 if(kstep.lt.nstep_p)
then
1005 torcur(i_tim)=platok
1010 betpol_t(i_tim)=betpol
1011 bettor_t(i_tim)=betful
1015 c-----------------------------------------------------------------------
1016 c for writing for
"motion picture"
1018 c psiplb(kstep)=pspl_av
1019 c psiexb(kstep)=psex_av
1020 c psimag(kstep)=psi0_ax
1021 c flu_tor(kstep)=flx_fi
1023 c
if(kstep.gt.0 .AnD. kstep.le.2000)
then
1025 c
if(kstep/kskw*kskw .eq. kstep)
then
1027 c call
wrdfmv(numwr,timev)
1028 c call
wrdump(numwr,timev,kstep,psiplb,psiexb,psimag,flu_tor)
1031 c 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100
1033 c 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100
1034 c-----------------------------------------------------------------------
1035 103
FORMAT(2x,8e12.5)
1036 1915
FORMAT(3x,
'LEVEL K =',i3,2x,
'ITERATION KNEL =',i3,2x,
1037 *
'TIME(K) =',e12.5)
1038 c********************************
subroutine sstepon(KLUCH, k_auto, nstep, dt, time,
subroutine tab_efit(tokf, psax, eqdfn, rax, zax, b0, r0)
subroutine zero(x1, y1, x2, y2, func, err, x, y, izero, ll)
subroutine get_par(psi_bnd)
subroutine psib_ext(psex_av)
subroutine conduc(NC, NCEQUI, NCPFC, NFW, NBP, NVV, RC, ZC, PC, VC, HC, NTYPE, RC1, ZC1, RC2, ZC2, RC3, ZC3, RC4, ZC4, RES, VOLK, VOLKP1, NECON, WECON, NOUT, NTER, NINFW, ngra1)
subroutine eq_par(z0cen_e, alp_e, alpnew_e, qcen_e, nctrl_e, numlim_e, up_e, rm_e, zm_e, rx0_e, zx0_e)
subroutine loopnt(NOUT, NTER, NINFW, NGRA1,
subroutine eq(pcequi, psicon, ncequi, nstep, ngrid,
subroutine eqb(alf0, alf1, alf2, bet0, bet1, bet2, alw0, alw1, alw2,
subroutine rd_loop(NLOO, RLOO, ZLOO)
subroutine get_flfi(flfi_m)
subroutine l_matr(NOUT,NTER, NC, NCPFC,
subroutine differ(AOLD, ANEW, N, ERRLOC, ERRVEC, ABSMAX, ABSMIN, NOUT, NTER)
subroutine flux(psitok, rk, zk, nk)
subroutine auto(rk, zk, tk, nk, nstep, ngrid,
subroutine out42(n, a, m, b)
subroutine eq_ax(pcequi, psicon, ncequi, nstep, ngrid,
subroutine wrcoil(nk, nkcoil, rk, zk, tk, necon, wecon)
subroutine fl_loo(NOUT, NTER, KEYPRI, NLOO, RLOO, ZLOO, PSLOO)
subroutine psib_pla(pspl_av)
subroutine evslv(NLES, NREG, TSTEP0, TSTEP, SIGM, NJ, VOLK, VOLKP1, RES, PSPK, PSPKP1, CRPK, CRPKP1, CRPKP, NOUT, NTER, KEYPRI, EREVE)
subroutine wrdfmv(numwr, time)
subroutine eq_0(pcequi, psitok, ncequi, nstep, ngrid,
subroutine evolution(T, R_in, R_out, El, Tr_l, Tr_U, Ip)
subroutine bp_prob(NOUT, NTER, KEYPRI, NPRO, RPRO, ZPRO, FIPRO, BRPRO, BZPRO, BPCOM)
subroutine propnt(NOUT, NTER, NINFW, NGRA1,
subroutine rd_prob(NPRO, RPRO, ZPRO, FIPRO)
subroutine wrdump(numwr, time, istep, psiplb, psiexb, psimag, flu_tor)