Function to compute average over local region.
1025 const auto & geom =
m_geom[lev];
1037 Real d_fact_new, d_fact_old;
1057 for (
int imf(0); imf < 4; ++imf) {
1060 if (!fields[imf])
continue;
1063 #pragma omp parallel if (Gpu::notInLaunchRegion())
1065 for (MFIter mfi(*fields[imf],
TileNoZ()); mfi.isValid(); ++mfi) {
1066 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1068 auto mf_arr = (
m_rotate) ? rot_fields[imf]->const_array(mfi) :
1069 fields[imf]->const_array(mfi);
1070 auto ma_arr = averages[imf]->array(mfi);
1073 const auto plo = geom.ProbLoArray();
1074 const auto dx = geom.CellSizeArray();
1075 const auto dxInv = geom.InvCellSizeArray();
1076 const auto z_phys_arr = z_phys->const_array(mfi);
1077 auto x_pos_arr = x_pos->array(mfi);
1078 auto y_pos_arr = y_pos->array(mfi);
1079 auto z_pos_arr = z_pos->array(mfi);
1080 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1082 ma_arr(i,j,k) *= d_fact_old;
1085 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1086 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1087 for (
int li(-d_radius); li <= (d_radius); ++li) {
1089 Real xp = x_pos_arr(i+li,j+lj,k);
1090 Real yp = y_pos_arr(i+li,j+lj,k);
1091 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1093 Real val = denom * interp * d_fact_new;
1094 ma_arr(i,j,k) += val;
1100 auto k_arr = k_indx->const_array(mfi);
1101 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1102 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1103 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1105 ma_arr(i,j,k) *= d_fact_old;
1107 int mk = k_arr(i,j,k);
1108 int mj = j_arr ? j_arr(i,j,k) : j;
1109 int mi = i_arr ? i_arr(i,j,k) : i;
1110 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1111 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1112 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1113 Real val = denom * mf_arr(li, lj, lk) * d_fact_new;
1114 ma_arr(i,j,k) += val;
1124 averages[imf]->FillBoundary(geom.periodicity());
1138 #pragma omp parallel if (Gpu::notInLaunchRegion())
1140 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1141 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1143 const Array4<Real const>& T_mf_arr = fields[2]->const_array(mfi);
1144 const Array4<Real const>& qv_mf_arr = (fields[3])? fields[3]->const_array(mfi) : Array4<const Real>{};
1145 const Array4<Real const>& qr_mf_arr = (fields[4])? fields[4]->const_array(mfi) : Array4<const Real>{};
1146 auto ma_arr = averages[iavg]->array(mfi);
1149 const auto plo = geom.ProbLoArray();
1150 const auto dx = geom.CellSizeArray();
1151 const auto dxInv = geom.InvCellSizeArray();
1152 const auto z_phys_arr = z_phys->const_array(mfi);
1153 auto x_pos_arr = x_pos->array(mfi);
1154 auto y_pos_arr = y_pos->array(mfi);
1155 auto z_pos_arr = z_pos->array(mfi);
1156 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1158 ma_arr(i,j,k) *= d_fact_old;
1161 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1162 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1163 for (
int li(-d_radius); li <= (d_radius); ++li) {
1166 Real xp = x_pos_arr(i+li,j+lj,k);
1167 Real yp = y_pos_arr(i+li,j+lj,k);
1168 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1176 &qr_interp, qr_mf_arr, z_phys_arr, plo, dxInv, 1);
1177 vfac = 1.0 + 0.61*qv_interp - qr_interp;
1179 vfac = 1.0 + 0.61*qv_interp;
1181 const Real mag = T_interp * vfac;
1182 const Real val = denom * mag * d_fact_new;
1183 ma_arr(i,j,k) += val;
1189 auto k_arr = k_indx->const_array(mfi);
1190 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1191 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1192 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1194 ma_arr(i,j,k) *= d_fact_old;
1196 int mk = k_arr(i,j,k);
1197 int mj = j_arr ? j_arr(i,j,k) : j;
1198 int mi = i_arr ? i_arr(i,j,k) : i;
1199 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1200 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1201 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1205 vfac = 1.0 + 0.61*qv_mf_arr(li,lj,lk) - qr_mf_arr(li,lj,lk);
1207 vfac = 1.0 + 0.61*qv_mf_arr(li,lj,lk);
1209 const Real mag = T_mf_arr(li,lj,lk) * vfac;
1210 const Real val = denom * mag * d_fact_new;
1211 ma_arr(i,j,k) += val;
1221 averages[iavg]->FillBoundary(geom.periodicity());
1227 IntVect
ng = averages[iavg]->nGrowVect();
1228 MultiFab::Copy(*(averages[iavg]),*(averages[2]),0,0,1,
ng);
1243 #pragma omp parallel if (Gpu::notInLaunchRegion())
1245 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1246 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1248 auto u_mf_arr = (
m_rotate) ? rot_fields[imf ]->const_array(mfi) :
1249 fields[imf ]->const_array(mfi);
1250 auto v_mf_arr = (
m_rotate) ? rot_fields[imf+1]->const_array(mfi) :
1251 fields[imf+1]->const_array(mfi);
1252 auto ma_arr = averages[iavg]->array(mfi);
1255 const auto plo = geom.ProbLoArray();
1256 const auto dx = geom.CellSizeArray();
1257 const auto dxInv = geom.InvCellSizeArray();
1258 const auto z_phys_arr = z_phys->const_array(mfi);
1259 auto x_pos_arr = x_pos->array(mfi);
1260 auto y_pos_arr = y_pos->array(mfi);
1261 auto z_pos_arr = z_pos->array(mfi);
1262 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1264 ma_arr(i,j,k) *= d_fact_old;
1267 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1268 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1269 for (
int li(-d_radius); li <= (d_radius); ++li) {
1272 Real xp = x_pos_arr(i+li,j+lj,k);
1273 Real yp = y_pos_arr(i+li,j+lj,k);
1274 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1277 const Real mag = std::sqrt(u_interp*u_interp + v_interp*v_interp + Vsg*Vsg);
1278 Real val = denom * mag * d_fact_new;
1279 ma_arr(i,j,k) += val;
1285 auto k_arr = k_indx->const_array(mfi);
1286 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1287 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1288 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1290 ma_arr(i,j,k) *= d_fact_old;
1292 int mk = k_arr(i,j,k);
1293 int mj = j_arr ? j_arr(i,j,k) : j;
1294 int mi = i_arr ? i_arr(i,j,k) : i;
1295 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1296 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1297 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1298 const Real u_val = 0.5 * (u_mf_arr(li,lj,lk) + u_mf_arr(li+1,lj ,lk));
1299 const Real v_val = 0.5 * (v_mf_arr(li,lj,lk) + v_mf_arr(li ,lj+1,lk));
1300 const Real mag = std::sqrt(u_val*u_val + v_val*v_val + Vsg*Vsg);
1301 Real val = denom * mag * d_fact_new;
1302 ma_arr(i,j,k) += val;
1312 averages[iavg]->FillBoundary(geom.periodicity());
1322 bool not_per_x = !(geom.periodicity().isPeriodic(0));
1323 bool not_per_y = !(geom.periodicity().isPeriodic(1));
1324 Box cc_bnd_bx = (
m_fields[lev][2]->boxArray()).minimalBox();
1325 Box domain = geom.Domain();
1326 if (domain.contains(cc_bnd_bx) || (not_per_x || not_per_y)) {
1327 for (
int iavg(0); iavg <
m_navg; ++iavg) {
1328 IntVect
ng = averages[iavg]->nGrowVect();
ng[2]=0;
1340 int imf = min(iavg,2);
1341 Box bnd_bx = (
m_fields[lev][imf]->boxArray()).minimalBox();
1343 #pragma omp parallel if (Gpu::notInLaunchRegion())
1345 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1346 Box gpbx = mfi.growntilebox(
ng); gpbx.setSmall(2,0); gpbx.setBig(2,0);
1348 if (bnd_bx.contains(gpbx))
continue;
1350 auto ma_arr = averages[iavg]->array(mfi);
1352 int i_lo = bnd_bx.smallEnd(0);
int i_hi = bnd_bx.bigEnd(0);
1353 int j_lo = bnd_bx.smallEnd(1);
int j_hi = bnd_bx.bigEnd(1);
1354 ParallelFor(gpbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1357 li = i < i_lo ? i_lo : i;
1358 li = li > i_hi ? i_hi : li;
1359 lj = j < j_lo ? j_lo : j;
1360 lj = lj > j_hi ? j_hi : lj;
1362 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:47
int m_radius
Definition: ERF_MOSTAverage.H:220
int m_ncell_region
Definition: ERF_MOSTAverage.H:221
@ ng
Definition: ERF_Morrison.H:48