1# 1 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
6# 1 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp" 1
7# 1 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 1
8# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
9# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
10# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
11# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
12# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
13# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
15# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
16# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
17# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
19# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
21# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
23# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
25# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
27# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
29# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
31# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
33# 145 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
35# 2 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
36# 1 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp" 1
37# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
38# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
39# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
40# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
41# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
42# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
44# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
45# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
46# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
48# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
50# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
52# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
54# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
56# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
58# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
60# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
62# 145 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
64# 2 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp" 2
66# 4 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
67# 5 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
68# 6 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
69# 7 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
70# 8 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
72# 20 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
74# 43 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
76# 48 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
78# 53 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
80# 58 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
82# 63 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
84# 68 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
86# 76 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
88# 81 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
90# 86 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
92# 91 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
94# 96 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
96# 101 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
98# 106 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
100# 111 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
102# 116 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
104# 121 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
106# 151 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
108# 192 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
110# 206 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
112# 231 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
114# 242 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
116# 244 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
117# 255 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
119# 284 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
121# 294 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
123# 304 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
125# 313 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
127# 330 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
129# 340 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
131# 347 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
133# 353 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
135# 359 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
137# 365 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
139# 371 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
141# 377 "/home/runner/work/MFC/MFC/src/common/include/omp_macros.fpp"
143# 3 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
144# 1 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp" 1
145# 1 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp" 1
146# 2 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
147# 3 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
148# 4 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
149# 5 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
150# 6 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
152# 8 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
153# 9 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
154# 10 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
156# 17 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
158# 46 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
160# 58 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
162# 68 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
164# 98 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
166# 110 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
168# 120 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
170# 145 "/home/runner/work/MFC/MFC/src/common/include/shared_parallel_macros.fpp"
172# 2 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp" 2
174# 7 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
176# 17 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
178# 22 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
180# 27 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
182# 32 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
184# 37 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
186# 42 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
188# 47 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
190# 52 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
192# 57 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
194# 62 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
196# 73 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
198# 78 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
200# 83 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
202# 88 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
204# 103 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
206# 131 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
208# 160 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
210# 175 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
212# 193 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
214# 215 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
216# 244 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
218# 259 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
220# 269 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
222# 278 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
224# 294 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
226# 304 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
228# 311 "/home/runner/work/MFC/MFC/src/common/include/acc_macros.fpp"
230# 4 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp" 2
233# 23 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
236# 43 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
239# 55 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
242# 112 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
245# 130 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
248# 145 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
251# 164 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
254# 193 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
257# 207 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
260# 219 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
263# 231 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
266# 242 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
269# 254 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
272# 266 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
275# 275 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
278# 282 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
281# 289 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
284# 296 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
287# 303 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
289# 305 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
290# 306 "/home/runner/work/MFC/MFC/src/common/include/parallel_macros.fpp"
292# 2 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp" 2
294# 14 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
299# 57 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
302# 77 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
305# 85 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
308# 109 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
311# 125 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
314# 150 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
316# 156 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
318# 163 "/home/runner/work/MFC/MFC/src/common/include/macros.fpp"
320# 6 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp" 2
341 type(
ghost_point),
dimension(:),
intent(inout) :: gps
342 integer,
intent(in) :: num_gps
343 integer :: i, patch_id, patch_geometry
349# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
351# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
352#if defined(MFC_OpenACC)
353# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
355# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
356#elif defined(MFC_OpenMP)
357# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
359# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
361# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
363# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
365# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
367# 33 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
369# 35 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
371 patch_id = gps(i)%ib_patch_id
372 patch_geometry = patch_ib(patch_id)%geometry
374 if (patch_geometry == 8)
then
376 else if (patch_geometry == 9)
then
378 else if (patch_geometry == 10)
then
380 else if (patch_geometry == 11)
then
382 else if (patch_geometry == 12)
then
387# 51 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
388#if defined(MFC_OpenACC)
389# 51 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
391# 51 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
392#elif defined(MFC_OpenMP)
393# 51 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
395# 51 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
397# 51 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
403# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
405# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
406#if defined(MFC_OpenACC)
407# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
409# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
410#elif defined(MFC_OpenMP)
411# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
413# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
415# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
417# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
419# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
421# 55 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
423# 57 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
425 patch_id = gps(i)%ib_patch_id
426 patch_geometry = patch_ib(patch_id)%geometry
428 if (patch_geometry == 2)
then
430 else if (patch_geometry == 3)
then
432 else if (patch_geometry == 4)
then
434 else if (patch_geometry == 5)
then
436 else if (patch_geometry == 6)
then
441# 73 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
442#if defined(MFC_OpenACC)
443# 73 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
445# 73 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
446#elif defined(MFC_OpenMP)
447# 73 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
449# 73 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
451# 73 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
461# 81 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
463# 81 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
465# 81 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
467# 81 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
469# 81 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
471# 81 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
473# 81 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
477 real(wp) :: radius, dist
478 real(wp),
dimension(3) :: dist_vec
479 integer :: i, j, ib_patch_id
480 ib_patch_id = gp%ib_patch_id
484 radius = patch_ib(ib_patch_id)%radius
486 dist_vec(1) =
x_cc(i) - (patch_ib(ib_patch_id)%x_centroid + real(gp%x_periodicity, wp)*(
x_domain%end -
x_domain%beg))
487 dist_vec(2) =
y_cc(j) - (patch_ib(ib_patch_id)%y_centroid + real(gp%y_periodicity, wp)*(
y_domain%end -
y_domain%beg))
489 dist = sqrt(sum(dist_vec**2))
491 gp%levelset = dist - radius
493 gp%levelset_norm = 0._wp
495 gp%levelset_norm = dist_vec(:)/dist
504# 110 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
506# 110 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
508# 110 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
510# 110 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
512# 110 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
514# 110 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
516# 110 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
520 real(wp) :: dist, global_dist
521 integer :: global_id, airfoil_id, Np_local
522 real(wp),
dimension(3) :: dist_vec
523 real(wp),
dimension(1:3) :: xy_local, offset
524 real(wp),
dimension(1:2) :: center
525 real(wp),
dimension(1:3,1:3) :: rotation, inverse_rotation
526 integer :: i, j, k, ib_patch_id
527 ib_patch_id = gp%ib_patch_id
531 airfoil_id = patch_ib(ib_patch_id)%airfoil_id
533 center(1) = patch_ib(ib_patch_id)%x_centroid + real(gp%x_periodicity, wp)*(
x_domain%end -
x_domain%beg)
534 center(2) = patch_ib(ib_patch_id)%y_centroid + real(gp%y_periodicity, wp)*(
y_domain%end -
y_domain%beg)
535 inverse_rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix_inverse(:,:)
536 rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix(:,:)
537 offset(:) = patch_ib(ib_patch_id)%centroid_offset(:)
539 xy_local = [
x_cc(i) - center(1),
y_cc(j) - center(2), 0._wp]
540 xy_local = matmul(inverse_rotation, xy_local)
541 xy_local = xy_local - offset
543 if (xy_local(2) >= 0._wp)
then
549 dist = sqrt(sum(dist_vec**2))
554 if (dist < global_dist)
then
569 dist = sqrt(sum(dist_vec**2))
574 if (dist < global_dist)
then
588 gp%levelset_norm = 0._wp
590 gp%levelset_norm = matmul(rotation, dist_vec(:))/dist
599# 191 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
601# 191 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
603# 191 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
605# 191 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
607# 191 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
609# 191 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
611# 191 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
615 real(wp) :: dist_surf, dist_side, global_dist
616 integer :: global_id, airfoil_id, Np_local
617 real(wp) :: lz, z_max, z_min
618 real(wp),
dimension(3) :: dist_vec
619 real(wp),
dimension(1:3) :: xyz_local, center, offset, normal
620 real(wp),
dimension(1:3,1:3) :: rotation, inverse_rotation
621 integer :: i, j, k, l, ib_patch_id
622 ib_patch_id = gp%ib_patch_id
627 airfoil_id = patch_ib(ib_patch_id)%airfoil_id
629 center(1) = patch_ib(ib_patch_id)%x_centroid + real(gp%x_periodicity, wp)*(
x_domain%end -
x_domain%beg)
630 center(2) = patch_ib(ib_patch_id)%y_centroid + real(gp%y_periodicity, wp)*(
y_domain%end -
y_domain%beg)
631 center(3) = patch_ib(ib_patch_id)%z_centroid + real(gp%z_periodicity, wp)*(
z_domain%end -
z_domain%beg)
632 lz = patch_ib(ib_patch_id)%length_z
633 inverse_rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix_inverse(:,:)
634 rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix(:,:)
635 offset(:) = patch_ib(ib_patch_id)%centroid_offset(:)
641 xyz_local = matmul(inverse_rotation, xyz_local)
642 xyz_local = xyz_local - offset
644 if (xyz_local(2) >= 0._wp)
then
649 dist_surf = sqrt(sum(dist_vec**2))
651 global_dist = dist_surf
654 if (dist_surf < global_dist)
then
655 global_dist = dist_surf
660 dist_vec(1) =
ib_airfoil_grids(airfoil_id)%upper(global_id)%x - xyz_local(1)
661 dist_vec(2) =
ib_airfoil_grids(airfoil_id)%upper(global_id)%y - xyz_local(2)
663 dist_surf = global_dist
669 dist_surf = sqrt(sum(dist_vec**2))
671 global_dist = dist_surf
674 if (dist_surf < global_dist)
then
675 global_dist = dist_surf
680 dist_vec(1) =
ib_airfoil_grids(airfoil_id)%lower(global_id)%x - xyz_local(1)
681 dist_vec(2) =
ib_airfoil_grids(airfoil_id)%lower(global_id)%y - xyz_local(2)
683 dist_surf = global_dist
686 dist_side = min(abs(xyz_local(3) - z_min), abs(z_max - xyz_local(3)))
688 if (dist_side < dist_surf)
then
689 gp%levelset = dist_side
696 gp%levelset_norm = matmul(rotation, normal)
698 gp%levelset = dist_surf
700 gp%levelset_norm = 0._wp
702 gp%levelset_norm = matmul(rotation, dist_vec(:)/dist_surf)
712# 290 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
714# 290 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
716# 290 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
718# 290 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
720# 290 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
722# 290 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
724# 290 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
728 real(wp) :: top_right(2), bottom_left(2)
730 real(wp) :: side_dists(4)
731 real(wp) :: length_x, length_y
732 real(wp),
dimension(1:3) :: xy_local, dist_vec
733 real(wp),
dimension(2) :: center
734 real(wp),
dimension(1:3,1:3) :: rotation, inverse_rotation
737 integer :: ib_patch_id
738 ib_patch_id = gp%ib_patch_id
742 length_x = patch_ib(ib_patch_id)%length_x
743 length_y = patch_ib(ib_patch_id)%length_y
744 center(1) = patch_ib(ib_patch_id)%x_centroid + real(gp%x_periodicity, wp)*(
x_domain%end -
x_domain%beg)
745 center(2) = patch_ib(ib_patch_id)%y_centroid + real(gp%y_periodicity, wp)*(
y_domain%end -
y_domain%beg)
746 inverse_rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix_inverse(:,:)
747 rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix(:,:)
749 top_right(1) = length_x/2
750 top_right(2) = length_y/2
751 bottom_left(1) = -length_x/2
752 bottom_left(2) = -length_y/2
755 xy_local = [
x_cc(i) - center(1),
y_cc(j) - center(2), 0._wp]
756 xy_local = matmul(inverse_rotation, xy_local)
758 side_dists(1) = bottom_left(1) - xy_local(1)
759 side_dists(2) = top_right(1) - xy_local(1)
760 side_dists(3) = bottom_left(2) - xy_local(2)
761 side_dists(4) = top_right(2) - xy_local(2)
762 min_dist = side_dists(1)
766 if (abs(side_dists(k)) < abs(min_dist))
then
768 min_dist = side_dists(idx)
772 gp%levelset = side_dists(idx)
775 if (idx == 1 .or. idx == 2)
then
777 dist_vec(1) = side_dists(idx)/abs(side_dists(idx))
780 dist_vec(2) = side_dists(idx)/abs(side_dists(idx))
783 gp%levelset_norm = matmul(rotation, dist_vec)
785 gp%levelset_norm = 0._wp
794# 358 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
796# 358 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
798# 358 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
800# 358 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
802# 358 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
804# 358 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
806# 358 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
810 real(wp) :: ellipse_coeffs(2)
811 real(wp) :: quadratic_coeffs(3)
812 real(wp) :: length_x, length_y
813 real(wp),
dimension(1:3) :: xy_local, normal_vector
814 real(wp),
dimension(2) :: center
815 real(wp),
dimension(1:3,1:3) :: rotation, inverse_rotation
817 integer :: ib_patch_id
818 ib_patch_id = gp%ib_patch_id
822 length_x = patch_ib(ib_patch_id)%length_x
823 length_y = patch_ib(ib_patch_id)%length_y
824 center(1) = patch_ib(ib_patch_id)%x_centroid + real(gp%x_periodicity, wp)*(
x_domain%end -
x_domain%beg)
825 center(2) = patch_ib(ib_patch_id)%y_centroid + real(gp%y_periodicity, wp)*(
y_domain%end -
y_domain%beg)
826 inverse_rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix_inverse(:,:)
827 rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix(:,:)
829 ellipse_coeffs(1) = 0.5_wp*length_x
830 ellipse_coeffs(2) = 0.5_wp*length_y
832 xy_local = [
x_cc(i) - center(1),
y_cc(j) - center(2), 0._wp]
833 xy_local = matmul(inverse_rotation, xy_local)
835 normal_vector = xy_local
837 normal_vector(2) = normal_vector(2)*(ellipse_coeffs(1)/ellipse_coeffs(2))**2._wp
838 normal_vector = normal_vector/sqrt(dot_product(normal_vector, normal_vector))
839 gp%levelset_norm = matmul(rotation, normal_vector)
842 quadratic_coeffs(1) = (normal_vector(1)/ellipse_coeffs(1))**2 + (normal_vector(2)/ellipse_coeffs(2))**2
843 quadratic_coeffs(2) = 2._wp*((xy_local(1)*normal_vector(1)/(ellipse_coeffs(1)**2)) + (xy_local(2)*normal_vector(2) &
844 & /(ellipse_coeffs(2)**2)))
845 quadratic_coeffs(3) = (xy_local(1)/ellipse_coeffs(1))**2._wp + (xy_local(2)/ellipse_coeffs(2))**2._wp - 1._wp
848 gp%levelset = -0.5_wp*(-quadratic_coeffs(2) + sqrt(quadratic_coeffs(2)**2._wp - 4._wp*quadratic_coeffs(1) &
849 & *quadratic_coeffs(3)))/quadratic_coeffs(1)
857# 407 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
859# 407 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
861# 407 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
863# 407 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
865# 407 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
867# 407 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
869# 407 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
873 real(wp) :: Right, Left, Bottom, Top, Front, Back
875 real(wp) :: dist_left, dist_right, dist_bottom, dist_top, dist_back, dist_front
876 real(wp),
dimension(3) :: center
877 real(wp) :: length_x, length_y, length_z
878 real(wp),
dimension(1:3) :: xyz_local, dist_vec
879 real(wp),
dimension(1:3,1:3) :: rotation, inverse_rotation
881 integer :: ib_patch_id
882 ib_patch_id = gp%ib_patch_id
887 length_x = patch_ib(ib_patch_id)%length_x
888 length_y = patch_ib(ib_patch_id)%length_y
889 length_z = patch_ib(ib_patch_id)%length_z
891 center(1) = patch_ib(ib_patch_id)%x_centroid + real(gp%x_periodicity, wp)*(
x_domain%end -
x_domain%beg)
892 center(2) = patch_ib(ib_patch_id)%y_centroid + real(gp%y_periodicity, wp)*(
y_domain%end -
y_domain%beg)
893 center(3) = patch_ib(ib_patch_id)%z_centroid + real(gp%z_periodicity, wp)*(
z_domain%end -
z_domain%beg)
895 inverse_rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix_inverse(:,:)
896 rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix(:,:)
906 xyz_local = matmul(inverse_rotation, xyz_local)
908 dist_left = left - xyz_local(1)
909 dist_right = xyz_local(1) - right
910 dist_bottom = bottom - xyz_local(2)
911 dist_top = xyz_local(2) - top
912 dist_back = back - xyz_local(3)
913 dist_front = xyz_local(3) - front
915 min_dist = min(abs(dist_left), abs(dist_right), abs(dist_bottom), abs(dist_top), abs(dist_back), abs(dist_front))
919 gp%levelset = dist_left
921 dist_vec(1) = dist_left/abs(dist_left)
924 gp%levelset = dist_right
926 dist_vec(1) = -dist_right/abs(dist_right)
929 gp%levelset = dist_bottom
931 dist_vec(2) = dist_bottom/abs(dist_bottom)
934 gp%levelset = dist_top
936 dist_vec(2) = -dist_top/abs(dist_top)
939 gp%levelset = dist_back
941 dist_vec(3) = dist_back/abs(dist_back)
944 gp%levelset = dist_front
946 dist_vec(3) = -dist_front/abs(dist_front)
950 gp%levelset_norm = matmul(rotation, dist_vec)
958# 494 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
960# 494 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
962# 494 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
964# 494 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
966# 494 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
968# 494 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
970# 494 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
974 real(wp) :: radius, dist
975 real(wp),
dimension(3) :: dist_vec, center, periodicity
976 integer :: i, j, k, ib_patch_id
977 ib_patch_id = gp%ib_patch_id
982 radius = patch_ib(ib_patch_id)%radius
986 center(1) = patch_ib(ib_patch_id)%x_centroid
987 center(2) = patch_ib(ib_patch_id)%y_centroid
988 center(3) = patch_ib(ib_patch_id)%z_centroid
989 center = center + periodicity
991 dist_vec(1) =
x_cc(i) - center(1)
992 dist_vec(2) =
y_cc(j) - center(2)
993 dist_vec(3) =
z_cc(k) - center(3)
994 dist = sqrt(sum(dist_vec**2))
995 gp%levelset = dist - radius
997 gp%levelset_norm = (/1, 0, 0/)
999 gp%levelset_norm = dist_vec(:)/dist
1008# 530 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1010# 530 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1012# 530 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1014# 530 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1016# 530 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1018# 530 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1020# 530 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1025 real(wp),
dimension(3) :: dist_sides_vec, dist_surface_vec, length
1026 real(wp),
dimension(2) :: boundary
1027 real(wp) :: dist_side, dist_surface, side_pos
1029 integer :: ib_patch_id
1030 real(wp),
dimension(1:3) :: xyz_local, center
1031 real(wp),
dimension(1:3,1:3) :: rotation, inverse_rotation
1033 ib_patch_id = gp%ib_patch_id
1038 radius = patch_ib(ib_patch_id)%radius
1039 center(1) = patch_ib(ib_patch_id)%x_centroid + real(gp%x_periodicity, wp)*(
x_domain%end -
x_domain%beg)
1040 center(2) = patch_ib(ib_patch_id)%y_centroid + real(gp%y_periodicity, wp)*(
y_domain%end -
y_domain%beg)
1041 center(3) = patch_ib(ib_patch_id)%z_centroid + real(gp%z_periodicity, wp)*(
z_domain%end -
z_domain%beg)
1042 length(1) = patch_ib(ib_patch_id)%length_x
1043 length(2) = patch_ib(ib_patch_id)%length_y
1044 length(3) = patch_ib(ib_patch_id)%length_z
1046 inverse_rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix_inverse(:,:)
1047 rotation(:,:) = patch_ib(ib_patch_id)%rotation_matrix(:,:)
1050 boundary(1) = -0.5_wp*length(1)
1051 boundary(2) = 0.5_wp*length(1)
1052 dist_sides_vec = (/1, 0, 0/)
1053 dist_surface_vec = (/0, 1, 1/)
1055 boundary(1) = -0.5_wp*length(2)
1056 boundary(2) = 0.5_wp*length(2)
1057 dist_sides_vec = (/0, 1, 0/)
1058 dist_surface_vec = (/1, 0, 1/)
1060 boundary(1) = -0.5_wp*length(3)
1061 boundary(2) = 0.5_wp*length(3)
1062 dist_sides_vec = (/0, 0, 1/)
1063 dist_surface_vec = (/1, 1, 0/)
1067 xyz_local = matmul(inverse_rotation, xyz_local)
1070 side_pos = dot_product(xyz_local, dist_sides_vec)
1071 dist_side = min(abs(side_pos - boundary(1)), abs(boundary(2) - side_pos))
1073 dist_surface = norm2(xyz_local*dist_surface_vec) - radius
1075 if (dist_side < abs(dist_surface))
then
1077 gp%levelset = -dist_side
1079 gp%levelset_norm = matmul(rotation, -dist_sides_vec)
1081 gp%levelset_norm = matmul(rotation, dist_sides_vec)
1084 gp%levelset = dist_surface
1085 xyz_local = xyz_local*dist_surface_vec
1086 xyz_local = xyz_local/max(norm2(xyz_local), sgm_eps)
1087 gp%levelset_norm = matmul(rotation, xyz_local)
1096# 604 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1098# 604 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1100# 604 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1102# 604 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1104# 604 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1106# 604 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1108# 604 "/home/runner/work/MFC/MFC/src/simulation/m_compute_levelset.fpp"
1112 integer :: i, j, k, patch_id, boundary_edge_count
1113 real(wp),
dimension(1:3) :: center, xyz_local
1114 real(wp) :: normals(1:3)
1115 real(wp) :: distance
1116 real(wp),
dimension(1:3,1:3) :: inverse_rotation, rotation
1118 patch_id = gp%ib_patch_id
1127 if (.not.
f_is_default(patch_ib(patch_id)%x_centroid)) center(1) = patch_ib(patch_id)%x_centroid + real(gp%x_periodicity, &
1129 if (.not.
f_is_default(patch_ib(patch_id)%y_centroid)) center(2) = patch_ib(patch_id)%y_centroid + real(gp%y_periodicity, &
1132 if (.not.
f_is_default(patch_ib(patch_id)%z_centroid)) center(3) = patch_ib(patch_id)%z_centroid &
1136 inverse_rotation(:,:) = patch_ib(patch_id)%rotation_matrix_inverse(:,:)
1137 rotation(:,:) = patch_ib(patch_id)%rotation_matrix(:,:)
1140 xyz_local = (/
x_cc(i) - center(1),
y_cc(j) - center(2), 0._wp/)
1142 xyz_local(3) =
z_cc(k) - center(3)
1144 xyz_local = matmul(inverse_rotation, xyz_local)
1153 gp%levelset = distance
1154 gp%levelset = -abs(gp%levelset)
1157 gp%levelset_norm = matmul(rotation, normals(1:3))
1160 call s_distance_normals_2d(patch_ib(patch_id)%model_id, boundary_edge_count, xyz_local, normals, distance)
1161 gp%levelset = -abs(distance)
1162 gp%levelset_norm = matmul(rotation, normals(1:3))
Computes signed-distance level-set fields and surface normals for immersed-boundary patch geometries.
impure subroutine, public s_apply_levelset(gps, num_gps)
Dispatch level-set distance and normal computations for all ghost points based on patch geometry type...
subroutine s_airfoil_levelset(gp)
Compute the signed distance and outward normal from a ghost point to a 2D NACA airfoil surface.
subroutine s_sphere_levelset(gp)
Compute the signed distance and outward normal from a ghost point to a spherical immersed boundary.
subroutine s_circle_levelset(gp)
Compute the signed distance and outward normal from a ghost point to a circular immersed boundary.
subroutine s_ellipse_levelset(gp)
Compute the signed distance and outward normal from a ghost point to an elliptical immersed boundary.
subroutine s_cylinder_levelset(gp)
Compute the signed distance and outward normal from a ghost point to a cylindrical immersed boundary.
subroutine s_3d_airfoil_levelset(gp)
Compute the signed distance and outward normal from a ghost point to a 3D extruded airfoil surface.
subroutine s_rectangle_levelset(gp)
Subroutine for computing the levelset values at a ghost point belonging to the rectangle IB.
subroutine s_model_levelset(gp)
The STL patch is a 2/3D geometry that is imported from an STL file.
subroutine s_cuboid_levelset(gp)
Compute the signed distance and outward normal from a ghost point to a cuboid immersed boundary.
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...
type(bounds_info) z_domain
type(bounds_info) x_domain
real(wp), dimension(:), allocatable, target y_cc
type(bounds_info) y_domain
real(wp), dimension(:), allocatable, target z_cc
real(wp), dimension(:), allocatable, target x_cc
type(ib_airfoil_grid), dimension(num_ib_airfoils_max) ib_airfoil_grids
Per-airfoil computed surface grids.
Basic floating-point utilities: approximate equality, default detection, and coordinate bounds.
logical elemental function, public f_approx_equal(a, b, tol_input)
Check if two floating point numbers of wp are within tolerance.
logical elemental function, public f_is_default(var)
Checks if a real(wp) variable is of default value.
Allocate memory and read initial condition data for IC extrusion.
Binary STL file reader and processor for immersed boundary geometry.
subroutine, public s_distance_normals_2d(pid, boundary_edge_count, point, normals, distance)
Determine the levelset distance and normals of 2D models by computing the exact closest point via pro...
integer, dimension(:), allocatable, public gpu_ntrs
GPU-friendly flat arrays for STL model data.
subroutine, public s_distance_normals_3d(ntrs, pid, point, normals, distance)
Determine the levelset distance and normals of 3D models by computing the exact closest point via pro...
integer, dimension(:), allocatable, public gpu_boundary_edge_count
MPI halo exchange, domain decomposition, and buffer packing/unpacking for the simulation solver.
Ghost Point for Immersed Boundaries.