ETS  \$Id: Doxyfile 2162 2020-02-26 14:16:09Z g2dpc $
 All Classes Files Functions Variables Pages
Dmfy_main_m.f
Go to the documentation of this file.
1  program main_spider
2 c---------------------------------------------------------------
3 c main PROGRAM of the evolution code "SPIDER"
4 c---------------------------------------------------------------
5 
6  include 'double.inc'
7 
8  parameter(mdim=50)
9  include 'dimpl1.inc'
10  dimension af_r(nrp,0:mdim),bf_r(nrp,0:mdim)
11  dimension af_z(nrp,0:mdim),bf_z(nrp,0:mdim)
12 
13  dimension contvals_mat(2500),voltpf(500),d_pf_mat(500)
14  dimension d_cam_mat(500)
15  dimension rcp(10),zcp(10)
16  character*40 prename
17  character*40 eqdfn
18 
19 c kpr=1 for debugging, kpr=0 no printing
20 
21  kpr=1
22  prename=''
23  kname=1
24  call aspid_flag(0)
25  call kpr_calc(kpr)
26  call put_name(prename,kname)
27 
28  call ppf2modul
29  call bnd2modul
30 
31  !key_dmf=-2
32  key_dmf=0
33 
34  nstop = 1500
35 
36  nstep=0
37  time=0.d0
38  dt=2.0d-2
39  tau_con=2.0d-2
40  k_con=(tau_con+1.d-8)/dt
41  !k_con=100000
42  !k_con=1
43  call put_tim(dt,time)
44 
45 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
46 
47  !call prof_rec
48 
49 
50 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
51 
52  kluch = 0
53  k_fixfree = 1
54 
55  call put_key_fix(k_fixfree)
56 
57 !----------------only fixed boundary adaptive grid case
58 !
59 !
60  if(k_fixfree.eq.0) then
61  k_auto= 1
62  call b_stepon( kluch, k_auto, nstep, dt, time,
63  * rax,zax ,key_dmf,dpsdt)
64  call get_flfi(flfi_m)
65  call cur_avg
66  call wrb
67  !call field_c
68  write(*,*) 'flux_fi',flfi_m
69  write(*,*) 'nstep done,time',nstep,time
70  write(*,*) '**'
71 
72  ! mg=6
73  !call furgrid(mdim,mg,af_r,bf_r,af_z,bf_z)
74 
75 
76  kluch = 1
77  k_auto= 0
78  !dpsdt=-3.2d0
79  dpsdt=0.d0
80  !dpsdt=100.d-3/dt
81 
82  !call dmf_test_rd(nstop)
83 
84  do nstep = 1,nstop
85  time=time+dt
86  call put_tim(dt,time)
87  !call savepsi
88  !if(nstep.eq.1) call press_p
89  !if(nstep.eq.5) key_dmf=-2
90 
91  call b_stepon( kluch, k_auto, nstep, dt, time,
92  * rax,zax ,key_dmf,dpsdt)
93  call cur_avg
94  call get_flfi(flfi_m)
95  !call field_c
96  !call pla_volt(dt)
97  call wrb
98  write(*,*) 'flux_fi',flfi_m
99  write(*,*) '**'
100  write(*,*) 'nstep done,time',nstep,time
101  write(*,*) '**'
102 
103  !call dmf_test_wr(nstep,nstop)
104  enddo
105  stop
106  endif
107 !
108 !
109 !---------------------only fixed boundary adaptive grid case
110  k_auto= 1
111 c----------------
112  k_grid= 0 ! rect. grid
113  !!! k_grid= 1 ! adap. grid
114 
115  !call tab_build
116 !
117 !!!!! basic free bound rectan, equilibrium ( KLUCH=0 )
118 !
119  key_ini=1
120 
121  if(key_ini .eq. 0) then
122  call sstepon( kluch, k_auto,nstep,dt,time,
123  * voltpf, d_pf_mat ,d_cam_mat,key_dmf)
124  else
125  call cf_init( k_auto, nstep, dt, time,
126  * voltpf, d_pf_mat,d_cam_mat )
127  endif
128  !call wrfb
129  call wrrec
130  eqdfn='eqdsk_128x129-tin047_I=1,5.wr'
131  !!call eqdsk_rebild
132  !call eqdsk_build(eqdfn)
133  call cur_avg
134  call wrb
135  call wr_spik
136  call coil_force
137  !call field_c
138  !call get_www(roomega)
139 
140  stop !!
141  call cntrlr_iter(0,k_grid,voltpf)
142 
143  !call get_bouL_bra(contvals_mat,g1r,g1z,g2r,g2z,g5r,g5z)
144 
145  k_auto= 0
146 
147  if(k_grid.eq.1) then
148 !
149 !!!!! basic free bound, adaptive equilibrium ( KLUCH=0 )
150 !
151 
152  call f_stepon( kluch, k_auto,nstep,dt,time,
153  * voltpf, d_pf_mat ,d_cam_mat,rax,zax,key_dmf)
154  call cur_avg
155  call f_wrd
156  endif
157 
158  !call eqdsk_build('eqdsk_spidat.dat.1480')
159 
160 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
161  pause 'pause:initial equilibrium '
162 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
163 
164 
165  kluch = 1
166 
167  do nstep = 1,nstop
168 
169 
170  nstep1=nstep !-1
171  if(nstep1/k_con*k_con .eq. nstep1) then
172  do i=1,19
173  voltpf(i)=0.d0
174  enddo
175  call cntrlr_iter(1,k_grid,voltpf)
176  endif
177 
178  time=time+dt
179  call put_tim(dt,time)
180  print *,' Next step: stepon',nstep
181 
182  if(k_grid.eq.0) then
183 
184  call sstepon( kluch, k_auto,nstep,dt,time,
185  * voltpf, d_pf_mat ,d_cam_mat,key_dmf)
186  print *,' stepon done'
187  call cur_avg
188  call wrd
189  call wrb
190  print *,' wrd done'
191  elseif(k_grid.eq.1) then
192 
193  call f_stepon( kluch, k_auto,nstep,dt,time,
194  * voltpf, d_pf_mat ,d_cam_mat,rax,zax,key_dmf)
195  call cur_avg
196  call f_wrd
197  endif
198 
199  print *,' After stepon'
200 
201 
202  !call get_bouL_bra(contvals_mat,g1r,g1z,g2r,g2z,g5r,g5z)
203 
204  if(nstep/5*5.eq.nstep) then
205  call wrd_tim
206  !pause 'pause'
207  endif
208  write(*,*) '**'
209  write(*,*) 'nstep done,time',nstep,time
210  write(*,*) '**'
211  enddo
212 
213  stop
214  end
215 
216 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
217 
218 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
219 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
220  subroutine dmf_test_wr(nstep,nstop)
221 
222  include 'double.inc'
223  include 'dim.inc'
224  include 'compol.inc'
225  common/psi_test/ psi_ext_bon(300)
226 
227  psi_ext_bon(nstep)=psi_eav
228 
229  if(nstep.eq.nstop) then
230  open(1,file='bonpsi.wr',form='formatted')
231  write(1,*) (psi_ext_bon(i),i=1,nstop)
232  close(1)
233  endif
234 
235  return
236  end
237 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
238  subroutine dmf_test_rd(nstop)
239 
240  include 'double.inc'
241  include 'dim.inc'
242  include 'compol.inc'
243  common/psi_test/ psi_ext_bon(300)
244 
245  open(1,file='bonpsi.wr',form='formatted')
246  read(1,*) (psi_ext_bon(i),i=1,nstop)
247  close(1)
248 
249  return
250  end
251 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
252 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
253 
254  subroutine press_p
255  include 'double.inc'
256  include 'dim.inc'
257  include 'compol.inc'
258 
259  ampl=2.50d0 !0.d0 !1.5d0 0.5d0
260  xx0=0.50d0
261  w=0.1d0
262  do i=1,iplas
263  xx =dfloat(i)/dfloat(iplas)
264  delp_prim = ampl*( 1.d0-dtanh(((xx0-xx)/w)**4) )
265  dpdpsi(i)=dpdpsi(i)+delp_prim
266  enddo
267 
268  return
269  end
270 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
271 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
272 
273  subroutine prof_rec
274  include 'double.inc'
275  parameter(np=1000)
276  dimension ps(np),fp(np),pp(np)
277  dimension ps1(np),fp1(np),pp1(np)
278 
279  alp=0.75d0
280  alp=0.d0
281 
282  open(1,file='tabppf_tin047p.dat')
283  read(1,*) n
284  do i=1,n
285  read(1,*) ps(i),pp(i),fp(i)
286  enddo
287  close(1)
288 
289  open(1,file='tabppf_tin047.dat')
290  read(1,*) n
291  do i=1,n
292  read(1,*) ps1(i),pp1(i),fp1(i)
293  enddo
294  close(1)
295 
296 
297  do i=1,n
298  fp(i)=alp*fp(i) + (1.d0-alp)*fp1(i)
299  enddo
300 
301  open(1,file='tabppf.dat')
302  write(1,*) n
303  do i=1,n
304  write(1,*) ps(i),pp(i),fp(i)
305  enddo
306  close(1)
307 
308  return
309  end
310 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
311  subroutine ppf2modul
312 
313  use ppf_modul
314 
315  include 'double.inc'
316 
317  write(fname,'(a,a)') path(1:kname),'tabppf.dat'
318  open(1,file=fname,form='formatted')
319  !open(1,file='tabppf.dat')
320  read(1,*) nutab
321  allocate( pstab(nutab), pptab(nutab), fptab(nutab) )
322  do i=1,nutab
323  read(1,*) pstab(i),pptab(i),fptab(i)
324  enddo
325  close(1)
326  !deallocate( pstab, pptab, fptab )
327 
328 
329  return
330  end
331 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
332  subroutine bnd2modul
333 
334  use bnd_modul
335 
336  include 'double.inc'
337 
338  write(fname,'(a,a)') path(1:kname),'tab_bnd.dat'
339  open(1,file=fname,form='formatted')
340  !open(1,file='tabppf.dat')
341  read(1,*) nbtab
342  allocate( rbtab(nbtab), zbtab(nbtab) )
343  do i=1,nbtab
344  read(1,*) rbtab(i),zbtab(i)
345  enddo
346  close(1)
347  !deallocate( rbtab, zbtab )
348 
349 
350  return
351  end
subroutine sstepon(KLUCH, k_auto, nstep, dt, time,
Definition: sstepon.f:3
subroutine b_stepon(KLUCH, k_auto, nstep, dt, time,
Definition: sstepon_r.f:3
subroutine put_tim(dt, time)
Definition: B_eqb.f:944
subroutine f_wrd
Definition: _wrd.f:107
subroutine cntrlr_iter(kon_ini, kgrid, voltpf)
Definition: controller.f:1
subroutine kpr_calc(kpr_xx)
Definition: Spider_call.f:215
real(r8) function dpdpsi(psi_n)
subroutine get_flfi(flfi_m)
Definition: com_sub.f:394
subroutine wrd
Definition: Eq2_m.f:1378
subroutine put_key_fix(k)
subroutine wrd_tim
Definition: _wrd.f:1
subroutine cur_avg
Definition: com_sub.f:813
subroutine wrb
Definition: B_wrd.f:1
subroutine coil_force
Definition: EQ1_m.f:332
subroutine code(ZIX, ZIY, C)
Definition: ppplib.f:570
subroutine wr_spik
Definition: B_wrd.f:646
subroutine wrrec
Definition: Eq2_m.f:1453
subroutine evolution(T, R_in, R_out, El, Tr_l, Tr_U, Ip)
subroutine f_stepon(KLUCH, k_auto, nstep, dt, time,
Definition: sstepon_r.f:169
subroutine put_name(name, ksym)
Definition: Spider_call.f:234