ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
MixEuler.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 MIXEULER_H
32#define MIXEULER_H
33
34#include "../Mixture.h"
35
38class MixEuler : public Mixture
39{
40 public:
41 MixEuler();
42 virtual ~MixEuler();
43
44 virtual void allocateAndCopyMixture(Mixture** mixture);
45 virtual void copyMixture(Mixture& /*mixture*/) {};
46 virtual double computeDensity(const double* /*alphak*/, const double* /*rhok*/) { return 0.; };
47 virtual double computePressure(const double* /*alphak*/, const double* /*pk*/) { return 0.; };
48 virtual double computeInternalEnergy(const double* /*Yk*/, const double* /*ek*/) { return 0.; };
49 virtual double computeFrozenSoundSpeed(const double* /*Yk*/, const double* /*ck*/) { return 0.; };
50
51 virtual void computeMixtureVariables(Phase** /*vecPhase*/) {};
52 virtual void computeTotalEnergy(std::vector<QuantitiesAddPhys*>& /*vecGPA*/) {};
53 virtual void totalEnergyToInternalEnergy(std::vector<QuantitiesAddPhys*>& /*vecGPA*/) {};
54
55 virtual void localProjection(const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/) {};
56 virtual void reverseProjection(const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/) {};
57
58 //Specific methods for data printing
59 //----------------------------------
60 virtual int getNumberScalars() const { return 0; };
61 virtual int getNumberVectors() const { return 0; };
62 virtual double returnScalar(const int& /*numVar*/) const { return 0.; };
63 virtual Coord returnVector(const int& /*numVar*/) const { return 0; };
64 virtual std::string returnNameScalar(const int& /*numVar*/) const { return 0; };
65 virtual std::string returnNameVector(const int& /*numVar*/) const { return 0; };
66
67 //Specific methods for parallel computing
68 //---------------------------------------
69 virtual int numberOfTransmittedVariables() const { return 0; };
70 virtual void fillBuffer(double* /*buffer*/, int& /*counter*/) const {};
71 virtual void fillBuffer(std::vector<double>& /*dataToSend*/) const {};
72 virtual void getBuffer(double* /*buffer*/, int& /*counter*/) {};
73 virtual void getBuffer(std::vector<double>& /*dataToReceive*/, int& /*counter*/) {};
74
75 //Specific methods for second order
76 //---------------------------------
77 virtual void computeSlopesMixture(const Mixture& /*sLeft*/, const Mixture& /*sRight*/, const double& /*distance*/) {};
78 virtual void setToZero() {};
79 virtual void setToMax() {};
80 virtual void extrapolate(const Mixture& /*slope*/, const double& /*distance*/) {};
81 virtual void limitSlopes(const Mixture& /*slopeGauche*/, const Mixture& /*slopeDroite*/, Limiter& /*globalLimiter*/) {};
82 virtual void setMin(const Mixture& /*mixture1*/, const Mixture& /*mixture2*/) {};
83 virtual void setMax(const Mixture& /*mixture1*/, const Mixture& /*mixture2*/) {};
84 virtual void computeGradientLimiter(const Limiter& /*globalLimiter*/, const Mixture& /*mixture*/, const Mixture& /*mixtureMin*/, const Mixture& /*mixtureMax*/, const Mixture& /*slope*/) {};
85
86 //Specific methods for parallele computing at second order
87 //--------------------------------------------------------
88 virtual int numberOfTransmittedSlopes() const { return 0; };
89 virtual void fillBufferSlopes(double* /*buffer*/, int& /*counter*/) const {};
90 virtual void getBufferSlopes(double* /*buffer*/, int& /*counter*/) {};
91
92 //Accessors
93 //---------
94 virtual const double& getDensity() const { return Errors::defaultDouble; };
95 virtual const double& getPressure() const { return Errors::defaultDouble; };
96 virtual const double& getU() const { return Errors::defaultDouble; };
97 virtual const double& getV() const { return Errors::defaultDouble; };
98 virtual const double& getW() const { return Errors::defaultDouble; };
99 virtual const Coord& getVelocity() const { return Coord::defaultCoord; };
101 virtual const double& getEnergy() const { return Errors::defaultDouble; };
102 virtual const double& getTotalEnergy() const { return Errors::defaultDouble; };
103 virtual const double& getFrozenSoundSpeed() const { return Errors::defaultDouble; };
104 virtual const double& getWoodSoundSpeed() const { return Errors::defaultDouble; };
105
106 virtual void setPressure(const double& /*p*/) {};
107 virtual void setVelocity(const double& /*u*/, const double& /*v*/, const double& /*w*/) {};
108 virtual void setVelocity(const Coord& /*vit*/) {};
109 virtual void setU(const double& /*u*/) {};
110 virtual void setV(const double& /*v*/) {};
111 virtual void setW(const double& /*w*/) {};
112 virtual void setTotalEnergy(double& /*totalEnergy*/) {};
113
114 //Operators
115 //---------
116 virtual void changeSign() {};
117 virtual void multiplyAndAdd(const Mixture& /*slopesMixtureTemp*/, const double& /*coeff*/) {};
118 virtual void divide(const double& /*coeff*/) {};
119
120 protected:
121 private:
122
123};
124
125#endif // MIXEULER_H
Class for a coordinate system object such as coordinates of the vertex or a vector.
Definition Coord.h:43
static Coord defaultCoordNonConst
Default Coord object (non-const version)
Definition Coord.h:58
static const Coord defaultCoord
Default Coord object (const version)
Definition Coord.h:55
static constexpr double defaultDouble
Definition Errors.h:93
Definition Limiter.h:38
Mixture variables for Euler equations (single phase)
Definition MixEuler.h:39
virtual void setPressure(const double &)
Definition MixEuler.h:106
virtual void setMax(const Mixture &, const Mixture &)
Definition MixEuler.h:83
virtual void getBuffer(std::vector< double > &, int &)
Definition MixEuler.h:73
virtual double computePressure(const double *, const double *)
Compute mixture pressure.
Definition MixEuler.h:47
virtual const double & getDensity() const
Definition MixEuler.h:94
virtual void localProjection(const Coord &, const Coord &, const Coord &)
velocity vector projection in a local Cartesian coordinate system
Definition MixEuler.h:55
virtual void copyMixture(Mixture &)
Copy mixture in mixture attributes.
Definition MixEuler.h:45
virtual void computeMixtureVariables(Phase **)
Fills some mixture attributes from a phase array.
Definition MixEuler.h:51
virtual const double & getV() const
Definition MixEuler.h:97
virtual void computeGradientLimiter(const Limiter &, const Mixture &, const Mixture &, const Mixture &, const Mixture &)
Definition MixEuler.h:84
virtual void limitSlopes(const Mixture &, const Mixture &, Limiter &)
Definition MixEuler.h:81
virtual void setVelocity(const double &, const double &, const double &)
Definition MixEuler.h:107
virtual void computeSlopesMixture(const Mixture &, const Mixture &, const double &)
Definition MixEuler.h:77
virtual int numberOfTransmittedVariables() const
Definition MixEuler.h:69
virtual void setVelocity(const Coord &)
Definition MixEuler.h:108
virtual double computeInternalEnergy(const double *, const double *)
Compute mixture specific internal energy.
Definition MixEuler.h:48
virtual void reverseProjection(const Coord &, const Coord &, const Coord &)
velocity vector reverse projection in the absolute Cartesian coordinate system
Definition MixEuler.h:56
virtual const double & getEnergy() const
Definition MixEuler.h:101
virtual int numberOfTransmittedSlopes() const
Definition MixEuler.h:88
virtual double computeFrozenSoundSpeed(const double *, const double *)
Compute mixture frozen speed of sound.
Definition MixEuler.h:49
virtual const double & getW() const
Definition MixEuler.h:98
virtual void setToZero()
Definition MixEuler.h:78
virtual const double & getWoodSoundSpeed() const
Definition MixEuler.h:104
virtual void setU(const double &)
Definition MixEuler.h:109
virtual void fillBufferSlopes(double *, int &) const
Definition MixEuler.h:89
virtual void multiplyAndAdd(const Mixture &, const double &)
Definition MixEuler.h:117
virtual const double & getTotalEnergy() const
Definition MixEuler.h:102
virtual void fillBuffer(double *, int &) const
Definition MixEuler.h:70
virtual void setW(const double &)
Definition MixEuler.h:111
virtual Coord returnVector(const int &) const
Definition MixEuler.h:63
virtual const double & getU() const
Definition MixEuler.h:96
MixEuler()
Definition MixEuler.cpp:37
virtual void getBuffer(double *, int &)
Definition MixEuler.h:72
virtual void extrapolate(const Mixture &, const double &)
Definition MixEuler.h:80
virtual int getNumberVectors() const
Definition MixEuler.h:61
virtual void setToMax()
Definition MixEuler.h:79
virtual void setV(const double &)
Definition MixEuler.h:110
virtual void allocateAndCopyMixture(Mixture **mixture)
Copy mixture attributes in mixture.
Definition MixEuler.cpp:45
virtual double computeDensity(const double *, const double *)
Compute mixture density.
Definition MixEuler.h:46
virtual int getNumberScalars() const
Definition MixEuler.h:60
virtual void divide(const double &)
Definition MixEuler.h:118
virtual Coord & getVelocity()
Definition MixEuler.h:100
virtual void changeSign()
Definition MixEuler.h:116
virtual double returnScalar(const int &) const
Definition MixEuler.h:62
virtual void getBufferSlopes(double *, int &)
Definition MixEuler.h:90
virtual const double & getPressure() const
Definition MixEuler.h:95
virtual void setTotalEnergy(double &)
Definition MixEuler.h:112
virtual void fillBuffer(std::vector< double > &) const
Definition MixEuler.h:71
virtual void setMin(const Mixture &, const Mixture &)
Definition MixEuler.h:82
virtual ~MixEuler()
Definition MixEuler.cpp:41
virtual const Coord & getVelocity() const
Definition MixEuler.h:99
virtual std::string returnNameScalar(const int &) const
Definition MixEuler.h:64
virtual void totalEnergyToInternalEnergy(std::vector< QuantitiesAddPhys * > &)
Compute mixture internal specific energy from total one taking account for energies associated to ext...
Definition MixEuler.h:53
virtual const double & getFrozenSoundSpeed() const
Definition MixEuler.h:103
virtual std::string returnNameVector(const int &) const
Definition MixEuler.h:65
virtual void computeTotalEnergy(std::vector< QuantitiesAddPhys * > &)
Compute mixture total specific energy from internal one taking account for energies associated to ext...
Definition MixEuler.h:52
Abstract class for mixture variables.
Definition Mixture.h:43
Abstract class for a phase.
Definition Phase.h:47