Skip to content

Commit

Permalink
Merge branch 'development' into pwxy/erf_containers
Browse files Browse the repository at this point in the history
  • Loading branch information
AMLattanzi authored Jul 23, 2024
2 parents acf7d92 + 9a0ddab commit 49e941c
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 25 deletions.
50 changes: 27 additions & 23 deletions Exec/DevTests/ABL_perturbation_inflow/toc_inout_inputs
Original file line number Diff line number Diff line change
@@ -1,24 +1,28 @@
# ------------------ INPUTS TO MAIN PROGRAM -------------------
stop_time = 20.0
stop_time = 60.0
#max_step = 5

erf.no_substepping = 1
amrex.fpe_trap_invalid = 1
fabarray.mfiter_tile_size = 1024 1024 1024

# PROBLEM SIZE & GEOMETRY
geometry.prob_extent = 40 2.5 10
#geometry.prob_extent = 2. 0.25 1.
amr.n_cell = 128 16 64
#Larger problem
geometry.prob_extent = 40 5 10
amr.n_cell = 256 32 64

# Quick debug problem
#geometry.prob_extent = 20 5 10
#amr.n_cell = 64 16 32

geometry.is_periodic = 0 1 0

xlo.type = "Inflow"
xhi.type = "Outflow"
zhi.type = "SlipWall"
#zlo.type = "NoSlipWall"
zlo.type = "Most"

zlo.type = "Most"
erf.most.flux_type = "custom"
erf.most.ustar = 0.0395 # z=10.
#erf.most.ustar = 0.395 # z=1.0
Expand All @@ -27,17 +31,16 @@ erf.most.qstar = 0. # qv flux

xlo.density = 1.0
xlo.theta = 300.0
#xlo.velocity = 1.0 0.0 0.0
xlo.dirichlet_file = "input_ReTau395Ana_inflow.txt"

# TIME STEP CONTROL
erf.cfl = 0.4
erf.cfl = 0.5
erf.dynamicViscosity = 0.001
erf.use_gravity = true
erf.buoyancy_type = 2

# DIAGNOSTICS & VERBOSITY
erf.sum_interval = 0 # timesteps between computing mass
erf.pert_interval = 5 # timesteps between perturbation output message XXX
erf.sum_interval = 1 # timesteps between computing mass
erf.pert_interval = 1 # timesteps between perturbation output message XXX
erf.v = 0 # verbosity in ERF.cpp XXX
amr.v = 0 # verbosity in Amr.cpp

Expand All @@ -46,8 +49,8 @@ amr.max_level = 0 # maximum level number allowed

# PLOTFILES
erf.plot_file_1 = plt # prefix of plotfile name
#erf.plot_per_1 = 0.1
erf.plot_int_1 = 5
erf.plot_per_1 = 0.05
#erf.plot_int_1 = 5
erf.plot_vars_1 = density rhoadv_0 x_velocity y_velocity z_velocity pressure temp theta

# CHECKPOINT FILES
Expand All @@ -56,28 +59,29 @@ erf.plot_vars_1 = density rhoadv_0 x_velocity y_velocity z_velocity pressure

# SOLVER CHOICE
erf.alpha_T = 0.0
erf.alpha_C = 1.0

erf.alpha_C = 0.0
erf.molec_diff_type = "None"
erf.les_type = "Smagorinsky"
erf.Cs = 0.1

# Initial condition for the entire field
erf.init_type = "input_sounding"
erf.input_sounding_file = "input_ReTau395Ana_sounding.txt"
erf.use_gravity = true
erf.buoyancy_type = 2

# Turbulent inflow generation
erf.perturbation_type = "source"
erf.perturbation_direction = 1 0 0
erf.perturbation_layers = 3
erf.perturbation_offset = 3

erf.perturbation_box_dims = 4 8 8
erf.perturbation_box_dims = 8 8 4
erf.perturbation_nondimensional = 0.042 # Ri
erf.perturbation_T_infinity = 300.0
erf.perturbation_T_intensity = 0.05
erf.perturbation_T_intensity = 0.1

# Initial condition for the entire field
#erf.init_type = "uniform"
erf.init_type = "input_sounding"
erf.input_sounding_file = "input_ReTau395Ana_sounding.txt"

# PROBLEM PARAMETERS
#prob.U_0_Pert_Mag = 1.0
#prob.V_0_Pert_Mag = 1.0
#prob.W_0_Pert_Mag = 0.0
prob.rho_0 = 1.0
prob.T_0 = 300.0
4 changes: 3 additions & 1 deletion Source/DataStructs/TurbPertStruct.H
Original file line number Diff line number Diff line change
Expand Up @@ -447,7 +447,9 @@ struct TurbulentPerturbation {
amrex::Vector<amrex::Real> pb_mag; // BP mean magnitude [m/s]

// Perturbation amplitude cell storage
amrex::MultiFab pb_cell; // per cell storage of perturbation amplitude
// This is after random assignment of equation (10) in Ma and Senocak 2023
amrex::MultiFab pb_cell;


private:

Expand Down
4 changes: 3 additions & 1 deletion Source/Initialization/ERF_init_TurbPert.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -46,10 +46,12 @@ ERF::turbPert_amplitude (int lev)
// Initializing perturbation to zero
cons_pert.setVal(0.);

// Defining BoxArray type
auto m_ixtype = cons_pert.boxArray().ixType();

#ifdef _OPENMP
#pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
#endif
auto m_ixtype = cons_pert.boxArray().ixType();
for (MFIter mfi(lev_new[Vars::cons], TileNoZ()); mfi.isValid(); ++mfi) {
const Box &bx = mfi.validbox();
const auto &cons_pert_arr = cons_pert.array(mfi); // Address of perturbation array
Expand Down

0 comments on commit 49e941c

Please sign in to comment.