Function to compute average over local region.
982 const auto & geom =
m_geom[lev];
994 Real d_fact_new, d_fact_old;
1014 for (
int imf(0); imf < 4; ++imf) {
1017 if (!fields[imf])
continue;
1020 #pragma omp parallel if (Gpu::notInLaunchRegion())
1022 for (MFIter mfi(*fields[imf],
TileNoZ()); mfi.isValid(); ++mfi) {
1023 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1025 auto mf_arr = (
m_rotate) ? rot_fields[imf]->const_array(mfi) :
1026 fields[imf]->const_array(mfi);
1027 auto ma_arr = averages[imf]->array(mfi);
1030 const auto plo = geom.ProbLoArray();
1031 const auto dx = geom.CellSizeArray();
1032 const auto dxInv = geom.InvCellSizeArray();
1033 const auto z_phys_arr = z_phys->const_array(mfi);
1034 auto x_pos_arr = x_pos->array(mfi);
1035 auto y_pos_arr = y_pos->array(mfi);
1036 auto z_pos_arr = z_pos->array(mfi);
1037 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1039 ma_arr(i,j,k) *= d_fact_old;
1042 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1043 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1044 for (
int li(-d_radius); li <= (d_radius); ++li) {
1046 Real xp = x_pos_arr(i+li,j+lj,k);
1047 Real yp = y_pos_arr(i+li,j+lj,k);
1048 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1050 Real val = denom * interp * d_fact_new;
1051 ma_arr(i,j,k) += val;
1057 auto k_arr = k_indx->const_array(mfi);
1058 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1059 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1060 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1062 ma_arr(i,j,k) *= d_fact_old;
1064 int mk = k_arr(i,j,k);
1065 int mj = j_arr ? j_arr(i,j,k) : j;
1066 int mi = i_arr ? i_arr(i,j,k) : i;
1067 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1068 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1069 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1070 Real val = denom * mf_arr(li, lj, lk) * d_fact_new;
1071 ma_arr(i,j,k) += val;
1081 averages[imf]->FillBoundary(geom.periodicity());
1095 #pragma omp parallel if (Gpu::notInLaunchRegion())
1097 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1098 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1100 const Array4<Real const>& T_mf_arr = fields[2]->const_array(mfi);
1101 const Array4<Real const>& qv_mf_arr = (fields[3])? fields[3]->const_array(mfi) : Array4<const Real>{};
1102 const Array4<Real const>& qr_mf_arr = (fields[4])? fields[4]->const_array(mfi) : Array4<const Real>{};
1103 auto ma_arr = averages[iavg]->array(mfi);
1106 const auto plo = geom.ProbLoArray();
1107 const auto dx = geom.CellSizeArray();
1108 const auto dxInv = geom.InvCellSizeArray();
1109 const auto z_phys_arr = z_phys->const_array(mfi);
1110 auto x_pos_arr = x_pos->array(mfi);
1111 auto y_pos_arr = y_pos->array(mfi);
1112 auto z_pos_arr = z_pos->array(mfi);
1113 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1115 ma_arr(i,j,k) *= d_fact_old;
1118 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1119 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1120 for (
int li(-d_radius); li <= (d_radius); ++li) {
1123 Real xp = x_pos_arr(i+li,j+lj,k);
1124 Real yp = y_pos_arr(i+li,j+lj,k);
1125 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1133 &qr_interp, qr_mf_arr, z_phys_arr, plo, dxInv, 1);
1134 vfac = 1.0 + 0.61*qv_interp - qr_interp;
1136 vfac = 1.0 + 0.61*qv_interp;
1138 const Real mag = T_interp * vfac;
1139 const Real val = denom * mag * d_fact_new;
1140 ma_arr(i,j,k) += val;
1146 auto k_arr = k_indx->const_array(mfi);
1147 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1148 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1149 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1151 ma_arr(i,j,k) *= d_fact_old;
1153 int mk = k_arr(i,j,k);
1154 int mj = j_arr ? j_arr(i,j,k) : j;
1155 int mi = i_arr ? i_arr(i,j,k) : i;
1156 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1157 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1158 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1162 vfac = 1.0 + 0.61*qv_mf_arr(li,lj,lk) - qr_mf_arr(li,lj,lk);
1164 vfac = 1.0 + 0.61*qv_mf_arr(li,lj,lk);
1166 const Real mag = T_mf_arr(li,lj,lk) * vfac;
1167 const Real val = denom * mag * d_fact_new;
1168 ma_arr(i,j,k) += val;
1178 averages[iavg]->FillBoundary(geom.periodicity());
1184 IntVect ng = averages[iavg]->nGrowVect();
1185 MultiFab::Copy(*(averages[iavg]),*(averages[2]),0,0,1,ng);
1197 const Real Vsg =
m_Vsg[lev];
1200 #pragma omp parallel if (Gpu::notInLaunchRegion())
1202 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1203 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1205 auto u_mf_arr = (
m_rotate) ? rot_fields[imf ]->const_array(mfi) :
1206 fields[imf ]->const_array(mfi);
1207 auto v_mf_arr = (
m_rotate) ? rot_fields[imf+1]->const_array(mfi) :
1208 fields[imf+1]->const_array(mfi);
1209 auto ma_arr = averages[iavg]->array(mfi);
1212 const auto plo = geom.ProbLoArray();
1213 const auto dx = geom.CellSizeArray();
1214 const auto dxInv = geom.InvCellSizeArray();
1215 const auto z_phys_arr = z_phys->const_array(mfi);
1216 auto x_pos_arr = x_pos->array(mfi);
1217 auto y_pos_arr = y_pos->array(mfi);
1218 auto z_pos_arr = z_pos->array(mfi);
1219 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1221 ma_arr(i,j,k) *= d_fact_old;
1224 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1225 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1226 for (
int li(-d_radius); li <= (d_radius); ++li) {
1229 Real xp = x_pos_arr(i+li,j+lj,k);
1230 Real yp = y_pos_arr(i+li,j+lj,k);
1231 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1234 const Real mag = std::sqrt(u_interp*u_interp + v_interp*v_interp + Vsg*Vsg);
1235 Real val = denom * mag * d_fact_new;
1236 ma_arr(i,j,k) += val;
1242 auto k_arr = k_indx->const_array(mfi);
1243 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1244 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1245 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1247 ma_arr(i,j,k) *= d_fact_old;
1249 int mk = k_arr(i,j,k);
1250 int mj = j_arr ? j_arr(i,j,k) : j;
1251 int mi = i_arr ? i_arr(i,j,k) : i;
1252 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1253 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1254 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1255 const Real u_val = 0.5 * (u_mf_arr(li,lj,lk) + u_mf_arr(li+1,lj ,lk));
1256 const Real v_val = 0.5 * (v_mf_arr(li,lj,lk) + v_mf_arr(li ,lj+1,lk));
1257 const Real mag = std::sqrt(u_val*u_val + v_val*v_val + Vsg*Vsg);
1258 Real val = denom * mag * d_fact_new;
1259 ma_arr(i,j,k) += val;
1269 averages[iavg]->FillBoundary(geom.periodicity());
1279 bool not_per_x = !(geom.periodicity().isPeriodic(0));
1280 bool not_per_y = !(geom.periodicity().isPeriodic(1));
1281 Box cc_bnd_bx = (
m_fields[lev][2]->boxArray()).minimalBox();
1282 Box domain = geom.Domain();
1283 if (domain.contains(cc_bnd_bx) || (not_per_x || not_per_y)) {
1284 for (
int iavg(0); iavg <
m_navg; ++iavg) {
1285 IntVect ng = averages[iavg]->nGrowVect(); ng[2]=0;
1297 int imf = min(iavg,2);
1298 Box bnd_bx = (
m_fields[lev][imf]->boxArray()).minimalBox();
1300 #pragma omp parallel if (Gpu::notInLaunchRegion())
1302 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1303 Box gpbx = mfi.growntilebox(ng); gpbx.setSmall(2,0); gpbx.setBig(2,0);
1305 if (bnd_bx.contains(gpbx))
continue;
1307 auto ma_arr = averages[iavg]->array(mfi);
1309 int i_lo = bnd_bx.smallEnd(0);
int i_hi = bnd_bx.bigEnd(0);
1310 int j_lo = bnd_bx.smallEnd(1);
int j_hi = bnd_bx.bigEnd(1);
1311 ParallelFor(gpbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1314 li = i < i_lo ? i_lo : i;
1315 li = li > i_hi ? i_hi : li;
1316 lj = j < j_lo ? j_lo : j;
1317 lj = lj > j_hi ? j_hi : lj;
1319 ma_arr(i,j,k) = ma_arr(li,lj,k);
AMREX_FORCE_INLINE AMREX_GPU_DEVICE amrex::Real Compute_h_zeta_AtCellCenter(const int &i, const int &j, const int &k, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, const amrex::Array4< const amrex::Real > &z_nd)
Definition: ERF_TerrainMetrics.H:46
int m_radius
Definition: ERF_MOSTAverage.H:207
int m_ncell_region
Definition: ERF_MOSTAverage.H:208