OpenLB
1.7
Loading...
Searching...
No Matches
src
reaction
explicitFiniteDifference
fdUpdater.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
29
#ifndef FD_UPDATER_H
30
#define FD_UPDATER_H
31
32
namespace
olb
{
33
34
template
<
typename
T,
typename
DESCRIPTOR>
35
class
FdUpdaterBase
{
36
protected
:
37
FdUpdaterBase
() { }
38
public
:
39
virtual
void
operator()
(
Cell<T,DESCRIPTOR>
& cell) =0;
40
};
41
42
template
<
typename
T,
typename
DESCRIPTOR,
typename
FIELD>
43
class
FdUpdater
:
public
FdUpdaterBase
<T,DESCRIPTOR> {
44
public
:
45
FdUpdater
() :
FdUpdaterBase
<T,DESCRIPTOR>() { }
46
virtual
void
operator()
(
Cell<T,DESCRIPTOR>
& cell)
override
47
{
48
T* f0 = &cell.template getFieldPointer<FIELD>()[0];
49
T f1 = cell.template getFieldPointer<FIELD>()[1];
50
*f0 = f1;
51
}
52
};
53
54
}
// namespace olb
55
56
#endif
olb::Cell
Highest-level interface to Cell data.
Definition
cell.h:148
olb::FdUpdaterBase
Definition
fdUpdater.h:35
olb::FdUpdaterBase::operator()
virtual void operator()(Cell< T, DESCRIPTOR > &cell)=0
olb::FdUpdaterBase::FdUpdaterBase
FdUpdaterBase()
Definition
fdUpdater.h:37
olb::FdUpdater
Definition
fdUpdater.h:43
olb::FdUpdater::operator()
virtual void operator()(Cell< T, DESCRIPTOR > &cell) override
Definition
fdUpdater.h:46
olb::FdUpdater::FdUpdater
FdUpdater()
Definition
fdUpdater.h:45
olb
Top level namespace for all of OpenLB.
Definition
boundaryPostProcessors2D.h:34
Generated on Tue Mar 5 2024 09:57:52 for OpenLB by
1.10.0