1# 1 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
2# 1 "/home/runner/work/MFC/MFC/src/common/include/case.fpp" 1
8# 9 "/home/runner/work/MFC/MFC/src/common/include/case.fpp"
11# 14 "/home/runner/work/MFC/MFC/src/common/include/case.fpp"
12# 2 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp" 2
13# 1 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp" 1
14# 1 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 1
15# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
16# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
17# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
18# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
19# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
20# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
22# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
23# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
24# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
26# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
28# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
30# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
32# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
34# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
36# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
38# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
40# 2 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
41# 1 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp" 1
42# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
43# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
44# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
45# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
46# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
47# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
49# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
50# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
51# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
53# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
55# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
57# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
59# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
61# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
63# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
65# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
67# 2 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp" 2
69# 4 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
70# 5 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
71# 6 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
72# 7 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
73# 8 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
75# 20 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
77# 43 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
79# 48 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
81# 53 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
83# 58 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
85# 63 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
87# 68 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
89# 76 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
91# 81 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
93# 86 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
95# 91 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
97# 96 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
99# 101 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
101# 106 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
103# 111 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
105# 116 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
107# 121 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
109# 151 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
111# 192 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
113# 206 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
115# 231 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
117# 242 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
119# 244 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
120# 255 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
122# 284 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
124# 294 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
126# 304 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
128# 313 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
130# 330 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
132# 340 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
134# 347 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
136# 353 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
138# 359 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
140# 365 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
142# 371 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
144# 377 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
146# 3 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
147# 1 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp" 1
148# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
149# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
150# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
151# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
152# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
153# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
155# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
156# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
157# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
159# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
161# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
163# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
165# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
167# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
169# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
171# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
173# 2 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp" 2
175# 7 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
177# 17 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
179# 22 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
181# 27 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
183# 32 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
185# 37 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
187# 42 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
189# 47 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
191# 52 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
193# 57 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
195# 62 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
197# 73 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
199# 78 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
201# 83 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
203# 88 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
205# 103 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
207# 131 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
209# 160 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
211# 175 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
213# 193 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
215# 215 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
217# 244 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
219# 259 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
221# 269 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
223# 278 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
225# 294 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
227# 304 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
229# 311 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
231# 4 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
234# 23 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
237# 43 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
240# 55 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
243# 112 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
246# 130 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
249# 145 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
252# 164 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
255# 193 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
258# 207 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
261# 219 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
264# 231 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
267# 242 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
270# 254 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
273# 266 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
276# 275 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
279# 282 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
282# 289 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
285# 296 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
288# 303 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
290# 305 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
291# 306 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
293# 2 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp" 2
295# 14 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
300# 57 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
303# 77 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
306# 85 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
309# 109 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
312# 125 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
315# 150 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
317# 156 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
319# 163 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
321# 3 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp" 2
332 use ieee_arithmetic !< for checking nan
348# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
350# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
352# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
354# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
356# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
358# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
360# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
362 real(wp),
intent(in) :: vftmp
363 real(wp),
dimension(nb),
intent(in) :: rtmp
364 real(wp),
intent(out) :: ntmp
365 real(wp),
dimension(nb),
intent(in) :: weights
368 r3 = dot_product(weights, rtmp**3._wp)
369 ntmp = (3._wp/(4._wp*pi))*vftmp/r3
377# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
379# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
381# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
383# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
385# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
387# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
389# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
391 real(wp),
intent(in) :: vftmp
392 real(wp),
dimension(nb),
intent(in) :: nrtmp
393 real(wp),
intent(out) :: ntmp
394 real(wp),
dimension(nb),
intent(in) :: weights
397 nr3 = dot_product(weights, nrtmp**3._wp)
398 ntmp = sqrt((4._wp*pi/3._wp)*nr3/vftmp)
405 real(wp),
dimension(:,:),
intent(in) :: a
406 real(wp),
optional,
intent(in) :: div
408 integer :: local_m, local_n
414 if (
present(div))
then
420 print *, local_m, local_n
424 write (*, fmt=
"(F12.4)", advance=
"no") a(i,
j)/c
426 write (*, fmt=
"(A1)")
" "
428 write (*, fmt=
"(A1)")
" "
438# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
440# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
441 use iso_fortran_env,
only: output_unit
442# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
444# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
445 print *,
'm_helper.fpp:90: ',
'@:ALLOCATE(weight(nb), R0(nb))'
446# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
448# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
449 call flush (output_unit)
450# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
452# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
454# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
456# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
458# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
460# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
462# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
463#if defined(MFC_OpenACC)
464# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
466# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
467#elif defined(MFC_OpenMP)
468# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
470# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
474# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
476# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
477 use iso_fortran_env,
only: output_unit
478# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
480# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
481 print *,
'm_helper.fpp:92: ',
'@:ALLOCATE(pb0(nb), Pe_T(nb), k_g(nb), k_v(nb), mass_g0(nb), mass_v0(nb))'
482# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
484# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
485 call flush (output_unit)
486# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
488# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
490# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
491 allocate (pb0(nb), pe_t(nb), k_g(nb), k_v(nb), mass_g0(nb), mass_v0(nb))
492# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
494# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
496# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
498# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
500# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
502# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
504# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
506# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
507#if defined(MFC_OpenACC)
508# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
510# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
511#elif defined(MFC_OpenMP)
512# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
514# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
517# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
519# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
520 use iso_fortran_env,
only: output_unit
521# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
523# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
524 print *,
'm_helper.fpp:93: ',
'@:ALLOCATE(Re_trans_T(nb), Re_trans_c(nb), Im_trans_T(nb), Im_trans_c(nb))'
525# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
527# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
528 call flush (output_unit)
529# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
531# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
533# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
534 allocate (re_trans_t(nb), re_trans_c(nb), im_trans_t(nb), im_trans_c(nb))
535# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
537# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
539# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
541# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
543# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
545# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
546#if defined(MFC_OpenACC)
547# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
549# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
550#elif defined(MFC_OpenMP)
551# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
553# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
557# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
559# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
560 use iso_fortran_env,
only: output_unit
561# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
563# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
564 print *,
'm_helper.fpp:95: ',
'@:ALLOCATE(pb0(nb))'
565# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
567# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
568 call flush (output_unit)
569# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
571# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
573# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
575# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
577# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
579# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
580#if defined(MFC_OpenACC)
581# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
583# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
584#elif defined(MFC_OpenMP)
585# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
587# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
594 else if (nb == 1)
then
598 stop
'Invalid value of nb'
611 r0ref = bub_pp%R0ref; p0ref = bub_pp%p0ref
612 rho0ref = bub_pp%rho0ref
613 ss = bub_pp%ss; pv = bub_pp%pv; vd = bub_pp%vd
614 mu_l = bub_pp%mu_l; mu_v = bub_pp%mu_v; mu_g = bub_pp%mu_g
615 gam_v = bub_pp%gam_v; gam_g = bub_pp%gam_g
616 if (.not. polytropic)
then
617 if (bubbles_euler)
then
618 m_v = bub_pp%M_v; m_g = bub_pp%M_g
619 k_v = bub_pp%k_v; k_g = bub_pp%k_g
621 r_v = bub_pp%R_v; r_g = bub_pp%R_g
624 if (bubbles_lagrange)
then
625 cp_v = bub_pp%cp_v; cp_g = bub_pp%cp_g
626 k_vl = bub_pp%k_v; k_gl = bub_pp%k_g
630 if (bubbles_euler .and. (.not. polytropic))
then
631 if (thermal == 2)
then
641 if (.not. f_is_default(bub_pp%ss)) web = 1._wp/ss
642 if (.not. f_is_default(bub_pp%mu_l)) re_inv = mu_l
643 if (.not. polytropic) pe_c = 1._wp/vd
645 if (bubbles_euler)
then
647 if (.not. polytropic)
then
651 if (qbmm .and. polytropic)
then
653 if (.not. f_is_default(web))
then
654 pb0 = pb0 + 2._wp/web/r0
665 real(wp),
dimension(nb) :: chi_vw0, cp_m0, k_m0, rho_m0, x_vw, omegan, rhol0
666 real(wp),
parameter :: k_poly = 1._wp
669 phi_vg = (1._wp + sqrt(mu_v/mu_g)*(m_g/m_v)**(0.25_wp))**2/(sqrt(8._wp)*sqrt(1._wp + m_v/m_g))
670 phi_gv = (1._wp + sqrt(mu_g/mu_v)*(m_v/m_g)**(0.25_wp))**2/(sqrt(8._wp)*sqrt(1._wp + m_g/m_v))
673 pb0 = eu + 2._wp/web/r0
676 chi_vw0 = 1._wp/(1._wp + r_v/r_g*(pb0/pv - 1._wp))
679 cp_m0 = chi_vw0*r_v*gam_v/(gam_v - 1._wp) + (1._wp - chi_vw0)*r_g*gam_g/(gam_g - 1._wp)
682 x_vw = m_g*chi_vw0/(m_v + (m_g - m_v)*chi_vw0)
685 k_m0 = x_vw*k_v/(x_vw + (1._wp - x_vw)*phi_vg) + (1._wp - x_vw)*k_g/(x_vw*phi_gv + 1._wp - x_vw)
686 k_g(:) = k_g(:)/k_m0(:)
687 k_v(:) = k_v(:)/k_m0(:)
690 rho_m0 = pv/(chi_vw0*r_v*tw)
693 mass_g0(:) = (4._wp*pi/3._wp)*(pb0(:) - pv)/(r_g*tw)*r0(:)**3
694 mass_v0(:) = (4._wp*pi/3._wp)*pv/(r_v*tw)*r0(:)**3
697 pe_t(:) = rho_m0*cp_m0(:)/k_m0(:)
700 omegan(:) = sqrt(3._wp*k_poly*ca + 2._wp*(3._wp*k_poly - 1._wp)/(web*r0))/r0/sqrt(rho0ref)
702 call s_transcoeff(omegan(ir)*r0(ir), pe_t(ir)*r0(ir), re_trans_t(ir), im_trans_t(ir))
703 call s_transcoeff(omegan(ir)*r0(ir), pe_c*r0(ir), re_trans_c(ir), im_trans_c(ir))
712 real(wp),
intent(in) :: omega, peclet
713 real(wp),
intent(out) :: re_trans, im_trans
714 complex(wp) :: imag, trans, c1, c2, c3
716 imag = (0._wp, 1._wp)
718 c1 = imag*omega*peclet
720 c3 = (exp(c2) - exp(-c2))/(exp(c2) + exp(-c2))
721 trans = ((c2/c3 - 1._wp)**(-1) - 3._wp/c1)**(-1)
724 im_trans = aimag(trans)
731 integer,
intent(in) :: i
732 character(len=*),
intent(inout) :: res
734 write (res,
'(I0)') i
742 real(wp),
dimension(:),
intent(inout) :: local_weight
743 real(wp),
dimension(:),
intent(inout) :: local_r0
745 real(wp) :: r0mn, r0mx, dphi, tmp, sd
746 real(wp),
dimension(nb) :: phi
749 r0mn = 0.8_wp*exp(-2.8_wp*sd)
750 r0mx = 0.2_wp*exp(9.5_wp*sd) + 1._wp
754 phi(ir) = log(r0mn) + (ir - 1._wp)*log(r0mx/r0mn)/(nb - 1._wp)
755 local_r0(ir) = exp(phi(ir))
758# 266 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
759 dphi = phi(2) - phi(1)
760# 268 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
765 tmp = exp(-0.5_wp*(phi(ir)/sd)**2)/sqrt(2._wp*pi)/sd
766 if (mod(ir, 2) == 0)
then
767 local_weight(ir) = tmp*4._wp*dphi/3._wp
769 local_weight(ir) = tmp*2._wp*dphi/3._wp
772 tmp = exp(-0.5_wp*(phi(1)/sd)**2)/sqrt(2._wp*pi)/sd
773 local_weight(1) = tmp*dphi/3._wp
774 tmp = exp(-0.5_wp*(phi(nb)/sd)**2)/sqrt(2._wp*pi)/sd
775 local_weight(nb) = tmp*dphi/3._wp
783# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
785# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
787# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
789# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
791# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
793# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
795# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
798 real(wp),
dimension(3),
intent(in) :: a, b
799 real(wp),
dimension(3) :: c
801 c(1) = a(2)*b(3) - a(3)*b(2)
802 c(2) = a(3)*b(1) - a(1)*b(3)
803 c(3) = a(1)*b(2) - a(2)*b(1)
810 real(wp),
intent(inout) :: lhs, rhs
822 type(ic_model_parameters),
intent(in) :: param
823 real(wp),
dimension(1:3),
optional,
intent(in) :: center
824 real(wp),
dimension(1:4,1:4) :: sc, rz, rx, ry, tr, t_back, t_to_origin, out_matrix
826 sc = transpose(reshape([param%scale(1), 0._wp, 0._wp, 0._wp, 0._wp, param%scale(2), 0._wp, 0._wp, 0._wp, 0._wp, &
827 & param%scale(3), 0._wp, 0._wp, 0._wp, 0._wp, 1._wp], shape(sc)))
829 rz = transpose(reshape([cos(param%rotate(3)), -sin(param%rotate(3)), 0._wp, 0._wp, sin(param%rotate(3)), &
830 & cos(param%rotate(3)), 0._wp, 0._wp, 0._wp, 0._wp, 1._wp, 0._wp, 0._wp, 0._wp, 0._wp, 1._wp], shape(rz)))
832 rx = transpose(reshape([1._wp, 0._wp, 0._wp, 0._wp, 0._wp, cos(param%rotate(1)), -sin(param%rotate(1)), 0._wp, 0._wp, &
833 & sin(param%rotate(1)), cos(param%rotate(1)), 0._wp, 0._wp, 0._wp, 0._wp, 1._wp], shape(rx)))
835 ry = transpose(reshape([cos(param%rotate(2)), 0._wp, sin(param%rotate(2)), 0._wp, 0._wp, 1._wp, 0._wp, 0._wp, &
836 & -sin(param%rotate(2)), 0._wp, cos(param%rotate(2)), 0._wp, 0._wp, 0._wp, 0._wp, 1._wp], shape(ry)))
838 tr = transpose(reshape([1._wp, 0._wp, 0._wp, param%translate(1), 0._wp, 1._wp, 0._wp, param%translate(2), 0._wp, 0._wp, &
839 & 1._wp, param%translate(3), 0._wp, 0._wp, 0._wp, 1._wp], shape(tr)))
841 if (
present(center))
then
843 t_to_origin = transpose(reshape([1._wp, 0._wp, 0._wp, -center(1), 0._wp, 1._wp, 0._wp, -center(2), 0._wp, 0._wp, &
844 & 1._wp, -center(3), 0._wp, 0._wp, 0._wp, 1._wp], shape(tr)))
847 t_back = transpose(reshape([1._wp, 0._wp, 0._wp, center(1), 0._wp, 1._wp, 0._wp, center(2), 0._wp, 0._wp, 1._wp, &
848 & center(3), 0._wp, 0._wp, 0._wp, 1._wp], shape(tr)))
850 out_matrix = matmul(tr, matmul(t_back, matmul(ry, matmul(rx, matmul(rz, matmul(sc, t_to_origin))))))
852 out_matrix = matmul(ry, matmul(rx, rz))
860 real(wp),
dimension(1:3),
intent(inout) :: vec
861 real(wp),
dimension(1:4,1:4),
intent(in) :: matrix
862 real(wp),
dimension(1:4) :: tmp
864 tmp = matmul(matrix, [vec(1), vec(2), vec(3), 1._wp])
872 type(t_triangle),
intent(inout) :: triangle
873 real(wp),
dimension(1:4,1:4),
intent(in) :: matrix, matrix_n
887 type(t_model),
intent(inout) :: model
888 real(wp),
dimension(1:4,1:4),
intent(in) :: matrix, matrix_n
891 do i = 1,
size(model%trs)
900 type(t_model),
intent(in) :: model
904 if (
size(model%trs) == 0)
then
910 bbox%min = model%trs(1)%v(1,:)
911 bbox%max = model%trs(1)%v(1,:)
913 do i = 1,
size(model%trs)
915 bbox%min = min(bbox%min, model%trs(i)%v(
j,:))
916 bbox%max = max(bbox%max, model%trs(i)%v(
j,:))
923 elemental function f_xor(lhs, rhs)
result(res)
925 logical,
intent(in) :: lhs, rhs
928 res = (lhs .and. .not. rhs) .or. (.not. lhs .and. rhs)
935 logical,
intent(in) :: predicate
950 integer,
intent(in) ::
l, m
951 real(wp),
intent(in) :: theta, phi
952 real(wp) :: y, x, prefac
980 integer,
intent(in) ::
l, m_order
981 real(wp),
intent(in) :: x
983 real(wp) :: one_minus_x2
987 if (
l < 0 .or. m_order < 0 .or. m_order >
l)
then
992 if (m_order <= 0 .and.
l <= 0)
then
994 else if (
l == 1 .and. m_order <= 0)
then
996 else if (
l == 1 .and. m_order == 1)
then
997 one_minus_x2 = max(0._wp, 1._wp - x**2)
998 result_p = -sqrt(one_minus_x2)
999 else if (m_order ==
l)
then
1001 one_minus_x2 = max(0._wp, 1._wp - x**2)
1003 else if (m_order ==
l - 1)
then
1007 & m_order))/(
l - m_order)
1015 integer,
intent(in) :: n_in
1016 integer,
parameter :: int64_kind = selected_int_kind(18)
1017 integer(kind=int64_kind) :: r_result
1020 r_result = product((/(i, i=n_in, 1, -2)/))
1027 integer,
intent(in) :: n_in
1028 integer,
parameter :: int64_kind = selected_int_kind(18)
1029 integer(kind=int64_kind) :: r_result
1032 r_result = product((/(i, i=n_in, 1, -1)/))
1040 real(wp),
intent(in) :: x, eps
1051 real(wp),
intent(in) :: x, eps
1061 real(wp),
intent(in) :: x
1073 subroutine s_downsample_data(q_cons_vf, q_cons_temp, m_ds, n_ds, p_ds, m_glb_ds, n_glb_ds, p_glb_ds)
1075 type(scalar_field),
dimension(sys_size),
intent(inout) ::
q_cons_vf, q_cons_temp
1078 integer :: i,
j,
k,
l
1079 integer :: ix, iy, iz, x_id, y_id, z_id
1080 integer,
intent(inout) :: m_ds, n_ds, p_ds, m_glb_ds, n_glb_ds, p_glb_ds
1082 m_ds = int((m + 1)/3) - 1
1083 n_ds = int((n + 1)/3) - 1
1084 p_ds = int((p + 1)/3) - 1
1086 m_glb_ds = int((m_glb + 1)/3) - 1
1087 n_glb_ds = int((n_glb + 1)/3) - 1
1088 p_glb_ds = int((p_glb + 1)/3) - 1
1097 q_cons_temp(i)%sf(
j,
k,
l) = 0
1102 q_cons_temp(i)%sf(
j,
k,
l) = q_cons_temp(i)%sf(
j,
k, &
1103 &
l) + (1._wp/27._wp)*
q_cons_vf(i)%sf(x_id + ix, y_id + iy, z_id + iz)
1117 type(scalar_field),
intent(inout),
dimension(sys_size) ::
q_cons_vf, q_cons_temp
1118 integer :: i,
j,
k,
l
1119 integer :: ix, iy, iz
1120 integer :: x_id, y_id, z_id
1121 real(wp),
dimension(4) :: temp
1131 x_id =
j - int(3*ix) - 1
1132 y_id =
k - int(3*iy) - 1
1133 z_id =
l - int(3*iz) - 1
1135 temp(1) = (2._wp/3._wp)*q_cons_temp(i)%sf(ix, iy, iz) + (1._wp/3._wp)*q_cons_temp(i)%sf(ix + x_id, iy, iz)
1136 temp(2) = (2._wp/3._wp)*q_cons_temp(i)%sf(ix, iy + y_id, iz) + (1._wp/3._wp)*q_cons_temp(i)%sf(ix + x_id, &
1138 temp(3) = (2._wp/3._wp)*temp(1) + (1._wp/3._wp)*temp(2)
1140 temp(1) = (2._wp/3._wp)*q_cons_temp(i)%sf(ix, iy, iz + z_id) + (1._wp/3._wp)*q_cons_temp(i)%sf(ix + x_id, &
1142 temp(2) = (2._wp/3._wp)*q_cons_temp(i)%sf(ix, iy + y_id, &
1143 & iz + z_id) + (1._wp/3._wp)*q_cons_temp(i)%sf(ix + x_id, iy + y_id, iz + z_id)
1144 temp(4) = (2._wp/3._wp)*temp(1) + (1._wp/3._wp)*temp(2)
1146 q_cons_vf(i)%sf(
j,
k,
l) = (2._wp/3._wp)*temp(3) + (1._wp/3._wp)*temp(4)
type(scalar_field), dimension(sys_size), intent(inout) q_cons_vf
Shared derived types for field data, patch geometry, bubble dynamics, and MPI I/O structures.
Defines global parameters for the computational domain, simulation algorithm, and initial conditions.
real(wp), dimension(:), allocatable weight
real(wp), dimension(:), allocatable r0
Utility routines for bubble model setup, coordinate transforms, array sampling, and special functions...
subroutine, public s_comp_n_from_prim(vftmp, rtmp, ntmp, weights)
Computes the bubble number density n from the primitive variables.
impure subroutine, public s_initialize_nonpoly()
Initializes non-polydisperse bubble modeling.
recursive real(wp) function, public associated_legendre(x, l, m_order)
Associated Legendre polynomial P_l^m(x) (Ferrers function, Condon-Shortley phase)....
subroutine, public s_transform_triangle(triangle, matrix, matrix_n)
Transform a triangle by a matrix, one vertex at a time.
real(wp) function, public f_cut_on(x, eps)
Calculate a smooth cut-on function that is zero for x values smaller than zero and goes to one,...
subroutine, public s_transform_model(model, matrix, matrix_n)
Transform a model by a matrix, one triangle at a time.
type(t_bbox) function, public f_create_bbox(model)
Create a bounding box for a model.
real(wp) function f_gx(x)
Helper function for f_cut_on and f_cut_off.
subroutine, public s_simpson(local_weight, local_r0)
Computes the Simpson weights for quadrature.
elemental integer(kind=int64_kind) function, public double_factorial(n_in)
Calculate the double factorial of an integer.
impure subroutine s_initialize_bubble_vars()
Set bubble physical parameters and nondimensional numbers from the input configuration.
elemental integer(kind=int64_kind) function, public factorial(n_in)
Calculate the factorial of an integer.
subroutine, public s_upsample_data(q_cons_vf, q_cons_temp)
Upsample conservative variable fields from a coarsened grid back to the original resolution using int...
real(wp) function, dimension(1:4, 1:4), public f_create_transform_matrix(param, center)
Create a transformation matrix.
real(wp) function, public f_cut_off(x, eps)
Calculate a smooth cut-off function that is one for x values smaller than zero and goes to zero,...
subroutine, public s_transform_vec(vec, matrix)
Transform a vector by a matrix.
impure subroutine, public s_initialize_bubbles_model()
Initialize bubble model arrays for Euler or Lagrangian bubbles with polytropic or non-polytropic gas.
impure subroutine, public s_print_2d_array(a, div)
Print a 2D real array to standard output, optionally dividing each element by a given scalar.
elemental subroutine, public s_transcoeff(omega, peclet, re_trans, im_trans)
Computes the transfer coefficient for the non-polytropic bubble compression process.
pure real(wp) function, dimension(3), public f_cross(a, b)
Compute the cross product of two vectors.
subroutine, public s_downsample_data(q_cons_vf, q_cons_temp, m_ds, n_ds, p_ds, m_glb_ds, n_glb_ds, p_glb_ds)
Downsample conservative variable fields by a factor of 3 in each direction using volume averaging.
elemental logical function, public f_xor(lhs, rhs)
Perform XOR on lhs and rhs.
subroutine, public s_comp_n_from_cons(vftmp, nrtmp, ntmp, weights)
Compute the bubble number density from the conservative void fraction and weighted bubble radii.
real(wp) function, public real_ylm(theta, phi, l, m)
Real spherical harmonic Y_lm(theta, phi). theta = polar angle from +z (acos(z/r)),...
elemental integer function, public f_logical_to_int(predicate)
Convert a logical to 1 or 0.
elemental subroutine, public s_int_to_str(i, res)
Convert an integer to its trimmed string representation.
elemental subroutine, public s_swap(lhs, rhs)
Swap two real numbers.