openPMD-api
 
Loading...
Searching...
No Matches
BlockSlicer.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
26#include <memory>
27
28namespace openPMD::auxiliary
29{
35{
36public:
44 virtual std::pair<Offset, Extent>
45 sliceBlock(Extent &totalExtent, int size, int rank) = 0;
46
47 virtual std::unique_ptr<BlockSlicer> clone() const = 0;
48
51 virtual ~BlockSlicer() = default;
52};
53} // namespace openPMD::auxiliary
Abstract class to associate a thread with its local cuboid in the total cuboid.
Definition BlockSlicer.hpp:35
virtual std::pair< Offset, Extent > sliceBlock(Extent &totalExtent, int size, int rank)=0
Associate the current thread with its cuboid.
virtual ~BlockSlicer()=default
This class will be derived from.