ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
FluxUEq.h
Go to the documentation of this file.
1//
2// ,---. ,--, .---. ,--, ,---. .-. .-.
3// | .-' .' .') / .-. ) .' .' | .-' | \| |
4// | `-. | |(_) | | |(_) | | __ | `-. | | |
5// | .-' \ \ | | | | \ \ ( _) | .-' | |\ |
6// | `--. \ `-. \ `-' / \ `-) ) | `--. | | |)|
7// /( __.' \____\ )---' )\____/ /( __.' /( (_)
8// (__) (_) (__) (__) (__)
9// Official webSite: https://code-mphi.github.io/ECOGEN/
10//
11// This file is part of ECOGEN.
12//
13// ECOGEN is the legal property of its developers, whose names
14// are listed in the copyright file included with this source
15// distribution.
16//
17// ECOGEN is free software: you can redistribute it and/or modify
18// it under the terms of the GNU General Public License as published
19// by the Free Software Foundation, either version 3 of the License,
20// or (at your option) any later version.
21//
22// ECOGEN is distributed in the hope that it will be useful,
23// but WITHOUT ANY WARRANTY; without even the implied warranty of
24// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25// GNU General Public License for more details.
26//
27// You should have received a copy of the GNU General Public License
28// along with ECOGEN (file LICENSE).
29// If not, see <http://www.gnu.org/licenses/>.
30
31#ifndef FLUXUEQ_H
32#define FLUXUEQ_H
33
34#include "../Flux.h"
35
36class FluxUEq;
37
38#include "ModUEq.h"
39
42class FluxUEq : public Flux
43{
44 public:
45 FluxUEq(const int& numbPhases);
46 virtual ~FluxUEq();
47
48 virtual void printFlux() const;
49 virtual void addFlux(double coefA);
50 virtual void addFlux(Flux* flux);
51 virtual void subtractFlux(double coefA);
52 virtual void addFluxRotatingRegion(double coefA);
53 virtual void subtractFluxRotatingRegion(double coefA);
54 virtual void multiply(double scalar);
55 virtual void setBufferFlux(Cell& cell);
56 virtual void buildCons(Phase** phases, Mixture* mixture);
57 virtual void buildPrim(Phase** phases, Mixture* mixture);
58 virtual void setToZero();
59 virtual void addNonCons(double coefA, const Cell* cell, const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/);
60 virtual void subtractNonCons(double coefA, const Cell* cell, const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/);
61 virtual void schemeCorrection(Cell& cell) const;
62
63 virtual void addFluxSmooth1D(double coefA, const Coord& normal, Cell* cell);
64 virtual void substractFluxSmooth1D(double coefA, const Coord& normal, Cell* cell);
65
66 virtual void addSymmetricTerms(Phase** phases, Mixture* mixture, const double& r, const double& v);
67 virtual void prepSourceTermsGravity(const Coord& g);
68 virtual void prepSourceTermsHeating(const double& q);
69 virtual void prepSourceTermsMRF(Cell* cell, const Coord& omega);
70
71 //Moving Reference Frame
72 virtual void addNonConsMrfFlux(Phase** phases);
73
74 // Accessors
75 //----------
76 virtual const double& getAlpha(const int& numPhase) const { return m_alpha[numPhase]; };
77 virtual const double& getMass(const int& numPhase) const { return m_mass[numPhase]; };
78 virtual const double& getEnergy(const int& numPhase) const { return m_energ[numPhase]; };
79 virtual const Coord& getMomentum() const { return m_momentum; };
80 virtual const double& getEnergyMix() const { return m_energMixture; };
81 virtual void setCons(const Flux* cons);
82
83 protected:
84 double* m_alpha;
85 double* m_mass;
86 double* m_energ;
89
90 private:
91 friend class ModUEq;
92 // To modify if needed, example: To add a class APUEqViscosity, add friend class APUEqViscosity.
93 friend class APUEqSurfaceTension;
94 friend class APUEqViscosity;
95 friend class APUEqConductivity;
96};
97
98#endif // FLUXUEQ_H
General class for thermal conductivity for the velocity-equilibrium system of equations.
Definition APUEqConductivity.h:41
General class for surface tension for the velocity-equilibrium system of equations.
Definition APUEqSurfaceTension.h:40
General class for thermal viscosity for the velocity-equilibrium system of equations.
Definition APUEqViscosity.h:41
Base class for a mesh cell.
Definition Cell.h:59
Class for a coordinate system object such as coordinates of the vertex or a vector.
Definition Coord.h:43
Flux class for the velocity-equilibrium system of equations.
Definition FluxUEq.h:43
Coord m_momentum
momentum array
Definition FluxUEq.h:87
virtual void schemeCorrection(Cell &cell) const
Definition FluxUEq.cpp:248
virtual void prepSourceTermsGravity(const Coord &g)
Gravity source term.
Definition FluxUEq.cpp:313
virtual const double & getAlpha(const int &numPhase) const
Definition FluxUEq.h:76
virtual void buildCons(Phase **phases, Mixture *mixture)
Build the conservative variables for a given cell from primitive one.
Definition FluxUEq.cpp:147
virtual void addNonCons(double coefA, const Cell *cell, const Coord &, const Coord &, const Coord &)
Add non conservative term to the flux.
Definition FluxUEq.cpp:224
virtual void prepSourceTermsMRF(Cell *cell, const Coord &omega)
MRF source term.
Definition FluxUEq.cpp:412
virtual void addSymmetricTerms(Phase **phases, Mixture *mixture, const double &r, const double &v)
Add symetric terms.
Definition FluxUEq.cpp:299
virtual ~FluxUEq()
Definition FluxUEq.cpp:45
virtual void multiply(double scalar)
multiply the flux of the corresponding model by a constant
Definition FluxUEq.cpp:126
virtual void prepSourceTermsHeating(const double &q)
Heating source term.
Definition FluxUEq.cpp:338
virtual void printFlux() const
Definition FluxUEq.cpp:54
virtual void addFluxRotatingRegion(double coefA)
Add flux to the rotating region in MRF context.
Definition FluxUEq.cpp:100
virtual const double & getMass(const int &numPhase) const
Definition FluxUEq.h:77
virtual void subtractNonCons(double coefA, const Cell *cell, const Coord &, const Coord &, const Coord &)
Subtract non conservative term to the flux.
Definition FluxUEq.cpp:236
virtual void setCons(const Flux *cons)
Definition FluxUEq.cpp:440
virtual void substractFluxSmooth1D(double coefA, const Coord &normal, Cell *cell)
Compute additionnal flux for 1D geometry with smooth varying cross section.
Definition FluxUEq.cpp:286
virtual void addFluxSmooth1D(double coefA, const Coord &normal, Cell *cell)
Compute additionnal flux for 1D geometry with smooth varying cross sectionFlux).
Definition FluxUEq.cpp:273
virtual void addNonConsMrfFlux(Phase **phases)
Definition FluxUEq.cpp:453
virtual void subtractFluxRotatingRegion(double coefA)
Subtract flux to the rotating region in MRF context.
Definition FluxUEq.cpp:113
double * m_alpha
volume fraction array
Definition FluxUEq.h:84
virtual void setBufferFlux(Cell &cell)
Temporary store the conservative variables of a given cell.
Definition FluxUEq.cpp:140
virtual const Coord & getMomentum() const
Definition FluxUEq.h:79
virtual void buildPrim(Phase **phases, Mixture *mixture)
Build the primitive variables for a given cell from conservative one.
Definition FluxUEq.cpp:161
virtual void addFlux(double coefA)
Add flux to the corresponding model flux.
Definition FluxUEq.cpp:61
double * m_mass
mass array
Definition FluxUEq.h:85
virtual void subtractFlux(double coefA)
Subtract flux to the corresponding model buffer flux.
Definition FluxUEq.cpp:87
virtual const double & getEnergyMix() const
Definition FluxUEq.h:80
virtual void setToZero()
set each attribute of the flux to zero
Definition FluxUEq.cpp:211
double m_energMixture
mixture energy
Definition FluxUEq.h:88
double * m_energ
specific internal energy array (may contain compaction energy for UEqSolid model)
Definition FluxUEq.h:86
virtual const double & getEnergy(const int &numPhase) const
Definition FluxUEq.h:78
Abstract class for conservative variables and fluxes.
Definition Flux.h:43
Abstract class for mixture variables.
Definition Mixture.h:43
Model class for the velocity-equilibrium system of equations.
Definition ModUEq.h:48
Abstract class for a phase.
Definition Phase.h:47