|
| 1 | +import json |
| 2 | +import math |
| 3 | + |
| 4 | +# 2D shock wave interacting with a bed of 20 free-floating circular particles. |
| 5 | + |
| 6 | +gam_a = 1.4 |
| 7 | + |
| 8 | +# Shock parameters (Mach 1.5) |
| 9 | +mach_number = 1.5 |
| 10 | +pre_shock_pressure = 1 |
| 11 | +pre_shock_density = 1.4 |
| 12 | +pre_shock_speed = 0.0 |
| 13 | +post_shock_pressure = 2.4583 |
| 14 | +post_shock_density = 2.6069 |
| 15 | +post_shock_speed = 0.6944 |
| 16 | + |
| 17 | +domain_size = 4.0 |
| 18 | +wave_front = -1.5 |
| 19 | + |
| 20 | +total_time = 1.5 |
| 21 | +num_time_steps = 2000 |
| 22 | +dt = float(total_time / num_time_steps) |
| 23 | +num_saves = 100 |
| 24 | +steps_to_save = int(num_time_steps / num_saves) |
| 25 | + |
| 26 | +# Soft-sphere collision parameters (from 3D_mibm_sphere_head_on_collision) |
| 27 | +collision_time = 20.0 * dt |
| 28 | + |
| 29 | +# Particle bed parameters |
| 30 | +bed_x = 0.5 |
| 31 | +bed_y = 0.0 |
| 32 | +bed_lx = 2.0 |
| 33 | +bed_ly = 3.5 |
| 34 | +particle_radius = 0.15 |
| 35 | +particle_mass = 0.25 |
| 36 | +particle_min_spacing = 0.05 |
| 37 | + |
| 38 | +print( |
| 39 | + json.dumps( |
| 40 | + { |
| 41 | + # Logistics |
| 42 | + "run_time_info": "T", |
| 43 | + # Computational Domain Parameters |
| 44 | + "x_domain%beg": -domain_size * 0.5, |
| 45 | + "x_domain%end": domain_size * 0.5, |
| 46 | + "y_domain%beg": -domain_size * 0.5, |
| 47 | + "y_domain%end": domain_size * 0.5, |
| 48 | + "cyl_coord": "F", |
| 49 | + "m": 256, |
| 50 | + "n": 256, |
| 51 | + "p": 0, |
| 52 | + "dt": dt, |
| 53 | + "t_step_start": 0, |
| 54 | + "t_step_stop": num_time_steps, |
| 55 | + "t_step_save": steps_to_save, |
| 56 | + # Simulation Algorithm Parameters |
| 57 | + "num_patches": 2, |
| 58 | + "model_eqns": 2, |
| 59 | + "alt_soundspeed": "F", |
| 60 | + "num_fluids": 1, |
| 61 | + "mpp_lim": "F", |
| 62 | + "mixture_err": "T", |
| 63 | + "time_stepper": 3, |
| 64 | + "weno_order": 5, |
| 65 | + "weno_eps": 1.0e-16, |
| 66 | + "weno_Re_flux": "T", |
| 67 | + "weno_avg": "T", |
| 68 | + "avg_state": 2, |
| 69 | + "mapped_weno": "T", |
| 70 | + "null_weights": "F", |
| 71 | + "mp_weno": "T", |
| 72 | + "riemann_solver": 2, |
| 73 | + "wave_speeds": 1, |
| 74 | + "bc_x%beg": -17, |
| 75 | + "bc_x%end": -8, |
| 76 | + "bc_y%beg": -15, |
| 77 | + "bc_y%end": -15, |
| 78 | + # Immersed boundaries — all circles come from the particle bed |
| 79 | + "ib": "T", |
| 80 | + "num_ibs": 0, |
| 81 | + "viscous": "T", |
| 82 | + # Collision model (soft-sphere, from 3D_mibm_sphere_head_on_collision) |
| 83 | + "collision_model": 1, |
| 84 | + "coefficient_of_restitution": 0.9, |
| 85 | + "collision_time": collision_time, |
| 86 | + "ib_coefficient_of_friction": 0.1, |
| 87 | + # Particle bed: 20 free-floating circles placed randomly in region |
| 88 | + "num_particle_beds": 1, |
| 89 | + "particle_bed(1)%x_centroid": bed_x, |
| 90 | + "particle_bed(1)%y_centroid": bed_y, |
| 91 | + "particle_bed(1)%z_centroid": 0.0, |
| 92 | + "particle_bed(1)%length_x": bed_lx, |
| 93 | + "particle_bed(1)%length_y": bed_ly, |
| 94 | + "particle_bed(1)%length_z": 0.0, |
| 95 | + "particle_bed(1)%num_particles": 20, |
| 96 | + "particle_bed(1)%radius": particle_radius, |
| 97 | + "particle_bed(1)%mass": particle_mass, |
| 98 | + "particle_bed(1)%min_spacing": particle_min_spacing, |
| 99 | + "particle_bed(1)%moving_ibm": 2, |
| 100 | + "particle_bed(1)%seed": 42, |
| 101 | + # Output |
| 102 | + "format": 1, |
| 103 | + "precision": 2, |
| 104 | + "prim_vars_wrt": "T", |
| 105 | + "E_wrt": "T", |
| 106 | + "ib_state_wrt": "F", |
| 107 | + "parallel_io": "T", |
| 108 | + # IC Patch 1: post-shock region (left of wave front) |
| 109 | + "patch_icpp(1)%geometry": 3, |
| 110 | + "patch_icpp(1)%x_centroid": 0.5 * wave_front - 0.25 * domain_size, |
| 111 | + "patch_icpp(1)%y_centroid": 0.0, |
| 112 | + "patch_icpp(1)%length_x": 0.5 * domain_size + wave_front, |
| 113 | + "patch_icpp(1)%length_y": domain_size, |
| 114 | + "patch_icpp(1)%vel(1)": post_shock_speed, |
| 115 | + "patch_icpp(1)%vel(2)": 0.0, |
| 116 | + "patch_icpp(1)%pres": post_shock_pressure, |
| 117 | + "patch_icpp(1)%alpha_rho(1)": post_shock_density, |
| 118 | + "patch_icpp(1)%alpha(1)": 1.0, |
| 119 | + # IC Patch 2: pre-shock region (right of wave front) |
| 120 | + "patch_icpp(2)%geometry": 3, |
| 121 | + "patch_icpp(2)%x_centroid": 0.5 * wave_front + 0.25 * domain_size, |
| 122 | + "patch_icpp(2)%y_centroid": 0.0, |
| 123 | + "patch_icpp(2)%length_x": 0.5 * domain_size - wave_front, |
| 124 | + "patch_icpp(2)%length_y": domain_size, |
| 125 | + "patch_icpp(2)%vel(1)": pre_shock_speed, |
| 126 | + "patch_icpp(2)%vel(2)": 0.0, |
| 127 | + "patch_icpp(2)%pres": pre_shock_pressure, |
| 128 | + "patch_icpp(2)%alpha_rho(1)": pre_shock_density, |
| 129 | + "patch_icpp(2)%alpha(1)": 1.0, |
| 130 | + # Fluid properties: air |
| 131 | + "fluid_pp(1)%gamma": 1.0 / (gam_a - 1.0), |
| 132 | + "fluid_pp(1)%pi_inf": 0, |
| 133 | + "fluid_pp(1)%Re(1)": 2500000, |
| 134 | + } |
| 135 | + ) |
| 136 | +) |
0 commit comments