Block-Structured AMR Software Framework
Loading...
Searching...
No Matches
AMReX_MLEBABecLap.H
Go to the documentation of this file.
1#ifndef AMREX_MLEBABECLAP_H_
2#define AMREX_MLEBABECLAP_H_
3#include <AMReX_Config.H>
4
7#include <AMReX_Array.H>
8#include <limits>
9
10namespace amrex {
11
12template <typename T>
14
15// (alpha * a - beta * (del dot b grad)) phi
16
19 : public MLCellABecLap
20{
21public:
22
23 MLEBABecLap () = default;
24 MLEBABecLap (const Vector<Geometry>& a_geom,
25 const Vector<BoxArray>& a_grids,
26 const Vector<DistributionMapping>& a_dmap,
27 const LPInfo& a_info,
28 const Vector<EBFArrayBoxFactory const*>& a_factory,
29 int a_ncomp = 1);
30
31 ~MLEBABecLap () override;
32
33 MLEBABecLap (const MLEBABecLap&) = delete;
37
38 void define (const Vector<Geometry>& a_geom,
39 const Vector<BoxArray>& a_grids,
40 const Vector<DistributionMapping>& a_dmap,
41 const LPInfo& a_info,
42 const Vector<EBFArrayBoxFactory const*>& a_factory,
43 int a_ncomp = 1);
44
45 void setPhiOnCentroid ();
46
47 void setScalars (Real a, Real b);
48 void setACoeffs (int amrlev, const MultiFab& alpha);
49 void setACoeffs (int amrlev, Real alpha);
50
51 void setBCoeffs (int amrlev, const Array<MultiFab const*,AMREX_SPACEDIM>& beta,
52 Location a_beta_loc);
54 {setBCoeffs (amrlev, beta, Location::FaceCenter);}
55
56 void setBCoeffs (int amrlev, Real beta);
57 void setBCoeffs (int amrlev, Vector<Real> const& beta);
58
59 // Tells the solver that EB boundaries have Dirichlet bc's specified by "phi"
60 void setEBDirichlet (int amrlev, const MultiFab& phi, const MultiFab& beta);
61 void setEBDirichlet (int amrlev, const MultiFab& phi, Real beta);
62 void setEBDirichlet (int amrlev, const MultiFab& phi, Vector<Real> const& beta);
63
64 // Tells the solver that EB boundaries have homogeneous Dirichlet bc's
65 void setEBHomogDirichlet (int amrlev, const MultiFab& beta);
66 void setEBHomogDirichlet (int amrlev, Real beta);
67 void setEBHomogDirichlet (int amrlev, Vector<Real> const& beta);
68
69 int getNComp () const override { return m_ncomp; }
70
71 bool needsUpdate () const override {
73 }
74 void update () override;
75
76 std::unique_ptr<FabFactory<FArrayBox> > makeFactory (int amrlev, int mglev) const final;
77
78 bool isCrossStencil () const override { return false; }
79
80 void applyBC (int amrlev, int mglev, MultiFab& in, BCMode bc_mode, StateMode s_mode,
81 const MLMGBndry* bndry=nullptr, bool skip_fillboundary=false) const final;
82 void apply (int amrlev, int mglev, MultiFab& out, MultiFab& in, BCMode bc_mode,
83 StateMode s_mode, const MLMGBndry* bndry=nullptr) const override;
84 void compGrad (int amrlev, const Array<MultiFab*,AMREX_SPACEDIM>& grad,
85 MultiFab& sol, Location loc) const final;
86
87 void prepareForSolve () override;
88 bool isSingular (int amrlev) const override { return m_is_singular[amrlev]; }
89 bool isBottomSingular () const override { return m_is_singular[0]; }
90 void Fapply (int amrlev, int mglev, MultiFab& out, const MultiFab& in) const final;
91 void Fsmooth (int amrlev, int mglev, MultiFab& sol, const MultiFab& rhs, int redblack) const final;
92 void FFlux (int amrlev, const MFIter& mfi,
94 const FArrayBox& sol, Location loc,
95 int face_only=0) const final;
96
97 void normalize (int amrlev, int mglev, MultiFab& mf) const final;
98
99 Real getAScalar () const final { return m_a_scalar; }
100 Real getBScalar () const final { return m_b_scalar; }
101 MultiFab const* getACoeffs (int amrlev, int mglev) const final
102 { return &(m_a_coeffs[amrlev][mglev]); }
103 Array<MultiFab const*,AMREX_SPACEDIM> getBCoeffs (int amrlev, int mglev) const final
104 { return amrex::GetArrOfConstPtrs(m_b_coeffs[amrlev][mglev]); }
105
106 std::unique_ptr<MLLinOp> makeNLinOp (int /*grid_size*/) const final {
107 amrex::Abort("MLABecLaplacian::makeNLinOp: Not implemented");
108 return std::unique_ptr<MLLinOp>{};
109 }
110
111 void restriction (int, int, MultiFab& crse, MultiFab& fine) const final;
112
113 void interpolation (int amrlev, int fmglev, MultiFab& fine, const MultiFab& crse) const final;
114
115 void averageDownSolutionRHS (int camrlev, MultiFab& crse_sol, MultiFab& crse_rhs,
116 const MultiFab& fine_sol, const MultiFab& fine_rhs) final;
117
118 void getEBFluxes (const Vector<MultiFab*>& a_flux,
119 const Vector<MultiFab*>& a_sol) const override;
120
122
123#if defined(AMREX_USE_HYPRE) && (AMREX_SPACEDIM > 1)
124 [[nodiscard]] std::unique_ptr<Hypre> makeHypre (Hypre::Interface hypre_interface) const override;
125#endif
126
127#if defined(AMREX_USE_PETSC) && (AMREX_SPACEDIM > 1)
128 [[nodiscard]] std::unique_ptr<PETScABecLap> makePETSc () const override;
129#endif
130
131 Real m_a_scalar = std::numeric_limits<Real>::quiet_NaN();
132 Real m_b_scalar = std::numeric_limits<Real>::quiet_NaN();
135
136 bool m_scalars_set = false;
137 bool m_acoef_set = false;
138
139protected:
140
141 int m_ncomp = 1;
142
143 bool m_needs_update = true;
144
145 Location m_beta_loc; // Location of coefficients: face centers or face centroids
146 Location m_phi_loc; // Location of solution variable: cell centers or cell centroids
147
149
152
154
155 mutable int m_is_eb_inhomog;
156
157 //
158 // functions
159 //
160 bool isEBDirichlet () const noexcept { return m_eb_phi[0] != nullptr; }
161
164 const Vector<MultiFab*>& b_eb);
165 void averageDownCoeffs ();
166 void averageDownCoeffsToCoarseAmrLevel (int flev);
167
168 [[nodiscard]] bool supportRobinBC () const noexcept override { return true; }
169
171};
172
174
175// Tag for applyBC EB version
176template <typename T>
177struct MLMGABCEBTag {
180 T bcloc;
181 amrex::Box bx;
182 amrex::BoundCond bctype;
183 int blen;
184 int comp;
185 int dir;
186 int is_eb;
187 int side;
188 int local_index;
189
191 amrex::Box const& box() const noexcept { return bx; }
192};
193
195
196}
197
198#endif
#define AMREX_FORCE_INLINE
Definition AMReX_Extension.H:119
#define AMREX_GPU_HOST_DEVICE
Definition AMReX_GpuQualifiers.H:20
Array4< Real > fine
Definition AMReX_InterpFaceRegister.cpp:90
Array4< int const > mask
Definition AMReX_InterpFaceRegister.cpp:93
Array4< Real const > crse
Definition AMReX_InterpFaceRegister.cpp:92
Maintain an identifier for boundary condition types.
Definition AMReX_BoundCond.H:20
A Fortran Array of REALs.
Definition AMReX_FArrayBox.H:231
Interface
Definition AMReX_Hypre.H:21
Iterator for looping ever tiles and boxes of amrex::FabArray based containers.
Definition AMReX_MFIter.H:85
Definition AMReX_MLCellABecLap.H:14
bool needsUpdate() const override
Does it need update if it's reused?
Definition AMReX_MLCellABecLap.H:47
typename MLLinOpT< MF >::Location Location
Definition AMReX_MLCellABecLap.H:20
typename MLLinOpT< MF >::BCMode BCMode
Definition AMReX_MLCellLinOp.H:31
typename MLLinOpT< MF >::StateMode StateMode
Definition AMReX_MLCellLinOp.H:32
Definition AMReX_MLEBABecLap.H:20
~MLEBABecLap() override
bool isCrossStencil() const override
Definition AMReX_MLEBABecLap.H:78
MLEBABecLap(MLEBABecLap &&)=delete
void prepareForSolve() override
Definition AMReX_MLEBABecLap.cpp:687
int m_is_eb_inhomog
Definition AMReX_MLEBABecLap.H:155
MLEBABecLap(const MLEBABecLap &)=delete
bool m_acoef_set
Definition AMReX_MLEBABecLap.H:137
Vector< Vector< std::unique_ptr< MultiFab > > > m_eb_b_coeffs
Definition AMReX_MLEBABecLap.H:151
void setPhiOnCentroid()
Definition AMReX_MLEBABecLap.cpp:104
Real getBScalar() const final
Definition AMReX_MLEBABecLap.H:100
Real m_b_scalar
Definition AMReX_MLEBABecLap.H:132
std::unique_ptr< MLLinOp > makeNLinOp(int) const final
Definition AMReX_MLEBABecLap.H:106
Vector< std::unique_ptr< MultiFab > > m_eb_phi
Definition AMReX_MLEBABecLap.H:150
bool supportRobinBC() const noexcept override
Definition AMReX_MLEBABecLap.H:168
void Fapply(int amrlev, int mglev, MultiFab &out, const MultiFab &in) const final
Definition AMReX_MLEBABecLap_F.cpp:12
void setBCoeffs(int amrlev, const Array< MultiFab const *, 3 > &beta, Location a_beta_loc)
Definition AMReX_MLEBABecLap.cpp:142
void restriction(int, int, MultiFab &crse, MultiFab &fine) const final
Definition AMReX_MLEBABecLap.cpp:951
void FFlux(int amrlev, const MFIter &mfi, const Array< FArrayBox *, 3 > &flux, const FArrayBox &sol, Location loc, int face_only=0) const final
Definition AMReX_MLEBABecLap_F.cpp:304
void applyRobinBCTermsCoeffs()
Definition AMReX_MLEBABecLap.cpp:1442
void setACoeffs(int amrlev, const MultiFab &alpha)
Definition AMReX_MLEBABecLap.cpp:126
MultiFab const * getACoeffs(int amrlev, int mglev) const final
Definition AMReX_MLEBABecLap.H:101
void normalize(int amrlev, int mglev, MultiFab &mf) const final
Definition AMReX_MLEBABecLap.cpp:858
Vector< Vector< MultiFab > > m_a_coeffs
Definition AMReX_MLEBABecLap.H:133
void averageDownSolutionRHS(int camrlev, MultiFab &crse_sol, MultiFab &crse_rhs, const MultiFab &fine_sol, const MultiFab &fine_rhs) final
Definition AMReX_MLEBABecLap.cpp:1006
void interpolation(int amrlev, int fmglev, MultiFab &fine, const MultiFab &crse) const final
Definition AMReX_MLEBABecLap.cpp:959
void applyBC(int amrlev, int mglev, MultiFab &in, BCMode bc_mode, StateMode s_mode, const MLMGBndry *bndry=nullptr, bool skip_fillboundary=false) const final
Definition AMReX_MLEBABecLap.cpp:1016
void averageDownCoeffs()
Definition AMReX_MLEBABecLap.cpp:608
bool isEBDirichlet() const noexcept
Definition AMReX_MLEBABecLap.H:160
void Fsmooth(int amrlev, int mglev, MultiFab &sol, const MultiFab &rhs, int redblack) const final
Definition AMReX_MLEBABecLap_F.cpp:157
void getEBFluxes(const Vector< MultiFab * > &a_flux, const Vector< MultiFab * > &a_sol) const override
Definition AMReX_MLEBABecLap.cpp:1369
MLEBABecLap & operator=(const MLEBABecLap &)=delete
Vector< int > m_is_singular
Definition AMReX_MLEBABecLap.H:153
std::unique_ptr< FabFactory< FArrayBox > > makeFactory(int amrlev, int mglev) const final
Definition AMReX_MLEBABecLap.cpp:33
void setEBDirichlet(int amrlev, const MultiFab &phi, const MultiFab &beta)
Definition AMReX_MLEBABecLap.cpp:191
Vector< Vector< iMultiFab > > m_cc_mask
Definition AMReX_MLEBABecLap.H:148
int m_ncomp
Definition AMReX_MLEBABecLap.H:141
void apply(int amrlev, int mglev, MultiFab &out, MultiFab &in, BCMode bc_mode, StateMode s_mode, const MLMGBndry *bndry=nullptr) const override
Definition AMReX_MLEBABecLap.cpp:1324
void averageDownCoeffsToCoarseAmrLevel(int flev)
Definition AMReX_MLEBABecLap.cpp:664
bool needsUpdate() const override
Does it need update if it's reused?
Definition AMReX_MLEBABecLap.H:71
void setEBHomogDirichlet(int amrlev, const MultiFab &beta)
Definition AMReX_MLEBABecLap.cpp:401
void compGrad(int amrlev, const Array< MultiFab *, 3 > &grad, MultiFab &sol, Location loc) const final
Definition AMReX_MLEBABecLap.cpp:732
bool m_needs_update
Definition AMReX_MLEBABecLap.H:143
Real getAScalar() const final
Definition AMReX_MLEBABecLap.H:99
MLEBABecLap()=default
Real m_a_scalar
Definition AMReX_MLEBABecLap.H:131
Vector< Vector< TagVector< MLMGABCEBTag< RT > > > > m_eb_bc_tags
Definition AMReX_MLEBABecLap.H:170
int getNComp() const override
Return number of components.
Definition AMReX_MLEBABecLap.H:69
bool isSingular(int amrlev) const override
Is it singular on given AMR level?
Definition AMReX_MLEBABecLap.H:88
void setScalars(Real a, Real b)
Definition AMReX_MLEBABecLap.cpp:110
void update() override
Update for reuse.
Definition AMReX_MLEBABecLap.cpp:1333
void averageDownCoeffsSameAmrLevel(int amrlev, Vector< MultiFab > &a, Vector< Array< MultiFab, 3 > > &b, const Vector< MultiFab * > &b_eb)
Definition AMReX_MLEBABecLap.cpp:633
void define(const Vector< Geometry > &a_geom, const Vector< BoxArray > &a_grids, const Vector< DistributionMapping > &a_dmap, const LPInfo &a_info, const Vector< EBFArrayBoxFactory const * > &a_factory, int a_ncomp=1)
Definition AMReX_MLEBABecLap.cpp:43
bool isBottomSingular() const override
Is the bottom of MG singular?
Definition AMReX_MLEBABecLap.H:89
Location m_phi_loc
Definition AMReX_MLEBABecLap.H:146
void setBCoeffs(int amrlev, const Array< MultiFab const *, 3 > &beta)
Definition AMReX_MLEBABecLap.H:53
Array< MultiFab const *, 3 > getBCoeffs(int amrlev, int mglev) const final
Definition AMReX_MLEBABecLap.H:103
bool m_scalars_set
Definition AMReX_MLEBABecLap.H:136
Vector< Vector< Array< MultiFab, 3 > > > m_b_coeffs
Definition AMReX_MLEBABecLap.H:134
Location m_beta_loc
Definition AMReX_MLEBABecLap.H:145
Definition AMReX_MLMGBndry.H:12
A collection (stored as an array) of FArrayBox objects.
Definition AMReX_MultiFab.H:40
This class is a thin wrapper around std::vector. Unlike vector, Vector::operator[] provides bound che...
Definition AMReX_Vector.H:28
amrex_real Real
Floating Point Type for Fields.
Definition AMReX_REAL.H:79
std::array< T, N > Array
Definition AMReX_Array.H:26
Definition AMReX_Amr.cpp:49
std::array< T const *, 3 > GetArrOfConstPtrs(const std::array< T, 3 > &a) noexcept
Definition AMReX_Array.H:1017
void Abort(const std::string &msg)
Print out message to cerr and exit via abort().
Definition AMReX.cpp:230
std::unique_ptr< Hypre > makeHypre(const BoxArray &grids, const DistributionMapping &dmap, const Geometry &geom, MPI_Comm comm_, Hypre::Interface interface, const iMultiFab *overset_mask)
Definition AMReX_Hypre.cpp:12
A multidimensional array accessor.
Definition AMReX_Array4.H:224
Definition AMReX_MLLinOp.H:36
Definition AMReX_MLEBABecLap.H:13