65 #ifndef adiabaticPerfectFluid_H 66 #define adiabaticPerfectFluid_H 77 template<
class Specie>
class adiabaticPerfectFluid;
79 template<
class Specie>
80 inline adiabaticPerfectFluid<Specie>
operator+
82 const adiabaticPerfectFluid<Specie>&,
83 const adiabaticPerfectFluid<Specie>&
86 template<
class Specie>
87 inline adiabaticPerfectFluid<Specie>
operator*
90 const adiabaticPerfectFluid<Specie>&
93 template<
class Specie>
94 inline adiabaticPerfectFluid<Specie>
operator==
96 const adiabaticPerfectFluid<Specie>&,
97 const adiabaticPerfectFluid<Specie>&
100 template<
class Specie>
104 const adiabaticPerfectFluid<Specie>&
112 template<
class Specie>
171 return "adiabaticPerfectFluid<" +
word(Specie::typeName_()) +
'>';
184 inline scalar
rho(scalar
p, scalar
T)
const;
187 inline scalar
H(
const scalar
p,
const scalar
T)
const;
190 inline scalar
Cp(scalar
p, scalar
T)
const;
193 inline scalar
E(
const scalar
p,
const scalar
T)
const;
196 inline scalar
Cv(scalar
p, scalar
T)
const;
199 inline scalar
Sp(
const scalar
p,
const scalar
T)
const;
202 inline scalar
Sv(
const scalar
p,
const scalar
T)
const;
205 inline scalar
psi(scalar
p, scalar
T)
const;
208 inline scalar
Z(scalar
p, scalar
T)
const;
211 inline scalar
CpMCv(scalar
p, scalar
T)
const;
214 inline scalar
alphav(
const scalar
p,
const scalar
T)
const;
220 void write(Ostream& os)
const;
234 const adiabaticPerfectFluid&
237 friend adiabaticPerfectFluid
operator* <Specie>
240 const adiabaticPerfectFluid&
243 friend adiabaticPerfectFluid
operator== <Specie>
245 const adiabaticPerfectFluid&,
246 const adiabaticPerfectFluid&
252 friend Ostream& operator<< <Specie>
255 const adiabaticPerfectFluid&
scalar Z(scalar p, scalar T) const
Return compression factor [].
scalar E(const scalar p, const scalar T) const
Return internal energy contribution [J/kg].
static autoPtr< adiabaticPerfectFluid > New(const dictionary &dict)
A list of keyword definitions, which are a keyword followed by any number of values (e...
adiabaticPerfectFluid(const Specie &sp, const scalar p0, const scalar rho0, const scalar gamma, const scalar B)
Construct from components.
static const bool incompressible
Is the equation of state is incompressible i.e. rho != f(p)
scalar psi(scalar p, scalar T) const
Return compressibility [s^2/m^2].
static word typeName()
Return the instantiated type name.
static const bool isochoric
Is the equation of state is isochoric i.e. rho = const.
void operator+=(const adiabaticPerfectFluid &)
gmvFile<< "tracers "<< particles.size()<< nl;forAllConstIter(Cloud< passiveParticle >, particles, iter){ gmvFile<< iter().position().x()<< " ";}gmvFile<< nl;forAllConstIter(Cloud< passiveParticle >, particles, iter){ gmvFile<< iter().position().y()<< " ";}gmvFile<< nl;forAllConstIter(Cloud< passiveParticle >, particles, iter){ gmvFile<< iter().position().z()<< " ";}gmvFile<< nl;forAll(lagrangianScalarNames, i){ word name=lagrangianScalarNames[i];IOField< scalar > s(IOobject(name, runTime.timeName(), cloud::prefix, mesh, IOobject::MUST_READ, IOobject::NO_WRITE))
scalar Cp(scalar p, scalar T) const
Return Cp contribution [J/(kg K].
A class for handling words, derived from string.
scalar CpMCv(scalar p, scalar T) const
Return (Cp - Cv) [J/(kg K].
scalar Sp(const scalar p, const scalar T) const
Return entropy contribution to the integral of Cp/T [J/kg/K].
scalar H(const scalar p, const scalar T) const
Return enthalpy contribution [J/kg].
An Ostream is an abstract base class for all output systems (streams, files, token lists...
autoPtr< adiabaticPerfectFluid > clone() const
Construct and return a clone.
void T(FieldField< Field, Type > &f1, const FieldField< Field, Type > &f2)
word name(const complex &)
Return a string representation of a complex.
scalar rho(scalar p, scalar T) const
Return density [kg/m^3].
scalar Sv(const scalar p, const scalar T) const
Return entropy contribution to the integral of Cv/T [J/kg/K].
Adiabatic perfect fluid equation of state for liquids:
scalar Cv(scalar p, scalar T) const
Return Cv contribution [J/(kg K].
scalar alphav(const scalar p, const scalar T) const
Return volumetric coefficient of thermal expansion [1/T].
void operator*=(const scalar)
An auto-pointer similar to the STL auto_ptr but with automatic casting to a reference to the type and...
void write(Ostream &os) const
Write to Ostream.