chombo-discharge
Loading...
Searching...
No Matches
CD_TracerParticleSolver.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_TRACERPARTICLESOLVER_H
14#define CD_TRACERPARTICLESOLVER_H
15
16// Our includes
17#include <CD_AmrMesh.H>
19#include <CD_TracerParticle.H>
21#include <CD_NamespaceHeader.H>
22
36template <typename P>
38{
39public:
44
50
56
63
70
77
81 virtual ~TracerParticleSolver();
82
86 virtual void
87 allocate();
88
92 virtual void
93 registerOperators() const;
94
99 virtual void
101
106 virtual void
108
113 virtual void
114 setName(const std::string& a_name) noexcept;
115
120 virtual void
121 setVolumeScale(const bool a_scale) noexcept;
122
127 virtual void
129
134 virtual void
136
144 virtual void
145 setTime(const int a_step, const Real a_time, const Real a_dt);
146
151 virtual void
153
160 virtual void
161 preRegrid(const int a_lbase, const int a_oldFinestLevel);
162
170 virtual void
171 regrid(const int a_lmin, const int a_oldFinestLevel, const int a_newFinestLevel);
172
176 virtual void
177 remap();
178
183 virtual void
185
190 virtual void
191 deposit(EBAMRCellData& a_phi) const noexcept;
192
197 virtual void
199
203 virtual void
205
209 virtual void
210 parseOptions();
211
215 virtual void
217
223 virtual void
225
230 virtual int
232
237 virtual Vector<std::string>
238 getPlotVariableNames() const;
239
248 virtual void
250 int& a_comp,
252 const int a_level) const noexcept;
253
254#ifdef CH_USE_HDF5
260 virtual void
262#endif
263
264#ifdef CH_USE_HDF5
270 virtual void
272#endif
273
278 virtual Real
279 computeDt() const;
280
285 virtual ParticleContainer<P>&
286 getParticles();
287
292 virtual const ParticleContainer<P>&
293 getParticles() const;
294
299 const EBAMRCellData&
300 getVelocityField() const;
301
306 virtual DepositionType
307 getDepositionType() const;
308
315
320 virtual DepositionType
321 getInterpolationType() const;
322
323protected:
328
333
338
343
348
353
358
363
368
373
378
383
388
393
398
403
408
413
417 void
419
423 void
425
429 void
431
439 template <class T, class Ret, Ret (T::*MemberFunc)() const>
440 void
444 const CoarseFineDeposition a_coarseFineDeposition) const noexcept;
445
456 virtual void
458 int& a_comp,
459 const EBAMRCellData& a_data,
461 const int a_level,
462 const bool a_interpToCentroids,
463 const bool a_interpGhost) const noexcept;
464};
465
466#include <CD_NamespaceFooter.H>
467
469
470#endif
Declaration of core class for handling AMR-related operations (with embedded boundaries)
CoarseFineDeposition
Coarse-fine deposition types (see CD_EBAMRParticleMesh for how these are handled).
Definition CD_CoarseFineDeposition.H:27
Declaration of base class for defining geometries.
DepositionType
Deposition types.
Definition CD_DepositionType.H:24
Declaration of a class for holding particles on an AMR hierarchy.
Implementation of CD_TracerParticleSolver.H.
Declaration of a tracer particle class.
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:38
virtual CoarseFineDeposition getCoarseFineDepositionType() const
Get the coarse-fine deposition type.
Definition CD_TracerParticleSolverImplem.H:711
ParticleContainer< P > m_particles
Computational particles.
Definition CD_TracerParticleSolver.H:412
virtual void remap()
Remap particles.
Definition CD_TracerParticleSolverImplem.H:339
virtual void setRealm(const std::string &a_realm)
Set the solver realm.
Definition CD_TracerParticleSolverImplem.H:233
void depositParticles(EBAMRCellData &a_phi, const ParticleContainer< T > &a_particles, const DepositionType a_baseDeposition, const CoarseFineDeposition a_coarseFineDeposition) const noexcept
Generic particle deposition method for putting a scalar field onto the mesh.
Definition CD_TracerParticleSolverImplem.H:736
void parsePlotVariables()
Parse plot variables.
Definition CD_TracerParticleSolverImplem.H:148
TracerParticleSolver & operator=(const TracerParticleSolver &a_other)=delete
Disallowed assignment operator.
virtual void registerOperators() const
Register operators needed for AMR core functionality.
Definition CD_TracerParticleSolverImplem.H:177
phase::which_phase m_phase
Phase where this solver lives.
Definition CD_TracerParticleSolver.H:367
virtual void setName(const std::string &a_name) noexcept
Set the solver name.
Definition CD_TracerParticleSolverImplem.H:209
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:26
virtual void setTime(const int a_step, const Real a_time, const Real a_dt)
Set the time for this solver.
Definition CD_TracerParticleSolverImplem.H:257
virtual void deposit(EBAMRCellData &a_phi) const noexcept
Deposit particle weight on mesh.
Definition CD_TracerParticleSolverImplem.H:363
CoarseFineDeposition m_coarseFineDeposition
Coarse-fine deposition strategy.
Definition CD_TracerParticleSolver.H:347
bool m_volumeScale
Do volumetric scaling when depositing (or not).
Definition CD_TracerParticleSolver.H:402
virtual void writeData(LevelData< EBCellFAB > &a_output, int &a_comp, const EBAMRCellData &a_data, const std::string a_outputRealm, const int a_level, const bool a_interpToCentroids, const bool a_interpGhost) const noexcept
Write data to output. Convenience function.
Definition CD_TracerParticleSolverImplem.H:539
virtual ~TracerParticleSolver()
Destructor.
Definition CD_TracerParticleSolverImplem.H:56
std::string m_realm
Realm where this solver lives.
Definition CD_TracerParticleSolver.H:352
virtual void preRegrid(const int a_lbase, const int a_oldFinestLevel)
Perform pre-regrid operations.
Definition CD_TracerParticleSolverImplem.H:307
DepositionType m_interpolation
Deposition type when interpolating to particles.
Definition CD_TracerParticleSolver.H:342
bool m_plotWeight
Hook for adding weight to plot file.
Definition CD_TracerParticleSolver.H:392
virtual ParticleContainer< P > & getParticles()
Get all particles.
Definition CD_TracerParticleSolverImplem.H:663
void parseDeposition()
Parse deposition method.
Definition CD_TracerParticleSolverImplem.H:91
void parseVerbosity()
Parse solver verbosity.
Definition CD_TracerParticleSolverImplem.H:163
int m_verbosity
Verbosity level.
Definition CD_TracerParticleSolver.H:387
RefCountedPtr< AmrMesh > m_amr
Handle to AMR mesh.
Definition CD_TracerParticleSolver.H:327
virtual Vector< std::string > getPlotVariableNames() const
Get plot variable names.
Definition CD_TracerParticleSolverImplem.H:482
DepositionType m_deposition
Deposition type when depositing particles to grid.
Definition CD_TracerParticleSolver.H:337
RefCountedPtr< ComputationalGeometry > m_computationalGeometry
Handle to computational geometry.
Definition CD_TracerParticleSolver.H:332
virtual void writePlotData(LevelData< EBCellFAB > &a_output, int &a_comp, const std::string &a_outputRealm, const int a_level) const noexcept
Write plot data.
Definition CD_TracerParticleSolverImplem.H:511
virtual void parseRuntimeOptions()
Parse solver run-time options.
Definition CD_TracerParticleSolverImplem.H:77
virtual void writePlotFile()
Write plot file.
Definition CD_TracerParticleSolverImplem.H:410
virtual void setDeposition(const DepositionType a_deposition) noexcept
Set deposition method.
Definition CD_TracerParticleSolverImplem.H:351
virtual void setPhase(const phase::which_phase &a_phase)
Set the solver phase.
Definition CD_TracerParticleSolverImplem.H:245
virtual DepositionType getDepositionType() const
Get the deposition type.
Definition CD_TracerParticleSolverImplem.H:699
Real m_dt
Time step.
Definition CD_TracerParticleSolver.H:372
TracerParticleSolver(const TracerParticleSolver &a_other)=delete
Disallowed constructor.
virtual void allocate()
Allocate storage for this solver.
Definition CD_TracerParticleSolverImplem.H:195
std::string m_name
Solver name.
Definition CD_TracerParticleSolver.H:357
bool m_plotVelocity
Hook for adding velocity field to plot file.
Definition CD_TracerParticleSolver.H:397
int m_timeStep
Time step.
Definition CD_TracerParticleSolver.H:382
virtual DepositionType getInterpolationType() const
Get the interpolation type.
Definition CD_TracerParticleSolverImplem.H:723
virtual void setComputationalGeometry(const RefCountedPtr< ComputationalGeometry > &a_compGeom)
Set the computational geometry.
Definition CD_TracerParticleSolverImplem.H:283
virtual void interpolateVelocities()
Interpolate particles velocities.
Definition CD_TracerParticleSolverImplem.H:393
const EBAMRCellData & getVelocityField() const
Return the velocity field.
Definition CD_TracerParticleSolverImplem.H:687
virtual void regrid(const int a_lmin, const int a_oldFinestLevel, const int a_newFinestLevel)
Regrid this solver.
Definition CD_TracerParticleSolverImplem.H:322
std::string m_className
Class name.
Definition CD_TracerParticleSolver.H:362
virtual void parseOptions()
Parse solver options.
Definition CD_TracerParticleSolverImplem.H:63
TracerParticleSolver(const TracerParticleSolver &&a_other)=delete
Disallowed move constructor.
virtual void setVelocity(const EBAMRCellData &a_velocityField)
Set the tracer particle velocity field.
Definition CD_TracerParticleSolverImplem.H:295
Real m_time
Time.
Definition CD_TracerParticleSolver.H:377
virtual void interpolateWeight(const EBAMRCellData &a_scalar) noexcept
Interpolate a scalar field onto the particle weight.
Definition CD_TracerParticleSolverImplem.H:381
EBAMRCellData m_velocityField
Mesh-based velocity field. Must be set through setVelocity.
Definition CD_TracerParticleSolver.H:407
virtual int getNumberOfPlotVariables() const
Get the number of plot variables.
Definition CD_TracerParticleSolverImplem.H:461
TracerParticleSolver & operator=(const TracerParticleSolver &&a_other)=delete
Disallowed move assignment operator.
virtual void setAmr(const RefCountedPtr< AmrMesh > &a_amrMesh)
Set AmrMesh.
Definition CD_TracerParticleSolverImplem.H:271
virtual Real computeDt() const
Compute dt = dx/max(v_x, v_y, v_z) minimized over all particles.
Definition CD_TracerParticleSolverImplem.H:623
virtual void setVolumeScale(const bool a_scale) noexcept
Turn on/off volume scaling.
Definition CD_TracerParticleSolverImplem.H:221
which_phase
Enumeration of supported phases.
Definition CD_MultiFluidIndexSpace.H:38