openPMD-api
include
openPMD
benchmark
mpi
OneDimensionalBlockSlicer.hpp
1
/* Copyright 2018-2021 Franz Poeschel
2
*
3
* This file is part of openPMD-api.
4
*
5
* openPMD-api is free software: you can redistribute it and/or modify
6
* it under the terms of of either the GNU General Public License or
7
* the GNU Lesser General Public License as published by
8
* the Free Software Foundation, either version 3 of the License, or
9
* (at your option) any later version.
10
*
11
* openPMD-api 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 and the GNU Lesser General Public License
15
* for more details.
16
*
17
* You should have received a copy of the GNU General Public License
18
* and the GNU Lesser General Public License along with openPMD-api.
19
* If not, see <http://www.gnu.org/licenses/>.
20
*/
21
22
#pragma once
23
24
#include "openPMD/Dataset.hpp"
25
#include "openPMD/benchmark/mpi/BlockSlicer.hpp"
26
27
28
namespace
openPMD
29
{
30
class
OneDimensionalBlockSlicer
:
31
public
BlockSlicer
32
{
33
public
:
34
Extent::value_type m_dim;
35
36
explicit
OneDimensionalBlockSlicer
( Extent::value_type dim = 0 );
37
38
std::pair<
39
Offset,
40
Extent
41
>
sliceBlock
(
42
Extent & totalExtent,
43
int
size,
44
int
rank
45
)
override
;
46
};
47
}
openPMD::OneDimensionalBlockSlicer::sliceBlock
std::pair< Offset, Extent > sliceBlock(Extent &totalExtent, int size, int rank) override
Associate the current thread with its cuboid.
Definition:
OneDimensionalBlockSlicer.cpp:37
openPMD::OneDimensionalBlockSlicer
Definition:
OneDimensionalBlockSlicer.hpp:30
openPMD
Public definitions of openPMD-api.
Definition:
Date.cpp:29
openPMD::BlockSlicer
Abstract class to associate a thread with its local cuboid in the total cuboid.
Definition:
BlockSlicer.hpp:33
Generated by
1.8.17