24#ifndef DUMUX_COMPONENTS_CONSTANT_HH
25#define DUMUX_COMPONENTS_CONSTANT_HH
27#include <dune/common/exceptions.hh>
55template<
int id,
class Scalar>
98 static const std::string&
name()
100 static const std::string
name = getParamFromGroup<std::string>(std::to_string(
id),
"Component.Name",
"component");
109 static const Scalar molarMass = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.MolarMass");
118 static const Scalar tripleTemperature = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.TripleTemperature");
127 static const Scalar triplePressure = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.TriplePressure");
149 static const Scalar density = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.LiquidDensity");
176 static const Scalar dynamicViscosity = [&]
178 if (
hasParamInGroup(std::to_string(
id),
"Component.LiquidKinematicViscosity"))
180 if (
hasParamInGroup(std::to_string(
id),
"Component.LiquidDynamicViscosity"))
181 DUNE_THROW(Dune::InvalidStateException,
"Found both Component.LiquidKinematicViscosity and Component.LiquidDynamicViscosity."
182 <<
" Please only specify either the kinematic or the dynamic viscosity for all constant components to avoid ambiguities.");
187 return getParamFromGroup<Scalar>(std::to_string(
id),
"Component.LiquidDynamicViscosity");
190 return dynamicViscosity;
200 static const Scalar thermalConductivity = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.LiquidThermalConductivity");
201 return thermalConductivity;
213 static const Scalar tRef = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.ReferenceTemperature", 293.15);
238 static const Scalar heatCapacity = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.LiquidHeatCapacity");
250 static const Scalar density = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.GasDensity");
278 static const Scalar dynamicViscosity = [&]
280 if (
hasParamInGroup(std::to_string(
id),
"Component.GasKinematicViscosity"))
282 if (
hasParamInGroup(std::to_string(
id),
"Component.GasDynamicViscosity"))
283 DUNE_THROW(Dune::InvalidStateException,
"Found both Component.GasKinematicViscosity and Component.GasDynamicViscosity."
284 <<
" Please only specify either the kinematic or the dynamic viscosity for all constant components to avoid ambiguities.");
289 return getParamFromGroup<Scalar>(std::to_string(
id),
"Component.GasDynamicViscosity");
292 return dynamicViscosity;
302 static const Scalar thermalConductivity = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.GasThermalConductivity");
303 return thermalConductivity;
335 static const Scalar tRef = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.ReferenceTemperature", 293.15);
347 static const Scalar heatCapacity = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.GasHeatCapacity");
378 static const Scalar density = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.SolidDensity");
398 static const Scalar solidHeatCapacity = getParamFromGroup<Scalar>(std::to_string(
id),
"Component.SolidHeatCapacity");
The infrastructure to retrieve run-time parameters from Dune::ParameterTrees.
Interface for components that have a gas state.
Interface for components that have a liquid state.
Interface for components that have a solid state.
Relations valid for an ideal gas.
bool hasParamInGroup(const std::string ¶mGroup, const std::string ¶m)
Check whether a key exists in the parameter tree with a model group prefix.
Definition: parameters.hh:177
std::string temperature() noexcept
I/O name of temperature for equilibrium models.
Definition: name.hh:51
std::string pressure(int phaseIdx) noexcept
I/O name of pressure for multiphase systems.
Definition: name.hh:34
std::string density(int phaseIdx) noexcept
I/O name of density for multiphase systems.
Definition: name.hh:65
Base class for all components Components provide the thermodynamic relations for the liquid,...
Definition: components/base.hh:59
Scalar Scalar
export the scalar type used by the component
Definition: components/base.hh:63
A component which returns run time specified values for all fluid properties.
Definition: constant.hh:61
static Scalar solidDensity(Scalar temperature)
The density in of the component at a given pressure in and temperature in .
Definition: constant.hh:376
static const std::string & name()
A human readable name for the component.
Definition: constant.hh:98
static Scalar solidThermalConductivity(Scalar temperature)
Thermal conductivity of the component as a solid.
Definition: constant.hh:386
static Scalar gasThermalConductivity(Scalar temperature, Scalar pressure)
Thermal conductivity of the component as a gas.
Definition: constant.hh:300
static Scalar triplePressure()
Returns the pressure at the component's triple point.
Definition: constant.hh:125
static Scalar liquidThermalConductivity(Scalar temperature, Scalar pressure)
Thermal conductivity of the component as a liquid.
Definition: constant.hh:198
static Scalar liquidEnthalpy(Scalar temperature, Scalar pressure)
Specific enthalpy of the component as a liquid.
Definition: constant.hh:223
static Scalar liquidMolarDensity(Scalar temperature, Scalar pressure)
The molar density in at a given pressure and temperature.
Definition: constant.hh:160
static Scalar gasInternalEnergy(Scalar temperature, Scalar pressure)
Specific internal energy of the component as a gas.
Definition: constant.hh:319
static constexpr bool gasIsCompressible()
Returns true if the gas phase is assumed to be compressible.
Definition: constant.hh:68
static Scalar liquidHeatCapacity(Scalar temperature, Scalar pressure)
Specific isobaric heat capacity of the component as a liquid.
Definition: constant.hh:236
static Scalar gasHeatCapacity(Scalar temperature, Scalar pressure)
Specific isobaric heat capacity of the component as a gas.
Definition: constant.hh:345
static Scalar gasMolarDensity(Scalar temperature, Scalar pressure)
The molar density in at a given pressure and temperature.
Definition: constant.hh:261
static Scalar gasEnthalpy(Scalar temperature, Scalar pressure)
Specific enthalpy of the component as a gas.
Definition: constant.hh:333
static Scalar tripleTemperature()
Returns the temperature at the components's triple point.
Definition: constant.hh:116
static Scalar solidHeatCapacity(Scalar temperature)
Specific isobaric heat capacity of the component as a solid.
Definition: constant.hh:396
static constexpr bool gasViscosityIsConstant()
Returns true if the gas phase viscosity is constant.
Definition: constant.hh:74
static Scalar liquidInternalEnergy(Scalar temperature, Scalar pressure)
Specific internal energy of the component as a liquid.
Definition: constant.hh:209
static Scalar gasDensity(Scalar temperature, Scalar pressure)
Sets the gas density in .
Definition: constant.hh:248
static constexpr bool liquidViscosityIsConstant()
Returns true if the liquid phase viscosity is constant.
Definition: constant.hh:92
static constexpr bool gasIsIdeal()
Returns true if the gas phase is assumed to be ideal.
Definition: constant.hh:80
static Scalar liquidDensity(Scalar temperature, Scalar pressure)
Sets the liquid density in .
Definition: constant.hh:147
static Scalar molarMass()
The mass in of one mole of the component.
Definition: constant.hh:107
static constexpr bool liquidIsCompressible()
Returns true if the liquid phase is assumed to be compressible.
Definition: constant.hh:86
static Scalar vaporPressure(Scalar T)
The vapor pressure in of a the component at a given temperature.
Definition: constant.hh:359
static Scalar vaporizationEnthalpy()
The vaporization enthalpy in needed to vaporize one kilogram of the liquid component to the gaseous ...
Definition: constant.hh:134
static Scalar liquidViscosity(Scalar temperature, Scalar pressure)
Sets the liquid dynamic viscosity in .
Definition: constant.hh:174
static Scalar gasViscosity(Scalar temperature, Scalar pressure)
Sets the gas dynamic viscosity in .
Definition: constant.hh:276
Interface for components that have a gas state.
Definition: gas.hh:41
Interface for components that have a liquid state.
Definition: liquid.hh:41
Interface for components that have a solid state.
Definition: solid.hh:41
Relations valid for an ideal gas.
Definition: idealgas.hh:37
static constexpr Scalar R
The ideal gas constant .
Definition: idealgas.hh:40
Base class for all components Components provide the thermodynamic relations for the liquid,...