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# 8 "/home/runner/work/MFC/MFC/src/common/include/case.fpp"
11# 12 "/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# 145 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
42# 2 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
43# 1 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp" 1
44# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
45# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
46# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
47# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
48# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
49# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
51# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
52# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
53# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
55# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
57# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
59# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
61# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
63# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
65# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
67# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
69# 145 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
71# 2 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp" 2
73# 4 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
74# 5 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
75# 6 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
76# 7 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
77# 8 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
79# 20 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
81# 43 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
83# 48 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
85# 53 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
87# 58 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
89# 63 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
91# 68 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
93# 76 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
95# 81 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
97# 86 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
99# 91 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
101# 96 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
103# 101 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
105# 106 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
107# 111 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
109# 116 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
111# 121 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
113# 151 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
115# 192 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
117# 206 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
119# 231 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
121# 242 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
123# 244 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
124# 255 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
126# 284 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
128# 294 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
130# 304 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
132# 313 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
134# 330 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
136# 340 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
138# 347 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
140# 353 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
142# 359 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
144# 365 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
146# 371 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
148# 377 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
150# 3 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
151# 1 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp" 1
152# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
153# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
154# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
155# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
156# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
157# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
159# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
160# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
161# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
163# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
165# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
167# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
169# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
171# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
173# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
175# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
177# 145 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
179# 2 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp" 2
181# 7 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
183# 17 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
185# 22 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
187# 27 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
189# 32 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
191# 37 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
193# 42 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
195# 47 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
197# 52 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
199# 57 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
201# 62 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
203# 73 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
205# 78 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
207# 83 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
209# 88 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
211# 103 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
213# 131 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
215# 160 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
217# 175 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
219# 193 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
221# 215 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
223# 244 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
225# 259 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
227# 269 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
229# 278 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
231# 294 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
233# 304 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
235# 311 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
237# 4 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
240# 23 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
243# 43 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
246# 55 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
249# 112 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
252# 130 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
255# 145 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
258# 164 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
261# 193 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
264# 207 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
267# 219 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
270# 231 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
273# 242 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
276# 254 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
279# 266 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
282# 275 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
285# 282 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
288# 289 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
291# 296 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
294# 303 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
296# 305 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
297# 306 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
299# 2 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp" 2
301# 14 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
306# 57 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
309# 77 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
312# 85 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
315# 109 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
318# 125 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
321# 150 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
323# 156 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
325# 163 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
327# 3 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp" 2
338 use ieee_arithmetic !< for checking nan
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# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
364# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
366# 28 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
368 real(wp),
intent(in) :: vftmp
369 real(wp),
dimension(nb),
intent(in) :: rtmp
370 real(wp),
intent(out) :: ntmp
371 real(wp),
dimension(nb),
intent(in) :: weights
374 r3 = dot_product(weights, rtmp**3._wp)
375 ntmp = (3._wp/(4._wp*pi))*vftmp/r3
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# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
393# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
395# 43 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
397 real(wp),
intent(in) :: vftmp
398 real(wp),
dimension(nb),
intent(in) :: nrtmp
399 real(wp),
intent(out) :: ntmp
400 real(wp),
dimension(nb),
intent(in) :: weights
403 nr3 = dot_product(weights, nrtmp**3._wp)
404 ntmp = sqrt((4._wp*pi/3._wp)*nr3/vftmp)
411 real(wp),
dimension(:,:),
intent(in) :: a
412 real(wp),
optional,
intent(in) :: div
414 integer :: local_m, local_n
420 if (
present(div))
then
426 print *, local_m, local_n
430 write (*, fmt=
"(F12.4)", advance=
"no") a(i,
j)/c
432 write (*, fmt=
"(A1)")
" "
434 write (*, fmt=
"(A1)")
" "
442 if (bubbles_euler)
then
444# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
446# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
447 use iso_fortran_env,
only: output_unit
448# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
450# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
451 print *,
'm_helper.fpp:90: ',
'@:ALLOCATE(weight(nb), R0(nb))'
452# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
454# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
455 call flush (output_unit)
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"
464# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
466# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
468# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
469#if defined(MFC_OpenACC)
470# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
472# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
473#elif defined(MFC_OpenMP)
474# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
476# 90 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
478 if (.not. polytropic)
then
480# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
482# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
483 use iso_fortran_env,
only: output_unit
484# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
486# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
487 print *,
'm_helper.fpp:92: ',
'@:ALLOCATE(pb0(nb), Pe_T(nb), k_g(nb), k_v(nb), mass_g0(nb), mass_v0(nb))'
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 call flush (output_unit)
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"
497 allocate (pb0(nb), pe_t(nb), k_g(nb), k_v(nb), mass_g0(nb), mass_v0(nb))
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"
508# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
510# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
512# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
513#if defined(MFC_OpenACC)
514# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
516# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
517#elif defined(MFC_OpenMP)
518# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
520# 92 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
523# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
525# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
526 use iso_fortran_env,
only: output_unit
527# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
529# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
530 print *,
'm_helper.fpp:93: ',
'@:ALLOCATE(Re_trans_T(nb), Re_trans_c(nb), Im_trans_T(nb), Im_trans_c(nb))'
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 call flush (output_unit)
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"
540 allocate (re_trans_t(nb), re_trans_c(nb), im_trans_t(nb), im_trans_c(nb))
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"
547# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
549# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
551# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
552#if defined(MFC_OpenACC)
553# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
555# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
556#elif defined(MFC_OpenMP)
557# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
559# 93 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
563# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
565# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
566 use iso_fortran_env,
only: output_unit
567# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
569# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
570 print *,
'm_helper.fpp:95: ',
'@:ALLOCATE(pb0(nb))'
571# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
573# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
574 call flush (output_unit)
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"
581# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
583# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
585# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
586#if defined(MFC_OpenACC)
587# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
589# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
590#elif defined(MFC_OpenMP)
591# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
593# 95 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
600 else if (nb == 1)
then
604 stop
'Invalid value of nb'
617 r0ref = bub_pp%R0ref; p0ref = bub_pp%p0ref
618 rho0ref = bub_pp%rho0ref
619 ss = bub_pp%ss; pv = bub_pp%pv; vd = bub_pp%vd
620 mu_l = bub_pp%mu_l; mu_v = bub_pp%mu_v; mu_g = bub_pp%mu_g
621 gam_v = bub_pp%gam_v; gam_g = bub_pp%gam_g
622 if (.not. polytropic)
then
623 if (bubbles_euler)
then
624 m_v = bub_pp%M_v; m_g = bub_pp%M_g
625 k_v = bub_pp%k_v; k_g = bub_pp%k_g
627 r_v = bub_pp%R_v; r_g = bub_pp%R_g
630 if (bubbles_lagrange)
then
631 cp_v = bub_pp%cp_v; cp_g = bub_pp%cp_g
632 k_vl = bub_pp%k_v; k_gl = bub_pp%k_g
636 if (bubbles_euler .and. (.not. polytropic))
then
637 if (thermal == 2)
then
647 if (.not. f_is_default(bub_pp%ss)) web = 1._wp/ss
648 if (.not. f_is_default(bub_pp%mu_l)) re_inv = mu_l
649 if (.not. polytropic) pe_c = 1._wp/vd
651 if (bubbles_euler)
then
653 if (.not. polytropic)
then
657 if (qbmm .and. polytropic)
then
659 if (.not. f_is_default(web))
then
660 pb0 = pb0 + 2._wp/web/r0
671 real(wp),
dimension(nb) :: chi_vw0, cp_m0, k_m0, rho_m0, x_vw, omegan
672 real(wp),
parameter :: k_poly = 1._wp
675 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))
676 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))
679 pb0 = eu + 2._wp/web/r0
682 chi_vw0 = 1._wp/(1._wp + r_v/r_g*(pb0/pv - 1._wp))
685 cp_m0 = chi_vw0*r_v*gam_v/(gam_v - 1._wp) + (1._wp - chi_vw0)*r_g*gam_g/(gam_g - 1._wp)
688 x_vw = m_g*chi_vw0/(m_v + (m_g - m_v)*chi_vw0)
691 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)
692 k_g(:) = k_g(:)/k_m0(:)
693 k_v(:) = k_v(:)/k_m0(:)
696 rho_m0 = pv/(chi_vw0*r_v*tw)
699 mass_g0(:) = (4._wp*pi/3._wp)*(pb0(:) - pv)/(r_g*tw)*r0(:)**3
700 mass_v0(:) = (4._wp*pi/3._wp)*pv/(r_v*tw)*r0(:)**3
703 pe_t(:) = rho_m0*cp_m0(:)/k_m0(:)
706 omegan(:) = sqrt(3._wp*k_poly*ca + 2._wp*(3._wp*k_poly - 1._wp)/(web*r0))/r0/sqrt(rho0ref)
708 call s_transcoeff(omegan(ir)*r0(ir), pe_t(ir)*r0(ir), re_trans_t(ir), im_trans_t(ir))
709 call s_transcoeff(omegan(ir)*r0(ir), pe_c*r0(ir), re_trans_c(ir), im_trans_c(ir))
718 real(wp),
intent(in) :: omega, peclet
719 real(wp),
intent(out) :: re_trans, im_trans
720 complex(wp) :: imag, trans, c1, c2, c3
722 imag = (0._wp, 1._wp)
724 c1 = imag*omega*peclet
726 c3 = (exp(c2) - exp(-c2))/(exp(c2) + exp(-c2))
727 trans = ((c2/c3 - 1._wp)**(-1) - 3._wp/c1)**(-1)
730 im_trans = aimag(trans)
737 integer,
intent(in) :: i
738 character(len=*),
intent(inout) :: res
740 write (res,
'(I0)') i
748 real(wp),
dimension(:),
intent(inout) :: local_weight
749 real(wp),
dimension(:),
intent(inout) :: local_r0
751 real(wp) :: r0mn, r0mx, dphi, tmp, sd
752 real(wp),
dimension(nb) :: phi
755 r0mn = 0.8_wp*exp(-2.8_wp*sd)
756 r0mx = 0.2_wp*exp(9.5_wp*sd) + 1._wp
760 phi(ir) = log(r0mn) + (ir - 1._wp)*log(r0mx/r0mn)/(nb - 1._wp)
761 local_r0(ir) = exp(phi(ir))
764# 266 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
765 dphi = phi(2) - phi(1)
766# 268 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
771 tmp = exp(-0.5_wp*(phi(ir)/sd)**2)/sqrt(2._wp*pi)/sd
772 if (mod(ir, 2) == 0)
then
773 local_weight(ir) = tmp*4._wp*dphi/3._wp
775 local_weight(ir) = tmp*2._wp*dphi/3._wp
778 tmp = exp(-0.5_wp*(phi(1)/sd)**2)/sqrt(2._wp*pi)/sd
779 local_weight(1) = tmp*dphi/3._wp
780 tmp = exp(-0.5_wp*(phi(nb)/sd)**2)/sqrt(2._wp*pi)/sd
781 local_weight(nb) = tmp*dphi/3._wp
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"
797# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
799# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
801# 289 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
804 real(wp),
dimension(3),
intent(in) :: a, b
805 real(wp),
dimension(3) :: c
807 c(1) = a(2)*b(3) - a(3)*b(2)
808 c(2) = a(3)*b(1) - a(1)*b(3)
809 c(3) = a(1)*b(2) - a(2)*b(1)
817# 303 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
819# 303 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
821# 303 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
823# 303 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
825# 303 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
827# 303 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
829# 303 "/home/runner/work/MFC/MFC/src/common/m_helper.fpp"
831 real(wp),
intent(in) :: a(3), b(3)
832 real(wp),
intent(out) :: c(3)
834 c(1) = a(2)*b(3) - a(3)*b(2)
835 c(2) = a(3)*b(1) - a(1)*b(3)
836 c(3) = a(1)*b(2) - a(2)*b(1)
845 real(wp),
intent(inout) :: lhs, rhs
857 type(ic_model_parameters),
intent(in) :: param
858 real(wp),
dimension(1:3),
optional,
intent(in) :: center
859 real(wp),
dimension(1:4,1:4) :: sc, rz, rx, ry, tr, t_back, t_to_origin, out_matrix
861 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, &
862 & param%scale(3), 0._wp, 0._wp, 0._wp, 0._wp, 1._wp], shape(sc)))
864 rz = transpose(reshape([cos(param%rotate(3)), -sin(param%rotate(3)), 0._wp, 0._wp, sin(param%rotate(3)), &
865 & 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)))
867 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, &
868 & sin(param%rotate(1)), cos(param%rotate(1)), 0._wp, 0._wp, 0._wp, 0._wp, 1._wp], shape(rx)))
870 ry = transpose(reshape([cos(param%rotate(2)), 0._wp, sin(param%rotate(2)), 0._wp, 0._wp, 1._wp, 0._wp, 0._wp, &
871 & -sin(param%rotate(2)), 0._wp, cos(param%rotate(2)), 0._wp, 0._wp, 0._wp, 0._wp, 1._wp], shape(ry)))
873 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, &
874 & 1._wp, param%translate(3), 0._wp, 0._wp, 0._wp, 1._wp], shape(tr)))
876 if (
present(center))
then
878 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, &
879 & 1._wp, -center(3), 0._wp, 0._wp, 0._wp, 1._wp], shape(tr)))
882 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, &
883 & center(3), 0._wp, 0._wp, 0._wp, 1._wp], shape(tr)))
885 out_matrix = matmul(tr, matmul(t_back, matmul(ry, matmul(rx, matmul(rz, matmul(sc, t_to_origin))))))
887 out_matrix = matmul(ry, matmul(rx, rz))
895 real(wp),
dimension(1:3),
intent(inout) :: vec
896 real(wp),
dimension(1:4,1:4),
intent(in) :: matrix
897 real(wp),
dimension(1:4) :: tmp
899 tmp = matmul(matrix, [vec(1), vec(2), vec(3), 1._wp])
907 type(t_triangle),
intent(inout) :: triangle
908 real(wp),
dimension(1:4,1:4),
intent(in) :: matrix, matrix_n
922 type(t_model),
intent(inout) :: model
923 real(wp),
dimension(1:4,1:4),
intent(in) :: matrix, matrix_n
926 do i = 1,
size(model%trs)
935 type(t_model),
intent(in) :: model
939 if (
size(model%trs) == 0)
then
945 bbox%min = model%trs(1)%v(1,:)
946 bbox%max = model%trs(1)%v(1,:)
948 do i = 1,
size(model%trs)
950 bbox%min = min(bbox%min, model%trs(i)%v(
j,:))
951 bbox%max = max(bbox%max, model%trs(i)%v(
j,:))
958 elemental function f_xor(lhs, rhs)
result(res)
960 logical,
intent(in) :: lhs, rhs
963 res = (lhs .and. .not. rhs) .or. (.not. lhs .and. rhs)
970 logical,
intent(in) :: predicate
985 integer,
intent(in) ::
l, m
986 real(wp),
intent(in) :: theta, phi
987 real(wp) :: y, x, prefac
1015 integer,
intent(in) ::
l, m_order
1016 real(wp),
intent(in) :: x
1017 real(wp) :: result_p
1018 real(wp) :: one_minus_x2
1022 if (
l < 0 .or. m_order < 0 .or. m_order >
l)
then
1027 if (m_order <= 0 .and.
l <= 0)
then
1029 else if (
l == 1 .and. m_order <= 0)
then
1031 else if (
l == 1 .and. m_order == 1)
then
1032 one_minus_x2 = max(0._wp, 1._wp - x**2)
1033 result_p = -sqrt(one_minus_x2)
1034 else if (m_order ==
l)
then
1036 one_minus_x2 = max(0._wp, 1._wp - x**2)
1038 else if (m_order ==
l - 1)
then
1042 & m_order))/(
l - m_order)
1050 integer,
intent(in) :: n_in
1051 integer,
parameter :: int64_kind = selected_int_kind(18)
1052 integer(kind=int64_kind) :: r_result
1055 r_result = product((/(i, i=n_in, 1, -2)/))
1062 integer,
intent(in) :: n_in
1063 integer,
parameter :: int64_kind = selected_int_kind(18)
1064 integer(kind=int64_kind) :: r_result
1067 r_result = product((/(i, i=n_in, 1, -1)/))
1075 real(wp),
intent(in) :: x, eps
1086 real(wp),
intent(in) :: x, eps
1096 real(wp),
intent(in) :: x
1108 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)
1110 type(scalar_field),
dimension(sys_size),
intent(inout) ::
q_cons_vf, q_cons_temp
1113 integer :: i,
j,
k,
l
1114 integer :: ix, iy, iz, x_id, y_id, z_id
1115 integer,
intent(inout) :: m_ds, n_ds, p_ds, m_glb_ds, n_glb_ds, p_glb_ds
1117 m_ds = int((m + 1)/3) - 1
1118 n_ds = int((n + 1)/3) - 1
1119 p_ds = int((p + 1)/3) - 1
1121 m_glb_ds = int((m_glb + 1)/3) - 1
1122 n_glb_ds = int((n_glb + 1)/3) - 1
1123 p_glb_ds = int((p_glb + 1)/3) - 1
1132 q_cons_temp(i)%sf(
j,
k,
l) = 0
1137 q_cons_temp(i)%sf(
j,
k,
l) = q_cons_temp(i)%sf(
j,
k, &
1138 &
l) + (1._wp/27._wp)*
q_cons_vf(i)%sf(x_id + ix, y_id + iy, z_id + iz)
1152 type(scalar_field),
intent(inout),
dimension(sys_size) ::
q_cons_vf, q_cons_temp
1153 integer :: i,
j,
k,
l
1154 integer :: ix, iy, iz
1155 integer :: x_id, y_id, z_id
1156 real(wp),
dimension(4) :: temp
1166 x_id =
j - int(3*ix) - 1
1167 y_id =
k - int(3*iy) - 1
1168 z_id =
l - int(3*iz) - 1
1170 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)
1171 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, &
1173 temp(3) = (2._wp/3._wp)*temp(1) + (1._wp/3._wp)*temp(2)
1175 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, &
1177 temp(2) = (2._wp/3._wp)*q_cons_temp(i)%sf(ix, iy + y_id, &
1178 & iz + z_id) + (1._wp/3._wp)*q_cons_temp(i)%sf(ix + x_id, iy + y_id, iz + z_id)
1179 temp(4) = (2._wp/3._wp)*temp(1) + (1._wp/3._wp)*temp(2)
1181 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.
Global parameters for the computational domain, fluid properties, and simulation algorithm configurat...
real(wp), dimension(:), allocatable weight
Simpson quadrature weights.
real(wp), dimension(:), allocatable r0
Bubble sizes.
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.
subroutine, public s_cross_product(a, b, c)
Computes the cross product c = a x b of two 3D vectors.
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)
This procedure swaps two real numbers.