chombo-discharge
Loading...
Searching...
No Matches
CD_EBHelmholtzRobinEBBC.H
1/*
2 * SPDX-FileCopyrightText: 2021-2026 SINTEF Energy Research
3 *
4 * SPDX-License-Identifier: GPL-3.0-or-later
5 */
6
7/*
8 @file CD_EBHelmholtzRobinEBBC.H
9 @brief Declaration of a boundary condition class for EBHelmholtzOp
10 @author Robert Marskar
11*/
12
13#ifndef CD_EBHELMHOLTZROBINEBBC_H
14#define CD_EBHELMHOLTZROBINEBBC_H
15
16// Std includes
17#include <functional>
18
19// Our includes
20#include <CD_VofUtils.H>
21#include <CD_EBHelmholtzEBBC.H>
22#include <CD_NamespaceHeader.H>
23
31{
32public:
37
46 EBHelmholtzRobinEBBC(const int a_order, const int a_weight, const Real a_A, const Real a_B, const Real a_C);
47
57 const int a_weight,
58 const std::function<Real(const RealVect& a_pos)>& a_A,
59 const std::function<Real(const RealVect& a_pos)>& a_B,
60 const std::function<Real(const RealVect& a_pos)>& a_C);
61
65 virtual ~EBHelmholtzRobinEBBC();
66
71 void
72 setOrder(const int a_order);
73
78 void
79 setWeight(const int a_weight);
80
85 virtual void
87
94 void
95 setCoefficients(const Real a_A, const Real a_B, const Real a_C);
96
103 void
105 const std::function<Real(const RealVect& a_pos)>& a_B,
106 const std::function<Real(const RealVect& a_pos)>& a_C);
107
118 virtual void
121 const EBCellFAB& a_phi,
123 const DataIndex& a_dit,
124 const Real& a_beta,
125 const bool& a_homogeneousPhysBC) const override;
126
127protected:
132
137
142
147
152
157
162
167
172
177
182
186 virtual void
187 define() override;
188
200 const DataIndex& a_dit,
202 const int a_order) const;
203};
204
205#include <CD_NamespaceFooter.H>
206
207#endif
Various functions for getting Vofs near cut-cells.
Base class for passing EB boundary conditions into EBHelmholtzOp.
Definition CD_EBHelmholtzEBBC.H:30
Base class for passing Robin EB boundary conditions into EBHelmholtzOp.
Definition CD_EBHelmholtzRobinEBBC.H:31
int m_domainDropOrder
Special flag for dropping stencil order when domains become coarser than this.
Definition CD_EBHelmholtzRobinEBBC.H:151
Real m_constantA
Constant A-coefficient.
Definition CD_EBHelmholtzRobinEBBC.H:156
VoFStencil getInterpolationStencil(const VolIndex &a_vof, const DataIndex &a_dit, const VofUtils::Neighborhood a_neighborhood, const int a_order) const
Get a least-squares based interpolation stencil.
Definition CD_EBHelmholtzRobinEBBC.cpp:301
bool m_useFunction
Use function for BC value.
Definition CD_EBHelmholtzRobinEBBC.H:136
EBHelmholtzRobinEBBC()
Default constructor. Must subsequently set coefficients.
Definition CD_EBHelmholtzRobinEBBC.cpp:23
virtual ~EBHelmholtzRobinEBBC()
Destructor.
Definition CD_EBHelmholtzRobinEBBC.cpp:63
Real m_constantB
Constant B-coefficient.
Definition CD_EBHelmholtzRobinEBBC.H:161
std::function< Real(const RealVect &a_pos)> m_functionB
Function-based B-coefficient.
Definition CD_EBHelmholtzRobinEBBC.H:176
std::function< Real(const RealVect &a_pos)> m_functionC
Function-based C-coefficient.
Definition CD_EBHelmholtzRobinEBBC.H:181
virtual void define() override
User define function.
Definition CD_EBHelmholtzRobinEBBC.cpp:125
int m_weight
Stencil weight (for weighting equations in least squares reconstruction)
Definition CD_EBHelmholtzRobinEBBC.H:146
void setOrder(const int a_order)
Set BC order.
Definition CD_EBHelmholtzRobinEBBC.cpp:69
int m_order
Stencil order.
Definition CD_EBHelmholtzRobinEBBC.H:141
Real m_constantC
Constant C-coefficient.
Definition CD_EBHelmholtzRobinEBBC.H:166
bool m_useConstant
Use constant for BC.
Definition CD_EBHelmholtzRobinEBBC.H:131
void setWeight(const int a_weight)
Set equation weights for least squares reconstruction.
Definition CD_EBHelmholtzRobinEBBC.cpp:79
std::function< Real(const RealVect &a_pos)> m_functionA
Function-based A-coefficient.
Definition CD_EBHelmholtzRobinEBBC.H:171
virtual void applyEBFlux(VoFIterator &a_vofit, EBCellFAB &a_Lphi, const EBCellFAB &a_phi, const BaseIVFAB< Real > &a_Bcoef, const DataIndex &a_dit, const Real &a_beta, const bool &a_homogeneousPhysBC) const override
Apply the EB flux. This is the version that is called by EBHelmholtzOp.
Definition CD_EBHelmholtzRobinEBBC.cpp:251
virtual void setDomainDropOrder(const int a_domainSize)
Drop BC order if domain size is equal or below this.
Definition CD_EBHelmholtzRobinEBBC.cpp:89
void setCoefficients(const Real a_A, const Real a_B, const Real a_C)
Set constant coefficients.
Definition CD_EBHelmholtzRobinEBBC.cpp:97
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:38
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:26
Neighborhood
Neighborhood type.
Definition CD_VofUtils.H:56