Function to compute average over local region.
1049 const auto & geom =
m_geom[lev];
1061 Real d_fact_new, d_fact_old;
1081 for (
int imf(0); imf < 4; ++imf) {
1084 if (!fields[imf])
continue;
1087 #pragma omp parallel if (Gpu::notInLaunchRegion())
1089 for (MFIter mfi(*fields[imf],
TileNoZ()); mfi.isValid(); ++mfi) {
1090 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1092 auto mf_arr = (
m_rotate) ? rot_fields[imf]->const_array(mfi) :
1093 fields[imf]->const_array(mfi);
1094 auto ma_arr = averages[imf]->array(mfi);
1097 const auto plo = geom.ProbLoArray();
1098 const auto dx = geom.CellSizeArray();
1099 const auto dxInv = geom.InvCellSizeArray();
1100 const auto z_phys_arr = z_phys->const_array(mfi);
1101 auto x_pos_arr = x_pos->array(mfi);
1102 auto y_pos_arr = y_pos->array(mfi);
1103 auto z_pos_arr = z_pos->array(mfi);
1104 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1106 ma_arr(i,j,k) *= d_fact_old;
1109 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1110 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1111 for (
int li(-d_radius); li <= (d_radius); ++li) {
1113 Real xp = x_pos_arr(i+li,j+lj,k);
1114 Real yp = y_pos_arr(i+li,j+lj,k);
1115 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1117 Real val = denom * interp * d_fact_new;
1118 ma_arr(i,j,k) += val;
1124 auto k_arr = k_indx->const_array(mfi);
1125 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1126 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1127 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1129 ma_arr(i,j,k) *= d_fact_old;
1131 int mk = k_arr(i,j,k);
1132 int mj = j_arr ? j_arr(i,j,k) : j;
1133 int mi = i_arr ? i_arr(i,j,k) : i;
1134 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1135 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1136 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1137 Real val = denom * mf_arr(li, lj, lk) * d_fact_new;
1138 ma_arr(i,j,k) += val;
1148 averages[imf]->FillBoundary(geom.periodicity());
1162 #pragma omp parallel if (Gpu::notInLaunchRegion())
1164 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1165 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1167 const Array4<Real const>& T_mf_arr = fields[2]->const_array(mfi);
1168 const Array4<Real const>& qv_mf_arr = (fields[3])? fields[3]->const_array(mfi) : Array4<const Real>{};
1169 const Array4<Real const>& qr_mf_arr = (fields[4])? fields[4]->const_array(mfi) : Array4<const Real>{};
1170 auto ma_arr = averages[iavg]->array(mfi);
1173 const auto plo = geom.ProbLoArray();
1174 const auto dx = geom.CellSizeArray();
1175 const auto dxInv = geom.InvCellSizeArray();
1176 const auto z_phys_arr = z_phys->const_array(mfi);
1177 auto x_pos_arr = x_pos->array(mfi);
1178 auto y_pos_arr = y_pos->array(mfi);
1179 auto z_pos_arr = z_pos->array(mfi);
1180 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1182 ma_arr(i,j,k) *= d_fact_old;
1185 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1186 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1187 for (
int li(-d_radius); li <= (d_radius); ++li) {
1190 Real xp = x_pos_arr(i+li,j+lj,k);
1191 Real yp = y_pos_arr(i+li,j+lj,k);
1192 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1200 &qr_interp, qr_mf_arr, z_phys_arr, plo, dxInv, 1);
1201 vfac = 1.0 + 0.61*qv_interp - qr_interp;
1203 vfac = 1.0 + 0.61*qv_interp;
1205 const Real mag = T_interp * vfac;
1206 const Real val = denom * mag * d_fact_new;
1207 ma_arr(i,j,k) += val;
1213 auto k_arr = k_indx->const_array(mfi);
1214 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1215 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1216 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1218 ma_arr(i,j,k) *= d_fact_old;
1220 int mk = k_arr(i,j,k);
1221 int mj = j_arr ? j_arr(i,j,k) : j;
1222 int mi = i_arr ? i_arr(i,j,k) : i;
1223 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1224 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1225 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1229 vfac = 1.0 + 0.61*qv_mf_arr(li,lj,lk) - qr_mf_arr(li,lj,lk);
1231 vfac = 1.0 + 0.61*qv_mf_arr(li,lj,lk);
1233 const Real mag = T_mf_arr(li,lj,lk) * vfac;
1234 const Real val = denom * mag * d_fact_new;
1235 ma_arr(i,j,k) += val;
1245 averages[iavg]->FillBoundary(geom.periodicity());
1251 IntVect
ng = averages[iavg]->nGrowVect();
1252 MultiFab::Copy(*(averages[iavg]),*(averages[2]),0,0,1,
ng);
1267 #pragma omp parallel if (Gpu::notInLaunchRegion())
1269 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1270 Box pbx = mfi.tilebox(); pbx.setSmall(2,0); pbx.setBig(2,0);
1272 auto u_mf_arr = (
m_rotate) ? rot_fields[imf ]->const_array(mfi) :
1273 fields[imf ]->const_array(mfi);
1274 auto v_mf_arr = (
m_rotate) ? rot_fields[imf+1]->const_array(mfi) :
1275 fields[imf+1]->const_array(mfi);
1276 auto ma_arr = averages[iavg]->array(mfi);
1279 const auto plo = geom.ProbLoArray();
1280 const auto dx = geom.CellSizeArray();
1281 const auto dxInv = geom.InvCellSizeArray();
1282 const auto z_phys_arr = z_phys->const_array(mfi);
1283 auto x_pos_arr = x_pos->array(mfi);
1284 auto y_pos_arr = y_pos->array(mfi);
1285 auto z_pos_arr = z_pos->array(mfi);
1286 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1288 ma_arr(i,j,k) *= d_fact_old;
1291 for (
int lk(-d_radius); lk <= (d_radius); ++lk) {
1292 for (
int lj(-d_radius); lj <= (d_radius); ++lj) {
1293 for (
int li(-d_radius); li <= (d_radius); ++li) {
1296 Real xp = x_pos_arr(i+li,j+lj,k);
1297 Real yp = y_pos_arr(i+li,j+lj,k);
1298 Real zp = z_pos_arr(i+li,j+lj,k) + met_h_zeta*lk*dx[2];
1301 const Real mag = std::sqrt(u_interp*u_interp + v_interp*v_interp + Vsg*Vsg);
1302 Real val = denom * mag * d_fact_new;
1303 ma_arr(i,j,k) += val;
1309 auto k_arr = k_indx->const_array(mfi);
1310 auto j_arr = j_indx ? j_indx->const_array(mfi) : Array4<const int> {};
1311 auto i_arr = i_indx ? i_indx->const_array(mfi) : Array4<const int> {};
1312 ParallelFor(pbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1314 ma_arr(i,j,k) *= d_fact_old;
1316 int mk = k_arr(i,j,k);
1317 int mj = j_arr ? j_arr(i,j,k) : j;
1318 int mi = i_arr ? i_arr(i,j,k) : i;
1319 for (
int lk(mk-d_radius); lk <= (mk+d_radius); ++lk) {
1320 for (
int lj(mj-d_radius); lj <= (mj+d_radius); ++lj) {
1321 for (
int li(mi-d_radius); li <= (mi+d_radius); ++li) {
1322 const Real u_val = 0.5 * (u_mf_arr(li,lj,lk) + u_mf_arr(li+1,lj ,lk));
1323 const Real v_val = 0.5 * (v_mf_arr(li,lj,lk) + v_mf_arr(li ,lj+1,lk));
1324 const Real mag = std::sqrt(u_val*u_val + v_val*v_val + Vsg*Vsg);
1325 Real val = denom * mag * d_fact_new;
1326 ma_arr(i,j,k) += val;
1336 averages[iavg]->FillBoundary(geom.periodicity());
1346 bool not_per_x = !(geom.periodicity().isPeriodic(0));
1347 bool not_per_y = !(geom.periodicity().isPeriodic(1));
1348 Box cc_bnd_bx = (
m_fields[lev][2]->boxArray()).minimalBox();
1349 Box domain = geom.Domain();
1350 if (domain.contains(cc_bnd_bx) || (not_per_x || not_per_y)) {
1351 for (
int iavg(0); iavg <
m_navg; ++iavg) {
1352 IntVect
ng = averages[iavg]->nGrowVect();
ng[2]=0;
1364 int imf = min(iavg,2);
1365 Box bnd_bx = (
m_fields[lev][imf]->boxArray()).minimalBox();
1367 #pragma omp parallel if (Gpu::notInLaunchRegion())
1369 for (MFIter mfi(*averages[iavg],
TileNoZ()); mfi.isValid(); ++mfi) {
1370 Box gpbx = mfi.growntilebox(
ng); gpbx.setSmall(2,0); gpbx.setBig(2,0);
1372 if (bnd_bx.contains(gpbx))
continue;
1374 auto ma_arr = averages[iavg]->array(mfi);
1376 int i_lo = bnd_bx.smallEnd(0);
int i_hi = bnd_bx.bigEnd(0);
1377 int j_lo = bnd_bx.smallEnd(1);
int j_hi = bnd_bx.bigEnd(1);
1378 ParallelFor(gpbx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept
1381 li = i < i_lo ? i_lo : i;
1382 li = li > i_hi ? i_hi : li;
1383 lj = j < j_lo ? j_lo : j;
1384 lj = lj > j_hi ? j_hi : lj;
1386 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:53
int m_radius
Definition: ERF_MOSTAverage.H:220
int m_ncell_region
Definition: ERF_MOSTAverage.H:221
@ ng
Definition: ERF_Morrison.H:48