chombo-discharge
Loading...
Searching...
No Matches
CD_CdrDomainBCImplem.H
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2021-2026 SINTEF Energy Research
3 *
4 * SPDX-License-Identifier: GPL-3.0-or-later
5 */
6
13#ifndef CD_CDRDOMAINBCIMPLEM_H
14#define CD_CDRDOMAINBCIMPLEM_H
15
16// Our includes
17#include <CD_CdrDomainBC.H>
18#include <CD_NamespaceHeader.H>
19
21{
22 // TLDR: The default constructor populates the m_bcTypes and m_bcFunctions with wall functions and types. Users
23 // can later override these.
24
25 // Flux function which returns zero everywhere.
26 auto wallBc = [](const RealVect& a_position, const Real a_time) -> Real {
27 return 0.0;
28 };
29
30 for (int dir = 0; dir < SpaceDim; dir++) {
31 for (SideIterator sit; sit.ok(); ++sit) {
32 const DomainSide domainSide = this->domainSide(dir, sit());
33
34 m_bcTypes.emplace(domainSide, BcType::Wall);
36 }
37 }
38}
39
42
45{
47}
48
54
60
61void
66
67void
72
73#include <CD_NamespaceFooter.H>
74
75#endif
Declaration of domain boundary condition types for CdrSolver.
~CdrDomainBC()
Destructor. Does nothing.
Definition CD_CdrDomainBCImplem.H:40
const FluxFunction & getBcFunction(const DomainSide &a_domainSide) const
Get the BC type on a particular domain side.
Definition CD_CdrDomainBCImplem.H:56
void setBcFunction(const DomainSide &a_domainSide, const FluxFunction &a_function)
Set the BC type on a domain side.
Definition CD_CdrDomainBCImplem.H:68
CdrDomainBC()
Initializing constructor.
Definition CD_CdrDomainBCImplem.H:20
std::function< Real(const RealVect a_position, const Real a_time)> FluxFunction
Function which maps f(R^3,t) : R. Used for setting the associated value and boundary condition type.
Definition CD_CdrDomainBC.H:52
const BcType & getBcType(const DomainSide &a_domainSide) const
Get the BC type on a particular domain side.
Definition CD_CdrDomainBCImplem.H:50
std::map< DomainSide, FluxFunction > m_bcFunctions
BC functions on various domain edges.
Definition CD_CdrDomainBC.H:147
std::map< DomainSide, BcType > m_bcTypes
BC types on various domain edges.
Definition CD_CdrDomainBC.H:142
std::pair< int, Side::LoHiSide > DomainSide
Alias for mapping a direction and side. The first element in pair is the coordinate direction and the...
Definition CD_CdrDomainBC.H:57
void setBcType(const DomainSide &a_domainSide, const BcType &a_bcType)
Set the BC type on a domain side.
Definition CD_CdrDomainBCImplem.H:62
BcType
Boundary condition types for the CDR solvers.
Definition CD_CdrDomainBC.H:38
DomainSide domainSide(const int a_dir, const Side::LoHiSide a_side) const
Create a domain side from dir/side.
Definition CD_CdrDomainBCImplem.H:44
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