413 Print() <<
"Asking for index " <<
idx <<
" but m_in_timesteps only has size " <<
m_in_timesteps.size() << std::endl;
417 const std::string chkname1 =
m_filename + Concatenate(
"/bndry_output", t_step);
419 const std::string level_prefix =
"Level_";
422 const Box& domain =
m_geom.Domain();
424 DistributionMapping dm{ba};
426 GpuArray<GpuArray<Real, AMREX_SPACEDIM*2>, AMREX_SPACEDIM+
NBCVAR_max> l_bc_extdir_vals_d;
430 for (OrientationIter oit; oit !=
nullptr; ++oit) {
432 l_bc_extdir_vals_d[i][ori] = m_bc_extdir_vals[i][ori];
436 int n_for_density = -1;
439 if (
m_var_names[i] ==
"density") n_for_density = i;
445 for (OrientationIter oit; oit !=
nullptr; ++oit) {
447 if (ori.coordDir() < 2) {
448 FArrayBox& d = (*data_to_fill[ori])[lev];
449 const auto& bx = d.box();
450 Array4<Real> d_arr = d.array();
452 bx, ncomp_for_bc, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k,
int n) noexcept {
453 d_arr(i,j,k,n) =
zero;
459 std::string filenamer = MultiFabFileFullPrefix(lev, chkname1, level_prefix,
"density");
462 for (OrientationIter oit; oit !=
nullptr; ++oit) {
464 if (ori.coordDir() < 2) {
465 std::string facenamer = Concatenate(filenamer +
'_', ori, 1);
466 bndry_r[ori].read(facenamer);
473 for (
int ivar = 0; ivar <
m_var_names.size(); ivar++)
477 std::string filename1 = MultiFabFileFullPrefix(lev, chkname1, level_prefix, var_name);
480 if (var_name ==
"velocity") {
481 ncomp = AMREX_SPACEDIM;
504 for (OrientationIter oit; oit !=
nullptr; ++oit) {
506 if (ori.coordDir() < 2) {
508 std::string facename1 = Concatenate(filename1 +
'_', ori, 1);
509 bndry[ori].read(facename1);
511 int normal = ori.coordDir();
512 IntVect v_offset =
offset(ori.faceDir(), normal);
513 if (real_bcs) { v_offset = IntVect(0); }
515 const auto& bbx = (*data_to_fill[ori])[lev].box();
522 bndry[ori].boxArray(), bndry[ori].DistributionMap(),
525 for (MFIter mfi(bndryMF); mfi.isValid(); ++mfi) {
527 const auto& vbx = mfi.validbox();
528 const auto& bndry_read_arr = bndry[ori].array(mfi);
529 const auto& bndry_read_r_arr = bndry_r[ori].array(mfi);
530 const auto& bndry_mf_arr = bndryMF.array(mfi);
532 const auto& bx = bbx & vbx;
544 bx_ghost.setBig (normal, domain.smallEnd(normal) - 1);
545 bx_int .setSmall(normal, domain.smallEnd(normal));
547 bx_ghost.setSmall(normal, domain.bigEnd(normal) + 1);
548 bx_int .setBig (normal, domain.bigEnd(normal));
550 const IntVect v_offset_int = -v_offset;
558 if (n_for_density >= 0) {
559 if (var_name ==
"temperature") {
561 bx_ghost, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
562 Real R1 = bndry_read_r_arr(i, j, k, 0);
563 Real R2 = bndry_read_r_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2],0);
564 Real T1 = bndry_read_arr(i, j, k, 0);
565 Real T2 = bndry_read_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2],0);
568 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
569 myhalf * (R1*Th1 + R2*Th2);
571 }
else if (var_name ==
"theta" || var_name ==
"ke" || var_name ==
"scalar" ||
572 var_name ==
"qv" || var_name ==
"qc") {
574 bx_ghost, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
575 Real R1 = bndry_read_r_arr(i, j, k, 0);
576 Real R2 = bndry_read_r_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2],0);
577 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
578 myhalf * ( R1 * bndry_read_arr(i, j, k, 0) +
579 R2 * bndry_read_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2], 0));
581 }
else if (var_name ==
"density") {
583 bx_ghost, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
584 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
585 myhalf * ( bndry_read_arr(i, j, k, 0) +
586 bndry_read_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2], 0));
590 if (var_name ==
"temperature") {
592 bx_ghost, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
595 Real T1 = bndry_read_arr(i, j, k, 0);
596 Real T2 = bndry_read_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2], 0);
599 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
600 myhalf * (R1*Th1 + R2*Th2);
602 }
else if (var_name ==
"theta" || var_name ==
"ke" || var_name ==
"scalar" ||
603 var_name ==
"qv" || var_name ==
"qc") {
605 bx_ghost, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
608 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
609 myhalf * (R1 * bndry_read_arr(i, j, k, 0) +
610 R2 * bndry_read_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2], 0));
616 if (var_name ==
"velocity") {
618 bx_ghost, ncomp, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k,
int n) noexcept {
619 bndry_mf_arr(i, j, k, n) = (real_bcs) ? bndry_read_arr(i, j, k, n) :
620 myhalf * (bndry_read_arr(i, j, k, n) +
621 bndry_read_arr(i+v_offset[0],j+v_offset[1],k+v_offset[2], n));
628 if (n_for_density >= 0) {
629 if (var_name ==
"temperature") {
631 bx_int, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
632 Real R1 = bndry_read_r_arr(i, j, k, 0);
633 Real R2 = bndry_read_r_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2],0);
634 Real T1 = bndry_read_arr(i, j, k, 0);
635 Real T2 = bndry_read_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2],0);
638 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
639 myhalf * (R1*Th1 + R2*Th2);
641 }
else if (var_name ==
"theta" || var_name ==
"ke" || var_name ==
"scalar" ||
642 var_name ==
"qv" || var_name ==
"qc") {
644 bx_int, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
645 Real R1 = bndry_read_r_arr(i, j, k, 0);
646 Real R2 = bndry_read_r_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2],0);
647 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
648 myhalf * ( R1 * bndry_read_arr(i, j, k, 0) +
649 R2 * bndry_read_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2], 0));
651 }
else if (var_name ==
"density") {
653 bx_int, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
654 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
655 myhalf * ( bndry_read_arr(i, j, k, 0) +
656 bndry_read_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2], 0));
660 if (var_name ==
"temperature") {
662 bx_int, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
665 Real T1 = bndry_read_arr(i, j, k, 0);
666 Real T2 = bndry_read_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2], 0);
669 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
670 myhalf * (R1*Th1 + R2*Th2);
672 }
else if (var_name ==
"theta" || var_name ==
"ke" || var_name ==
"scalar" ||
673 var_name ==
"qv" || var_name ==
"qc") {
675 bx_int, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) noexcept {
678 bndry_mf_arr(i, j, k, 0) = (real_bcs) ? bndry_read_arr(i, j, k, 0) :
679 myhalf * (R1 * bndry_read_arr(i, j, k, 0) +
680 R2 * bndry_read_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2], 0));
685 if (var_name ==
"velocity") {
687 bx_int, ncomp, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k,
int n) noexcept {
688 bndry_mf_arr(i, j, k, n) = (real_bcs) ? bndry_read_arr(i, j, k, n) :
689 myhalf * (bndry_read_arr(i, j, k, n) +
690 bndry_read_arr(i+v_offset_int[0],j+v_offset_int[1],k+v_offset_int[2], n));
695 bndryMF.copyTo((*data_to_fill[ori])[lev], 0, n_offset, ncomp);
constexpr amrex::Real bogus_large_value
Definition: ERF_Constants.H:26
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:13
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getThgivenRandT(const amrex::Real rho, const amrex::Real T, const amrex::Real rdOcp, const amrex::Real qv=amrex::Real(0))
Definition: ERF_EOS.H:64
#define NBCVAR_max
Definition: ERF_IndexDefines.H:29
const Real rdOcp
Definition: ERF_InitCustomPert_Bomex.H:16
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE int idx(int i, int j, int k, int nx, int ny)
Definition: ERF_InitForEnsemble.cpp:287
AMREX_FORCE_INLINE IntVect offset(const int face_dir, const int normal)
Definition: ERF_ReadBndryPlanes.cpp:28
amrex::Vector< int > m_in_timesteps
Definition: ERF_ReadBndryPlanes.H:88
int ingested_density() const
Definition: ERF_ReadBndryPlanes.H:46
const int m_extent_rad
Definition: ERF_ReadBndryPlanes.H:96
@ RhoScalar_bc_comp
Definition: ERF_IndexDefines.H:90
@ RhoQ1_bc_comp
Definition: ERF_IndexDefines.H:91
@ RhoKE_bc_comp
Definition: ERF_IndexDefines.H:89
@ RhoTheta_bc_comp
Definition: ERF_IndexDefines.H:88
@ RhoQ2_bc_comp
Definition: ERF_IndexDefines.H:92
@ Rho_bc_comp
Definition: ERF_IndexDefines.H:87
@ xvel_bc
Definition: ERF_IndexDefines.H:102