ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
Phase.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 PHASE_H
32#define PHASE_H
33
34#include <fstream>
35#include "../Errors.h"
36#include "../Eos/Eos.h"
37#include "../Maths/Coord.h"
38#include "../Maths/Tensor.h"
39#include "../libTierces/tinyxml2.h"
40#include "../Order2/HeaderLimiter.h"
41#include "../Tools.h"
42
46class Phase
47{
48 public:
49 Phase();
50 virtual ~Phase();
53 void printPhase(std::ofstream& fileStream) const;
56 virtual void allocateAndCopyPhase(Phase** /*vecPhase*/) { Errors::errorMessage("allocateAndCopyPhase not available for requested phase type"); };
59 virtual void copyPhase(Phase& /*phase*/) { Errors::errorMessage("copyPhase not available for requested phase type"); };
63 virtual void extendedCalculusPhase(const Coord& /*velocity*/) { Errors::errorMessage("extendedCalculusPhase not available for requested phase type"); };
64
65 virtual void computeMassFraction(const double& /*density*/) { Errors::errorMessage("computeMassFraction not available for requested phase type"); };
66
67 virtual void localProjection(const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/) { Errors::errorMessage("projection not available for requested phase type"); };
68 virtual void reverseProjection(const Coord& /*normal*/, const Coord& /*tangent*/, const Coord& /*binormal*/) { Errors::errorMessage("reverseProjection not available for requested phase type"); };
69
70 //Specific methods for data printing
71 //----------------------------------
72 virtual int getNumberScalars() const { Errors::errorMessage("getNumberScalars not available for requested phase type"); return 0; };
73 virtual int getNumberVectors() const { Errors::errorMessage("getNumberVectors not available for requested phase type"); return 0; };
74 virtual double returnScalar(const int& /*numVar*/) const { Errors::errorMessage("returnScalar not available for requested phase type"); return 0.; };
75 virtual Coord returnVector(const int& /*numVar*/) const { Errors::errorMessage("returnVector not available for requested phase type"); return 0; };
76 virtual std::string returnNameScalar(const int& /*numVar*/) const { Errors::errorMessage("returnNameScalar not available for requested phase type"); return 0; };
77 virtual std::string returnNameVector(const int& /*numVar*/) const { Errors::errorMessage("returnNameVector not available for requested phase type"); return 0; };
78
79 //Specific method for reading from file
80 //-------------------------------------
81 virtual void setScalar(const int& /*numVar*/, const double& /*value*/) { Errors::errorMessage("setScalar not available for requested phase type"); };
82 virtual void setVector(const int& /*numVar*/, const Coord& /*value*/) { Errors::errorMessage("setVector not available for requested phase type"); };
83
84 //Specific methods for parallel computing
85 //---------------------------------------
86 virtual int numberOfTransmittedVariables() const { Errors::errorMessage("numberOfTransmittedVariables not available for requested phase type"); return 0; };
87 virtual void fillBuffer(double* /*buffer*/, int& /*counter*/) const { Errors::errorMessage("fillBuffer not available for requested phase type"); };
88 virtual void fillBuffer(std::vector<double>& /*dataToSend*/) const { Errors::errorMessage("fillBuffer not available for requested phase type"); };
89 virtual void getBuffer(double* /*buffer*/, int& /*counter*/, Eos** /*eos*/) { Errors::errorMessage("getBuffer not available for requested phase type"); };
90 virtual void getBuffer(std::vector<double>& /*dataToReceive*/, int& /*counter*/, Eos** /*eos*/) { Errors::errorMessage("getBuffer not available for requested phase type"); };
91
92 //Specific methods for second order
93 //---------------------------------
94 virtual void computeSlopesPhase(const Phase& /*sLeft*/, const Phase& /*sRight*/, const double& /*distance*/) { Errors::errorMessage("computeSlopesPhase not available for requested phase type"); };
95 virtual void setToZero() { Errors::errorMessage("setToZero not available for requested phase type"); };
96 virtual void setToMax() { Errors::errorMessage("setToMax not available for requested phase type"); };
97 virtual void extrapolate(const Phase& /*slope*/, const double& /*distance*/) { Errors::errorMessage("extrapolate not available for requested phase type"); };
98 virtual void limitSlopes(const Phase& /*slopeGauche*/, const Phase& /*slopeDroite*/, Limiter& /*globalLimiter*/, Limiter& /*volumeFractionLimiter*/) { Errors::errorMessage("limitSlopes not available for requested phase type"); };
99 virtual void setMin(const Phase& /*phase1*/, const Phase& /*phase2*/) { Errors::errorMessage("setMin not available for requested phase type"); };
100 virtual void setMax(const Phase& /*phase1*/, const Phase& /*phase2*/) { Errors::errorMessage("setMax not available for requested phase type"); };
101 virtual void computeGradientLimiter(const Limiter& /*globalLimiter*/, const Phase& /*phase*/, const Phase& /*phaseMin*/, const Phase& /*phaseMax*/, const Phase& /*slope*/) { Errors::errorMessage("computeGradientLimiter not available for requested phase type"); };
102
103 //Specific methods for parallele computing at second order
104 //--------------------------------------------------------
105 virtual int numberOfTransmittedSlopes() const { Errors::errorMessage("numberOfTransmittedSlopes not available for requested phase type"); return 0; };
106 virtual void fillBufferSlopes(double* /*buffer*/, int& /*counter*/) const { Errors::errorMessage("fillBufferSlopes not available for requested phase type"); };
107 virtual void getBufferSlopes(double* /*buffer*/, int& /*counter*/) { Errors::errorMessage("getBufferSlopes not available for requested phase type"); };
108
109 //Specific methods for solids
110 //---------------------------
111 virtual double getSquareLongitudinalWaveSpeed() const { Errors::errorMessage("getSquareLongitudinalWaveSpeed not available for requested phase type"); return Errors::defaultDouble; };
112
113 //Verifications
114 //-------------
115 virtual void verifyPhase(const std::string& /*message*/ = "") const { Errors::errorMessage("verifyPhase not available for requested phase type"); };
116 virtual void verifyAndCorrectPhase() { Errors::errorMessage("verifyAndCorrectPhase not available for requested phase type"); };
117 virtual void verifyAndCorrectDensityMax(const double& /*mass*/) { Errors::errorMessage("verifyAndCorrectDensityMax not available for requested phase type"); };
118 virtual void verifyAndCorrectDensityMax() { Errors::errorMessage("verifyAndCorrectDensityMax not available for requested phase type"); };
119
120 //Accessors
121 //---------
122 virtual const double& getAlpha() const { Errors::errorMessage("getAlpha not available for requested phase type"); return Errors::defaultDouble; };
123 virtual const double& getMassFraction() const { Errors::errorMessage("getMassFraction not available for requested phase type"); return Errors::defaultDouble; };
124 virtual const double& getDensity() const { Errors::errorMessage("getDensity not available for requested phase type"); return Errors::defaultDouble; };
125 virtual const double& getOmega() const { Errors::errorMessage("getOmega not available for requested phase type"); return Errors::defaultDouble; };
126 virtual const double& getEta() const { Errors::errorMessage("getEta not available for requested phase type"); return Errors::defaultDouble; };
127 virtual const double& getPressure() const { Errors::errorMessage("getPressure not available for requested phase type"); return Errors::defaultDouble; };
128 virtual const double& getY() const { Errors::errorMessage("getY not available for requested phase type"); return Errors::defaultDouble; };
129 virtual const double& getU() const { Errors::errorMessage("getU not available for requested phase type"); return Errors::defaultDouble; };
130 virtual const double& getV() const { Errors::errorMessage("getV not available for requested phase type"); return Errors::defaultDouble; };
131 virtual const double& getW() const { Errors::errorMessage("getW not available for requested phase type"); return Errors::defaultDouble; };
132 virtual Coord& getVelocity() { Errors::errorMessage("getVelocity not available for requested phase type"); return Coord::defaultCoordNonConst; };
133 virtual const Coord& getVelocity() const { Errors::errorMessage("getVelocity not available for requested phase type"); return Coord::defaultCoord; };
134 virtual const double& getVectorPX() const { Errors::errorMessage("getVectorPX not available for requested phase type"); return Errors::defaultDouble; };
135 virtual const double& getVectorPY() const { Errors::errorMessage("getVectorPY not available for requested phase type"); return Errors::defaultDouble; };
136 virtual const double& getVectorPZ() const { Errors::errorMessage("getVectorPZ not available for requested phase type"); return Errors::defaultDouble; };
137 virtual Coord& getVectorP() { Errors::errorMessage("getVectorP not available for requested phase type"); return Coord::defaultCoordNonConst; };
138 virtual const Coord& getVectorP() const { Errors::errorMessage("getVectorP not available for requested phase type"); return Coord::defaultCoordNonConst; };
139 virtual Eos* getEos() const { Errors::errorMessage("EOS not available for requested phase type"); return 0; };
140 virtual const double& getEnergy() const { Errors::errorMessage("getEnergy impossible avec type de phase demande"); return Errors::defaultDouble; };
141 virtual const double& getSoundSpeed() const { Errors::errorMessage("getSoundSpeed impossible avec type de phase demande"); return Errors::defaultDouble; };
142 virtual const double& getTotalEnergy() const { Errors::errorMessage("getTotalEnergy impossible avec type de phase demande"); return Errors::defaultDouble; };
143 virtual double getTemperature() const { Errors::errorMessage("getT impossible avec type de phase demande"); return 0.; };
144 virtual const double& getLambda() const { Errors::errorMessage("getLambda not available for requested phase type"); return Errors::defaultDouble; };
145 virtual const double& getEnergyCompaction() const { Errors::errorMessage("getEnergyCompaction not available for requested phase type"); return Errors::defaultDouble; };
146 virtual const Tensor& getCobase() const { Errors::errorMessage("getCobase not available for requested phase type"); return Tensor::defaultTensor; };
147 virtual Tensor& getCobase() { Errors::errorMessage("getCobase not available for requested phase type"); return Tensor::defaultTensorNonConst; };
148 virtual const double& getEnergyElastic() const { Errors::errorMessage("getEnergyElastic not available for requested phase type"); return Errors::defaultDouble; };
149 virtual const Tensor& getStressTensor() const { Errors::errorMessage("getStressTensor not available for requested phase type"); return Tensor::defaultTensor; };
150 virtual Tensor& getStressTensor() { Errors::errorMessage("getStressTensor not available for requested phase type"); return Tensor::defaultTensorNonConst; };
151
152 virtual void setAlpha(double /*alpha*/) { Errors::errorMessage("setAlpha not available for requested phase type"); };
153 virtual void setDensity(double /*density*/) { Errors::errorMessage("setDensity not available for requested phase type"); };
154 virtual void setOmega(const double& /*omega*/) { Errors::errorMessage("setOmega not available for requested phase type"); };
155 virtual void setEta(const double& /*eta*/) { Errors::errorMessage("setEta not available for requested phase type"); };
156 virtual void setPressure(double /*pressure*/) { Errors::errorMessage("setPressure not available for requested phase type"); };
157 virtual void setVelocity(const double& /*u*/, const double& /*v*/, const double& /*w*/) { Errors::errorMessage("setVelocity not available for requested phase type"); };
158 virtual void setVelocity(const Coord& /*vit*/) { Errors::errorMessage("setVelocity not available for requested phase type"); };
159 virtual void setU(const double& /*u*/) { Errors::errorMessage("setU not available for requested phase type"); };
160 virtual void setV(const double& /*v*/) { Errors::errorMessage("setV not available for requested phase type"); };
161 virtual void setW(const double& /*w*/) { Errors::errorMessage("setW not available for requested phase type"); };
162 virtual void setVectorP(const double& /*x*/, const double& /*y*/, const double& /*z*/) { Errors::errorMessage("setVector not available for requested phase type"); };
163 virtual void setVectorP(const Coord& /*vit*/) { Errors::errorMessage("setVectorP not available for requested phase type"); };
164 virtual void setX(const double& /*x*/) { Errors::errorMessage("setX not available for requested phase type"); };
165 virtual void setY(const double& /*y*/) { Errors::errorMessage("setY not available for requested phase type"); };
166 virtual void setZ(const double& /*z*/) { Errors::errorMessage("setZ not available for requested phase type"); };
167 virtual void setEos(Eos* /*eos*/) { Errors::errorMessage("impossible to associate EOS to the requested phase type"); };
168 virtual void setEnergy(double /*energy*/) { Errors::errorMessage("setEnergy not available for requested phase type"); };
169 virtual void setSoundSpeed(double /*soundSpeed*/) { Errors::errorMessage("setSoundSpeed not available for requested phase type"); };
170 virtual void setTotalEnergy(double /*totalEnergy*/) { Errors::errorMessage("setTotalEnergy not available for requested phase type"); };
171 virtual void setTotalEnergy(const double & /*energy*/, const Coord& /*vel*/) { Errors::errorMessage("setTotalEnergy not available for requested phase type"); };
172 virtual void setTemperature(double /*temperature*/) { Errors::errorMessage("setTemperature not available for requested phase type"); };
173 virtual void setLambda(double /*lambda*/) { Errors::errorMessage("setLambda not available for requested phase type"); };
174 virtual void setEnergyCompaction(double /*energyCompaction*/) { Errors::errorMessage("setEnergyCompaction not available for requested phase type"); };
175 virtual void setCobase(const Tensor& /*cobase*/) { Errors::errorMessage("setCobase not available for requested phase type"); };
176 virtual void setEnergyElastic(double /*energyElastic*/) { Errors::errorMessage("setEnergyElastic not available for requested phase type"); };
177 virtual void setStressTensor(const Tensor& /*stressTensor*/) { Errors::errorMessage("setStressTensor not available for requested phase type"); };
178
179 //Operators
180 //---------
181 virtual void changeSign() { Errors::errorMessage("changeSign not available for requested phase type"); };
182 virtual void multiplyAndAdd(const Phase& /*slopesPhasesTemp*/, const double& /*coeff*/) { Errors::errorMessage("multiplyAndAdd not available for requested phase type"); };
183 virtual void divide(const double& /*coeff*/) { Errors::errorMessage("divide not available for requested phase type"); };
184
185 protected:
186
187};
188
189extern int numberScalarsPhase;
190
191#endif // PHASE_H
int numberScalarsPhase
Definition Phase.cpp:33
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
General class for Equation of State (EOS).
Definition Eos.h:54
static void errorMessage(const std::string &message)
Definition Errors.cpp:56
static constexpr double defaultDouble
Definition Errors.h:93
Definition Limiter.h:38
Abstract class for a phase.
Definition Phase.h:47
virtual void fillBufferSlopes(double *, int &) const
Definition Phase.h:106
virtual int numberOfTransmittedSlopes() const
Definition Phase.h:105
virtual void setOmega(const double &)
Definition Phase.h:154
virtual const double & getVectorPX() const
Definition Phase.h:134
virtual void setToMax()
Definition Phase.h:96
virtual void setToZero()
Definition Phase.h:95
virtual void setAlpha(double)
Definition Phase.h:152
virtual std::string returnNameScalar(const int &) const
Definition Phase.h:76
virtual void setPressure(double)
Definition Phase.h:156
virtual const double & getPressure() const
Definition Phase.h:127
virtual void setMin(const Phase &, const Phase &)
Definition Phase.h:99
virtual const Tensor & getStressTensor() const
Definition Phase.h:149
virtual void setEnergyElastic(double)
Definition Phase.h:176
virtual void changeSign()
Definition Phase.h:181
virtual void verifyPhase(const std::string &="") const
Definition Phase.h:115
Phase()
Definition Phase.cpp:37
virtual const double & getV() const
Definition Phase.h:130
virtual const double & getY() const
Definition Phase.h:128
virtual const double & getDensity() const
Definition Phase.h:124
virtual const double & getTotalEnergy() const
Definition Phase.h:142
virtual const double & getAlpha() const
Definition Phase.h:122
virtual void setVelocity(const Coord &)
Definition Phase.h:158
virtual std::string returnNameVector(const int &) const
Definition Phase.h:77
virtual void setVectorP(const double &, const double &, const double &)
Definition Phase.h:162
void printPhase(std::ofstream &fileStream) const
Print phase variables in file stream.
Definition Phase.cpp:45
virtual const Coord & getVelocity() const
Definition Phase.h:133
virtual void setZ(const double &)
Definition Phase.h:166
virtual void extendedCalculusPhase(const Coord &)
Compute extra thermodynammical variables.
Definition Phase.h:63
virtual void computeMassFraction(const double &)
Definition Phase.h:65
virtual void setEta(const double &)
Definition Phase.h:155
virtual const double & getLambda() const
Definition Phase.h:144
virtual void getBuffer(double *, int &, Eos **)
Definition Phase.h:89
virtual void getBufferSlopes(double *, int &)
Definition Phase.h:107
virtual double returnScalar(const int &) const
Definition Phase.h:74
virtual Tensor & getCobase()
Definition Phase.h:147
virtual void reverseProjection(const Coord &, const Coord &, const Coord &)
Definition Phase.h:68
virtual void localProjection(const Coord &, const Coord &, const Coord &)
Definition Phase.h:67
virtual double getSquareLongitudinalWaveSpeed() const
Definition Phase.h:111
virtual void copyPhase(Phase &)
Copy phase in phase attributes.
Definition Phase.h:59
virtual void verifyAndCorrectPhase()
Definition Phase.h:116
virtual void setTotalEnergy(const double &, const Coord &)
Definition Phase.h:171
virtual void setEos(Eos *)
Definition Phase.h:167
virtual void fillBuffer(std::vector< double > &) const
Definition Phase.h:88
virtual void fillBuffer(double *, int &) const
Definition Phase.h:87
virtual void computeGradientLimiter(const Limiter &, const Phase &, const Phase &, const Phase &, const Phase &)
Definition Phase.h:101
virtual const double & getW() const
Definition Phase.h:131
virtual void setSoundSpeed(double)
Definition Phase.h:169
virtual const Tensor & getCobase() const
Definition Phase.h:146
virtual const double & getVectorPY() const
Definition Phase.h:135
virtual void computeSlopesPhase(const Phase &, const Phase &, const double &)
Definition Phase.h:94
virtual const double & getOmega() const
Definition Phase.h:125
virtual const Coord & getVectorP() const
Definition Phase.h:138
virtual const double & getEta() const
Definition Phase.h:126
virtual void setMax(const Phase &, const Phase &)
Definition Phase.h:100
virtual void setVectorP(const Coord &)
Definition Phase.h:163
virtual const double & getVectorPZ() const
Definition Phase.h:136
virtual void setX(const double &)
Definition Phase.h:164
virtual const double & getEnergy() const
Definition Phase.h:140
virtual void setTemperature(double)
Definition Phase.h:172
virtual void setU(const double &)
Definition Phase.h:159
virtual ~Phase()
Definition Phase.cpp:41
virtual void setDensity(double)
Definition Phase.h:153
virtual Coord & getVelocity()
Definition Phase.h:132
virtual void verifyAndCorrectDensityMax()
Definition Phase.h:118
virtual Coord returnVector(const int &) const
Definition Phase.h:75
virtual const double & getMassFraction() const
Definition Phase.h:123
virtual void allocateAndCopyPhase(Phase **)
Copy phase attributes in phase.
Definition Phase.h:56
virtual const double & getSoundSpeed() const
Definition Phase.h:141
virtual int getNumberScalars() const
Definition Phase.h:72
virtual void divide(const double &)
Definition Phase.h:183
virtual void limitSlopes(const Phase &, const Phase &, Limiter &, Limiter &)
Definition Phase.h:98
virtual const double & getU() const
Definition Phase.h:129
virtual void extrapolate(const Phase &, const double &)
Definition Phase.h:97
virtual void setVector(const int &, const Coord &)
Definition Phase.h:82
virtual void setEnergy(double)
Definition Phase.h:168
virtual int numberOfTransmittedVariables() const
Definition Phase.h:86
virtual void setCobase(const Tensor &)
Definition Phase.h:175
virtual void setTotalEnergy(double)
Definition Phase.h:170
virtual const double & getEnergyElastic() const
Definition Phase.h:148
virtual void setW(const double &)
Definition Phase.h:161
virtual double getTemperature() const
Definition Phase.h:143
virtual void setY(const double &)
Definition Phase.h:165
virtual void setV(const double &)
Definition Phase.h:160
virtual void setScalar(const int &, const double &)
Definition Phase.h:81
virtual void setEnergyCompaction(double)
Definition Phase.h:174
virtual Eos * getEos() const
Definition Phase.h:139
virtual void multiplyAndAdd(const Phase &, const double &)
Definition Phase.h:182
virtual Coord & getVectorP()
Definition Phase.h:137
virtual void getBuffer(std::vector< double > &, int &, Eos **)
Definition Phase.h:90
virtual int getNumberVectors() const
Definition Phase.h:73
virtual const double & getEnergyCompaction() const
Definition Phase.h:145
virtual void setLambda(double)
Definition Phase.h:173
virtual Tensor & getStressTensor()
Definition Phase.h:150
virtual void verifyAndCorrectDensityMax(const double &)
Definition Phase.h:117
virtual void setStressTensor(const Tensor &)
Definition Phase.h:177
virtual void setVelocity(const double &, const double &, const double &)
Definition Phase.h:157
Class for a matrix 3x3 system object.
Definition Tensor.h:46
static const Tensor defaultTensor
Default Tensor object (const version)
Definition Tensor.h:56
static Tensor defaultTensorNonConst
Default Tensor object (non-const version)
Definition Tensor.h:59