ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
CellInterfaceO2.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 CELLINTERFACEO2_H
32#define CELLINTERFACEO2_H
33
34#include "../Order1/CellInterface.h"
35
37{
38 public:
40 CellInterfaceO2(int lvl); //Pour AMR
41 virtual ~CellInterfaceO2();
42
43 virtual void allocateSlopes(int& allocateSlopeLocal);
44 virtual void computeFlux(double& dtMax, Limiter& globalLimiter, Limiter& interfaceLimiter, Limiter& globalVolumeFractionLimiter, Limiter& interfaceVolumeFractionLimiter, Prim type = vecPhases);
46 virtual void solveRiemann(double& /*dtMax*/, Limiter& /*globalLimiter*/, Limiter& /*interfaceLimiter*/, Limiter& /*globalVolumeFractionLimiter*/, Limiter& /*interfaceVolumeFractionLimiter*/, Prim /*type*/ = vecPhases) = 0;
47
48 // -- Cartesian --
49 virtual void computeSlopes(Prim /*type*/ = vecPhases) {};
50
51 //Accessors
52 virtual Phase* getSlopesPhase(const int& /*phaseNumber*/) const { return nullptr; };
53 virtual Mixture* getSlopesMixture() const { return nullptr; };
54 virtual Transport* getSlopesTransport(const int& /*numberTransport*/) const { return nullptr; };
55
56 //For AMR method
57 virtual void creerCellInterfaceChild() {};
58 virtual void creerCellInterfaceChildInterne(const int& /*lvl*/, std::vector<CellInterface*>* /*childrenInternalCellInterfaces*/) {};
59};
60
65extern double* slopesTransportLocal1;
66extern double* slopesTransportLocal2;
67
68#endif // CELLINTERFACEO2_H
Phase ** slopesPhasesLocal1
Definition CellInterfaceO2.cpp:33
double * slopesTransportLocal1
Definition CellInterfaceO2.cpp:37
Mixture * slopesMixtureLocal1
Definition CellInterfaceO2.cpp:35
double * slopesTransportLocal2
Definition CellInterfaceO2.cpp:38
Mixture * slopesMixtureLocal2
Definition CellInterfaceO2.cpp:36
Phase ** slopesPhasesLocal2
Definition CellInterfaceO2.cpp:34
Prim
Enumeration for the primitive-variable type (usefull for second order, slopes, etc....
Definition Tools.h:39
@ vecPhases
Definition Tools.h:39
Definition CellInterfaceO2.h:37
virtual void computeSlopes(Prim=vecPhases)
Definition CellInterfaceO2.h:49
virtual void creerCellInterfaceChild()
Definition CellInterfaceO2.h:57
virtual Transport * getSlopesTransport(const int &) const
Definition CellInterfaceO2.h:54
virtual ~CellInterfaceO2()
Definition CellInterfaceO2.cpp:52
virtual Mixture * getSlopesMixture() const
Definition CellInterfaceO2.h:53
virtual void allocateSlopes(int &allocateSlopeLocal)
Definition CellInterfaceO2.cpp:58
virtual void solveRiemann(double &, Limiter &, Limiter &, Limiter &, Limiter &, Prim=vecPhases)=0
CellInterfaceO2()
Definition CellInterfaceO2.cpp:42
virtual Phase * getSlopesPhase(const int &) const
Definition CellInterfaceO2.h:52
virtual void creerCellInterfaceChildInterne(const int &, std::vector< CellInterface * > *)
Definition CellInterfaceO2.h:58
virtual void computeFlux(double &dtMax, Limiter &globalLimiter, Limiter &interfaceLimiter, Limiter &globalVolumeFractionLimiter, Limiter &interfaceVolumeFractionLimiter, Prim type=vecPhases)
Definition CellInterfaceO2.cpp:89
Definition CellInterface.h:52
Definition Limiter.h:38
Abstract class for mixture variables.
Definition Mixture.h:43
Abstract class for a phase.
Definition Phase.h:47
Class for additional transport equations.
Definition Transport.h:41