add citation information
[LbmBenchmarkKernelsPublic.git] / src / BenchKernelD3Q19ListAaPvCommon.h
CommitLineData
10988083
MW
1// --------------------------------------------------------------------------
2//
3// Copyright
4// Markus Wittmann, 2016-2017
5// RRZE, University of Erlangen-Nuremberg, Germany
6// markus.wittmann -at- fau.de or hpc -at- rrze.fau.de
7//
8// Viktor Haag, 2016
9// LSS, University of Erlangen-Nuremberg, Germany
10//
11// This file is part of the Lattice Boltzmann Benchmark Kernels (LbmBenchKernels).
12//
13// LbmBenchKernels is free software: you can redistribute it and/or modify
14// it under the terms of the GNU General Public License as published by
15// the Free Software Foundation, either version 3 of the License, or
16// (at your option) any later version.
17//
18// LbmBenchKernels is distributed in the hope that it will be useful,
19// but WITHOUT ANY WARRANTY; without even the implied warranty of
20// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21// GNU General Public License for more details.
22//
23// You should have received a copy of the GNU General Public License
24// along with LbmBenchKernels. If not, see <http://www.gnu.org/licenses/>.
25//
26// --------------------------------------------------------------------------
27#ifndef __BENCH_KERNEL_D3Q19_LIST_AA_PV_COMMON_H__
28#define __BENCH_KERNEL_D3Q19_LIST_AA_PV_COMMON_H__
29
30#if !defined(DATA_LAYOUT_SOA)
31 #error List AA Pv works only with DATA_LAYOUT_SOA
32#endif
33
34#include "BenchKernelD3Q19ListAaCommon.h"
35
36typedef struct KernelDataListRia_ {
37 KernelDataList kdl;
38
39 // Array contains information of how many adjacent nodes share the same access pattern.
40 uint32_t * ConsecNodes;
41 uint32_t nConsecNodes; // Number of entries in ConsecNodes array.
42
43 // Array contains (for each thread) an index into ConsecNodes.
44 uint32_t * ConsecThreadIndices;
45 // Number of entries in ConsecThreadIndices.
46 uint32_t nConsecThreadIndices;
47
48 // Array contains fluid node indices for each thread where to start in the
49 // vector of fluid nodes.
50 int * FluidNodeThreadIndices;
51 // Number of entries in FluidNodeThreadIndices.
52 int nFluidNodeThreadIndices;
53
54} KernelDataListRia;
55
56// Macro for casting KernelData * to KernelDataList *.
57#define KDLR(_x_) ((KernelDataListRia *)(_x_))
58
59
60#endif // __BENCH_KERNEL_D3Q19_LIST_AA_PV_COMMON_H__
61
This page took 0.053727 seconds and 5 git commands to generate.