|
| 1 | +#!/usr/bin/env python3 |
| 2 | +"""Minimal 2D acoustic case with geometry 13 (2D modal Fourier shape). Additive form.""" |
| 3 | +import math |
| 4 | +import json |
| 5 | + |
| 6 | +Nx, Ny = 64, 64 |
| 7 | +Lx, Ly = 8.0, 8.0 |
| 8 | +dx = Lx / (Nx + 1) |
| 9 | +p_inf = 101325.0 |
| 10 | +rho_inf = 1.0 |
| 11 | +gam = 1.4 |
| 12 | +# Patch 2: same pressure, higher sound speed (different gas) -> lower density |
| 13 | +c_ratio = 1.5 |
| 14 | +rho2 = rho_inf / (c_ratio * c_ratio) |
| 15 | +c = math.sqrt(gam * p_inf / rho_inf) |
| 16 | +cfl = 0.3 |
| 17 | +mydt = cfl * dx / c |
| 18 | +Tfinal = 10.0 / c |
| 19 | +Nt = int(Tfinal / mydt) |
| 20 | + |
| 21 | +# Acoustic source (similar to 2D_acoustic_support5) |
| 22 | +t_cross = Lx / c # domain crossing time |
| 23 | +gauss_sigma_time = 0.03 * t_cross |
| 24 | +acoustic_delay = 0.15 * t_cross |
| 25 | +acoustic_loc_x = -3.5 |
| 26 | +acoustic_loc_y = 0.0 |
| 27 | +acoustic_aperture = 6.0 |
| 28 | +acoustic_foc_length = 3.5 |
| 29 | + |
| 30 | +config = { |
| 31 | + "run_time_info": "T", |
| 32 | + "x_domain%beg": -4.0, |
| 33 | + "x_domain%end": 4.0, |
| 34 | + "y_domain%beg": -4.0, |
| 35 | + "y_domain%end": 4.0, |
| 36 | + "m": Nx, |
| 37 | + "n": Ny, |
| 38 | + "p": 0, |
| 39 | + "dt": mydt, |
| 40 | + "t_step_start": 0, |
| 41 | + "t_step_stop": Nt, |
| 42 | + "t_step_save": max(1, int(Nt / 10)), |
| 43 | + "num_patches": 2, |
| 44 | + "model_eqns": 2, |
| 45 | + "alt_soundspeed": "F", |
| 46 | + "num_fluids": 2, |
| 47 | + "mpp_lim": "F", |
| 48 | + "mixture_err": "F", |
| 49 | + "time_stepper": 3, |
| 50 | + "weno_order": 5, |
| 51 | + "weno_eps": 1.0e-16, |
| 52 | + "mapped_weno": "T", |
| 53 | + "null_weights": "F", |
| 54 | + "mp_weno": "F", |
| 55 | + "riemann_solver": 2, |
| 56 | + "wave_speeds": 1, |
| 57 | + "avg_state": 2, |
| 58 | + "bc_x%beg": -8, |
| 59 | + "bc_x%end": -8, |
| 60 | + "bc_y%beg": -8, |
| 61 | + "bc_y%end": -8, |
| 62 | + "format": 1, |
| 63 | + "precision": 2, |
| 64 | + "prim_vars_wrt": "T", |
| 65 | + "parallel_io": "T", |
| 66 | + "omega_wrt(3)": "T", |
| 67 | + "fd_order": 2, |
| 68 | + "patch_icpp(1)%geometry": 3, |
| 69 | + "patch_icpp(1)%x_centroid": 0.0, |
| 70 | + "patch_icpp(1)%y_centroid": 0.0, |
| 71 | + "patch_icpp(1)%length_x": 8.0, |
| 72 | + "patch_icpp(1)%length_y": 8.0, |
| 73 | + "patch_icpp(1)%vel(1)": 0.0, |
| 74 | + "patch_icpp(1)%vel(2)": 0.0, |
| 75 | + "patch_icpp(1)%pres": p_inf, |
| 76 | + "patch_icpp(1)%alpha_rho(1)": rho_inf, |
| 77 | + "patch_icpp(1)%alpha_rho(2)": 0.0, |
| 78 | + "patch_icpp(1)%alpha(1)": 1.0, |
| 79 | + "patch_icpp(1)%alpha(2)": 0.0, |
| 80 | + "patch_icpp(2)%geometry": 13, |
| 81 | + "patch_icpp(2)%x_centroid": 0.0, |
| 82 | + "patch_icpp(2)%y_centroid": 0.0, |
| 83 | + "patch_icpp(2)%radius": 1.0, |
| 84 | + "patch_icpp(2)%fourier_cos(1)": 0.2, |
| 85 | + "patch_icpp(2)%fourier_sin(1)": 0.1, |
| 86 | + "patch_icpp(2)%fourier_sin(3)": -0.3, |
| 87 | + "patch_icpp(2)%fourier_cos(5)": 0.5, |
| 88 | + "patch_icpp(2)%modal_clip_r_to_min": "T", |
| 89 | + "patch_icpp(2)%modal_r_min": 0.5, |
| 90 | + "patch_icpp(2)%vel(1)": 0.0, |
| 91 | + "patch_icpp(2)%vel(2)": 0.0, |
| 92 | + "patch_icpp(2)%pres": p_inf, |
| 93 | + "patch_icpp(2)%alpha_rho(1)": 0.0, |
| 94 | + "patch_icpp(2)%alpha_rho(2)": rho2, |
| 95 | + "patch_icpp(2)%alpha(1)": 0.0, |
| 96 | + "patch_icpp(2)%alpha(2)": 1.0, |
| 97 | + "patch_icpp(2)%alter_patch(1)": "T", |
| 98 | + "bc_x%grcbc_in": "F", |
| 99 | + "bc_x%grcbc_out": "T", |
| 100 | + "bc_x%grcbc_vel_out": "F", |
| 101 | + "bc_x%pres_out": p_inf, |
| 102 | + "bc_y%grcbc_in": "F", |
| 103 | + "bc_y%grcbc_out": "T", |
| 104 | + "bc_y%grcbc_vel_out": "F", |
| 105 | + "bc_y%pres_out": p_inf, |
| 106 | + "fluid_pp(1)%gamma": 1.0 / (gam - 1.0), |
| 107 | + "fluid_pp(1)%pi_inf": 0.0, |
| 108 | + "fluid_pp(2)%gamma": 1.0 / (gam - 1.0), |
| 109 | + "fluid_pp(2)%pi_inf": 0.0, |
| 110 | + # Acoustic source (similar to 2D_acoustic_support5) |
| 111 | + "acoustic_source": "T", |
| 112 | + "num_source": 1, |
| 113 | + "acoustic(1)%support": 5, |
| 114 | + "acoustic(1)%loc(1)": acoustic_loc_x, |
| 115 | + "acoustic(1)%loc(2)": acoustic_loc_y, |
| 116 | + "acoustic(1)%pulse": 2, |
| 117 | + "acoustic(1)%npulse": 1, |
| 118 | + "acoustic(1)%mag": 1.0, |
| 119 | + "acoustic(1)%gauss_sigma_time": gauss_sigma_time, |
| 120 | + "acoustic(1)%foc_length": acoustic_foc_length, |
| 121 | + "acoustic(1)%aperture": acoustic_aperture, |
| 122 | + "acoustic(1)%delay": acoustic_delay, |
| 123 | +} |
| 124 | +print(json.dumps(config)) |
0 commit comments