3.2-git
DUNE for Multi-{Phase, Component, Scale, Physics, ...} flow and transport in porous media
region4.hh
Go to the documentation of this file.
1// -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2// vi: set et ts=4 sw=4 sts=4:
3/*****************************************************************************
4 * See the file COPYING for full copying permissions. *
5 * *
6 * This program is free software: you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation, either version 3 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program. If not, see <http://www.gnu.org/licenses/>. *
18 *****************************************************************************/
30#ifndef DUMUX_IAPWS_REGION4_HH
31#define DUMUX_IAPWS_REGION4_HH
32
33#include <cmath>
34#include <iostream>
35
36namespace Dumux {
37namespace IAPWS {
38
50template <class Scalar>
52{
53public:
63 static Scalar saturationPressure(Scalar temperature)
64 {
65 constexpr Scalar n[10] = {
66 0.11670521452767e4, -0.72421316703206e6, -0.17073846940092e2,
67 0.12020824702470e5, -0.32325550322333e7, 0.14915108613530e2,
68 -0.48232657361591e4, 0.40511340542057e6, -0.23855557567849,
69 0.65017534844798e3
70 };
71
72 Scalar sigma = temperature + n[8]/(temperature - n[9]);
73
74 Scalar A = (sigma + n[0])*sigma + n[1];
75 Scalar B = (n[2]*sigma + n[3])*sigma + n[4];
76 Scalar C = (n[5]*sigma + n[6])*sigma + n[7];
77
78 using std::sqrt;
79 Scalar tmp = 2*C/(sqrt(B*B - 4*A*C) - B);
80 tmp *= tmp;
81 tmp *= tmp;
82
83 return 1e6*tmp;
84 }
85
94 static Scalar vaporTemperature(Scalar pressure)
95 {
96 constexpr Scalar n[10] = {
97 0.11670521452767e4, -0.72421316703206e6, -0.17073846940092e2,
98 0.12020824702470e5, -0.32325550322333e7, 0.14915108613530e2,
99 -0.48232657361591e4, 0.40511340542057e6, -0.23855557567849,
100 0.65017534844798e3
101 };
102
103 using std::pow;
104 Scalar beta = pow((pressure/1e6 /*from Pa to MPa*/), (1./4.));
105 Scalar beta2 = pow(beta, 2.);
106 Scalar E = beta2 + n[2] * beta + n[5];
107 Scalar F = n[0]*beta2 + n[3]*beta + n[6];
108 Scalar G = n[1]*beta2 + n[4]*beta + n[7];
109
110 using std::sqrt;
111 Scalar D = ( 2.*G)/(-F -sqrt(pow(F,2.) - 4.*E*G));
112 Scalar temperature = (n[9] + D - sqrt(pow(n[9]+D , 2.) - 4.* (n[8] + n[9]*D)) ) * 0.5;
113
114 return temperature;
115 }
116};
117
118} // end namespace IAPWS
119} // end namespace Dumux
120
121#endif
Definition: adapt.hh:29
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
Implements the equations for region 4 of the IAPWS '97 formulation.
Definition: region4.hh:52
static Scalar saturationPressure(Scalar temperature)
Returns the saturation pressure in of pure water at a given temperature.
Definition: region4.hh:63
static Scalar vaporTemperature(Scalar pressure)
Returns the saturation temperature in of pure water at a given pressure.
Definition: region4.hh:94