OpenLB
1.7
Loading...
Searching...
No Matches
src
reaction
explicitFiniteDifference
fdSchemeSpecs
upwind.h
Go to the documentation of this file.
1
/* This file is part of the OpenLB library
2
*
3
* Copyright (C) 2020 Davide Dapelo
4
* E-mail contact: info@openlb.net
5
* The most recent release of OpenLB can be downloaded at
6
* <http://www.openlb.net/>
7
*
8
* This program is free software; you can redistribute it and/or
9
* modify it under the terms of the GNU General Public License
10
* as published by the Free Software Foundation; either version 2
11
* of the License, or (at your option) any later version.
12
*
13
* This program is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
* GNU General Public License for more details.
17
*
18
* You should have received a copy of the GNU General Public
19
* License along with this program; if not, write to the Free
20
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
21
* Boston, MA 02110-1301, USA.
22
*/
23
28
#ifndef FD_SCHEMES_UPWIND_H
29
#define FD_SCHEMES_UPWIND_H
30
31
namespace
olb
{
32
33
namespace
fd {
34
35
namespace
tag {
36
37
struct
UPWIND
final :
FD_TAG
{
38
UPWIND
() =
delete
;
39
static
constexpr
int
extent
() {
return
1;}
40
};
41
42
}
// namespace tag
43
44
template
<
unsigned
D,
typename
T>
45
struct
AdvectionScheme
<D,T,tag::UPWIND> final :
FdScheme
<tag::UPWIND> {
46
AdvectionScheme
() =
delete
;
47
template
<
typename
PARAMETERS>
48
static
T
apply
(T& f0, T f[], T F[], T u[], PARAMETERS& params);
49
};
50
51
template
<
unsigned
D,
typename
T>
52
struct
AdNeumannZeroBoundaryScheme
<D,T,tag::UPWIND> final :
FdScheme
<tag::UPWIND> {
53
AdNeumannZeroBoundaryScheme
() =
delete
;
54
static
constexpr
int
getExtraExtent
();
55
template
<
typename
PARAMETERS>
56
static
void
apply
(T fOut[], T& f0, T fIn[],
int
normal[], T u[], PARAMETERS& params);
57
};
58
59
}
// namespace fd
60
61
}
// namespace olb
62
63
#endif
olb
Top level namespace for all of OpenLB.
Definition
boundaryPostProcessors2D.h:34
olb::fd::AdNeumannZeroBoundaryScheme< D, T, tag::UPWIND >::AdNeumannZeroBoundaryScheme
AdNeumannZeroBoundaryScheme()=delete
olb::fd::AdNeumannZeroBoundaryScheme
Definition
fdScheme.h:64
olb::fd::AdNeumannZeroBoundaryScheme::getExtraExtent
static constexpr int getExtraExtent()
Definition
fdScheme.h:66
olb::fd::AdNeumannZeroBoundaryScheme::apply
static void apply(T fOut[], T &f0, T fIn[], int normal[], T u[], PARAMETERS ¶ms)
Definition
fdScheme.h:71
olb::fd::AdvectionScheme< D, T, tag::UPWIND >::AdvectionScheme
AdvectionScheme()=delete
olb::fd::AdvectionScheme
Definition
fdScheme.h:44
olb::fd::AdvectionScheme::apply
static T apply(T &f0, T f[], T F[], T u[], PARAMETERS ¶ms)
Definition
fdScheme.h:47
olb::fd::FdScheme
Definition
fdScheme.h:36
olb::fd::tag::FD_TAG
Base of a finite-difference tag.
Definition
fdTags.h:38
olb::fd::tag::UPWIND
Definition
upwind.h:37
olb::fd::tag::UPWIND::extent
static constexpr int extent()
Definition
upwind.h:39
olb::fd::tag::UPWIND::UPWIND
UPWIND()=delete
Generated on Tue Mar 5 2024 09:57:52 for OpenLB by
1.10.0