chombo-discharge
Loading...
Searching...
No Matches
CD_ItoLayout.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_ITOLAYOUT_H
14#define CD_ITOLAYOUT_H
15
16// Our includes
17#include <CD_ItoSolver.H>
18#include <CD_NamespaceHeader.H>
19
20template <class T>
21class ItoIterator;
22
29template <class T>
31{
32public:
36 ItoLayout() = delete;
37
43
47 virtual ~ItoLayout();
48
53 virtual phase::which_phase
54 getPhase() const;
55
60 virtual ItoIterator<T>
61 iterator();
62
67 virtual const std::string
68 getRealm() const;
69
74 virtual void
76
81 virtual void
83
87 virtual void
89
93 virtual void
95
100 virtual void
101 allocate();
102
107 virtual void
109
116 virtual void
117 preRegrid(const int a_lbase, const int a_finestLevel);
118
123 virtual void
124 initialData();
125
130 virtual void
132
138 virtual void
140
144 virtual void
145 remap();
146
151 virtual void
153
158 virtual void
160
167 virtual void
168 regrid(const int a_lmin, const int a_oldFinestLevel, const int a_newFinestLevel);
169
173 virtual void
175
180 virtual void
182
187 virtual void
189
194 virtual void
196
201 virtual void
202 setVerbosity(const int a_verbosity);
203
211 virtual void
212 setTime(const int a_step, const Real a_time, const Real a_dt);
213
218 virtual void
220
225 virtual void
227
233 virtual void
240 virtual void
242
248 virtual Real
249 computeDt();
250
257 virtual Real
259
267 virtual Real
269
275 virtual Real
277
285 virtual size_t
287
293 getSolvers();
294
300 getSpecies();
301
309
316 getDensities();
317
325
333
341
342protected:
347
352
357
362
367
372};
373
380template <class T, class S>
382{
383public:
387 ItoFactory();
388
392 ~ItoFactory();
393
402};
403
404#include <CD_NamespaceFooter.H>
405
406#include <CD_ItoLayoutImplem.H>
407
408#endif
Implementation of CD_ItoLayout.H.
Declaration of solver class for Ito diffusion.
Factory class for making ItoLayout.
Definition CD_ItoLayout.H:382
~ItoFactory()
Destructor (does nothing).
Definition CD_ItoLayoutImplem.H:413
RefCountedPtr< ItoLayout< T > > newLayout(const Vector< RefCountedPtr< ItoSpecies > > &a_species) const
Factory method which creates a new layout from a set of species. This can do automated casting betwee...
Definition CD_ItoLayoutImplem.H:418
ItoFactory()
Constructor.
Definition CD_ItoLayoutImplem.H:409
"Iterator" class for going through solvers in an ItoLayout.
Definition CD_ItoIterator.H:25
Class for holding a set of ItoSolvers.
Definition CD_ItoLayout.H:31
virtual Real computeAdvectiveDt()
Compute the classical advection time step for all solvers. This returns dt = dx/max(v) where max(v) t...
Definition CD_ItoLayoutImplem.H:287
virtual void allocate()
Allocate internals for all solvers.
Definition CD_ItoLayoutImplem.H:87
virtual void parseRuntimeOptions()
Utility function – parse runtime options for all solvers.
Definition CD_ItoLayoutImplem.H:78
virtual Vector< EBAMRCellData * > getDiffusionFunctions()
Get all diffusion coefficients.
Definition CD_ItoLayoutImplem.H:367
virtual Real computeDt()
Compute smallest possible time step.
Definition CD_ItoLayoutImplem.H:273
virtual void addSolver(RefCountedPtr< T > &a_solver)
Add solver to the list of solvers.
Definition CD_ItoLayoutImplem.H:96
virtual Vector< EBAMRCellData * > getMobilityFunctions()
Get all mobility mesh functions.
Definition CD_ItoLayoutImplem.H:379
virtual void makeSuperparticles(const ItoSolver::WhichContainer a_whichContainer, const int a_ppc)
Rearrange the input container particle into new superparticles – this is done for all solvers.
Definition CD_ItoLayoutImplem.H:211
virtual ItoIterator< T > iterator()
Return a fresh iterator. The iterator is a simple random access object that can iterate through the s...
Definition CD_ItoLayoutImplem.H:37
virtual void setVerbosity(const int a_verbosity)
Set verbosity for each solver.
Definition CD_ItoLayoutImplem.H:175
phase::which_phase m_phase
Phase where solvers live.
Definition CD_ItoLayout.H:366
virtual void initialData()
Fill all solvers with initial data.
Definition CD_ItoLayoutImplem.H:121
virtual void organizeParticlesByCell(const ItoSolver::WhichContainer a_whichContainer)
Sort ItoSolver particles by cell – this is done for all solvers.
Definition CD_ItoLayoutImplem.H:193
virtual void interpolateVelocities()
Interpolate velocities.
Definition CD_ItoLayoutImplem.H:103
virtual Real computeDiffusiveDt()
Compute the classical diffusive time step dt = dx*dx/(2*D) where D is the diffusion coefficient (not ...
Definition CD_ItoLayoutImplem.H:315
virtual void regrid(const int a_lmin, const int a_oldFinestLevel, const int a_newFinestLevel)
Regrid method – calls the regrid method for each solver.
Definition CD_ItoLayoutImplem.H:130
virtual Vector< RefCountedPtr< ItoSpecies > > & getSpecies()
Get species.
Definition CD_ItoLayoutImplem.H:336
virtual void parseOptions()
Utility function – parse options for all solvers.
Definition CD_ItoLayoutImplem.H:69
Vector< RefCountedPtr< ItoSpecies > > m_species
ItoSolver species.
Definition CD_ItoLayout.H:356
virtual Real computeHopDt(const Real a_maxCellsToMove)
Compute the largest dt which restricts all particles to move less than a_maxCellsToMove.
Definition CD_ItoLayoutImplem.H:301
virtual void define(const Vector< RefCountedPtr< ItoSpecies > > &a_species)
Define function.
Definition CD_ItoLayoutImplem.H:62
virtual void organizeParticlesByPatch(const ItoSolver::WhichContainer a_whichContainer)
Sort ItoSolver particles by patch – this is done for all solvers.
Definition CD_ItoLayoutImplem.H:202
ItoLayout()=delete
Disallowed weak construction.
Vector< RefCountedPtr< T > > m_solvers
ItoSolver solvers.
Definition CD_ItoLayout.H:351
virtual Vector< EBAMRCellData * > getVelocityFunctions()
Get all velocity functions.
Definition CD_ItoLayoutImplem.H:343
virtual Vector< ParticleContainer< ItoParticle > * > getParticles(const ItoSolver::WhichContainer a_whichContainer)
Get particle containers of a particular container type.
Definition CD_ItoLayoutImplem.H:391
virtual phase::which_phase getPhase() const
Return phase where the solvers are defined.
Definition CD_ItoLayoutImplem.H:403
std::string m_realm
Realm where all the solvers are registered.
Definition CD_ItoLayout.H:346
virtual void setTime(const int a_step, const Real a_time, const Real a_dt)
Set time for each solver.
Definition CD_ItoLayoutImplem.H:184
int m_verbosity
Verbosity level.
Definition CD_ItoLayout.H:361
virtual ~ItoLayout()
Destructor (does nothing).
Definition CD_ItoLayoutImplem.H:32
virtual void setComputationalGeometry(const RefCountedPtr< ComputationalGeometry > &a_computationalGeometry)
Set the computational geometry. This sets the computational geometry for each solver.
Definition CD_ItoLayoutImplem.H:157
virtual void remap()
Remap function – calls remap(ItoSolver::WhichContainer::bulk) for each solver.
Definition CD_ItoLayoutImplem.H:245
virtual void depositParticles()
All solvers deposit their particles.
Definition CD_ItoLayoutImplem.H:229
bool m_isDefined
Layout is defined or not.
Definition CD_ItoLayout.H:371
virtual const std::string getRealm() const
Get the realm name where the solvers are defined.
Definition CD_ItoLayoutImplem.H:44
virtual void preRegrid(const int a_lbase, const int a_finestLevel)
Utility function which caches states before regrid step.
Definition CD_ItoLayoutImplem.H:112
virtual Vector< RefCountedPtr< T > > & getSolvers()
Get solvers all solvers.
Definition CD_ItoLayoutImplem.H:329
virtual size_t getNumParticles(const ItoSolver::WhichContainer a_ptype, const bool a_localOnly)
Get total number of particles.
Definition CD_ItoLayoutImplem.H:261
virtual void setAmr(const RefCountedPtr< AmrMesh > &a_amr)
Set AmrMesh object for each solver.
Definition CD_ItoLayoutImplem.H:148
virtual void setRealm(const std::string &a_realm)
Set the realm where the solvers are defined.
Definition CD_ItoLayoutImplem.H:51
virtual void registerOperators()
Register operators. Calls registerOperators for each solver.
Definition CD_ItoLayoutImplem.H:139
virtual Vector< EBAMRCellData * > getDensities()
Get all densities.
Definition CD_ItoLayoutImplem.H:355
virtual void setPhase(phase::which_phase a_phase)
Set phase for each solver.
Definition CD_ItoLayoutImplem.H:166
WhichContainer
Enum class for distinguishing various types of particle containers.
Definition CD_ItoSolver.H:50
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
which_phase
Enumeration of supported phases.
Definition CD_MultiFluidIndexSpace.H:38