chombo-discharge
Loading...
Searching...
No Matches
CD_EddingtonSP1.H
Go to the documentation of this file.
1/* chombo-discharge
2 * Copyright © 2021 SINTEF Energy Research.
3 * Please refer to Copyright.txt and LICENSE in the chombo-discharge root directory.
4 */
5
12#ifndef CD_EddingtonSP1_H
13#define CD_EddingtonSP1_H
14
15// Std includes
16#include <random>
17
18// Chombo includes
19#include <AMRMultiGrid.H>
20#include <AMRTGA.H>
21#include <EBBackwardEuler.H>
22#include <EBSimpleSolver.H>
23#include <BiCGStabSolver.H>
24#include <GMRESSolver.H>
25
26// Our includes
27#include <CD_RtSolver.H>
29#include <CD_EddingtonSP1DomainBc.H>
30#include <CD_NamespaceHeader.H>
31
35class EddingtonSP1 : public RtSolver
36{
37public:
45 static Real
47
52
57
62
66 virtual ~EddingtonSP1();
67
72 operator=(const EddingtonSP1& a_other) = delete;
73
78 operator=(const EddingtonSP1&& a_other) = delete;
79
88 virtual bool
89 advance(const Real a_dt, EBAMRCellData& a_phi, const EBAMRCellData& a_source, const bool a_zeroPhi = false) override;
90
100 virtual void
101 advanceEuler(EBAMRCellData& a_phi, const EBAMRCellData& a_source, const Real a_dt, const bool a_zeroPhi) noexcept;
102
106 virtual void
107 parseOptions() override;
108
112 virtual void
113 parseRuntimeOptions() override;
114
122 virtual void
126
130 virtual void
131 allocate() override;
132
138 virtual void
139 preRegrid(const int a_base, const int a_oldFinestLevel) override;
140
144 virtual void
145 deallocate() override;
146
153 virtual void
154 regrid(const int a_lmin, const int a_oldFinestLevel, const int a_newFinestLevel) override;
155
159 virtual void
160 registerOperators() override;
161
167 virtual void
169
175 virtual void
177
183 virtual void
185
192 virtual void
194
198 virtual void
199 writePlotFile() override;
200
206#ifdef CH_USE_HDF5
207 virtual void
208 writeCheckpointLevel(HDF5Handle& a_handle, const int a_level) const override;
209#endif
210
216#ifdef CH_USE_HDF5
217 virtual void
218 readCheckpointLevel(HDF5Handle& a_handle, const int a_level) override;
219#endif
220
221protected:
225 static constexpr Real m_alpha = 1.0;
226
230 static constexpr Real m_beta = -1.0;
231
236 {
237 Simple,
238 BiCGStab,
239 GMRES,
240 };
241
245 enum class MultigridType
246 {
247 VCycle,
248 WCycle,
249 };
250
254 enum class EBBCType
255 {
256 Dirichlet,
257 Neumann,
258 Larsen
259 };
260
265
270
275
280
285
290
295
300
305
310
315
320
325
330
335
340
344 Real m_multigridExitTolerance;
345
349 Real m_multigridExitHang;
350
355
360
365
370
375
380
385
390
395
400
405
410
415
420
425
429 virtual void
430 setupSolver();
431
435 virtual void
437
447 virtual void
451 const int a_lvl,
452 const DataIndex& a_dit);
453
457 virtual void
459
463 virtual void
465
473 virtual std::string
474 makeBcString(const int a_dir, const Side::LoHiSide a_side) const;
475
481 parseBcString(const std::string a_str) const;
482
486 virtual void
488
492 virtual void
493 parseEBBC();
494
498 virtual void
500
504 virtual void
506
510 virtual void
512
516 virtual void
518
522 virtual void
524
528 virtual void
530
534 virtual void
536};
537
538#include <CD_NamespaceFooter.H>
539
540#endif
Declaration of a factory class for making Poisson operators for multigrid.
Abstract parent class for various radiative transfer solvers.
Smoother
Relaxation method for the operators.
Definition CD_EBHelmholtzOp.H:47
Class which maps boundary condition types to a side and direction.
Definition CD_EddingtonSP1DomainBc.H:31
std::function< Real(const RealVect a_position, const Real a_time)> BcFunction
Function which maps f(R^3,t) : R. Used for setting the associated value and boundary condition type.
Definition CD_EddingtonSP1DomainBc.H:46
BcType
Boundary condition type.
Definition CD_EddingtonSP1DomainBc.H:37
Radiative tranfer equation solver in the SP1 (diffusion) approximation.
Definition CD_EddingtonSP1.H:36
virtual void setupSolver()
Set up geometric multigrid.
Definition CD_EddingtonSP1.cpp:739
virtual void computeBoundaryFlux(EBAMRIVData &a_ebFlux, const EBAMRCellData &a_phi) override
Compute the boundary flux. For Eddington, the boundary flux is = c*phi/2.
Definition CD_EddingtonSP1.cpp:1047
EBAMRCellData m_resid
Multigrid residue.
Definition CD_EddingtonSP1.H:394
RefCountedPtr< EBHelmholtzOpFactory > m_helmholtzOpFactory
Operator factory.
Definition CD_EddingtonSP1.H:379
GMRESSolver< LevelData< EBCellFAB > > m_gmres
GMRES solver.
Definition CD_EddingtonSP1.H:374
virtual void regrid(const int a_lmin, const int a_oldFinestLevel, const int a_newFinestLevel) override
Regrid function for this class.
Definition CD_EddingtonSP1.cpp:527
MultigridType m_multigridType
GMG multigrid type.
Definition CD_EddingtonSP1.H:269
int m_multigridBcWeight
Multigrid EBBC weight (only relevant for Dirichlet)
Definition CD_EddingtonSP1.H:324
virtual void advanceEuler(EBAMRCellData &a_phi, const EBAMRCellData &a_source, const Real a_dt, const bool a_zeroPhi) noexcept
Advance using the Euler rule.
Definition CD_EddingtonSP1.cpp:673
virtual void parseReflection()
Parse reflection coefficients for Robin bcs.
Definition CD_EddingtonSP1.cpp:442
EBHelmholtzOp::Smoother m_multigridRelaxMethod
Relaxation type for gmg.
Definition CD_EddingtonSP1.H:264
BottomSolverType m_bottomSolverType
Bottom solver type.
Definition CD_EddingtonSP1.H:329
EBAMRFluxData m_helmBco
b-coefficient
Definition CD_EddingtonSP1.H:404
virtual void computeFlux(EBAMRCellData &a_flux, const EBAMRCellData &a_phi) override
Compute the flux. For Eddington, the flux is F = -c/(3*kappa)*grad(phi)
Definition CD_EddingtonSP1.cpp:1138
virtual void setupMultigrid()
Set the GMG solver.
Definition CD_EddingtonSP1.cpp:973
EddingtonSP1 & operator=(const EddingtonSP1 &a_other)=delete
Disallowed copy assignment.
virtual void writePlotFile() override
Write plot file.
Definition CD_EddingtonSP1.cpp:1180
int m_multigridPreSmooth
Number of smoothings before averaging.
Definition CD_EddingtonSP1.H:294
virtual void setupHelmholtzFactory()
Set the operator factory.
Definition CD_EddingtonSP1.cpp:895
virtual void setHelmholtzCoefficients()
Set multigrid coefficients.
Definition CD_EddingtonSP1.cpp:754
Real m_reflectCoefTwo
Reflection coefficient.
Definition CD_EddingtonSP1.H:359
virtual void setDefaultDomainBcFunctions()
Set default domain BC functions.
Definition CD_EddingtonSP1.cpp:95
virtual void deallocate() override
Deallocate internal storage.
Definition CD_EddingtonSP1.cpp:511
virtual ~EddingtonSP1()
Destructor.
Definition CD_EddingtonSP1.cpp:57
int m_minCellsBottom
Set bottom drop depth.
Definition CD_EddingtonSP1.H:339
virtual bool advance(const Real a_dt, EBAMRCellData &a_phi, const EBAMRCellData &a_source, const bool a_zeroPhi=false) override
Advance RTE onto state a_phi.
Definition CD_EddingtonSP1.cpp:580
virtual void parsePlotVariables()
Parse plot variables.
Definition CD_EddingtonSP1.cpp:327
EddingtonSP1 & operator=(const EddingtonSP1 &&a_other)=delete
Disallowed move assignment.
int m_multigridMaxIterations
Maximum number of iterations.
Definition CD_EddingtonSP1.H:309
virtual void preRegrid(const int a_base, const int a_oldFinestLevel) override
Cache state.
Definition CD_EddingtonSP1.cpp:472
static Real s_defaultDomainBcFunction(const RealVect a_position, const Real a_time)
Default function for space-time dependence of domain boundary conditions.
Definition CD_EddingtonSP1.cpp:36
virtual std::string makeBcString(const int a_dir, const Side::LoHiSide a_side) const
Make domain bc string.
Definition CD_EddingtonSP1.cpp:126
EddingtonSP1(const EddingtonSP1 &&a_other)=delete
Disallowed move construction.
virtual void parseEBBC()
Parse domain BC settings.
Definition CD_EddingtonSP1.cpp:270
std::pair< EBBCType, Real > m_ebbc
Associated boundary condition on the embedded boundary.
Definition CD_EddingtonSP1.H:424
int m_numSmoothingsForSimpleSolver
Number of smoothing for bottom solver.
Definition CD_EddingtonSP1.H:334
EBSimpleSolver m_simpleSolver
multi-fluid simple solver
Definition CD_EddingtonSP1.H:384
virtual void parseDomainBC()
Parse domain BC settings.
Definition CD_EddingtonSP1.cpp:186
bool m_kappaScale
Use kappa scaling for source or not.
Definition CD_EddingtonSP1.H:279
static constexpr Real m_beta
Beta-coefficient for Helmholtz operator.
Definition CD_EddingtonSP1.H:230
EBAMRIVData m_helmBcoIrreg
b-coefficient
Definition CD_EddingtonSP1.H:409
bool m_isSolverSetup
Needs setup.
Definition CD_EddingtonSP1.H:274
virtual void setDomainSideBcFunction(const int a_dir, const Side::LoHiSide a_side, const EddingtonSP1DomainBc::BcFunction &a_function)
Set the boundary condition function on a domain side.
Definition CD_EddingtonSP1.cpp:111
EBAMRCellData m_cacheSrc
For regridding the source term. This is needed when doing a stationary solve.
Definition CD_EddingtonSP1.H:389
Real m_reflectCoefOne
Reflection coefficient.
Definition CD_EddingtonSP1.H:354
RefCountedPtr< AMRMultiGrid< LevelData< EBCellFAB > > > m_multigridSolver
Geometric multigrid solver.
Definition CD_EddingtonSP1.H:364
virtual void computeDensity(EBAMRCellData &a_isotropic, const EBAMRCellData &a_phi) override
Get isotropic part.
Definition CD_EddingtonSP1.cpp:1167
virtual void computeDomainFlux(EBAMRIFData &a_domainflux, const EBAMRCellData &a_phi) override
Compute the domain flux. For Eddington, the domain flux is = c*phi/2.
Definition CD_EddingtonSP1.cpp:1071
EddingtonSP1DomainBc m_domainBc
Wrapper calss.
Definition CD_EddingtonSP1.H:414
BiCGStabSolver< LevelData< EBCellFAB > > m_bicgstab
Conjugate gradient solver bottom MG level.
Definition CD_EddingtonSP1.H:369
int m_multigridBcOrder
Multigrid EBBC order (only relevant for Dirichlet)
Definition CD_EddingtonSP1.H:319
int m_multigridVerbosity
Verbosity for geometric multigrid.
Definition CD_EddingtonSP1.H:289
EddingtonSP1()
Weak constructor.
Definition CD_EddingtonSP1.cpp:41
EddingtonSP1(const EddingtonSP1 &a_other)=delete
Disallowed copy construction.
EBAMRCellData m_helmAco
a-coefficient
Definition CD_EddingtonSP1.H:399
virtual void setHelmholtzCoefficientsBox(EBCellFAB &a_helmAco, EBFluxFAB &a_helmBco, BaseIVFAB< Real > &a_helmBcoIrreg, const int a_lvl, const DataIndex &a_dit)
Set EBHelmholtzOp A- and B-coefficients.
Definition CD_EddingtonSP1.cpp:783
int m_multigridMinIterations
Minimum number of iterations.
Definition CD_EddingtonSP1.H:314
virtual void parseKappaScale()
Parse kappa-scaling or not.
Definition CD_EddingtonSP1.cpp:351
static constexpr Real m_alpha
Write checkpoint data into HDF5 file.
Definition CD_EddingtonSP1.H:225
BottomSolverType
Enum class for supported bottom solvers in multigrid.
Definition CD_EddingtonSP1.H:236
virtual void parseRuntimeOptions() override
Parse class options.
Definition CD_EddingtonSP1.cpp:80
virtual EddingtonSP1DomainBc::BcType parseBcString(const std::string a_str) const
Returns BC type based on string.
Definition CD_EddingtonSP1.cpp:160
virtual void parseOptions() override
Parse class options.
Definition CD_EddingtonSP1.cpp:61
virtual void allocate() override
Allocate internal storage.
Definition CD_EddingtonSP1.cpp:489
EBBCType
Enum for boundary condition types on EBs.
Definition CD_EddingtonSP1.H:255
virtual void registerOperators() override
Register operators.
Definition CD_EddingtonSP1.cpp:558
bool m_regridSlopes
Use slopes when regridding (or not)
Definition CD_EddingtonSP1.H:284
std::map< EddingtonSP1DomainBc::DomainSide, EddingtonSP1DomainBc::BcFunction > m_domainBcFunctions
Actual functions on domain edges (faces).
Definition CD_EddingtonSP1.H:419
virtual void parseStationary()
Parse whether or not this is a stationary solver.
Definition CD_EddingtonSP1.cpp:313
int m_multigridBottomSmooth
Number of smoothing before bottom solver.
Definition CD_EddingtonSP1.H:304
MultigridType
Enum for multigrid cycle types.
Definition CD_EddingtonSP1.H:246
int m_multigridPostSmooth
Number of smoothings before averaging.
Definition CD_EddingtonSP1.H:299
virtual void parseMultigridSettings()
Parse multigrid settings.
Definition CD_EddingtonSP1.cpp:359
virtual void parseRegridSlopes()
Parse whether or not to use slopes when regridding.
Definition CD_EddingtonSP1.cpp:459
Abstract RTE solver class for doing various kinds of radiative transfer equations....
Definition CD_RtSolver.H:30
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:37
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:25