1 #ifndef ERF_MOSTAverage_H
2 #define ERF_MOSTAverage_H
5 #include "AMReX_FArrayBox.H"
6 #include "AMReX_MultiFab.H"
7 #include "AMReX_iMultiFab.H"
8 #include "AMReX_ParmParse.H"
18 const bool& has_zphys,
19 std::string a_pp_prefix,
22 const amrex::Vector<const eb_*>& eb_vec = {});
43 const
amrex::Vector<
amrex::MultiFab*>& vars_old,
44 std::unique_ptr<
amrex::MultiFab>& Theta_prim,
45 std::unique_ptr<
amrex::MultiFab>& Qv_prim,
46 std::unique_ptr<
amrex::MultiFab>& Qr_prim,
47 std::unique_ptr<
amrex::MultiFab>& z_phys_nd);
52 amrex::Vector<std::unique_ptr<
amrex::MultiFab>>& Theta_prim,
53 amrex::Vector<std::unique_ptr<
amrex::MultiFab>>& Qv_prim,
54 amrex::Vector<std::unique_ptr<
amrex::MultiFab>>& Qr_prim);
113 [[nodiscard]]
const amrex::MultiFab*
get_average (
const int& lev,
const int& comp)
const {
return m_averages[lev][comp].get(); }
116 [[nodiscard]] amrex::MultiFab*
get_zref (
const int& lev)
const {
return m_zref[lev].get(); }
133 AMREX_GPU_HOST_DEVICE AMREX_INLINE
138 amrex::Array4<amrex::Real const>
const& interp_array,
139 amrex::Array4<amrex::Real const>
const& z_arr,
140 const amrex::GpuArray<amrex::Real, AMREX_SPACEDIM>& plo,
141 const amrex::GpuArray<amrex::Real, AMREX_SPACEDIM>& dxi,
142 const int interp_comp)
146 int kmax = ubound(z_arr).z;
153 int i_new = (int) (ireal -
myhalf);
154 int j_new = (int) (jreal -
myhalf);
156 for (
int lk(0); lk<kmax; ++lk) {
157 amrex::Real z_lo =
fourth * ( z_arr(i_new,j_new ,lk ) + z_arr(i_new+1,j_new ,lk )
158 + z_arr(i_new,j_new+1,lk ) + z_arr(i_new+1,j_new+1,lk ) );
159 amrex::Real z_hi =
fourth * ( z_arr(i_new,j_new ,lk+1) + z_arr(i_new+1,j_new ,lk+1)
160 + z_arr(i_new,j_new+1,lk+1) + z_arr(i_new+1,j_new+1,lk+1) );
161 if (z_target > z_lo && z_target < z_hi){
168 amrex::ignore_unused(found);
169 AMREX_ALWAYS_ASSERT_WITH_MESSAGE(found,
"MOSTAverage: Height above terrain not found, try increasing z_ref!");
172 const amrex::RealVect lx(ireal +
myhalf, jreal +
myhalf, zval);
174 const amrex::IntVect ijk = lx.floor();
176 int i = ijk[0];
int j = ijk[1];
int k = ijk[2];
179 amrex::RealVect ijk_r(
static_cast<amrex::Real>(ijk[0]),
184 const amrex::RealVect sx_hi = lx - ijk_r;
185 const amrex::RealVect sx_lo =
one - sx_hi;
187 for (
int n = 0; n < interp_comp; n++) {
188 interp_vals[n] = sx_lo[0]*sx_lo[1]*sx_lo[2]*interp_array(i-1, j-1, k-1,n) +
189 sx_lo[0]*sx_lo[1]*sx_hi[2]*interp_array(i-1, j-1, k ,n) +
190 sx_lo[0]*sx_hi[1]*sx_lo[2]*interp_array(i-1, j , k-1,n) +
191 sx_lo[0]*sx_hi[1]*sx_hi[2]*interp_array(i-1, j , k ,n) +
192 sx_hi[0]*sx_lo[1]*sx_lo[2]*interp_array(i , j-1, k-1,n) +
193 sx_hi[0]*sx_lo[1]*sx_hi[2]*interp_array(i , j-1, k ,n) +
194 sx_hi[0]*sx_hi[1]*sx_lo[2]*interp_array(i , j , k-1,n) +
195 sx_hi[0]*sx_hi[1]*sx_hi[2]*interp_array(i , j , k ,n);
203 const amrex::Vector<amrex::Geometry>
m_geom;
204 amrex::Vector<amrex::Vector<amrex::MultiFab*>>
m_fields;
217 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
m_zref;
218 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
m_x_pos;
219 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
m_y_pos;
220 amrex::Vector<std::unique_ptr<amrex::MultiFab>>
m_z_pos;
221 amrex::Vector<std::unique_ptr<amrex::iMultiFab>>
m_i_indx;
222 amrex::Vector<std::unique_ptr<amrex::iMultiFab>>
m_j_indx;
223 amrex::Vector<std::unique_ptr<amrex::iMultiFab>>
m_k_indx;
224 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
m_averages;
225 amrex::Vector<amrex::Vector<std::unique_ptr<amrex::MultiFab>>>
m_rot_fields;
constexpr amrex::Real one
Definition: ERF_Constants.H:7
constexpr amrex::Real fourth
Definition: ERF_Constants.H:12
constexpr amrex::Real zero
Definition: ERF_Constants.H:6
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:11
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_MOSTAverage.H:15
int m_navg
Definition: ERF_MOSTAverage.H:213
bool m_t_avg
Definition: ERF_MOSTAverage.H:250
void write_xz_positions(const int &lev, const int &j)
Definition: ERF_MOSTAverage.cpp:1997
void compute_plane_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:929
int m_policy
Definition: ERF_MOSTAverage.H:215
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > m_averages
Definition: ERF_MOSTAverage.H:224
amrex::Vector< std::unique_ptr< amrex::MultiFab > > m_y_pos
Definition: ERF_MOSTAverage.H:219
int m_radius
Definition: ERF_MOSTAverage.H:234
void set_z_positions_EB(const int &lev)
Definition: ERF_MOSTAverage.cpp:558
void write_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:2039
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > m_i_indx
Definition: ERF_MOSTAverage.H:221
void compute_region_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:1228
amrex::Vector< amrex::MultiFab * > m_z_phys_nd
Definition: ERF_MOSTAverage.H:205
amrex::Vector< int > m_t_init
Definition: ERF_MOSTAverage.H:251
void compute_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:900
void set_rotated_fields(const int &lev)
Definition: ERF_MOSTAverage.cpp:298
amrex::Vector< amrex::Vector< amrex::Real > > m_total_bndry_area
Definition: ERF_MOSTAverage.H:246
void set_region_normalization(const int &)
Definition: ERF_MOSTAverage.H:66
void set_z_positions_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:748
amrex::Vector< std::unique_ptr< amrex::MultiFab > > m_x_pos
Definition: ERF_MOSTAverage.H:218
void set_norm_positions_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:811
amrex::Vector< amrex::Real > m_Vsg
Definition: ERF_MOSTAverage.H:258
void set_k_indices_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:580
amrex::Vector< amrex::Vector< std::unique_ptr< amrex::MultiFab > > > m_rot_fields
Definition: ERF_MOSTAverage.H:225
bool m_rotate
Definition: ERF_MOSTAverage.H:216
amrex::MultiFab * get_zref(const int &lev) const
Definition: ERF_MOSTAverage.H:116
amrex::Vector< amrex::Vector< amrex::Real > > m_plane_average
Definition: ERF_MOSTAverage.H:230
amrex::Vector< std::unique_ptr< amrex::MultiFab > > m_z_pos
Definition: ERF_MOSTAverage.H:220
amrex::Vector< amrex::Vector< int > > m_ncell_plane
Definition: ERF_MOSTAverage.H:229
void set_plane_normalization(const int &lev)
Definition: ERF_MOSTAverage.cpp:357
void write_k_indices(const int &lev)
Definition: ERF_MOSTAverage.cpp:1893
TerrainType m_terrain_type
Definition: ERF_MOSTAverage.H:208
std::string m_pp_prefix
Definition: ERF_MOSTAverage.H:206
bool m_norm_vec
Definition: ERF_MOSTAverage.H:241
int m_nvar
Definition: ERF_MOSTAverage.H:212
amrex::Real m_fact_new
Definition: ERF_MOSTAverage.H:253
const amrex::iMultiFab * get_k_indices(const int &lev) const
Definition: ERF_MOSTAverage.H:119
int m_ncell_region
Definition: ERF_MOSTAverage.H:235
void set_norm_indices_T(const int &lev)
Definition: ERF_MOSTAverage.cpp:660
amrex::Vector< std::unique_ptr< amrex::MultiFab > > m_zref
Definition: ERF_MOSTAverage.H:217
int m_maxlev
Definition: ERF_MOSTAverage.H:214
const amrex::MultiFab * get_average(const int &lev, const int &comp) const
Definition: ERF_MOSTAverage.H:113
void set_eb_normalization(const int &lev)
Definition: ERF_MOSTAverage.cpp:414
bool include_subgrid_vel
Definition: ERF_MOSTAverage.H:257
void update_field_ptrs(const int &lev, amrex::Vector< amrex::Vector< amrex::MultiFab >> &vars_old, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Theta_prim, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Qv_prim, amrex::Vector< std::unique_ptr< amrex::MultiFab >> &Qr_prim)
Definition: ERF_MOSTAverage.cpp:279
~MOSTAverage()
Definition: ERF_MOSTAverage.H:25
MOSTAverage(amrex::Vector< amrex::Geometry > geom, const bool &has_zphys, std::string a_pp_prefix, const MeshType &m_mesh_type, const TerrainType &m_terrain_type, const amrex::Vector< const eb_ * > &eb_vec={})
amrex::Real m_time_window
Definition: ERF_MOSTAverage.H:252
MeshType m_mesh_type
Definition: ERF_MOSTAverage.H:207
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > m_j_indx
Definition: ERF_MOSTAverage.H:222
void set_k_indices_N(const int &lev)
Definition: ERF_MOSTAverage.cpp:502
void make_MOSTAverage_at_level(const int &lev, const amrex::Vector< amrex::MultiFab * > &vars_old, std::unique_ptr< amrex::MultiFab > &Theta_prim, std::unique_ptr< amrex::MultiFab > &Qv_prim, std::unique_ptr< amrex::MultiFab > &Qr_prim, std::unique_ptr< amrex::MultiFab > &z_phys_nd)
Definition: ERF_MOSTAverage.cpp:90
MOSTAverage(MOSTAverage &&) noexcept=default
void write_norm_indices(const int &lev)
Definition: ERF_MOSTAverage.cpp:1940
amrex::Vector< amrex::Vector< amrex::MultiFab * > > m_fields
Definition: ERF_MOSTAverage.H:204
amrex::Vector< int > m_k_in
Definition: ERF_MOSTAverage.H:236
amrex::Vector< const eb_ * > m_eb_vec
Definition: ERF_MOSTAverage.H:245
const amrex::Real zref_default
Definition: ERF_MOSTAverage.H:262
amrex::Real m_fact_old
Definition: ERF_MOSTAverage.H:253
bool m_interp
Definition: ERF_MOSTAverage.H:240
const amrex::Vector< amrex::Geometry > m_geom
Definition: ERF_MOSTAverage.H:203
AMREX_GPU_HOST_DEVICE static AMREX_INLINE void trilinear_interp_T(const amrex::Real &xp, const amrex::Real &yp, const amrex::Real &zp, amrex::Real *interp_vals, amrex::Array4< amrex::Real const > const &interp_array, amrex::Array4< amrex::Real const > const &z_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &plo, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dxi, const int interp_comp)
Definition: ERF_MOSTAverage.H:134
void compute_eb_averages(const int &lev)
Definition: ERF_MOSTAverage.cpp:1605
amrex::Vector< std::unique_ptr< amrex::iMultiFab > > m_k_indx
Definition: ERF_MOSTAverage.H:223
Definition: ERF_ConsoleIO.cpp:12