openPMD-api
 
Loading...
Searching...
No Matches
Dataset.hpp
1/* Copyright 2017-2025 Fabian Koller, Franz Poeschel, Axel Huebl, Junmin Gu
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#pragma once
22
23#include "openPMD/Datatype.hpp"
24
25#include <limits>
26#include <memory>
27#include <optional>
28#include <string>
29#include <type_traits>
30#include <vector>
31
32namespace openPMD
33{
34using Extent = std::vector<std::uint64_t>;
35using Offset = std::vector<std::uint64_t>;
36
37class Dataset
38{
39 friend class RecordComponent;
40
41public:
42 enum : std::uint64_t
43 {
55 JOINED_DIMENSION = std::numeric_limits<std::uint64_t>::max(),
73 UNDEFINED_EXTENT = std::numeric_limits<std::uint64_t>::max() - 1
74 };
75
76 Dataset(Datatype, Extent, std::string options = "{}");
77
89 Dataset(Extent = {UNDEFINED_EXTENT});
90
91 Dataset &extend(Extent newExtent);
92
93 Extent extent;
94 Datatype dtype;
95 uint8_t rank;
96 std::string options = "{}";
97
98 bool empty() const;
99
100 std::optional<size_t> joinedDimension() const;
101 static std::optional<size_t> joinedDimension(Extent const &);
102
103 bool undefinedExtent() const;
104 static bool undefinedExtent(Extent const &);
105};
106} // namespace openPMD
Definition Dataset.hpp:38
@ JOINED_DIMENSION
Setting one dimension of the extent as JOINED_DIMENSION means that the extent along that dimension wi...
Definition Dataset.hpp:55
@ UNDEFINED_EXTENT
In some use cases, the extent needs not be specified.
Definition Dataset.hpp:73
std::string options
backend-dependent JSON configuration
Definition Dataset.hpp:96
Public definitions of openPMD-api.
Definition Date.cpp:29
Datatype
Concrete datatype of an object available at runtime.
Definition Datatype.hpp:51