3.3.0
DUNE for Multi-{Phase, Component, Scale, Physics, ...} flow and transport in porous media
awnsurfacepolynomialedgezero2ndorder.hh
Go to the documentation of this file.
1/*****************************************************************************
2 * See the file COPYING for full copying permissions. *
3 * *
4 * This program is free software: you can redistribute it and/or modify *
5 * it under the terms of the GNU General Public License as published by *
6 * the Free Software Foundation, either version 3 of the License, or *
7 * (at your option) any later version. *
8 * *
9 * This program is distributed in the hope that it will be useful, *
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12 * GNU General Public License for more details. *
13 * *
14 * You should have received a copy of the GNU General Public License *
15 * along with this program. If not, see <http://www.gnu.org/licenses/>. *
16 *****************************************************************************/
23#ifndef AWN_SURFACE_POLYNOMIAL_EDGE_ZERO_2ND_ORDER_HH
24#define AWN_SURFACE_POLYNOMIAL_EDGE_ZERO_2ND_ORDER_HH
25
27
28#include <dune/common/exceptions.hh>
29
30#include <algorithm>
31#include <math.h>
32#include <assert.h>
33
34#warning "This header is deprecated. Removal after 3.3. Use new material laws."
35
36namespace Dumux {
37
43template <class ParamsT>
44class [[deprecated("Use new material laws and FluidMatrix::InterfacialAreaolynomialEdgeZero2ndOrder instead!")]] AwnSurfacePolynomialEdgeZero2ndOrder
45{
46public:
47 using Params = ParamsT;
48 using Scalar = typename Params::Scalar;
49
60 static Scalar interfacialArea(const Params &params, const Scalar Sw, const Scalar pc)
61 {
62 const Scalar a1 = params.a1();
63 const Scalar a2 = params.a2();
64 const Scalar a3 = params.a3();
65 const Scalar Swr = params.Swr();
66 const Scalar factor = (Swr-Sw)*(1.-Sw) ;
67
68 const Scalar aAlphaBeta = a1*factor + a2*factor*pc + a3*factor*pc*pc;
69 return aAlphaBeta;
70 }
71
72
80 static Scalar dawn_dpc (const Params &params, const Scalar Sw, const Scalar pc)
81 {
82 const Scalar Swr = params.Swr();
83 const Scalar a1 = params.a1();
84 const Scalar a2 = params.a2();
85 const Scalar a3 = params.a3();
86 const Scalar value = a2*(Swr-Sw)*(1-Sw) + a3*(Swr-Sw)*(1-Sw)*pc;
87 return value;
88 }
89
97 static Scalar dawn_dsw (const Params &params, const Scalar Sw, const Scalar pc)
98 {
99 const Scalar Swr = params.Swr();
100 const Scalar a1 = params.a1();
101 const Scalar a2 = params.a2();
102 const Scalar a3 = params.a3();
103 const Scalar derivativeFactor = (Sw-1.)+(Sw-Swr);
104 const Scalar value = a1 * derivativeFactor + a2 * derivativeFactor * pc + a3 * derivativeFactor * pc*pc ;
105 return value;
106 }
107
108};
109} // namespace Dumux
110
111#endif
Specification of the parameters for a function relating volume specific interfacial area to capillary...
Definition: adapt.hh:29
Implementation of the polynomial of second order relating specific interfacial area to wetting phase ...
Definition: awnsurfacepolynomialedgezero2ndorder.hh:45
ParamsT Params
Definition: awnsurfacepolynomialedgezero2ndorder.hh:47
static Scalar dawn_dpc(const Params &params, const Scalar Sw, const Scalar pc)
the derivative of specific interfacial area function w.r.t. capillary pressure
Definition: awnsurfacepolynomialedgezero2ndorder.hh:80
static Scalar dawn_dsw(const Params &params, const Scalar Sw, const Scalar pc)
the derivative of specific interfacial area function w.r.t. saturation
Definition: awnsurfacepolynomialedgezero2ndorder.hh:97
typename Params::Scalar Scalar
Definition: awnsurfacepolynomialedgezero2ndorder.hh:48
static Scalar interfacialArea(const Params &params, const Scalar Sw, const Scalar pc)
The awn surface the suggested (as estimated from pore network models) awn surface: ].
Definition: awnsurfacepolynomialedgezero2ndorder.hh:60