ECOGEN 4.0
Evolutive, Compressible, Open, Genuine, Easy, N-phase
Loading...
Searching...
No Matches
EosIG.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 EOSIG_H
32#define EOSIG_H
33
34#include "Eos.h"
35
38class EosIG : public Eos
39{
40 public:
41 EosIG(std::vector<std::string>& nameParameterEos, int& number);
42 virtual ~EosIG();
43
48 virtual void assignParametersEos(std::string name, std::vector<double> parametersEos);
49
50 //Constant methods (virtual because inherited from class Eos )
56 virtual double computeTemperature(const double& density,const double& pressure) const;
57
63 virtual double computeEnergy(const double& density,const double& pressure) const;
64
70 virtual double computePressure(const double& density,const double& energy) const;
71
77 virtual double computeDensity(const double& pressure, const double& temperature) const;
78
84 virtual double computeSoundSpeed(const double& density,const double& pressure) const;
85
92 virtual double computeInterfaceSoundSpeed(const double& density, const double& interfacePressure, const double& pressure) const;
93
99 virtual double computeAcousticImpedance(const double& density, const double& pressure) const;
100
107 virtual double computeDensityTimesInterfaceSoundSpeedSquare(const double& /*density*/, const double& interfacePressure, const double& pressure) const;
108
114 virtual double computeEntropy(const double& temperature, const double& pressure) const;
115
122 virtual double computePressureIsentropic(const double& initialPressure, const double& initialDensity, const double& finalDensity) const;
123
130 virtual double computePressureHugoniot(const double& initialPressure, const double& initialDensity, const double& finalDensity) const;
131
138 virtual double computeDensityIsentropic(const double& initialPressure, const double& initialDensity, const double& finalPressure, double* drhodp=0) const;
139
146 virtual double computeDensityHugoniot(const double& initialPressure, const double& initialDensity, const double& finalPressure, double* drhodp = 0) const;
147
154 virtual double computeDensityPfinal(const double& initialPressure, const double& initialDensity, const double& finalPressure, double* drhodp = 0) const;
155
162 virtual double computeEnthalpyIsentropic(const double& initialPressure, const double& initialDensity, const double& finalPressure, double* dhdp = 0) const;
163
170 virtual double computeDensitySaturation(const double& pressure, const double& Tsat, const double& dTsatdP, double* drhodp = 0) const;
171
178 virtual double computeDensityEnergySaturation(const double& pressure, const double& rho, const double& drhodp, double* drhoedp = 0) const;
179
184 virtual void sendSpecialMixtureEos(double& gamPinfOverGamMinusOne, double& eRef, double& oneOverGamMinusOne, double& covolume) const;
185
190 virtual double vfpfh(const double& pressure, const double& enthalpy) const;
191
192 //Partial derivatives
197 virtual double dvdpch(const double& pressure, const double& enthalpy) const;
198
202 virtual double dvdhcp(const double& pressure) const;
203
207 virtual double drhodpcT(const double& /*pressure*/, const double& temperature) const;
208
209 //Checking
214 virtual void verifyPressure(const double& pressure, const std::string& message = "") const;
215
219 virtual void verifyAndModifyPressure(double& pressure) const;
221 virtual void verifyAndCorrectDensityMax(const double& /*mass*/, double& /*alpha*/, double& /*density*/) const {};
223 virtual void verifyAndCorrectDensityMax(double& /*density*/) const {};
224
225 //Get
228 virtual const double& getGamma() const { return m_gamma; };
229
232 virtual const double& getCv() const { return m_cv; };
233
236 virtual const double& getERef() const { return m_eRef; };
237
240 virtual const double& getSRef() const { return m_sRef; };
241
244 virtual TypeEOS getType() const { return TypeEOS::IG; };
245
246 private:
247 double m_gamma;
248 double m_cv;
249 double m_eRef;
250 double m_sRef;
251};
252
253#endif // EOSIG_H
TypeEOS
Enumeration for the type of EOS (IG: ideal gas, SG: stiffened gas, NASG: Noble-Abel stiffened gas,...
Definition Eos.h:40
@ IG
Definition Eos.h:40
@ rho
Definition Tools.h:60
Class describing an ideal gas equation of state.
Definition EosIG.h:39
virtual TypeEOS getType() const
Get the type that is to say the reduced name of the EOS in ECOGEN.
Definition EosIG.h:244
virtual double computeDensity(const double &pressure, const double &temperature) const
Compute density.
Definition EosIG.cpp:85
virtual void verifyAndModifyPressure(double &pressure) const
Modify the pressure if its value is under a limit value equal to .
Definition EosIG.cpp:251
virtual void verifyPressure(const double &pressure, const std::string &message="") const
Add a message error if the pressure is too low and under a limit value equal to .
Definition EosIG.cpp:244
virtual double computePressureIsentropic(const double &initialPressure, const double &initialDensity, const double &finalDensity) const
Compute phase pressure along an isentropic path.
Definition EosIG.cpp:127
virtual double computeDensityTimesInterfaceSoundSpeedSquare(const double &, const double &interfacePressure, const double &pressure) const
Compute density times interface sound speed square.
Definition EosIG.cpp:113
virtual double computePressure(const double &density, const double &energy) const
Compute pressure.
Definition EosIG.cpp:78
virtual void sendSpecialMixtureEos(double &gamPinfOverGamMinusOne, double &eRef, double &oneOverGamMinusOne, double &covolume) const
Send specific values of the parameters useful for mixture EOS based on Ideal Gas and Stiffened Gas.
Definition EosIG.cpp:206
virtual const double & getCv() const
Get the volume calorific energy of the fluid.
Definition EosIG.h:232
virtual double computeEnergy(const double &density, const double &pressure) const
Compute internal energy.
Definition EosIG.cpp:71
virtual double computeAcousticImpedance(const double &density, const double &pressure) const
Compute acoustic impedance.
Definition EosIG.cpp:106
virtual double computeTemperature(const double &density, const double &pressure) const
Compute temperature.
Definition EosIG.cpp:64
virtual const double & getERef() const
Get the energy of reference of the fluid.
Definition EosIG.h:236
virtual double dvdhcp(const double &pressure) const
Compute the partial derivative of the specific volume versus enthalpy at constant pressure.
Definition EosIG.cpp:230
virtual double computeDensitySaturation(const double &pressure, const double &Tsat, const double &dTsatdP, double *drhodp=0) const
Compute density on the saturation curve at the saturation temperature AND its derivative versus the p...
Definition EosIG.cpp:183
virtual double computeEntropy(const double &temperature, const double &pressure) const
Compute entropy.
Definition EosIG.cpp:120
virtual void verifyAndCorrectDensityMax(double &) const
Do nothing for IG.
Definition EosIG.h:223
virtual const double & getSRef() const
Get the entropy of reference of the fluid  
Definition EosIG.h:240
double m_cv
Volume calorific energy of the fluid.
Definition EosIG.h:248
virtual void verifyAndCorrectDensityMax(const double &, double &, double &) const
Do nothing for IG.
Definition EosIG.h:221
virtual ~EosIG()
Definition EosIG.cpp:46
virtual double computeDensityHugoniot(const double &initialPressure, const double &initialDensity, const double &finalPressure, double *drhodp=0) const
Compute density along the Hugoniot curve path AND its derivature versus the pressure along Hugoniot c...
Definition EosIG.cpp:150
virtual double computeSoundSpeed(const double &density, const double &pressure) const
Compute sound speed.
Definition EosIG.cpp:92
virtual double computeDensityIsentropic(const double &initialPressure, const double &initialDensity, const double &finalPressure, double *drhodp=0) const
Compute density along an isentropic path AND its derivature versus the pressure at constant entropy.
Definition EosIG.cpp:141
virtual const double & getGamma() const
Get the adiabatic exponent of the fluid.
Definition EosIG.h:228
virtual double computeDensityPfinal(const double &initialPressure, const double &initialDensity, const double &finalPressure, double *drhodp=0) const
Compute density during relaxation step AND its derivative versus the pressure.
Definition EosIG.cpp:161
virtual double drhodpcT(const double &, const double &temperature) const
Compute the partial derivative of density versus pressure at constant temperature.
Definition EosIG.cpp:237
double m_eRef
Energy of reference of the fluid.
Definition EosIG.h:249
virtual double vfpfh(const double &pressure, const double &enthalpy) const
Compute the specific volume with the pressure and the enthalpy.
Definition EosIG.cpp:216
virtual double dvdpch(const double &pressure, const double &enthalpy) const
Compute the partial derivative of the specific volume versus pressure at constant enthalpy.
Definition EosIG.cpp:223
virtual void assignParametersEos(std::string name, std::vector< double > parametersEos)
Assign the values of the attributes for EosIG from data defined in the code.
Definition EosIG.cpp:50
virtual double computeDensityEnergySaturation(const double &pressure, const double &rho, const double &drhodp, double *drhoedp=0) const
Compute the volumic internal energy at the saturation AND its derivative versus the pressure at const...
Definition EosIG.cpp:196
double m_gamma
Adiabatic exponent of the fluid.
Definition EosIG.h:247
virtual double computePressureHugoniot(const double &initialPressure, const double &initialDensity, const double &finalDensity) const
Compute pressure along the Hugoniot curve.
Definition EosIG.cpp:134
virtual double computeEnthalpyIsentropic(const double &initialPressure, const double &initialDensity, const double &finalPressure, double *dhdp=0) const
Compute enthalpy at the end of an isentropic path AND the enthalpy derivature versus the pressure.
Definition EosIG.cpp:172
double m_sRef
Entropy of the fluid.
Definition EosIG.h:250
virtual double computeInterfaceSoundSpeed(const double &density, const double &interfacePressure, const double &pressure) const
Compute interface sound speed.
Definition EosIG.cpp:99
General class for Equation of State (EOS).
Definition Eos.h:54