Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Resuse macproj w robin and Update Docs #126

Merged
merged 8 commits into from
Mar 11, 2024
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 0 additions & 23 deletions Docs/source/EB/EB_example.fig

This file was deleted.

Binary file removed Docs/source/EB/EB_example.png
Binary file not shown.
69 changes: 0 additions & 69 deletions Docs/source/EB/areas_and_volumes.fig

This file was deleted.

Binary file removed Docs/source/EB/areas_and_volumes.png
Binary file not shown.
38 changes: 0 additions & 38 deletions Docs/source/EB/eb_fluxes.fig

This file was deleted.

Binary file removed Docs/source/EB/eb_fluxes.png
Binary file not shown.
41 changes: 0 additions & 41 deletions Docs/source/EB/redist.fig

This file was deleted.

Binary file removed Docs/source/EB/redist.png
Binary file not shown.
2 changes: 1 addition & 1 deletion Docs/source/Godunov.rst
Original file line number Diff line number Diff line change
Expand Up @@ -231,7 +231,7 @@ Godunov with Embedded Boundaries (EBGodunov)

AMReX-Hydro contains an embedded boundary (EB) aware version of the Godunov algorithm
discussed above, although with fewer options available.
This EB implementation employs a piecewise linear method (PLM) :cite:`needref`, and
This EB implementation employs a piecewise linear method (PLM), and
always includes any forcing terms *after* the computation of the transverse terms.
EBGodunov attempts to use fourth-order limited slopes wherever possible, as described in :ref:`EBslopes`.

Expand Down
4 changes: 2 additions & 2 deletions Docs/source/Introduction.rst
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ is as follows:
5. Difference fluxes to create the convective term.

AMReX-Hydro provides routines to support all of these steps.
Here we group the AMReX-Hydro routines into a few general categories and map them to the step(s) they address:
Here we group the routines into a few general categories and map them to the step(s) they address:

* :ref:`Schemes`: the fundamental algorithm is either a Method-of-Lines (MOL) or Godunov approach
(used in steps 1 and 3).
Expand All @@ -43,7 +43,7 @@ Here we group the AMReX-Hydro routines into a few general categories and map the
(not generally used as part of computing the convective term, but used in application codes to define a
cell-centered velocity update that approximately obeys a divergence constraint).

* :ref:`Redistribution:Redistribution` schemes: to address the "small cell problem" associated with explicit cut
* :ref:`Redistribution <amrex:sec:EB:redistribution>`: AMReX contains schemes to address the "small cell problem" associated with explicit cut
cell algorithms (part of step 4 for problems with embedded boundaries).

* :ref:`utilities`: to do things like compute slopes, create fluxes from face-centered values, and
Expand Down
6 changes: 3 additions & 3 deletions Docs/source/MOL.rst
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ These alogrithms are applied in the MOL namespace. For API documentation, see


Pre-MAC (API ref. `MOL::ExtrapVelToFaces <https://amrex-fluids.github.io/amrex-hydro/Doxygen/html/namespaceMOL.html#acdde2acf756048b8ef0bca332e4bf748>`_)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

For computing the pre-MAC edge states to be MAC-projected, we define on
every x-face:
Expand Down Expand Up @@ -45,7 +45,7 @@ We similarly compute :math:`v_{i,j-\frac{1}{2},k}` on y-faces and


Post-MAC (API ref. `MOL::ComputeEdgeState <https://amrex-fluids.github.io/amrex-hydro/Doxygen/html/namespaceMOL.html#acdde2acf756048b8ef0bca332e4bf748>`_)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Once we have the MAC-projected velocities, we extrapolate all quantities to
faces as above:
Expand Down Expand Up @@ -83,7 +83,7 @@ All slope computations use second-order limited slopes as described in :ref:`EBs


Pre-MAC (API ref. `EBMOL::ExtrapVelToFaces <https://amrex-fluids.github.io/amrex-hydro/Doxygen/html/namespaceEBMOL.html#a7add53a153ade9c5cb83e79a61ad1929>`_)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

For computing the pre-MAC edge states to be MAC-projected, we define on every x-face with non-zero area fraction:

Expand Down
2 changes: 0 additions & 2 deletions Docs/source/Utilities.rst
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,6 @@ Note that EB is only an option for Cartesian geometries as of this writing.

.. include:: Slopes.rst

.. include:: bcs.rst

.. include:: Fluxes.rst

.. include:: AdvectiveTerm.rst
Expand Down
43 changes: 41 additions & 2 deletions Docs/source/bcs.rst
Original file line number Diff line number Diff line change
@@ -1,16 +1,55 @@
.. role:: cpp(code)
:language: c++

.. _bcs:


Boundary conditions
-------------------
====================

AMReX-Hydro uses underlying AMReX functionality in implementing boundary conditions
(see AMReX's documentation section :ref:`amrex:sec:basics:boundary`).
Physical boundary conditions, such as
inflow, outflow, slip/no-slip walls, etc., and are ultimately linked to
inflow, outflow, slip/no-slip walls, etc. are ultimately linked to
mathematical Dirichlet or Neumann conditions.
See ``amrex/Src/Base/AMReX_BC_TYPES.H`` for common physical and mathematical types.


.. _mixedBC:

Mixed Boundary Conditions
--------------------------

.. note::

This has only been tested in geometries where the Neumann and Dirchlet areas are separated
by an embedded boundary, and is not guaranteed to work for other cases.

In addition to the bc types listed in AMReX, mixed boundary conditions can be implemented.
To this end, the (EB)Godunov advection routines support position-dependent boundary conditions.
The routines accept a boundary condition MultiFab (BC MF), or Array4. The BC MF is a cell-centered
(integer) :cpp:`iMultiFab` that carries an :cpp:`amrex::BCType` in the first ghost cell
and must fully specify the BC on all faces.
If a position-dependent BCs are passed in, they take precedent and single BC per face :cpp:`BCRecs` are
ignored.


The MacProjector supports mixed boundary conditions by making use of the underlying linear solver's
Robin BC (:ref:`amrex:sec:linearsolver:bc`) option. Robin boundary conditions are formulated as
:math:`a\phi + b\frac{\partial\phi}{\partial n} = f`.
:math:`a`, :math:`b`, and :math:`f` are each a cell-centered (real) :cpp:`MultiFab` that carries
the relevant values in the first ghost cell. All three must be specified on each level with a call to
:cpp:`setLevelBC` (see :ref:`amrex:sec:linearsolver:bc` for usage).

The NodalProjector can support mixed boundary conditions through the use of an overset mask
(see :ref:`amrex:sec:linearsolver:bc`).
The overset mask specifies a Dirichlet BC with 0 (meaning no solve is needed since the solution is known) or Neumann with 1 (meaning do the solve). Note this is an integer (not bool) MultiFab, so the values must be only either 0 or 1.



Advective BC details
--------------------

Domain boundary conditions affect the pre-MAC extrapolated velocities in three ways.

#. Potential impact to the slope computation in cells
Expand Down
1 change: 0 additions & 1 deletion Docs/source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,6 @@ def get_amrex_hydro_version():
'MOL.rst',
'AdvectiveTerm.rst',
'Fluxes.rst',
'bcs.rst',
'Slopes.rst'
]

Expand Down
1 change: 1 addition & 0 deletions Docs/source/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ applications.
Installation Guide <Install>
Advection Schemes <Schemes>
Projections
Boundary Conditions <bcs>
Helper functions <Utilities>

.. toctree::
Expand Down
3 changes: 3 additions & 0 deletions Projections/hydro_MacProjector.H
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,8 @@ public:

//! Update Bcoeffs for the linear operator
void updateBeta (const amrex::Vector<amrex::Array<amrex::MultiFab const*,AMREX_SPACEDIM> >&);
//! Update Bcoeff and if Robin BC also reset scalars in order to reuse the linear operator
void updateCoeffs (const amrex::Vector<amrex::Array<amrex::MultiFab const*,AMREX_SPACEDIM> >&);

#ifndef AMREX_USE_EB
void initProjector (amrex::Vector<amrex::BoxArray> const& a_grids,
Expand Down Expand Up @@ -184,6 +186,7 @@ private:

bool m_needs_domain_bcs = true;
amrex::Vector<int> m_needs_level_bcs;
bool m_has_robin = false;

// Location of umac -- face center vs face centroid
amrex::MLMG::Location m_umac_loc;
Expand Down
31 changes: 28 additions & 3 deletions Projections/hydro_MacProjector.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -147,15 +147,39 @@ void MacProjector::updateBeta (
m_poisson == nullptr,
"MacProjector::updateBeta: should not be called for constant beta");

AMREX_ALWAYS_ASSERT_WITH_MESSAGE(
m_has_robin == false,
"MacProjector::updateBeta: should not be called with Robin BC. Call updateCoeffs");

updateCoeffs(a_beta);
}

void MacProjector::updateCoeffs (
const Vector<Array<MultiFab const*, AMREX_SPACEDIM>>& a_beta)
{
AMREX_ALWAYS_ASSERT_WITH_MESSAGE(
m_linop != nullptr,
"MacProjector::updateCoeffs: initProjector must be called before calling this method");

AMREX_ALWAYS_ASSERT_WITH_MESSAGE(
m_poisson == nullptr,
"MacProjector::updateCoeffs: should not be called for constant beta");

const auto nlevs = int(a_beta.size());
#ifdef AMREX_USE_EB
const bool has_eb = a_beta[0][0]->hasEBFabFactory();
if (has_eb) {
if (m_has_robin) {
m_eb_abeclap->setScalars(0.0, 1.0);
}
for (int ilev=0; ilev < nlevs; ++ilev)
m_eb_abeclap->setBCoeffs(ilev, a_beta[ilev], m_beta_loc);
} else
#endif
{
if (m_has_robin) {
m_abeclap->setScalars(0.0, 1.0);
}
for (int ilev=0; ilev < nlevs; ++ilev)
m_abeclap->setBCoeffs(ilev, a_beta[ilev]);
}
Expand Down Expand Up @@ -210,11 +234,12 @@ MacProjector::setLevelBC (int amrlev, const MultiFab* levelbcdata, const MultiFa
{
AMREX_ALWAYS_ASSERT_WITH_MESSAGE(!m_needs_domain_bcs,
"setDomainBC must be called before setLevelBC");
AMREX_ALWAYS_ASSERT_WITH_MESSAGE(
!robin_a || (robin_a && !m_abeclap),
"MacProjector::setLevelBC(): Projection only tested for case of EB separated mixed BC.");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think we can add this assertion. What if someone has already been using Robin BC for non-EB case?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In fact, the Robin BC was first developed because someone requested the feature for non-EB cases.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fair enough (although I don't think the way the MAC Projector was before pr 122 would allow for robin bcs). I've just not tested the Mac Projector with anything other than EB separated cases. But if you say it's fine, then it's fine.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In principle, all one needed to do before pr 122 was getLinOp.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I tried that first, but the MacProjector has this private member flag m_needs_level_bcs that made a using getLinOp ineffective because there would be a subsequent call to setLevelBC(ilev, nullptr) in project. ... doesn't matter now though. thanks for merging

m_linop->setLevelBC(amrlev, levelbcdata, robin_a, robin_b, robin_f);
m_needs_level_bcs[amrlev] = false;
if (robin_a) {
m_needs_init = true; // Solver is not safe for reuse with Robin BC
}
if (robin_a) { m_has_robin = true; }
}


Expand Down
Loading