opm-common
Common.hpp
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  This file is part of the Open Porous Media project (OPM).
5 
6  OPM 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 2 of the License, or
9  (at your option) any later version.
10 
11  OPM 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 OPM. If not, see <http://www.gnu.org/licenses/>.
18 
19  Consult the COPYING file in the top-level source directory of this
20  module for the precise wording of the license and the list of
21  copyright holders.
22 */
27 #ifndef OPM_IAPWS_COMMON_HPP
28 #define OPM_IAPWS_COMMON_HPP
29 
32 #include <opm/common/utility/gpuDecorators.hpp>
33 
34 #include <cmath>
35 
36 namespace Opm {
37 namespace IAPWS {
38 
54 template <class Scalar>
55 class Common
56 {
57 public:
59  static constexpr Scalar molarMass = Scalar(18.01518e-3);
60 
62  static constexpr Scalar Rs = Constants<Scalar>::R / molarMass;
63 
65  static constexpr Scalar criticalTemperature = Scalar(647.096);
66 
68  static constexpr Scalar criticalPressure = Scalar(22.064e6);
69 
71  static constexpr Scalar criticalDensity = Scalar(322.0);
72 
74  static constexpr Scalar criticalVolume = Scalar(5.595e-2);
75 
77  static constexpr Scalar criticalMolarVolume = molarMass / criticalDensity;
78 
80  static constexpr Scalar acentricFactor = Scalar(0.344);
81 
83  static constexpr Scalar tripleTemperature = Scalar(273.16);
84 
86  static constexpr Scalar triplePressure = Scalar(611.657);
87 
102  template <class Evaluation>
103  OPM_HOST_DEVICE static Evaluation viscosity(const Evaluation& temperature, const Evaluation& rho)
104  {
105  Evaluation rhoBar = rho/322.0;
106  Evaluation TBar = temperature/criticalTemperature;
107  // Evaluation TBar = temperature/Scalar(647.096);
108 
109  // muBar = muBar_1
110  const Scalar Hij[6][7] = {
111  { 5.20094e-1, 2.22531e-1,-2.81378e-1, 1.61913e-1,-3.25372e-2, 0, 0 },
112  { 8.50895e-2, 9.99115e-1,-9.06851e-1, 2.57399e-1, 0, 0, 0 },
113  { -1.08374, 1.88797 ,-7.72479e-1, 0, 0, 0, 0 },
114  { -2.89555e-1, 1.26613 ,-4.89837e-1, 0, 6.98452e-2, 0,-4.35673e-3 },
115  { 0, 0,-2.57040e-1, 0, 0, 8.72102e-3, 0 },
116  { 0, 1.20573e-1, 0, 0, 0, 0,-5.93264e-4 }
117  };
118 
119  Evaluation tmp, tmp2, tmp3 = 1;
120  Evaluation muBar = 0;
121  for (int i = 0; i <= 5; ++i) {
122  tmp = 0;
123  tmp2 = 1;
124  for (int j = 0; j <= 6; ++j) {
125  tmp += Hij[i][j]*tmp2;
126  tmp2 *= (rhoBar - 1);
127  };
128  muBar += tmp3 * tmp;
129  tmp3 *= 1.0/TBar - 1;
130  };
131  muBar *= rhoBar;
132  muBar = exp(muBar);
133 
134  // muBar *= muBar_0
135  muBar *= 100*sqrt(TBar);
136  const Scalar H[4] = {
137  1.67752, 2.20462, 0.6366564, -0.241605
138  };
139 
140  tmp = 0, tmp2 = 1;
141  for (int i = 0; i < 4; ++i) {
142  tmp += H[i]/tmp2;
143  tmp2 *= TBar;
144  };
145  muBar /= tmp;
146 
147  return 1e-6*muBar;
148  }
149 
163  template <class Evaluation>
164  OPM_HOST_DEVICE static Evaluation thermalConductivityIAPWS(const Evaluation& T, const Evaluation& rho)
165  {
166  static const Scalar thcond_tstar = 647.26 ;
167  static const Scalar thcond_rhostar = 317.7 ;
168  /*static const Scalar thcond_kstar = 1.0 ;*/
169 
170  static const Scalar thcond_b0 = -0.397070 ;
171  static const Scalar thcond_b1 = 0.400302 ;
172  static const Scalar thcond_b2 = 1.060000 ;
173  static const Scalar thcond_B1 = -0.171587 ;
174  static const Scalar thcond_B2 = 2.392190 ;
175 
176  static const Scalar thcond_c1 = 0.642857 ;
177  static const Scalar thcond_c2 = -4.11717 ;
178  static const Scalar thcond_c3 = -6.17937 ;
179  static const Scalar thcond_c4 = 0.00308976 ;
180  static const Scalar thcond_c5 = 0.0822994 ;
181  static const Scalar thcond_c6 = 10.0932 ;
182 
183  static const Scalar thcond_d1 = 0.0701309 ;
184  static const Scalar thcond_d2 = 0.0118520 ;
185  static const Scalar thcond_d3 = 0.00169937 ;
186  static const Scalar thcond_d4 = -1.0200 ;
187  static const int thcond_a_count = 4;
188  static const Scalar thcond_a[thcond_a_count] = {
189  0.0102811
190  ,0.0299621
191  ,0.0156146
192  ,-0.00422464
193  };
194 
195  Evaluation Tbar = T / thcond_tstar;
196  Evaluation rhobar = rho / thcond_rhostar;
197 
198  /* fast implementation... minimised calls to 'pow' routine... */
199  Evaluation Troot = sqrt(Tbar);
200  Evaluation Tpow = Troot;
201  Evaluation lam = 0;
202 
203  for(int k = 0; k < thcond_a_count; ++k) {
204  lam += thcond_a[k] * Tpow;
205  Tpow *= Tbar;
206  }
207 
208  lam +=
209  thcond_b0 + thcond_b1
210  * rhobar + thcond_b2
211  * exp(thcond_B1 * ((rhobar + thcond_B2)*(rhobar + thcond_B2)));
212 
213  Evaluation DTbar = abs(Tbar - 1) + thcond_c4;
214  Evaluation DTbarpow = pow(DTbar, 3./5);
215  Evaluation Q = 2. + thcond_c5 / DTbarpow;
216 
217  Evaluation S;
218  if(Tbar >= 1)
219  S = 1. / DTbar;
220  else
221  S = thcond_c6 / DTbarpow;
222 
223  Evaluation rhobar18 = pow(rhobar, 1.8);
224  Evaluation rhobarQ = pow(rhobar, Q);
225 
226  lam +=
227  (thcond_d1 / pow(Tbar,10.0) + thcond_d2) * rhobar18 *
228  exp(thcond_c1 * (1 - rhobar * rhobar18))
229  + thcond_d3 * S * rhobarQ *
230  exp((Q/(1+Q))*(1 - rhobar*rhobarQ))
231  + thcond_d4 *
232  exp(thcond_c2 * pow(Troot,3.0) + thcond_c3 / pow(rhobar,5.0));
233  return /*thcond_kstar * */ lam;
234  }
235 };
236 
237 } // namespace IAPWS
238 } // namespace Opm
239 
240 #endif
static constexpr Scalar acentricFactor
The acentric factor of water .
Definition: Common.hpp:80
A traits class which provides basic mathematical functions for arbitrary scalar floating point values...
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition: Exceptions.hpp:30
static OPM_HOST_DEVICE Evaluation thermalConductivityIAPWS(const Evaluation &T, const Evaluation &rho)
Thermal conductivity water (IAPWS) .
Definition: Common.hpp:164
Definition: Constants.hpp:41
static constexpr Scalar tripleTemperature
Triple temperature of water .
Definition: Common.hpp:83
static constexpr Scalar criticalTemperature
Critical temperature of water .
Definition: Common.hpp:65
static constexpr Scalar criticalMolarVolume
Critical molar volume of water .
Definition: Common.hpp:77
static OPM_HOST_DEVICE Evaluation viscosity(const Evaluation &temperature, const Evaluation &rho)
The dynamic viscosity of pure water.
Definition: Common.hpp:103
Implements relations which are common for all regions of the IAPWS &#39;97 formulation.
Definition: Common.hpp:55
static constexpr Scalar criticalDensity
Density of water at the critical point .
Definition: Common.hpp:71
static constexpr Scalar criticalVolume
Critical volume of water .
Definition: Common.hpp:74
static constexpr Scalar Rs
Specific gas constant of water .
Definition: Common.hpp:62
static constexpr Scalar criticalPressure
Critical pressure of water .
Definition: Common.hpp:68
static constexpr Scalar molarMass
The molar mass of water .
Definition: Common.hpp:59
static constexpr Scalar triplePressure
Triple pressure of water .
Definition: Common.hpp:86