ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
FluxPUEq.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 FLUXPUEQ_H
32#define FLUXPUEQ_H
33
34#include "../UEq/FluxUEq.h"
35
36class FluxPUEq;
37
38#include "ModPUEq.h"
39
42class FluxPUEq : public FluxUEq
43{
44 public:
45 FluxPUEq(const int& numbPhases);
46 virtual ~FluxPUEq();
47
48 virtual void addNonCons(double coefA, const Cell* cell, const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/);
49 virtual void subtractNonCons(double coefA, const Cell* cell, const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/);
50 virtual void schemeCorrection(Cell& /*cell*/) const {};
51 virtual void correctionEnergy(Cell* cell, Prim type = vecPhases) const;
52
53 private:
54 friend class ModPUEq;
55};
56
57#endif // FLUXPUEQ_H
Prim
Enumeration for the primitive-variable type (usefull for second order, slopes, etc....
Definition Tools.h:39
@ vecPhases
Definition Tools.h:39
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 pressure-velocity-equilibrium (mechanical equilibrium) system of equations (Kapila...
Definition FluxPUEq.h:43
virtual void addNonCons(double coefA, const Cell *cell, const Coord &, const Coord &, const Coord &)
Add non conservative term to the flux.
Definition FluxPUEq.cpp:44
virtual void schemeCorrection(Cell &) const
Definition FluxPUEq.h:50
virtual void subtractNonCons(double coefA, const Cell *cell, const Coord &, const Coord &, const Coord &)
Subtract non conservative term to the flux.
Definition FluxPUEq.cpp:56
virtual void correctionEnergy(Cell *cell, Prim type=vecPhases) const
Method to correct energy in non conservative models using total energy conservation.
Definition FluxPUEq.cpp:68
virtual ~FluxPUEq()
Definition FluxPUEq.cpp:40
Flux class for the velocity-equilibrium system of equations.
Definition FluxUEq.h:43
Model class for the pressure-velocity-equilibrium (mechanical equilibrium) system of equations (Kapil...
Definition ModPUEq.h:45