openPMD-api
 
Loading...
Searching...
No Matches
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/auxiliary/BlockSlicer.hpp"
26
27namespace openPMD::auxiliary
28{
29class OneDimensionalBlockSlicer : public BlockSlicer
30{
31public:
32 Extent::value_type m_dim;
33
34 explicit OneDimensionalBlockSlicer(Extent::value_type dim = 0);
35
36 static std::pair<size_t, size_t>
37 n_th_block_inside(size_t length, size_t rank, size_t size);
38
39 std::pair<Offset, Extent>
40 sliceBlock(Extent &totalExtent, int size, int rank) override;
41
42 virtual std::unique_ptr<BlockSlicer> clone() const override;
43};
44} // namespace openPMD::auxiliary
Abstract class to associate a thread with its local cuboid in the total cuboid.
Definition BlockSlicer.hpp:35
std::pair< Offset, Extent > sliceBlock(Extent &totalExtent, int size, int rank) override
Associate the current thread with its cuboid.
Definition OneDimensionalBlockSlicer.cpp:70