Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

"ODE" quantities and user defined external sources #427

Merged
merged 49 commits into from
Oct 22, 2024
Merged
Show file tree
Hide file tree
Changes from 34 commits
Commits
Show all changes
49 commits
Select commit Hold shift + click to select a range
ac193c4
Initial commit. Needs debugging for source terms.
dmontgomeryNREL Sep 30, 2024
96e4df1
Merge branch 'AMReX-Combustion:development' into spatiallyInvariantAu…
dmontgomeryNREL Sep 30, 2024
f790c8d
Added ode_var to typical values. Still debugging initialization and s…
dmontgomeryNREL Oct 1, 2024
27eff1f
Minor edit in set_ode_names function.
dmontgomeryNREL Oct 1, 2024
7badae1
Fixed misalignment in plotting. IC's appear to be correct now for mul…
dmontgomeryNREL Oct 1, 2024
9376aa9
Fix indexing.
dmontgomeryNREL Oct 7, 2024
0751a38
Updated problem_modify_ext_sources. Works with local case definition.
dmontgomeryNREL Oct 8, 2024
d6256db
Comment arguments in problem_modify_ext_sources in Source code.
dmontgomeryNREL Oct 8, 2024
e65ff24
Added compilation variable USE_MODIFIED_SOURCES to avoid unnecessary …
dmontgomeryNREL Oct 8, 2024
dd1d46d
Tested plotting for Efield and Spray. Tested all args of ProblemSpec…
dmontgomeryNREL Oct 8, 2024
2637025
Added ode_srcstrength to test case, fixed minor bugs.
dmontgomeryNREL Oct 11, 2024
59c987a
Changed flag for user defined external sources. Added future flag fo…
dmontgomeryNREL Oct 11, 2024
2ee8c70
Set peleLM.user_defined_ext_sources to true in input file.
dmontgomeryNREL Oct 11, 2024
561e4a8
Added Euler step for advancing the ODE quantities in time.
dmontgomeryNREL Oct 11, 2024
c286ee4
Changed name of advanceODEQty() to predictODEQty() for consistency wi…
dmontgomeryNREL Oct 11, 2024
d1d088d
Updated input.2d for validation
dmontgomeryNREL Oct 14, 2024
905d6b3
Added .cpp file for ProblemSpecificFunctions to avoid need for static…
dmontgomeryNREL Oct 14, 2024
283b8b1
Added convergence test for ODE Qty.
dmontgomeryNREL Oct 15, 2024
d433041
Updated the test case to include 3 odes with increasing stiffness.
dmontgomeryNREL Oct 15, 2024
dd7efa4
Renamed case
dmontgomeryNREL Oct 15, 2024
65e35ff
Combined all external forces in single function call to clean up Pele…
dmontgomeryNREL Oct 15, 2024
8f447ff
Update README for case.
dmontgomeryNREL Oct 15, 2024
e24675d
Update README for case.
dmontgomeryNREL Oct 15, 2024
bd21d5a
Update README.md
dmontgomeryNREL Oct 15, 2024
a07cd3b
Merge branch 'AMReX-Combustion:development' into odeQty
dmontgomeryNREL Oct 15, 2024
5700778
Removed NUM_AUX for now.
dmontgomeryNREL Oct 15, 2024
afb0aa7
Cleaning up
dmontgomeryNREL Oct 15, 2024
91d4b66
Documentation for ode quantities.
dmontgomeryNREL Oct 15, 2024
c1a94cc
Clang-format
dmontgomeryNREL Oct 15, 2024
9a9de0a
Remove validation tests from case directory.
dmontgomeryNREL Oct 15, 2024
064562d
Minor fix for soot and spray
dmontgomeryNREL Oct 15, 2024
ab2f6e2
Spelling and unused variable handling.
dmontgomeryNREL Oct 15, 2024
c401965
Unused variable handling
dmontgomeryNREL Oct 16, 2024
d998f5e
Formatting
dmontgomeryNREL Oct 16, 2024
44e6c4a
Removed unwanted print statements, renamed some files/vars for consis…
dmontgomeryNREL Oct 16, 2024
838ca88
Added case to CI
dmontgomeryNREL Oct 16, 2024
88ca2d0
Add USE_EB to EB_ODEQty/CmakeLists.txt
dmontgomeryNREL Oct 17, 2024
afbc707
Add EB_ODEQty to RegTests/CMakeLists.txt
dmontgomeryNREL Oct 17, 2024
fcdd8f3
CI fix
dmontgomeryNREL Oct 17, 2024
e070e3d
More CI
dmontgomeryNREL Oct 17, 2024
9707476
Add ODEQty.cpp to cmake
dmontgomeryNREL Oct 17, 2024
9728a0f
More CI...
dmontgomeryNREL Oct 17, 2024
b0f9f35
Only define predictODEQty if NUM_ODE > 0
dmontgomeryNREL Oct 17, 2024
3e32ab3
Updated CMake to handle user defined EB's and ProblemSpecificFunctions
dmontgomeryNREL Oct 18, 2024
19279b1
Now passes in MultiFabs for state_old and state_new. This provides ac…
dmontgomeryNREL Oct 21, 2024
897bb41
Update PeleLMeX_ProblemSpecificFunctions.cpp
dmontgomeryNREL Oct 21, 2024
3452ff5
Removed lev argument in problem_modify_ext_sources
dmontgomeryNREL Oct 22, 2024
27c4bed
Update comment
dmontgomeryNREL Oct 22, 2024
beeb8da
Merge branch 'development' into odeQty
baperry2 Oct 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions CMake/BuildPeleExe.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,8 @@ function(build_pele_exe pele_exe_name pele_physics_lib_name)
${SRC_DIR}/PeleLMeX_PatchFlowVariables.cpp
${SRC_DIR}/PeleLMeX_Init.cpp
${SRC_DIR}/PeleLMeX_Plot.cpp
${SRC_DIR}/PeleLMeX_ProblemSpecificFunctions.H
${SRC_DIR}/PeleLMeX_ProblemSpecificFunctions.cpp
${SRC_DIR}/PeleLMeX_Projection.cpp
${SRC_DIR}/PeleLMeX_Reactions.cpp
${SRC_DIR}/PeleLMeX_Regrid.cpp
Expand Down
2 changes: 2 additions & 0 deletions Docs/sphinx/manual/LMeXControls.rst
Original file line number Diff line number Diff line change
Expand Up @@ -269,6 +269,8 @@ PeleLMeX algorithm
peleLM.spark1.radius = 1e-3 # [OPT] Radius of the spark [m]
peleLM.spark1.duration = 1e-3 # [OPT] Duration of the spark [s]
peleLM.spark1.time = 1e-2 # [OPT] Time when spark starts [s]

peleLM.user_defined_ext_sources = 0 # [OPT, DEF=0] Enable user defined source terms. Requires local ProblemSpecificFunctions.cpp.


Transport coefficients and LES
Expand Down
6 changes: 6 additions & 0 deletions Docs/sphinx/manual/Model.rst
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,12 @@ For the standard ideal gas EOS, the divergence constraint on velocity becomes:
\nabla \cdot \boldsymbol{u} &= \frac{1}{\rho c_p T} \left(\nabla \cdot \lambda\nabla T - \sum_m \boldsymbol{\Gamma_m} \cdot \nabla h_m \right) \\
&- \frac{1}{\rho} \sum_m \frac{W}{W_m} \nabla \cdot \boldsymbol{\Gamma_m} + \frac{1}{\rho}\sum_m \left(\frac{W}{W_m} - \frac{h_m}{c_p T} \right) \dot \omega \equiv S .

In addition to the flow equations, `PeleLMeX` can also solve for a set of quantities that are neither advected nor diffused, satisfying:

.. math::

\frac{\partial B_k}{\partial t} = S_{\text{ext},B_k}.
baperry2 marked this conversation as resolved.
Show resolved Hide resolved

Confined domain ambient pressure
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Expand Down
4 changes: 4 additions & 0 deletions Exec/Make.PeleLMeX
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,10 @@ ifeq ($(USE_RADIATION), TRUE)
DEFINES += -DPELE_USE_RADIATION
endif

ifeq ($(shell test 0$(NUM_ODE) -gt 0; echo $$?), 0)
DEFINES += -DNUM_ODE=$(NUM_ODE)
endif

Bpack += $(foreach dir, $(LMdirs), $(PELE_HOME)/$(dir)/Make.package)
Blocs += $(foreach dir, $(LMdirs), $(PELE_HOME)/$(dir))

Expand Down
8 changes: 8 additions & 0 deletions Exec/RegTests/EB_ODEQty/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
set(PELE_PHYSICS_EOS_MODEL Fuego)
set(PELE_PHYSICS_CHEMISTRY_MODEL air)
set(PELE_PHYSICS_TRANSPORT_MODEL Constant)
set(PELE_PHYSICS_ENABLE_SPRAY OFF)
set(PELE_PHYSICS_SPRAY_FUEL_NUM 0)
set(PELE_PHYSICS_ENABLE_SOOT OFF)
set(PELE_PHYSICS_ENABLE_RADIATION OFF)
include(BuildExeAndLib)
39 changes: 39 additions & 0 deletions Exec/RegTests/EB_ODEQty/GNUmakefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
# AMReX
DIM = 2
COMP = gnu
PRECISION = DOUBLE
USE_EB = TRUE
USE_HYPRE = FALSE

# Profiling
PROFILE = FALSE
TINY_PROFILE = FALSE
COMM_PROFILE = FALSE
TRACE_PROFILE = FALSE
MEM_PROFILE = FALSE
USE_GPROF = FALSE

# Performance
USE_MPI = TRUE
USE_OMP = FALSE
USE_CUDA = FALSE
USE_HIP = FALSE
USE_SYCL = FALSE

# Debugging
DEBUG = FALSE
FSANITIZER = FALSE
THREAD_SANITIZER = FALSE

# PeleLMeX
CEXE_headers += EBUserDefined.H
CEXE_sources += PeleLMeX_ProblemSpecificFunctions.cpp
NUM_ODE = 3

# PelePhysics
Chemistry_Model = air
Eos_Model = Fuego
Transport_Model = Constant

PELE_HOME ?= ../../..
include $(PELE_HOME)/Exec/Make.PeleLMeX
58 changes: 58 additions & 0 deletions Exec/RegTests/EB_ODEQty/PeleLMeX_EBUserDefined.H
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#ifndef EBUSERDEFINED_H
#define EBUSERDEFINED_H

using namespace amrex;

#ifdef AMREX_USE_EB
#include <AMReX_EB2.H>
#include <AMReX_EB2_IF.H>
void
EBUserDefined(
const Geometry& /*geom*/,
const int /*required_coarsening_level*/,
const int /*max_coarsening_level*/)
{
// ParmParse your geometry parameters

// Build geometry pieces using EB2::* methods

// Build your geometry shop using EB2::makeShop

// Build geom using EB2::Build

// We shoulnd't be here, copy this file in your run folder
// and implement your geometry
Abort("In default EBUserDefined function! Shouldn't be here. Copy and edit "
"this file for your needs");
}

AMREX_GPU_DEVICE
AMREX_FORCE_INLINE
void
setEBState(
const amrex::Real xEBface[AMREX_SPACEDIM],
amrex::Real s_ext[NVAR],
const amrex::Real /*time*/,
amrex::GeometryData const& /*geomdata*/,
ProbParm const& /*prob_parm*/)
{
if (xEBface[1] > 0.02) {
s_ext[TEMP] = 500.0;
} else {
s_ext[TEMP] = 300.0;
}
}

AMREX_GPU_DEVICE
AMREX_FORCE_INLINE
void
setEBType(
const amrex::Real* /*xEBface[AMREX_SPACEDIM]*/,
amrex::Real& EBflagType,
amrex::GeometryData const& /*geomdata*/,
ProbParm const& /*prob_parm*/)
{
EBflagType = 1.0;
}
#endif
#endif
56 changes: 56 additions & 0 deletions Exec/RegTests/EB_ODEQty/PeleLMeX_ProblemSpecificFunctions.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
#include <PeleLMeX.H>
#include <PeleLMeX_K.H>
#include <PeleLMeX_ProblemSpecificFunctions.H>

using namespace amrex;

/*
Problem specific functions:
- This file must be copied locally to the case directory
- Add the following to GNUmakefile:
CEXE_sources += PeleLMeX_ProblemSpecificFunctions.cpp
- Modify as needed
*/

#if NUM_ODE > 0
void
set_ode_names(Vector<std::string>& a_ode_names)
{
a_ode_names.resize(NUM_ODE);
for (int n = 0; n < NUM_ODE; n++) {
a_ode_names[n] = "MY_ODE_" + std::to_string(n);
}
}
#endif

void
problem_modify_ext_sources(
Real /*time*/,
Real /*dt*/,
int lev,
MultiArray4<const Real> const& state_old_arr,
MultiArray4<const Real> const& /*state_new_arr*/,
Vector<std::unique_ptr<MultiFab>>& a_extSource,
const GeometryData& geomdata,
ProbParm const& prob_parm)
{
/*
Notes:
1) a_extSource contains sources from velocity forcing coming in.
This function should add to rather than overwrite a_extSource.
2) Requires "peleLM.user_defined_ext_sources = true" in input file
*/

auto ext_source_arr = a_extSource[lev]->arrays();

ParallelFor(
*a_extSource[lev],
[=] AMREX_GPU_DEVICE(int box_no, int i, int j, int k) noexcept {
for (int n = 0; n < NUM_ODE; n++) {
Real B_n = state_old_arr[box_no](i, j, k, FIRSTODE + n);
Real src = prob_parm.ode_srcstrength * pow(10.0, n + 1) * B_n;
ext_source_arr[box_no](i, j, k, FIRSTODE + n) += src;
}
});
Gpu::streamSynchronize();
}
2 changes: 2 additions & 0 deletions Exec/RegTests/EB_ODEQty/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
## EB\_ODEQty
A 2D inflow/outflow setup with an optional EB cylinder in the middle of the flow. Demonstrates how to use ProblemSpecificFunctions and the ODE quantities. The ODE quantities experience simple exponential decay that gets stiffer for each quantity. Specifically, $\frac{\partial B_k}{\partial t} = \gamma \cdot 10^{k+1} B_k$, for $k = 0, 1,\dots,$ NUM_ODE and $\gamma < 0$.
75 changes: 75 additions & 0 deletions Exec/RegTests/EB_ODEQty/input.2d
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
#----------------------DOMAIN DEFINITION-------------------------
geometry.is_periodic = 0 1 # For each dir, 0: non-perio, 1: periodic
geometry.coord_sys = 0 # 0 => cart, 1 => RZ
geometry.prob_lo = -0.02 -0.02 # x_lo y_lo (z_lo)
geometry.prob_hi = 0.10 0.02 # x_hi y_hi (z_hi)

#--------------------------BC FLAGS------------------------------
# Interior, Inflow, Outflow, Symmetry,
# SlipWallAdiab, NoSlipWallAdiab, SlipWallIsotherm, NoSlipWallIsotherm
peleLM.lo_bc = Inflow Interior
peleLM.hi_bc = Outflow Interior

#-------------------------AMR CONTROL----------------------------
amr.n_cell = 96 32 # Level 0 number of cells in each direction
amr.v = 1 # AMR verbose
amr.max_level = 0 # maximum level number allowed
amr.ref_ratio = 2 2 2 2 # refinement ratio
amr.regrid_int = 5 # how often to regrid
amr.n_error_buf = 2 2 2 2 # number of buffer cells in error est
amr.grid_eff = 0.7 # what constitutes an efficient grid
amr.blocking_factor = 16 # block factor in grid generation (min box size)
amr.max_grid_size = 64 # max box size

#--------------------------- Problem ----------------------------
prob.T_mean = 300.0
prob.P_mean = 101325.0
prob.meanFlowMag = 4.255
prob.meanFlowDir = 1
prob.ode_IC = 10.0
prob.ode_xy_lo = -0.01
prob.ode_length = 0.01
prob.ode_height = 0.02
prob.ode_srcstrength = -10.0

#-----------------INPUTS TO CONSTANT TRANSPORT ------------------
transport.units = MKS
transport.const_viscosity = 0.0001
transport.const_bulk_viscosity = 0.0
transport.const_conductivity = 0.0
transport.const_diffusivity = 0.0

#---------------------------TIME STEPPING------------------------
#amr.max_step = 1
amr.stop_time = 0.02
amr.dt_shrink = 0.1
amr.dt_change_max = 1.1
amr.fixed_dt = 0.0001

#-------------------------PELE CONTROLS----------------------
peleLM.v = 1
peleLM.user_defined_ext_sources = 1

#---------------------------IO CONTROL---------------------------
#amr.restart = chk_07136
amr.check_file = "chk_"
amr.check_per = -1
amr.plot_file = "plt_"
amr.plot_per = 0.001
amr.derive_plot_vars = avg_pressure mag_vort

#------------------------- EB SETUP -----------------------------
eb2.geom_type = sphere
eb2.sphere_radius = 0.005
eb2.sphere_center = 0.03 0.0
eb2.sphere_has_fluid_inside = 0
eb2.small_volfrac = 1.0e-4

#--------------------REFINEMENT CONTROL--------------------------
amr.refinement_indicators = VortL VortH
amr.VortL.max_level = 1
amr.VortL.value_less = -1000
amr.VortL.field_name = mag_vort
amr.VortH.max_level = 1
amr.VortH.value_greater = 1000
amr.VortH.field_name = mag_vort
Loading
Loading