ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
PhaseEuler.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 PHASEEULER_H
32#define PHASEEULER_H
33
34#include "../Phase.h"
35#include "../../Eos/Eos.h"
36#include <fstream>
37
40class PhaseEuler : public Phase
41{
42 public:
43 PhaseEuler();
52 PhaseEuler(tinyxml2::XMLElement* material, Eos* eos, std::string fileName);
53 virtual ~PhaseEuler();
54
55 virtual void allocateAndCopyPhase(Phase** vecPhase);
56 virtual void copyPhase(Phase& vecPhase);
57 virtual void extendedCalculusPhase(const Coord& /*velocity*/);
58
59 virtual void localProjection(const Coord& normal, const Coord& tangent, const Coord& binormal);
60 virtual void reverseProjection(const Coord& normal, const Coord& tangent, const Coord& binormal);
61
62 //Specific methods for data printing
63 //----------------------------------
64 virtual int getNumberScalars() const { return 3; };
65 virtual int getNumberVectors() const { return 1; };
66 virtual double returnScalar(const int& numVar) const;
67 virtual Coord returnVector(const int& numVar) const;
68 virtual std::string returnNameScalar(const int& numVar) const;
69 virtual std::string returnNameVector(const int& numVar) const;
70
71 //Specific method for reading from file
72 //-------------------------------------
73 virtual void setScalar(const int& numVar, const double& value);
74 virtual void setVector(const int& numVar, const Coord& value);
75
76 //Specific methods for parallel computing
77 //---------------------------------------
78 virtual int numberOfTransmittedVariables() const;
79 virtual void fillBuffer(double* buffer, int& counter) const;
80 virtual void fillBuffer(std::vector<double>& dataToSend) const;
81 virtual void getBuffer(double* buffer, int& counter, Eos** eos);
82 virtual void getBuffer(std::vector<double>& dataToReceive, int& counter, Eos** eos);
83
84 //Specific methods for second order
85 //---------------------------------
86 virtual void computeSlopesPhase(const Phase& sLeft, const Phase& sRight, const double& distance);
87 virtual void setToZero();
88 virtual void setToMax();
89 virtual void extrapolate(const Phase& slope, const double& distance);
90 virtual void limitSlopes(const Phase& slopeGauche, const Phase& slopeDroite, Limiter& globalLimiter, Limiter& /*volumeFractionLimiter*/);
91 virtual void setMin(const Phase& phase1, const Phase& phase2);
92 virtual void setMax(const Phase& phase1, const Phase& phase2);
93 virtual void computeGradientLimiter(const Limiter& globalLimiter, const Phase& phase, const Phase& phaseMin, const Phase& phaseMax, const Phase& slope);
94
95 //Specific methods for parallele computing at second order
96 //--------------------------------------------------------
97 virtual int numberOfTransmittedSlopes() const;
98 virtual void fillBufferSlopes(double* buffer, int& counter) const;
99 virtual void getBufferSlopes(double* buffer, int& counter);
100
101 //Verifications
102 //-------------
103 virtual void verifyPhase(const std::string& message = "") const;
104 virtual void verifyAndCorrectPhase();
105 virtual void verifyAndCorrectDensityMax(const double& /*mass*/);
106 virtual void verifyAndCorrectDensityMax();
107
108 //Accessors
109 //---------
110 virtual const double& getAlpha() const { return Errors::defaultDouble; };
111 virtual const double& getMassFraction() const { return Errors::defaultDouble; };
112 virtual const double& getDensity() const { return m_density; };
113 virtual const double& getPressure() const { return m_pressure; };
114 virtual const double& getU() const { return m_velocity.getX(); };
115 virtual const double& getV() const { return m_velocity.getY(); };
116 virtual const double& getW() const { return m_velocity.getZ(); };
117 virtual Coord& getVelocity() { return m_velocity; };
118 virtual const Coord& getVelocity() const { return m_velocity; };
119 virtual Eos* getEos() const { return m_eos; };
120 virtual const double& getEnergy() const { return m_energy; };
121 virtual const double& getSoundSpeed() const { return m_soundSpeed; };
122 virtual const double& getTotalEnergy() const { return m_totalEnergy; };
123 virtual double getTemperature() const { return m_eos->computeTemperature(m_density, m_pressure); };
124
125 virtual void setAlpha(double /*alpha*/) {};
126 virtual void setDensity(double density);
127 virtual void setPressure(double pressure);
128 virtual void setVelocity(const double& u, const double& v, const double& w);
129 virtual void setVelocity(const Coord& vit);
130 virtual void setU(const double& u);
131 virtual void setV(const double& v);
132 virtual void setW(const double& w);
133 virtual void setEos(Eos* eos);
134 virtual void setEnergy(double energy);
135 virtual void setSoundSpeed(double soundSpeed);
136 virtual void setTotalEnergy(double totalEnergy);
137 virtual void setTemperature(double temperature);
138
139 //Operators
140 //---------
141 virtual void changeSign();
142 virtual void multiplyAndAdd(const Phase& slopesPhasesTemp, const double& coeff);
143 virtual void divide(const double& coeff);
144
145 protected:
146 double m_density;
147 double m_pressure;
151 double m_energy;
154 private:
155};
156
157#endif // PHASEEULER_H
Class for a coordinate system object such as coordinates of the vertex or a vector.
Definition Coord.h:43
const double & getX() const
Return the value in the x-direction of the Coord object.
Definition Coord.h:75
const double & getY() const
Return the value in the y-direction of the Coord object.
Definition Coord.h:77
const double & getZ() const
Return the value in the z-direction of the Coord object.
Definition Coord.h:79
General class for Equation of State (EOS).
Definition Eos.h:54
virtual double computeTemperature(const double &, const double &) const
See derived classes.
Definition Eos.h:106
static constexpr double defaultDouble
Definition Errors.h:93
Definition Limiter.h:38
Phase variables for Euler equations (single phase)
Definition PhaseEuler.h:41
PhaseEuler()
Definition PhaseEuler.cpp:37
virtual void setVelocity(const double &u, const double &v, const double &w)
Definition PhaseEuler.cpp:442
virtual void changeSign()
Definition PhaseEuler.cpp:484
virtual void extrapolate(const Phase &slope, const double &distance)
Definition PhaseEuler.cpp:310
virtual const double & getSoundSpeed() const
Definition PhaseEuler.h:121
virtual void reverseProjection(const Coord &normal, const Coord &tangent, const Coord &binormal)
Definition PhaseEuler.cpp:122
virtual void computeGradientLimiter(const Limiter &globalLimiter, const Phase &phase, const Phase &phaseMin, const Phase &phaseMax, const Phase &slope)
Definition PhaseEuler.cpp:356
virtual void setTotalEnergy(double totalEnergy)
Definition PhaseEuler.cpp:474
virtual double returnScalar(const int &numVar) const
Definition PhaseEuler.cpp:131
virtual void setW(const double &w)
Definition PhaseEuler.cpp:458
virtual void setScalar(const int &numVar, const double &value)
Definition PhaseEuler.cpp:193
virtual void getBufferSlopes(double *buffer, int &counter)
Definition PhaseEuler.cpp:388
double m_soundSpeed
speed of sound
Definition PhaseEuler.h:153
virtual const double & getTotalEnergy() const
Definition PhaseEuler.h:122
virtual void limitSlopes(const Phase &slopeGauche, const Phase &slopeDroite, Limiter &globalLimiter, Limiter &)
Definition PhaseEuler.cpp:321
virtual const double & getEnergy() const
Definition PhaseEuler.h:120
virtual const double & getU() const
Definition PhaseEuler.h:114
virtual void setEos(Eos *eos)
Definition PhaseEuler.cpp:462
virtual void copyPhase(Phase &vecPhase)
Copy phase in phase attributes.
Definition PhaseEuler.cpp:92
virtual void setAlpha(double)
Definition PhaseEuler.h:125
double m_temperature
temperature
Definition PhaseEuler.h:148
virtual void setSoundSpeed(double soundSpeed)
Definition PhaseEuler.cpp:470
Coord m_velocity
velocity
Definition PhaseEuler.h:149
virtual int getNumberScalars() const
Definition PhaseEuler.h:64
virtual void setPressure(double pressure)
Definition PhaseEuler.cpp:438
virtual Eos * getEos() const
Definition PhaseEuler.h:119
virtual std::string returnNameScalar(const int &numVar) const
Definition PhaseEuler.cpp:161
virtual void verifyAndCorrectPhase()
Definition PhaseEuler.cpp:410
virtual int getNumberVectors() const
Definition PhaseEuler.h:65
virtual const double & getAlpha() const
Definition PhaseEuler.h:110
virtual void setDensity(double density)
Definition PhaseEuler.cpp:434
virtual std::string returnNameVector(const int &numVar) const
Definition PhaseEuler.cpp:178
double m_energy
internal energy
Definition PhaseEuler.h:151
virtual void setMax(const Phase &phase1, const Phase &phase2)
Definition PhaseEuler.cpp:344
virtual Coord returnVector(const int &numVar) const
Definition PhaseEuler.cpp:148
virtual void setToMax()
Definition PhaseEuler.cpp:302
virtual void setEnergy(double energy)
Definition PhaseEuler.cpp:466
virtual const double & getMassFraction() const
Definition PhaseEuler.h:111
virtual void verifyAndCorrectDensityMax()
Definition PhaseEuler.cpp:425
virtual void setTemperature(double temperature)
Definition PhaseEuler.cpp:478
virtual void extendedCalculusPhase(const Coord &)
Compute extra thermodynammical variables.
Definition PhaseEuler.cpp:105
virtual const double & getV() const
Definition PhaseEuler.h:115
virtual Coord & getVelocity()
Definition PhaseEuler.h:117
virtual void fillBuffer(double *buffer, int &counter) const
Definition PhaseEuler.cpp:233
virtual void fillBufferSlopes(double *buffer, int &counter) const
Definition PhaseEuler.cpp:377
virtual void divide(const double &coeff)
Definition PhaseEuler.cpp:502
virtual void setV(const double &v)
Definition PhaseEuler.cpp:454
virtual const Coord & getVelocity() const
Definition PhaseEuler.h:118
virtual const double & getPressure() const
Definition PhaseEuler.h:113
virtual void setVector(const int &numVar, const Coord &value)
Definition PhaseEuler.cpp:210
virtual void setU(const double &u)
Definition PhaseEuler.cpp:450
virtual void getBuffer(double *buffer, int &counter, Eos **eos)
Definition PhaseEuler.cpp:257
double m_density
specific mass
Definition PhaseEuler.h:146
virtual void multiplyAndAdd(const Phase &slopesPhasesTemp, const double &coeff)
Definition PhaseEuler.cpp:493
double m_totalEnergy
total energy
Definition PhaseEuler.h:152
virtual void verifyPhase(const std::string &message="") const
Definition PhaseEuler.cpp:402
virtual void setMin(const Phase &phase1, const Phase &phase2)
Definition PhaseEuler.cpp:332
double m_pressure
pressure
Definition PhaseEuler.h:147
virtual double getTemperature() const
Definition PhaseEuler.h:123
virtual int numberOfTransmittedVariables() const
Definition PhaseEuler.cpp:225
virtual void setToZero()
Definition PhaseEuler.cpp:294
virtual void localProjection(const Coord &normal, const Coord &tangent, const Coord &binormal)
Definition PhaseEuler.cpp:115
virtual const double & getW() const
Definition PhaseEuler.h:116
virtual const double & getDensity() const
Definition PhaseEuler.h:112
virtual void computeSlopesPhase(const Phase &sLeft, const Phase &sRight, const double &distance)
Definition PhaseEuler.cpp:283
Eos * m_eos
pointer to equation of state
Definition PhaseEuler.h:150
virtual int numberOfTransmittedSlopes() const
Definition PhaseEuler.cpp:370
virtual void allocateAndCopyPhase(Phase **vecPhase)
Copy phase attributes in phase.
Definition PhaseEuler.cpp:85
virtual ~PhaseEuler()
Definition PhaseEuler.cpp:81
Abstract class for a phase.
Definition Phase.h:47
Definition tinyxml2.h:1149