Skip to content

Commit

Permalink
WIP - the mac and nodal proj work as expected for mixed BCs (given
Browse files Browse the repository at this point in the history
the appropriate setup in inputs.split).
advection not working (hacked to get umac to project)
not in any way elegantly coded
  • Loading branch information
cgilet committed Feb 7, 2024
1 parent a3a3870 commit 69cb3b5
Show file tree
Hide file tree
Showing 11 changed files with 600 additions and 132 deletions.
1 change: 1 addition & 0 deletions src/boundary_conditions/boundary_conditions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,7 @@ void incflo::init_bcs ()
else if (bc_type == "mixed" )
{
amrex::Print() << bcid << " set to mixed inflow outflow.\n";
m_has_mixedBC = true;
#ifdef AMREX_USE_EB
ParmParse ipp("incflo");

Expand Down
162 changes: 142 additions & 20 deletions src/boundary_conditions/incflo_set_bcs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,27 +6,49 @@

using namespace amrex;

void
incflo::make_mixedBC_mask(int lev,
const BoxArray& ba, // do we really need to pass these, use member vars? - i think we need to pass to be safe when calling from RemakeLevel...
const DistributionMapping& dm)
iMultiFab
incflo::make_ccBC_mask(int lev)
{
bool has_mixedBC = false;
for (OrientationIter oit; oit; ++oit) {
if (m_bc_type[oit()] == BC::mixed )
{
has_mixedBC = true;
break;
// BC info stored in ghost cell.
iMultiFab new_mask(grids[lev], dmap[lev], 1, 1);
// No expectation in MLMG for there to be valid data where there is no Robin BC
//new_mask = 0;

Geometry const& gm = Geom(lev);
Box const& domain = gm.Domain();
for (int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
Orientation olo(dir,Orientation::low);
Orientation ohi(dir,Orientation::high);
if (m_bc_type[olo] == BC::mixed || m_bc_type[ohi] == BC::mixed) {
Box dlo = (m_bc_type[olo] == BC::mixed) ? adjCellLo(domain,dir) : Box();
Box dhi = (m_bc_type[ohi] == BC::mixed) ? adjCellHi(domain,dir) : Box();
#ifdef _OPENMP
#pragma omp parallel if (Gpu::notInLaunchRegion())
#endif
for (MFIter mfi(new_mask); mfi.isValid(); ++mfi) {
Box blo = mfi.growntilebox() & dlo;
Box bhi = mfi.growntilebox() & dhi;
Array4<int> const& mask_arr = new_mask.array(mfi);
if (blo.ok()) {
prob_set_BC_MF(olo, blo, mask_arr, lev);
}
if (bhi.ok()) {
prob_set_BC_MF(ohi, bhi, mask_arr, lev);
}
}
}
}

if (!has_mixedBC) { return; }

return new_mask;
}

iMultiFab
incflo::make_nodalBC_mask(int lev)
{
// MLNodeLap does not require any ghost cells...
std::unique_ptr<iMultiFab> new_mask(new iMultiFab(amrex::convert(ba,IntVect::TheNodeVector()),
dm, 1, 0));
*new_mask = 1;
iMultiFab new_mask(amrex::convert(grids[lev], IntVect::TheNodeVector()), dmap[lev], 1, 0);
// Overset mask needs to be defined everywhere
new_mask = 1;

Geometry const& gm = Geom(lev);
Box const& domain = gm.Domain();
Expand All @@ -39,23 +61,123 @@ incflo::make_mixedBC_mask(int lev,
#ifdef _OPENMP
#pragma omp parallel if (Gpu::notInLaunchRegion())
#endif
for (MFIter mfi(*new_mask); mfi.isValid(); ++mfi) {
for (MFIter mfi(new_mask); mfi.isValid(); ++mfi) {
Box blo = mfi.validbox() & dlo;
Box bhi = mfi.validbox() & dhi;
Array4<int> const& mask_arr = new_mask->array(mfi);
Array4<int> const& mask_arr = new_mask.array(mfi);
if (blo.ok()) {
prob_set_mixedBC_mask(olo, blo, mask_arr, lev);
prob_set_BC_MF(olo, blo, mask_arr, lev);
}
if (bhi.ok()) {
prob_set_mixedBC_mask(ohi, bhi, mask_arr, lev);
prob_set_BC_MF(ohi, bhi, mask_arr, lev);
}
}
}
}

m_mixedBC_mask[lev] = std::move(new_mask);
return new_mask;
}

// void
// incflo::make_ccBC_mask(int lev,
// const BoxArray& ba, // do we really need to pass these, use member vars? - i think we need to pass to be safe when calling from RemakeLevel...
// const DistributionMapping& dm)
// {
// bool has_mixedBC = false;
// for (OrientationIter oit; oit; ++oit) {
// if (m_bc_type[oit()] == BC::mixed )
// {
// has_mixedBC = true;
// break;
// }
// }

// if (!has_mixedBC) { return; }


// // BC info stored in ghost cell.
// std::unique_ptr<iMultiFab> new_mask(new iMultiFab(ba, dm, 1, 1));
// *new_mask = 0;

// Geometry const& gm = Geom(lev);
// Box const& domain = gm.Domain();
// for (int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
// Orientation olo(dir,Orientation::low);
// Orientation ohi(dir,Orientation::high);
// if (m_bc_type[olo] == BC::mixed || m_bc_type[ohi] == BC::mixed) {
// Box dlo = (m_bc_type[olo] == BC::mixed) ? adjCellLo(domain,dir) : Box();
// Box dhi = (m_bc_type[ohi] == BC::mixed) ? adjCellHi(domain,dir) : Box();
// #ifdef _OPENMP
// #pragma omp parallel if (Gpu::notInLaunchRegion())
// #endif
// for (MFIter mfi(*new_mask); mfi.isValid(); ++mfi) {
// Box blo = mfi.growntilebox() & dlo;
// Box bhi = mfi.growntilebox() & dhi;
// Array4<int> const& mask_arr = new_mask->array(mfi);
// if (blo.ok()) {
// prob_set_BC_MF(olo, blo, mask_arr, lev);
// }
// if (bhi.ok()) {
// prob_set_BC_MF(ohi, bhi, mask_arr, lev);
// }
// }
// }
// }

// m_BC_MF[lev] = std::move(new_mask);
// }

// void
// incflo::make_nodalBC_mask(int lev,
// const BoxArray& ba, // do we really need to pass these, use member vars? - i think we need to pass to be safe when calling from RemakeLevel...
// const DistributionMapping& dm)
// {
// // FIXME do we really want this check here?
// bool has_mixedBC = false;
// for (OrientationIter oit; oit; ++oit) {
// if (m_bc_type[oit()] == BC::mixed )
// {
// has_mixedBC = true;
// break;
// }
// }

// if (!has_mixedBC) { return; }


// // MLNodeLap does not require any ghost cells...
// std::unique_ptr<iMultiFab> new_mask(new iMultiFab(amrex::convert(ba,IntVect::TheNodeVector()),
// dm, 1, 0));
// *new_mask = 1;

// Geometry const& gm = Geom(lev);
// Box const& domain = gm.Domain();
// for (int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
// Orientation olo(dir,Orientation::low);
// Orientation ohi(dir,Orientation::high);
// if (m_bc_type[olo] == BC::mixed || m_bc_type[ohi] == BC::mixed) {
// Box dlo = (m_bc_type[olo] == BC::mixed) ? surroundingNodes(bdryLo(domain,dir)) : Box();
// Box dhi = (m_bc_type[ohi] == BC::mixed) ? surroundingNodes(bdryHi(domain,dir)) : Box();
// #ifdef _OPENMP
// #pragma omp parallel if (Gpu::notInLaunchRegion())
// #endif
// for (MFIter mfi(*new_mask); mfi.isValid(); ++mfi) {
// Box blo = mfi.validbox() & dlo;
// Box bhi = mfi.validbox() & dhi;
// Array4<int> const& mask_arr = new_mask->array(mfi);
// if (blo.ok()) {
// prob_set_BC_MF(olo, blo, mask_arr, lev);
// }
// if (bhi.ok()) {
// prob_set_BC_MF(ohi, bhi, mask_arr, lev);
// }
// }
// }
// }

// m_BC_MF[lev] = std::move(new_mask);
// }

#ifdef AMREX_USE_EB
void
incflo::set_eb_velocity (int lev, amrex::Real /*time*/, MultiFab& eb_vel, int nghost)
Expand Down
Loading

0 comments on commit 69cb3b5

Please sign in to comment.