1#ifndef ICNS_ADVECTION_H
2#define ICNS_ADVECTION_H
9#include "AMReX_MultiFabUtil.H"
10#include "hydro_MacProjector.H"
12#include "hydro_utils.H"
15#include "AMReX_REAL.H"
17using namespace amrex::literals;
25 amrex::Vector<amrex::Array<const amrex::MultiFab*, ICNS::ndim>>;
44 amrex::Array<amrex::MultiFab*, ICNS::ndim>& ,
55 const amrex::Vector<amrex::Array<amrex::MultiFab*, AMREX_SPACEDIM>>&
61#ifdef AMR_WIND_USE_FFT
62 std::unique_ptr<Hydro::FFTMacProjector> m_fft_mac_proj;
84 bool variable_density,
88 ,
u_mac(fields_in.repo.get_field(
"u_mac"))
89 ,
v_mac(fields_in.repo.get_field(
"v_mac"))
90 ,
w_mac(fields_in.repo.get_field(
"w_mac"))
93 sim.physics_manager(),
100 amrex::ParmParse pp(
"incflo");
103 if (pp.contains(
"use_ppm") || pp.contains(
"use_limiter")) {
105 "Godunov: use_ppm and use_limiter are deprecated. Please "
106 "update input file");
113 }
else if (amrex::toLower(
godunov_type) ==
"ppm_nolim") {
115 amrex::Print() <<
"WARNING: Using advection type ppm_nolim is not "
116 "recommended. Prefer using weno_z."
131 "Invalid godunov_type specified. For godunov_type select "
132 "between plm, ppm, ppm_nolim, bds, weno_js, and weno_z. If no "
133 "godunov_type is specified, the default weno_z is used.");
140 }
else if (amrex::toLower(
mflux_type) ==
"upwind") {
143 amrex::Abort(
"Invalid argument entered for mflux_type.");
148 pp.query(
"icns_conserv",
m_cons);
154 amrex::ParmParse pp_eq(
"ICNS");
160 const FieldState fstate,
const amrex::Real dt,
const amrex::Real time)
163 const auto& repo =
fields.repo;
164 const auto& geom = repo.mesh().Geom();
166 const auto& src_term =
fields.src_term;
167 const auto& dof_field =
fields.field.state(fstate);
168 auto bcrec_device = dof_field.bcrec_device();
179 const bool godunov_use_ppm =
184 limiter_type = PPM::NoLimiter;
186 limiter_type = PPM::WENOZ;
188 limiter_type = PPM::WENO_JS;
190 limiter_type = PPM::default_limiter;
195 const amrex::Real dt_extrap =
197 for (
int lev = 0; lev < repo.num_active_levels(); ++lev) {
198 HydroUtils::ExtrapVelToFaces(
199 dof_field(lev), src_term(lev),
u_mac(lev),
v_mac(lev),
200 w_mac(lev), dof_field.bcrec(), bcrec_device.data(),
201 repo.mesh().Geom(lev), dt_extrap, godunov_use_ppm,
206 amrex::Abort(
"Invalid godunov scheme");
221 amrex::Array<Field*, AMREX_SPACEDIM> mac_vel = {
223 dof_field.fillpatch_sibling_fields(time,
u_mac.num_grow(), mac_vel);
226 for (
int lev = 0; lev < repo.num_active_levels(); ++lev) {
227 u_mac(lev).FillBoundary(geom[lev].periodicity());
228 v_mac(lev).FillBoundary(geom[lev].periodicity());
229 w_mac(lev).FillBoundary(geom[lev].periodicity());
239 const auto& repo =
fields.repo;
240 const auto& geom = repo.mesh().Geom();
242 const auto& src_term =
fields.src_term;
244 auto& conv_term =
fields.conv_term;
245 const auto& dof_field =
fields.field.state(fstate);
263 const auto& rho_nph =
266 const bool mphase_vof = repo.field_exists(
"vof");
271 for (
int lev = 0; lev < repo.num_active_levels(); ++lev) {
275 dof_field(lev).boxArray(), dof_field(lev).DistributionMap(),
277 amrex::MultiFab::Copy(
281 src_term(lev).boxArray(), src_term(lev).DistributionMap(),
283 amrex::MultiFab::Copy(
286 amrex::MultiFab q_nph(
287 dof_field(lev).boxArray(), dof_field(lev).DistributionMap(),
289 amrex::MultiFab::Copy(
296 for (
int idim = 0; idim < dof_field.num_comp(); ++idim) {
297 amrex::MultiFab::Multiply(
300 amrex::MultiFab::Multiply(
303 amrex::MultiFab::Multiply(
304 q_nph, rho_nph(lev), 0, idim, 1,
309 amrex::MFItInfo mfi_info;
310 if (amrex::Gpu::notInLaunchRegion()) {
311 mfi_info.EnableTiling(amrex::IntVect(1024, 1024, 1024))
320 const bool is_velocity =
true;
321 const bool known_edge_state =
false;
322 const bool godunov_use_ppm =
329 limiter_type = PPM::NoLimiter;
331 limiter_type = PPM::WENOZ;
333 limiter_type = PPM::WENO_JS;
335 limiter_type = PPM::default_limiter;
340 const amrex::Real dt_extrap =
343#pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
345 for (amrex::MFIter mfi(dof_field(lev), mfi_info); mfi.isValid();
347 const auto& bx = mfi.tilebox();
348 amrex::FArrayBox tmpfab(
349 amrex::grow(bx, 1), 1, amrex::The_Async_Arena());
350 tmpfab.setVal<amrex::RunOn::Device>(0.0_rt);
351 const auto& divu = tmpfab.array();
352 HydroUtils::ComputeFluxesOnBoxFromState(
354 q_nph.const_array(mfi), (*flux_x)(lev).array(mfi),
355 (*flux_y)(lev).array(mfi), (*flux_z)(lev).array(mfi),
356 (*face_x)(lev).array(mfi), (*face_y)(lev).array(mfi),
357 (*face_z)(lev).array(mfi), known_edge_state,
358 u_mac(lev).const_array(mfi),
359 v_mac(lev).const_array(mfi),
360 w_mac(lev).const_array(mfi), divu, fq.const_array(mfi),
361 geom[lev], dt_extrap, dof_field.bcrec(),
362 dof_field.bcrec_device().data(),
iconserv.data(),
369 amrex::Abort(
"Invalid godunov scheme");
378 dof_field, dof_nph, src_term, rho_o, rho_nph,
u_mac,
v_mac,
379 w_mac, dof_field.bcrec(), dof_field.bcrec_device().data(),
380 rho_o.bcrec(), rho_o.bcrec_device().data(), dt,
mflux_scheme,
384 amrex::Vector<amrex::Array<amrex::MultiFab*, AMREX_SPACEDIM>> fluxes(
385 repo.num_active_levels());
386 for (
int lev = 0; lev < repo.num_active_levels(); ++lev) {
387 fluxes[lev][0] = &(*flux_x)(lev);
388 fluxes[lev][1] = &(*flux_y)(lev);
389 fluxes[lev][2] = &(*flux_z)(lev);
394 for (
int lev = repo.num_active_levels() - 1; lev > 0; --lev) {
396 geom[lev].Domain().size() / geom[lev - 1].Domain().size();
397 amrex::average_down_faces(
398 GetArrOfConstPtrs(fluxes[lev]), fluxes[lev - 1], rr,
402 for (
int lev = 0; lev < repo.num_active_levels(); ++lev) {
405#pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
407 for (amrex::MFIter mfi(dof_field(lev), amrex::TilingIfNotGPU());
408 mfi.isValid(); ++mfi) {
409 const auto& bx = mfi.tilebox();
411 HydroUtils::ComputeDivergence(
412 bx, conv_term(lev).array(mfi), (*flux_x)(lev).array(mfi),
413 (*flux_y)(lev).array(mfi), (*flux_z)(lev).array(mfi),
414 ICNS::ndim, geom[lev],
static_cast<amrex::Real
>(-1.0_rt),
418 amrex::FArrayBox div_umac(bx, 1, amrex::The_Async_Arena());
419 auto const& divum_arr = div_umac.array();
420 HydroUtils::ComputeDivergence(
421 bx, divum_arr,
u_mac(lev).const_array(mfi),
422 v_mac(lev).const_array(mfi),
423 w_mac(lev).const_array(mfi), 1, geom[lev],
424 static_cast<amrex::Real
>(1.0_rt),
false);
425 HydroUtils::ComputeConvectiveTerm(
426 bx,
ICNS::ndim, mfi, dof_field(lev).const_array(mfi),
427 (*face_x)(lev).const_array(mfi),
428 (*face_y)(lev).const_array(mfi),
429 (*face_z)(lev).const_array(mfi), divum_arr,
430 conv_term(lev).array(mfi),
iconserv.data(),
468 bool variable_density,
472 ,
u_mac(fields_in.repo.get_field(
"u_mac"))
473 ,
v_mac(fields_in.repo.get_field(
"v_mac"))
474 ,
w_mac(fields_in.repo.get_field(
"w_mac"))
478 sim.physics_manager(),
487 const amrex::Real dt,
491 const auto& repo =
fields.repo;
492 auto& dof_field =
fields.field.state(fstate);
497 dof_field.to_stretched_space();
504 for (
int lev = 0; lev < repo.num_active_levels(); ++lev) {
505 MOL::ExtrapVelToFaces(
507 repo.mesh().Geom(lev), dof_field.bcrec(),
508 dof_field.bcrec_device().data());
517 const auto& repo =
fields.repo;
518 const auto& geom = repo.mesh().Geom();
520 auto& conv_term =
fields.conv_term.state(fstate);
521 const auto& dof_field =
fields.field.state(fstate);
522 const auto& rho = repo.get_field(
"density").state(fstate);
528 int nmaxcomp = AMREX_SPACEDIM;
529 for (
int lev = 0; lev < repo.num_active_levels(); ++lev) {
531 amrex::MFItInfo mfi_info;
534 if (amrex::Gpu::notInLaunchRegion()) {
535 mfi_info.EnableTiling(amrex::IntVect(1024, 1024, 1024))
539#pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
541 for (amrex::MFIter mfi(dof_field(lev), mfi_info); mfi.isValid();
543 amrex::Box
const& bx = mfi.tilebox();
547 amrex::FArrayBox qfab(
549 const auto& q = qfab.array();
551 auto rho_arr = rho(lev).const_array(mfi);
552 auto vel_arr = dof_field(lev).const_array(mfi);
555 [=] AMREX_GPU_DEVICE(
int i,
int j,
int k,
int n)
noexcept {
556 q(i, j, k, n) = rho_arr(i, j, k) * vel_arr(i, j, k, n);
562 amrex::Box tmpbox = amrex::surroundingNodes(bx);
563 const int tmpcomp = nmaxcomp * AMREX_SPACEDIM;
565 amrex::FArrayBox tmpfab(
566 tmpbox, tmpcomp, amrex::The_Async_Arena());
568 amrex::Array4<amrex::Real> fx = tmpfab.array(0);
569 amrex::Array4<amrex::Real> fy = tmpfab.array(nmaxcomp);
570 amrex::Array4<amrex::Real> fz = tmpfab.array(nmaxcomp * 2);
573 lev, bx, AMREX_SPACEDIM, fx, fy, fz, q,
574 u_mac(lev).const_array(mfi),
v_mac(lev).const_array(mfi),
575 w_mac(lev).const_array(mfi), dof_field.bcrec().data(),
576 dof_field.bcrec_device().data(), geom);
579 bx, AMREX_SPACEDIM, conv_term(lev).array(mfi), fx, fy, fz,
580 geom[lev].InvCellSizeArray());
Definition FieldRepo.H:86
Definition icns_advection.H:22
MacProjOp(FieldRepo &, PhysicsMgr &, bool, bool, bool, bool)
Definition icns_advection.cpp:43
amrex::Real rho0() const
Definition icns_advection.H:48
bool m_need_init
Definition icns_advection.H:67
void operator()(const FieldState fstate, const amrex::Real dt)
Definition icns_advection.cpp:208
bool m_mesh_mapping
Definition icns_advection.H:69
void set_inflow_velocity(amrex::Real time)
Definition icns_advection.cpp:156
amrex::Real m_rho_0
Definition icns_advection.H:71
void enforce_inout_solvability(const amrex::Vector< amrex::Array< amrex::MultiFab *, AMREX_SPACEDIM > > &a_umac) noexcept
Definition icns_advection.cpp:68
MLMGOptions m_options
Definition icns_advection.H:65
std::unique_ptr< Hydro::MacProjector > m_mac_proj
Definition icns_advection.H:60
amrex::Vector< amrex::Array< const amrex::MultiFab *, ICNS::ndim > > FaceFabPtrVec
Definition icns_advection.H:24
bool m_is_anelastic
Definition icns_advection.H:70
bool m_has_overset
Definition icns_advection.H:66
FieldRepo & m_repo
Definition icns_advection.H:58
PhysicsMgr & m_phy_mgr
Definition icns_advection.H:59
void init_projector(const FaceFabPtrVec &) noexcept
Definition icns_advection.cpp:79
bool m_variable_density
Definition icns_advection.H:68
static void mac_proj_to_uniform_space(const amr_wind::FieldRepo &, amr_wind::Field &, amr_wind::Field &, amr_wind::Field &, amrex::Array< amrex::MultiFab *, ICNS::ndim > &, amrex::Real, int) noexcept
Definition icns_advection.cpp:378
FieldState
Definition FieldDescTypes.H:14
@ ZFACE
Face-centered in z-direction.
Definition FieldDescTypes.H:32
@ XFACE
Face-centered in x-direction (e.g., face normal velocity)
Definition FieldDescTypes.H:30
@ YFACE
Face-centered in y-direction.
Definition FieldDescTypes.H:31
@ NPH
State at (n + 1/2) (intermediate) timestep.
Definition FieldDescTypes.H:18
@ Old
Same as FieldState::N.
Definition FieldDescTypes.H:21
amrex::Array< amrex::Real, 24 > PrintMaxMACVelLocations(const amr_wind::FieldRepo &repo, const std::string &header)
Definition diagnostics.cpp:434
Definition SchemeTraits.H:6
static void hybrid_fluxes(const FieldRepo &repo, const int ncomp, const amrex::Gpu::DeviceVector< int > &iconserv, ScratchField &flux_x, ScratchField &flux_y, ScratchField &flux_z, const Field &dof_field, const Field &dof_nph, const Field &src_term, const Field &rho_o, const Field &rho_nph, const Field &u_mac, const Field &v_mac, const Field &w_mac, amrex::Vector< amrex::BCRec > const &velbc, amrex::BCRec const *velbc_d, amrex::Vector< amrex::BCRec > const &rhobc, amrex::BCRec const *rhobc_d, const amrex::Real dt, godunov::scheme mflux_scheme, bool allow_inflow_on_outflow, bool use_forces_in_trans, bool pre_multiplied_src_term=false)
Definition vof_momentum_flux.H:11
Definition AdvOp_Godunov.H:21
scheme
Definition Godunov.H:11
@ BDS
Definition Godunov.H:11
@ PPM
Definition Godunov.H:11
@ UPWIND
Definition Godunov.H:11
@ PLM
Definition Godunov.H:11
@ WENO_JS
Definition Godunov.H:11
@ MINMOD
Definition Godunov.H:11
@ PPM_NOLIM
Definition Godunov.H:11
@ WENOZ
Definition Godunov.H:11
void compute_convective_rate(amrex::Box const &bx, int ncomp, amrex::Array4< amrex::Real > const &dUdt, amrex::Array4< amrex::Real const > const &fx, amrex::Array4< amrex::Real const > const &fy, amrex::Array4< amrex::Real const > const &fz, amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > dxi)
Definition incflo_mol_fluxes.cpp:9
void compute_convective_fluxes(int lev, amrex::Box const &bx, int ncomp, amrex::Array4< amrex::Real > const &fx, amrex::Array4< amrex::Real > const &fy, amrex::Array4< amrex::Real > const &fz, amrex::Array4< amrex::Real const > const &q, amrex::Array4< amrex::Real const > const &umac, amrex::Array4< amrex::Real const > const &vmac, amrex::Array4< amrex::Real const > const &wmac, amrex::BCRec const *h_bcrec, amrex::BCRec const *d_bcrec, amrex::Vector< amrex::Geometry > geom)
Definition incflo_mol_fluxes.cpp:29
Definition MLMGOptions.H:27
static constexpr int nghost_state
Number of ghost in the state variable.
Definition SchemeTraits.H:19
static constexpr int nghost_src
Number of ghost cells in the source term variable.
Definition SchemeTraits.H:21
static constexpr int nghost_state
Number of ghost cells in the state variable.
Definition SchemeTraits.H:41
MacProjOp m_macproj_op
Definition icns_advection.H:442
godunov::scheme mflux_scheme
Definition icns_advection.H:446
Field & w_mac
Definition icns_advection.H:440
int m_verbose
Definition icns_advection.H:452
godunov::scheme godunov_scheme
Definition icns_advection.H:445
std::string postmac_advection_type
Definition icns_advection.H:455
AdvectionOp(CFDSim &sim, PDEFields &fields_in, bool has_overset, bool variable_density, bool mesh_mapping, bool is_anelastic)
Definition icns_advection.H:80
void preadvect(const FieldState fstate, const amrex::Real dt, const amrex::Real time)
Definition icns_advection.H:159
int m_cons
Definition icns_advection.H:451
std::string mflux_type
Definition icns_advection.H:448
const bool fluxes_are_area_weighted
Definition icns_advection.H:449
bool m_allow_inflow_on_outflow
Definition icns_advection.H:453
void operator()(const FieldState fstate, const amrex::Real dt)
Definition icns_advection.H:237
bool godunov_use_forces_in_trans
Definition icns_advection.H:450
std::string godunov_type
Definition icns_advection.H:447
Field & u_mac
Definition icns_advection.H:438
std::string premac_advection_type
Definition icns_advection.H:454
amrex::Gpu::DeviceVector< int > iconserv
Definition icns_advection.H:443
PDEFields & fields
Definition icns_advection.H:437
Field & v_mac
Definition icns_advection.H:439
bool m_mesh_mapping
Definition icns_advection.H:590
Field & u_mac
Definition icns_advection.H:586
void preadvect(const FieldState fstate, const amrex::Real dt, const amrex::Real)
Definition icns_advection.H:485
Field & v_mac
Definition icns_advection.H:587
AdvectionOp(CFDSim &sim, PDEFields &fields_in, bool has_overset, bool variable_density, bool mesh_mapping, bool is_anelastic)
Definition icns_advection.H:464
Field & w_mac
Definition icns_advection.H:588
PDEFields & fields
Definition icns_advection.H:585
MacProjOp m_macproj_op
Definition icns_advection.H:592
void operator()(const FieldState fstate, const amrex::Real)
Definition icns_advection.H:514
static constexpr int ndim
Definition icns.H:40
Definition PDEFields.H:27