Line | Branch | Exec | Source |
---|---|---|---|
1 | // SPDX-FileCopyrightText: 2022-2023 Dennis Gläser <dennis.glaeser@iws.uni-stuttgart.de> | ||
2 | // SPDX-License-Identifier: MIT | ||
3 | /*! | ||
4 | * \file | ||
5 | * \ingroup Common | ||
6 | * \brief Helpers for I/O from HDF5 files. | ||
7 | */ | ||
8 | #ifndef GRIDFORMAT_COMMON_HDF5_HPP_ | ||
9 | #define GRIDFORMAT_COMMON_HDF5_HPP_ | ||
10 | #if GRIDFORMAT_HAVE_HIGH_FIVE | ||
11 | |||
12 | #include <type_traits> | ||
13 | #include <algorithm> | ||
14 | #include <concepts> | ||
15 | #include <ranges> | ||
16 | #include <cstdint> | ||
17 | |||
18 | #ifdef GRIDFORMAT_DISABLE_HIGHFIVE_WARNINGS | ||
19 | #pragma GCC diagnostic push | ||
20 | #pragma GCC diagnostic ignored "-Wold-style-cast" | ||
21 | #pragma GCC diagnostic ignored "-Wswitch-enum" | ||
22 | #pragma GCC diagnostic ignored "-Wuseless-cast" | ||
23 | #pragma GCC diagnostic ignored "-Wcast-qual" | ||
24 | #pragma GCC diagnostic ignored "-Wnull-dereference" | ||
25 | #pragma GCC diagnostic ignored "-Warray-bounds" | ||
26 | #pragma GCC diagnostic ignored "-Wstringop-overflow" | ||
27 | #endif // GRIDFORMAT_DISABLE_HIGHFIVE_WARNINGS | ||
28 | |||
29 | #include <highfive/H5Easy.hpp> | ||
30 | #include <highfive/H5File.hpp> | ||
31 | |||
32 | #ifdef GRIDFORMAT_DISABLE_HIGHFIVE_WARNINGS | ||
33 | #pragma GCC diagnostic pop | ||
34 | #endif // GRIDFORMAT_DISABLE_HIGHFIVE_WARNINGS | ||
35 | |||
36 | #include <gridformat/common/field.hpp> | ||
37 | #include <gridformat/common/logging.hpp> | ||
38 | #include <gridformat/common/concepts.hpp> | ||
39 | #include <gridformat/common/md_layout.hpp> | ||
40 | #include <gridformat/common/buffer_field.hpp> | ||
41 | #include <gridformat/common/precision.hpp> | ||
42 | |||
43 | #include <gridformat/parallel/communication.hpp> | ||
44 | #include <gridformat/grid/grid.hpp> | ||
45 | |||
46 | |||
47 | namespace GridFormat::HDF5 { | ||
48 | |||
49 | #ifndef DOXYGEN | ||
50 | namespace Detail { | ||
51 | |||
52 | 2644 | HighFive::DataTransferProps parallel_transfer_props() { | |
53 | 2644 | HighFive::DataTransferProps xfer_props; | |
54 | #if GRIDFORMAT_HAVE_PARALLEL_HIGH_FIVE | ||
55 |
1/2✓ Branch 2 taken 2644 times.
✗ Branch 3 not taken.
|
2644 | xfer_props.add(HighFive::UseCollectiveIO{}); |
56 | #else | ||
57 | throw NotImplemented("Parallel HighFive required for parallel I/O"); | ||
58 | #endif | ||
59 | 2644 | return xfer_props; | |
60 | ✗ | } | |
61 | |||
62 | template<Concepts::Communicator Communicator> | ||
63 | 354 | auto parallel_file_access_props([[maybe_unused]] const Communicator& communicator) { | |
64 | 354 | HighFive::FileAccessProps fapl; | |
65 | #if GRIDFORMAT_HAVE_PARALLEL_HIGH_FIVE | ||
66 | if constexpr (!std::is_same_v<Communicator, NullCommunicator>) { | ||
67 |
1/2✓ Branch 2 taken 250 times.
✗ Branch 3 not taken.
|
354 | fapl.add(HighFive::MPIOFileAccess{communicator, MPI_INFO_NULL}); |
68 |
1/2✓ Branch 2 taken 250 times.
✗ Branch 3 not taken.
|
354 | fapl.add(HighFive::MPIOCollectiveMetadata{}); |
69 | } else { | ||
70 | ✗ | throw TypeError("Cannot establish parallel I/O with null communicator"); | |
71 | } | ||
72 | #else | ||
73 | throw NotImplemented("Parallel HighFive required for parallel I/O"); | ||
74 | #endif | ||
75 | 354 | return fapl; | |
76 | ✗ | } | |
77 | |||
78 | 2644 | void check_successful_collective_io([[maybe_unused]] const HighFive::DataTransferProps& xfer_props) { | |
79 | #if GRIDFORMAT_HAVE_PARALLEL_HIGH_FIVE | ||
80 |
1/2✓ Branch 1 taken 2644 times.
✗ Branch 2 not taken.
|
2644 | auto mnccp = HighFive::MpioNoCollectiveCause(xfer_props); |
81 |
3/6✓ Branch 1 taken 2644 times.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 2644 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 2644 times.
|
2644 | if (mnccp.getLocalCause() || mnccp.getGlobalCause()) |
82 | ✗ | log_warning( | |
83 | ✗ | std::string{"The operation was successful, but couldn't use collective MPI-IO. "} | |
84 | ✗ | + "Local cause: " + std::to_string(mnccp.getLocalCause()) + " " | |
85 | ✗ | + "Global cause:" + std::to_string(mnccp.getGlobalCause()) + "\n" | |
86 | ); | ||
87 | #else | ||
88 | throw NotImplemented("Parallel HighFive required for parallel I/O"); | ||
89 | #endif | ||
90 | 2644 | } | |
91 | |||
92 | 42860 | std::pair<std::string, std::string> split_group(const std::string& in) { | |
93 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 42860 times.
|
42860 | if (in.ends_with('/')) |
94 | ✗ | return {in, ""}; | |
95 | |||
96 | 42860 | const auto split_pos = in.find_last_of("/"); | |
97 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 42860 times.
|
42860 | if (split_pos == std::string::npos ) |
98 | ✗ | throw ValueError("Could not split name from given path: " + in); | |
99 | return { | ||
100 |
6/10✓ Branch 0 taken 42304 times.
✓ Branch 1 taken 556 times.
✓ Branch 3 taken 42304 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 556 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 556 times.
✓ Branch 9 taken 42304 times.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
|
86832 | split_pos > 0 ? in.substr(0, split_pos) : "/", |
101 |
1/2✓ Branch 1 taken 42860 times.
✗ Branch 2 not taken.
|
85720 | in.substr(split_pos + 1) |
102 | 42860 | }; | |
103 | } | ||
104 | |||
105 | template<typename T> | ||
106 | using HighFiveDataType = std::conditional_t<std::is_same_v<T, bool>, char, T>; | ||
107 | |||
108 | } // namespace Detail | ||
109 | #endif // DOXYGEN | ||
110 | |||
111 | //! Represents a dataset slice | ||
112 | struct Slice { | ||
113 | std::vector<std::size_t> offset; | ||
114 | std::vector<std::size_t> count; | ||
115 | std::optional<std::vector<std::size_t>> total_size = {}; | ||
116 | }; | ||
117 | |||
118 | //! Custom string data type using ascii encoding. | ||
119 | //! HighFive uses UTF-8, but VTKHDF, for instance, uses ascii. | ||
120 | struct AsciiString : public HighFive::DataType { | ||
121 | 338 | explicit AsciiString(std::size_t n) { | |
122 |
2/4✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 338 times.
✗ Branch 5 not taken.
|
338 | _hid = H5Tcopy(H5T_C_S1); |
123 |
2/4✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 338 times.
|
338 | if (H5Tset_size(_hid, n) < 0) { |
124 | ✗ | HighFive::HDF5ErrMapper::ToException<HighFive::DataTypeException>( | |
125 | ✗ | "Unable to define datatype size to " + std::to_string(n) | |
126 | ); | ||
127 | } | ||
128 | // define encoding to ASCII | ||
129 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
338 | H5Tset_cset(_hid, H5T_CSET_ASCII); |
130 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
338 | H5Tset_strpad(_hid, H5T_STR_SPACEPAD); |
131 | 338 | } | |
132 | |||
133 | template<std::size_t N> | ||
134 | 503 | static AsciiString from(const char (&input)[N]) { | |
135 |
1/2✓ Branch 0 taken 338 times.
✗ Branch 1 not taken.
|
503 | if (input[N-1] == '\0') |
136 | 503 | return AsciiString{N-1}; | |
137 | ✗ | return AsciiString{N}; | |
138 | } | ||
139 | |||
140 | static AsciiString from(const std::string& n) { | ||
141 | return AsciiString{n.size()}; | ||
142 | } | ||
143 | }; | ||
144 | |||
145 | /*! | ||
146 | * \ingroup Common | ||
147 | * \brief Helper class for I/O from HDF5 files. | ||
148 | * \note Currently, strings are ascii encoded, in contrast to the standard utf-8 | ||
149 | * that HighFive uses. Once necessary, we'll make the encoding settable. | ||
150 | */ | ||
151 | template<Concepts::Communicator Communicator = NullCommunicator> | ||
152 | class File { | ||
153 | public: | ||
154 | enum Mode { | ||
155 | overwrite, //!< remove all content before writing | ||
156 | append, //!< append given data to existing datasets | ||
157 | read_only //!< only read data | ||
158 | }; | ||
159 | |||
160 | 2 | File(const std::string& filename, Mode mode = Mode::read_only) | |
161 | requires(std::same_as<Communicator, NullCommunicator>) | ||
162 |
1/2✓ Branch 1 taken 2 times.
✗ Branch 2 not taken.
|
2 | : File(filename, NullCommunicator{}, mode) |
163 | 2 | {} | |
164 | |||
165 | 601 | File(const std::string& filename, const Communicator& comm, Mode mode = Mode::read_only) | |
166 | 354 | : _comm{comm} | |
167 | 601 | , _mode{mode} | |
168 | 601 | , _file{_open(filename)} | |
169 | 601 | {} | |
170 | |||
171 | //! Clear the contents of the file with the given name | ||
172 | 48 | static void clear(const std::string& filename, const Communicator& comm) { | |
173 |
2/2✓ Branch 1 taken 34 times.
✓ Branch 2 taken 14 times.
|
48 | if (Parallel::rank(comm) == 0) // clear file by open it in overwrite mode |
174 |
1/2✓ Branch 2 taken 34 times.
✗ Branch 3 not taken.
|
34 | HighFive::File{filename, HighFive::File::Overwrite}; |
175 | 48 | Parallel::barrier(comm); | |
176 | 48 | } | |
177 | |||
178 | //! Write the given values to the attribute with the given name into the given group | ||
179 | template<typename Values> | ||
180 | 2310 | void write_attribute(const Values& values, const std::string& path) { | |
181 |
1/2✓ Branch 1 taken 1162 times.
✗ Branch 2 not taken.
|
2310 | _check_writable(); |
182 |
1/2✓ Branch 1 taken 1162 times.
✗ Branch 2 not taken.
|
2310 | const auto [group, name] = Detail::split_group(path); |
183 |
1/2✓ Branch 1 taken 1162 times.
✗ Branch 2 not taken.
|
2310 | _clear_attribute(name, group); |
184 |
2/4✓ Branch 1 taken 1162 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1162 times.
✗ Branch 5 not taken.
|
2310 | _get_group(group).createAttribute(name, values); |
185 | 2310 | } | |
186 | |||
187 | //! Write the given characters to the attribute with the given name into the given group | ||
188 | template<std::size_t N> | ||
189 | 503 | void write_attribute(const char (&values)[N], const std::string& path) { | |
190 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
503 | _check_writable(); |
191 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
503 | const auto [group, name] = Detail::split_group(path); |
192 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
503 | _clear_attribute(name, group); |
193 |
2/4✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 338 times.
✗ Branch 5 not taken.
|
1006 | auto type_attr = _get_group(group).createAttribute( |
194 | name, | ||
195 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
1006 | HighFive::DataSpace{1}, |
196 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
1006 | AsciiString::from(values) |
197 | ); | ||
198 |
1/2✓ Branch 1 taken 338 times.
✗ Branch 2 not taken.
|
503 | type_attr.write(values); |
199 | 503 | } | |
200 | |||
201 | //! Write the given values into the dataset with the given path | ||
202 | template<std::ranges::range Values> | ||
203 | 7780 | void write(const Values& values, | |
204 | const std::string& path, | ||
205 | const std::optional<Slice>& slice = {}) { | ||
206 |
1/2✓ Branch 1 taken 3890 times.
✗ Branch 2 not taken.
|
7780 | _check_writable(); |
207 |
1/2✓ Branch 1 taken 3890 times.
✗ Branch 2 not taken.
|
7780 | const auto [group_name, ds_name] = Detail::split_group(path); |
208 |
5/8✓ Branch 1 taken 684 times.
✓ Branch 2 taken 3206 times.
✓ Branch 5 taken 684 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 684 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 3206 times.
✗ Branch 12 not taken.
|
7780 | const auto space = slice ? HighFive::DataSpace{slice->total_size.value()} |
209 | : HighFive::DataSpace::From(values); | ||
210 |
1/2✓ Branch 1 taken 3890 times.
✗ Branch 2 not taken.
|
7780 | auto group = _get_group(group_name); |
211 |
1/2✓ Branch 1 taken 3890 times.
✗ Branch 2 not taken.
|
7780 | auto [offset, dataset] = _prepare_dataset<FieldScalar<Values>>(group, ds_name, space); |
212 |
2/6✓ Branch 1 taken 3206 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3206 times.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
|
14192 | Slice _slice{ |
213 |
6/10✓ Branch 1 taken 684 times.
✓ Branch 2 taken 3206 times.
✓ Branch 5 taken 684 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 3206 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 3206 times.
✓ Branch 11 taken 684 times.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
|
21972 | .offset = slice ? slice->offset : std::vector<std::size_t>(space.getNumberDimensions(), 0), |
214 |
3/4✓ Branch 1 taken 684 times.
✓ Branch 2 taken 3206 times.
✓ Branch 5 taken 684 times.
✗ Branch 6 not taken.
|
7780 | .count = slice ? slice->count : space.getDimensions() |
215 | }; | ||
216 |
1/2✓ Branch 1 taken 3890 times.
✗ Branch 2 not taken.
|
7780 | _slice.offset.at(0) += offset; |
217 | |||
218 |
3/4✓ Branch 1 taken 2306 times.
✓ Branch 2 taken 1584 times.
✓ Branch 3 taken 2306 times.
✗ Branch 4 not taken.
|
7780 | if (Parallel::size(_comm) > 1) { |
219 |
2/2✓ Branch 1 taken 684 times.
✓ Branch 2 taken 1622 times.
|
4612 | if (slice) { // collective I/O |
220 |
1/2✓ Branch 1 taken 684 times.
✗ Branch 2 not taken.
|
1368 | const auto props = Detail::parallel_transfer_props(); |
221 |
2/4✓ Branch 1 taken 684 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 684 times.
✗ Branch 5 not taken.
|
1368 | _write_to(dataset, values, _slice, props); |
222 |
1/2✓ Branch 1 taken 684 times.
✗ Branch 2 not taken.
|
1368 | Detail::check_successful_collective_io(props); |
223 |
3/4✓ Branch 2 taken 1622 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 811 times.
✓ Branch 5 taken 811 times.
|
4612 | } else if (Parallel::rank(_comm) == 0) { // write only on rank 0 to avoid clashes |
224 |
1/2✓ Branch 2 taken 811 times.
✗ Branch 3 not taken.
|
1622 | _write_to(dataset, values, _slice); |
225 | } | ||
226 | } else { | ||
227 |
1/2✓ Branch 2 taken 1584 times.
✗ Branch 3 not taken.
|
3168 | _write_to(dataset, values, _slice); |
228 | } | ||
229 |
1/2✓ Branch 1 taken 3890 times.
✗ Branch 2 not taken.
|
7780 | _file.flush(); |
230 | 7780 | } | |
231 | |||
232 | //! Write a field into the dataset with the given path | ||
233 | 3362 | void write(const Field& field, | |
234 | const std::string& path, | ||
235 | const std::optional<Slice>& slice = {}) { | ||
236 |
1/2✓ Branch 1 taken 3362 times.
✗ Branch 2 not taken.
|
3362 | _check_writable(); |
237 |
1/2✓ Branch 1 taken 3362 times.
✗ Branch 2 not taken.
|
3362 | const auto layout = field.layout(); |
238 |
1/2✓ Branch 1 taken 3362 times.
✗ Branch 2 not taken.
|
3362 | const HighFive::DataSpace space{[&] () { |
239 |
2/2✓ Branch 1 taken 2424 times.
✓ Branch 2 taken 938 times.
|
3362 | if (slice) |
240 |
2/4✓ Branch 2 taken 2424 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 2424 times.
✗ Branch 6 not taken.
|
2424 | return slice->total_size.value(); |
241 |
2/4✓ Branch 1 taken 938 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 938 times.
✗ Branch 5 not taken.
|
938 | std::vector<std::size_t> dims(layout.dimension()); |
242 |
1/2✓ Branch 1 taken 938 times.
✗ Branch 2 not taken.
|
938 | layout.export_to(dims); |
243 | 938 | return dims; | |
244 |
1/2✓ Branch 1 taken 3362 times.
✗ Branch 2 not taken.
|
7662 | } ()}; |
245 | |||
246 |
1/2✓ Branch 1 taken 3362 times.
✗ Branch 2 not taken.
|
3362 | const auto [group_name, ds_name] = Detail::split_group(path); |
247 |
1/2✓ Branch 1 taken 3362 times.
✗ Branch 2 not taken.
|
3362 | auto group = _get_group(group_name); |
248 |
2/4✓ Branch 1 taken 3362 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3362 times.
✗ Branch 5 not taken.
|
10086 | field.precision().visit([&] <typename T> (const Precision<T>&) { |
249 |
6/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 6 taken 222 times.
✗ Branch 7 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✗ Branch 21 not taken.
✗ Branch 22 not taken.
✓ Branch 26 taken 2 times.
✗ Branch 27 not taken.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✓ Branch 36 taken 125 times.
✗ Branch 37 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
✓ Branch 46 taken 28 times.
✗ Branch 47 not taken.
✓ Branch 51 taken 1647 times.
✗ Branch 52 not taken.
✓ Branch 56 taken 1338 times.
✗ Branch 57 not taken.
|
3362 | auto [offset, dataset] = _prepare_dataset<T>(group, ds_name, space); |
250 |
12/72✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 11 taken 114 times.
✗ Branch 12 not taken.
✓ Branch 14 taken 114 times.
✗ Branch 15 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✗ Branch 21 not taken.
✗ Branch 22 not taken.
✗ Branch 24 not taken.
✗ Branch 25 not taken.
✗ Branch 27 not taken.
✗ Branch 28 not taken.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✗ Branch 34 not taken.
✗ Branch 35 not taken.
✗ Branch 37 not taken.
✗ Branch 38 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
✗ Branch 44 not taken.
✗ Branch 45 not taken.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✓ Branch 51 taken 2 times.
✗ Branch 52 not taken.
✓ Branch 54 taken 2 times.
✗ Branch 55 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✗ Branch 61 not taken.
✗ Branch 62 not taken.
✗ Branch 64 not taken.
✗ Branch 65 not taken.
✗ Branch 67 not taken.
✗ Branch 68 not taken.
✓ Branch 71 taken 71 times.
✗ Branch 72 not taken.
✓ Branch 74 taken 71 times.
✗ Branch 75 not taken.
✗ Branch 77 not taken.
✗ Branch 78 not taken.
✗ Branch 81 not taken.
✗ Branch 82 not taken.
✗ Branch 84 not taken.
✗ Branch 85 not taken.
✗ Branch 87 not taken.
✗ Branch 88 not taken.
✓ Branch 91 taken 28 times.
✗ Branch 92 not taken.
✓ Branch 94 taken 28 times.
✗ Branch 95 not taken.
✗ Branch 97 not taken.
✗ Branch 98 not taken.
✓ Branch 101 taken 408 times.
✗ Branch 102 not taken.
✓ Branch 104 taken 408 times.
✗ Branch 105 not taken.
✗ Branch 107 not taken.
✗ Branch 108 not taken.
✓ Branch 111 taken 315 times.
✗ Branch 112 not taken.
✓ Branch 114 taken 315 times.
✗ Branch 115 not taken.
✗ Branch 117 not taken.
✗ Branch 118 not taken.
|
4300 | Slice _slice{ |
251 |
30/120✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 8 not taken.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✓ Branch 15 taken 108 times.
✓ Branch 16 taken 114 times.
✓ Branch 19 taken 108 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 114 times.
✗ Branch 23 not taken.
✓ Branch 24 taken 114 times.
✓ Branch 25 taken 108 times.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✗ Branch 33 not taken.
✗ Branch 34 not taken.
✗ Branch 36 not taken.
✗ Branch 37 not taken.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✗ Branch 41 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✗ Branch 50 not taken.
✗ Branch 51 not taken.
✗ Branch 52 not taken.
✗ Branch 53 not taken.
✗ Branch 54 not taken.
✗ Branch 55 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✗ Branch 61 not taken.
✗ Branch 62 not taken.
✗ Branch 64 not taken.
✗ Branch 65 not taken.
✗ Branch 66 not taken.
✗ Branch 67 not taken.
✗ Branch 68 not taken.
✗ Branch 69 not taken.
✗ Branch 71 not taken.
✓ Branch 72 taken 2 times.
✗ Branch 75 not taken.
✗ Branch 76 not taken.
✓ Branch 78 taken 2 times.
✗ Branch 79 not taken.
✓ Branch 80 taken 2 times.
✗ Branch 81 not taken.
✗ Branch 82 not taken.
✗ Branch 83 not taken.
✗ Branch 85 not taken.
✗ Branch 86 not taken.
✗ Branch 89 not taken.
✗ Branch 90 not taken.
✗ Branch 92 not taken.
✗ Branch 93 not taken.
✗ Branch 94 not taken.
✗ Branch 95 not taken.
✗ Branch 96 not taken.
✗ Branch 97 not taken.
✓ Branch 99 taken 54 times.
✓ Branch 100 taken 71 times.
✓ Branch 103 taken 54 times.
✗ Branch 104 not taken.
✓ Branch 106 taken 71 times.
✗ Branch 107 not taken.
✓ Branch 108 taken 71 times.
✓ Branch 109 taken 54 times.
✗ Branch 110 not taken.
✗ Branch 111 not taken.
✗ Branch 113 not taken.
✗ Branch 114 not taken.
✗ Branch 117 not taken.
✗ Branch 118 not taken.
✗ Branch 120 not taken.
✗ Branch 121 not taken.
✗ Branch 122 not taken.
✗ Branch 123 not taken.
✗ Branch 124 not taken.
✗ Branch 125 not taken.
✗ Branch 127 not taken.
✓ Branch 128 taken 28 times.
✗ Branch 131 not taken.
✗ Branch 132 not taken.
✓ Branch 134 taken 28 times.
✗ Branch 135 not taken.
✓ Branch 136 taken 28 times.
✗ Branch 137 not taken.
✗ Branch 138 not taken.
✗ Branch 139 not taken.
✓ Branch 141 taken 1239 times.
✓ Branch 142 taken 408 times.
✓ Branch 145 taken 1239 times.
✗ Branch 146 not taken.
✓ Branch 148 taken 408 times.
✗ Branch 149 not taken.
✓ Branch 150 taken 408 times.
✓ Branch 151 taken 1239 times.
✗ Branch 152 not taken.
✗ Branch 153 not taken.
✓ Branch 155 taken 1023 times.
✓ Branch 156 taken 315 times.
✓ Branch 159 taken 1023 times.
✗ Branch 160 not taken.
✓ Branch 162 taken 315 times.
✗ Branch 163 not taken.
✓ Branch 164 taken 315 times.
✓ Branch 165 taken 1023 times.
✗ Branch 166 not taken.
✗ Branch 167 not taken.
|
7662 | .offset = slice ? slice->offset : std::vector<std::size_t>(space.getNumberDimensions(), 0), |
252 |
14/48✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 8 taken 108 times.
✓ Branch 9 taken 114 times.
✓ Branch 12 taken 108 times.
✗ Branch 13 not taken.
✗ Branch 15 not taken.
✗ Branch 16 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✗ Branch 22 not taken.
✗ Branch 23 not taken.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✗ Branch 33 not taken.
✗ Branch 34 not taken.
✗ Branch 36 not taken.
✓ Branch 37 taken 2 times.
✗ Branch 40 not taken.
✗ Branch 41 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✓ Branch 50 taken 54 times.
✓ Branch 51 taken 71 times.
✓ Branch 54 taken 54 times.
✗ Branch 55 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✗ Branch 61 not taken.
✗ Branch 62 not taken.
✗ Branch 64 not taken.
✓ Branch 65 taken 28 times.
✗ Branch 68 not taken.
✗ Branch 69 not taken.
✓ Branch 71 taken 1239 times.
✓ Branch 72 taken 408 times.
✓ Branch 75 taken 1239 times.
✗ Branch 76 not taken.
✓ Branch 78 taken 1023 times.
✓ Branch 79 taken 315 times.
✓ Branch 82 taken 1023 times.
✗ Branch 83 not taken.
|
3362 | .count = slice ? slice->count : space.getDimensions() |
253 | }; | ||
254 |
6/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 4 taken 222 times.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 22 taken 125 times.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 28 taken 28 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 1647 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 1338 times.
✗ Branch 35 not taken.
|
3362 | _slice.offset.at(0) += offset; |
255 | |||
256 |
6/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 4 taken 222 times.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 22 taken 125 times.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 28 taken 28 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 1647 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 1338 times.
✗ Branch 35 not taken.
|
3362 | const auto serialization = field.serialized(); |
257 |
6/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 4 taken 222 times.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 22 taken 125 times.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 28 taken 28 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 1647 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 1338 times.
✗ Branch 35 not taken.
|
3362 | const std::span<const T> span = serialization.template as_span_of<T>(); |
258 | |||
259 |
16/53✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 94 times.
✓ Branch 6 taken 128 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 128 times.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 16 not taken.
✓ Branch 17 taken 2 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✗ Branch 21 not taken.
✗ Branch 22 not taken.
✓ Branch 23 taken 53 times.
✗ Branch 24 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 28 not taken.
✓ Branch 29 taken 12 times.
✗ Branch 31 not taken.
✓ Branch 32 taken 605 times.
✗ Branch 33 not taken.
✗ Branch 34 not taken.
✓ Branch 35 taken 498 times.
✓ Branch 36 taken 72 times.
✗ Branch 37 not taken.
✓ Branch 38 taken 72 times.
✗ Branch 39 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✓ Branch 46 taken 16 times.
✗ Branch 47 not taken.
✓ Branch 48 taken 16 times.
✗ Branch 49 not taken.
✓ Branch 51 taken 1042 times.
✗ Branch 52 not taken.
✓ Branch 53 taken 1042 times.
✗ Branch 54 not taken.
✓ Branch 56 taken 840 times.
✗ Branch 57 not taken.
✓ Branch 58 taken 840 times.
✗ Branch 59 not taken.
|
3362 | if (Parallel::size(_comm) > 1) { |
260 |
7/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 4 taken 52 times.
✓ Branch 5 taken 76 times.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 22 taken 26 times.
✓ Branch 23 taken 46 times.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 28 not taken.
✓ Branch 29 taken 16 times.
✓ Branch 31 taken 1042 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 840 times.
✗ Branch 35 not taken.
|
2098 | if (slice) { // collective I/O |
261 |
4/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 4 taken 52 times.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 22 taken 26 times.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 28 not taken.
✗ Branch 29 not taken.
✓ Branch 31 taken 1042 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 840 times.
✗ Branch 35 not taken.
|
1960 | const auto props = Detail::parallel_transfer_props(); |
262 |
8/48✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 10 taken 52 times.
✗ Branch 11 not taken.
✓ Branch 14 taken 52 times.
✗ Branch 15 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✗ Branch 23 not taken.
✗ Branch 24 not taken.
✗ Branch 28 not taken.
✗ Branch 29 not taken.
✗ Branch 32 not taken.
✗ Branch 33 not taken.
✗ Branch 37 not taken.
✗ Branch 38 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
✗ Branch 46 not taken.
✗ Branch 47 not taken.
✗ Branch 50 not taken.
✗ Branch 51 not taken.
✗ Branch 55 not taken.
✗ Branch 56 not taken.
✗ Branch 59 not taken.
✗ Branch 60 not taken.
✓ Branch 64 taken 26 times.
✗ Branch 65 not taken.
✓ Branch 68 taken 26 times.
✗ Branch 69 not taken.
✗ Branch 73 not taken.
✗ Branch 74 not taken.
✗ Branch 77 not taken.
✗ Branch 78 not taken.
✗ Branch 82 not taken.
✗ Branch 83 not taken.
✗ Branch 86 not taken.
✗ Branch 87 not taken.
✓ Branch 91 taken 1042 times.
✗ Branch 92 not taken.
✓ Branch 95 taken 1042 times.
✗ Branch 96 not taken.
✓ Branch 100 taken 840 times.
✗ Branch 101 not taken.
✓ Branch 104 taken 840 times.
✗ Branch 105 not taken.
|
1960 | _write_to(dataset, span.data(), _slice, props); |
263 |
4/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 4 taken 52 times.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 22 taken 26 times.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 28 not taken.
✗ Branch 29 not taken.
✓ Branch 31 taken 1042 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 840 times.
✗ Branch 35 not taken.
|
1960 | Detail::check_successful_collective_io(props); |
264 |
9/58✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✓ Branch 9 taken 76 times.
✗ Branch 10 not taken.
✓ Branch 11 taken 34 times.
✓ Branch 12 taken 42 times.
✗ Branch 13 not taken.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
✗ Branch 22 not taken.
✗ Branch 23 not taken.
✗ Branch 24 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 28 not taken.
✗ Branch 30 not taken.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✗ Branch 33 not taken.
✗ Branch 37 not taken.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 40 not taken.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✗ Branch 45 not taken.
✗ Branch 46 not taken.
✗ Branch 47 not taken.
✗ Branch 48 not taken.
✓ Branch 51 taken 46 times.
✗ Branch 52 not taken.
✓ Branch 53 taken 21 times.
✓ Branch 54 taken 25 times.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✗ Branch 59 not taken.
✗ Branch 60 not taken.
✗ Branch 61 not taken.
✓ Branch 65 taken 16 times.
✗ Branch 66 not taken.
✓ Branch 67 taken 8 times.
✓ Branch 68 taken 8 times.
✗ Branch 72 not taken.
✗ Branch 73 not taken.
✗ Branch 74 not taken.
✗ Branch 75 not taken.
✗ Branch 79 not taken.
✗ Branch 80 not taken.
✗ Branch 81 not taken.
✗ Branch 82 not taken.
|
2098 | } else if (Parallel::rank(_comm) == 0) { // write only on rank 0 to avoid clashes |
265 |
3/24✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 10 taken 34 times.
✗ Branch 11 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✗ Branch 24 not taken.
✗ Branch 25 not taken.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 45 not taken.
✗ Branch 46 not taken.
✓ Branch 52 taken 21 times.
✗ Branch 53 not taken.
✗ Branch 59 not taken.
✗ Branch 60 not taken.
✓ Branch 66 taken 8 times.
✗ Branch 67 not taken.
✗ Branch 73 not taken.
✗ Branch 74 not taken.
✗ Branch 80 not taken.
✗ Branch 81 not taken.
|
63 | _write_to(dataset, span.data(), _slice); |
266 | } | ||
267 | } else { | ||
268 |
6/24✗ Branch 3 not taken.
✗ Branch 4 not taken.
✓ Branch 10 taken 94 times.
✗ Branch 11 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✗ Branch 24 not taken.
✗ Branch 25 not taken.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✓ Branch 38 taken 2 times.
✗ Branch 39 not taken.
✗ Branch 45 not taken.
✗ Branch 46 not taken.
✓ Branch 52 taken 53 times.
✗ Branch 53 not taken.
✗ Branch 59 not taken.
✗ Branch 60 not taken.
✓ Branch 66 taken 12 times.
✗ Branch 67 not taken.
✓ Branch 73 taken 605 times.
✗ Branch 74 not taken.
✓ Branch 80 taken 498 times.
✗ Branch 81 not taken.
|
1264 | _write_to(dataset, span.data(), _slice); |
269 | } | ||
270 |
6/24✗ Branch 1 not taken.
✗ Branch 2 not taken.
✓ Branch 4 taken 222 times.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✓ Branch 16 taken 2 times.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✓ Branch 22 taken 125 times.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✓ Branch 28 taken 28 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 1647 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 1338 times.
✗ Branch 35 not taken.
|
3362 | _file.flush(); |
271 | 3362 | }); | |
272 | 3362 | } | |
273 | |||
274 | //! Read dataset values into an instance of the given T | ||
275 | template<typename T> | ||
276 | requires(Concepts::ResizableMDRange<T> or Concepts::Scalar<T>) | ||
277 | 13174 | T read_dataset_to(const std::string& path, | |
278 | const std::optional<Slice>& slice = {}) const { | ||
279 |
1/2✓ Branch 1 taken 3219 times.
✗ Branch 2 not taken.
|
26215 | return visit_dataset(path, [&] <typename F> (BufferField<F>&& field) { |
280 | 6603 | return field.template export_to<T>(); | |
281 |
1/2✓ Branch 1 taken 3384 times.
✗ Branch 2 not taken.
|
26348 | }, slice); |
282 | } | ||
283 | |||
284 | //! Visit the dataset field | ||
285 | template<std::invocable<BufferField<int>&&> Visitor> | ||
286 | 17208 | decltype(auto) visit_dataset(const std::string& path, | |
287 | Visitor&& visitor, | ||
288 | const std::optional<Slice>& slice = {}) const { | ||
289 |
2/4✓ Branch 1 taken 8620 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 8620 times.
|
17208 | if (!has_dataset_at(path)) |
290 | ✗ | throw ValueError("Given data set '" + path + "' does not exist."); | |
291 | |||
292 |
1/2✓ Branch 1 taken 8620 times.
✗ Branch 2 not taken.
|
17208 | auto [group, name] = Detail::split_group(path); |
293 |
2/2✓ Branch 1 taken 7052 times.
✓ Branch 2 taken 1568 times.
|
17208 | if (slice) |
294 |
1/2✓ Branch 2 taken 3219 times.
✗ Branch 3 not taken.
|
6406 | return _visit_data( |
295 | std::forward<Visitor>(visitor), | ||
296 |
3/6✓ Branch 1 taken 7052 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 7052 times.
✗ Branch 6 not taken.
✓ Branch 12 taken 7052 times.
✗ Branch 13 not taken.
|
28144 | _file.getGroup(group).getDataSet(name).select(slice->offset, slice->count) |
297 |
1/2✓ Branch 2 taken 3833 times.
✗ Branch 3 not taken.
|
14072 | ); |
298 |
3/6✓ Branch 1 taken 1568 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 1568 times.
✗ Branch 6 not taken.
✓ Branch 9 taken 1568 times.
✗ Branch 10 not taken.
|
3136 | return _visit_data(std::forward<Visitor>(visitor), _file.getGroup(group).getDataSet(name)); |
299 | 17208 | } | |
300 | |||
301 | //! Read attribute values into an instance of the given T | ||
302 | template<typename T> | ||
303 | requires(Concepts::ResizableMDRange<T> or Concepts::Scalar<T>) | ||
304 | 466 | T read_attribute_to(const std::string& path) const { | |
305 | 699 | return visit_attribute(path, [&] <typename F> (BufferField<F>&& field) { | |
306 | 233 | return field.template export_to<T>(); | |
307 |
1/2✓ Branch 1 taken 233 times.
✗ Branch 2 not taken.
|
932 | }); |
308 | } | ||
309 | |||
310 | //! Visit the attribute field | ||
311 | template<std::invocable<BufferField<int>&&> Visitor> | ||
312 | 684 | decltype(auto) visit_attribute(const std::string& path, Visitor&& visitor) const { | |
313 |
2/4✓ Branch 1 taken 342 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 342 times.
|
684 | if (!has_attribute_at(path)) |
314 | ✗ | throw ValueError("Given attribute '" + path + "' does not exist."); | |
315 | |||
316 |
1/2✓ Branch 1 taken 342 times.
✗ Branch 2 not taken.
|
684 | auto [group, name] = Detail::split_group(path); |
317 |
3/6✓ Branch 1 taken 342 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 342 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 342 times.
✗ Branch 9 not taken.
|
1368 | return _visit_data(std::forward<Visitor>(visitor), _file.getGroup(group).getAttribute(name)); |
318 | 684 | } | |
319 | |||
320 | //! Get the dimensions of a dataset; returns null optional if it doesn't exist. | ||
321 | 8352 | std::optional<std::vector<std::size_t>> get_dimensions(const std::string& path) const { | |
322 |
2/2✓ Branch 1 taken 4972 times.
✓ Branch 2 taken 576 times.
|
8352 | if (has_dataset_at(path)) { |
323 |
1/2✓ Branch 1 taken 4972 times.
✗ Branch 2 not taken.
|
7560 | const auto [group, name] = Detail::split_group(path); |
324 |
3/6✓ Branch 1 taken 4972 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 4972 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 4972 times.
✗ Branch 9 not taken.
|
7560 | return _file.getGroup(group).getDataSet(name).getDimensions(); |
325 | 7560 | } | |
326 | 792 | return {}; | |
327 | } | ||
328 | |||
329 | //! Get the precision of a dataset; returns null optional if it doesn't exist. | ||
330 | 4381 | std::optional<DynamicPrecision> get_precision(const std::string& path) const { | |
331 |
1/2✓ Branch 1 taken 2701 times.
✗ Branch 2 not taken.
|
4381 | if (has_dataset_at(path)) { |
332 |
1/2✓ Branch 1 taken 2701 times.
✗ Branch 2 not taken.
|
4381 | const auto [group, name] = Detail::split_group(path); |
333 |
4/8✓ Branch 1 taken 2701 times.
✗ Branch 2 not taken.
✓ Branch 5 taken 2701 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 2701 times.
✗ Branch 9 not taken.
✓ Branch 11 taken 2701 times.
✗ Branch 12 not taken.
|
4381 | return _to_precision(_file.getGroup(group).getDataSet(name).getDataType()); |
334 | 4381 | } | |
335 | ✗ | return {}; | |
336 | } | ||
337 | |||
338 | //! Return the names of all datasets in the given group | ||
339 | 333 | std::ranges::range auto dataset_names_in(const std::string& group) const { | |
340 |
2/4✓ Branch 1 taken 203 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 203 times.
✗ Branch 5 not taken.
|
666 | return _file.getGroup(group).listObjectNames() |
341 |
2/6✓ Branch 1 taken 203 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 203 times.
✗ Branch 5 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
|
1300 | | std::views::filter([&, group=group] (const auto& name) { |
342 |
4/8✓ Branch 1 taken 722 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 722 times.
✗ Branch 5 not taken.
✓ Branch 9 taken 270 times.
✗ Branch 10 not taken.
✓ Branch 12 taken 270 times.
✗ Branch 13 not taken.
|
992 | return _file.getGroup(group).getObjectType(name) == HighFive::ObjectType::Dataset; |
343 |
1/2✓ Branch 1 taken 203 times.
✗ Branch 2 not taken.
|
666 | }); |
344 | } | ||
345 | |||
346 | //! Return true if the given path exists in the file | ||
347 | 3223 | bool exists(const std::string& path) const { | |
348 | 3223 | return _file.exist(path); | |
349 | } | ||
350 | |||
351 | //! Return true if a dataset exists at the given path | ||
352 | 27786 | bool has_dataset_at(const std::string& path) const { | |
353 |
2/2✓ Branch 1 taken 16883 times.
✓ Branch 2 taken 576 times.
|
27786 | if (_file.exist(path)) { |
354 |
1/2✓ Branch 1 taken 16883 times.
✗ Branch 2 not taken.
|
26994 | const auto [group, name] = Detail::split_group(path); |
355 |
3/6✓ Branch 1 taken 16883 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 16883 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 16883 times.
✗ Branch 8 not taken.
|
26994 | if (_file.getGroup(group).exist(name)) |
356 |
2/4✓ Branch 1 taken 16883 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 16883 times.
✗ Branch 5 not taken.
|
26994 | return _file.getGroup(group).getObjectType(name) == HighFive::ObjectType::Dataset; |
357 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 16883 times.
|
26994 | } |
358 | 792 | return false; | |
359 | } | ||
360 | |||
361 | //! Return true if an attribute exists at the given path | ||
362 | 943 | bool has_attribute_at(const std::string& path) const { | |
363 |
1/2✓ Branch 1 taken 590 times.
✗ Branch 2 not taken.
|
943 | const auto [parent_path, attr_name] = Detail::split_group(path); |
364 |
2/4✓ Branch 1 taken 590 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 590 times.
✗ Branch 4 not taken.
|
943 | if (_file.exist(parent_path)) { |
365 |
2/4✓ Branch 1 taken 590 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✓ Branch 4 taken 590 times.
|
943 | if (has_dataset_at(parent_path)) { |
366 | ✗ | const auto [group, dataset] = Detail::split_group(parent_path); | |
367 | ✗ | return _file.getGroup(group).getDataSet(dataset).hasAttribute(attr_name); | |
368 | ✗ | } else { | |
369 |
2/4✓ Branch 1 taken 590 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 590 times.
✗ Branch 5 not taken.
|
943 | return _file.getGroup(parent_path).hasAttribute(attr_name); |
370 | } | ||
371 | } | ||
372 | ✗ | return false; | |
373 | 943 | } | |
374 | |||
375 | private: | ||
376 | 8752 | void _check_writable() const { | |
377 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 8752 times.
|
8752 | if (_mode == read_only) |
378 | ✗ | throw InvalidState("Cannot modify hdf-file opened in read-only mode"); | |
379 | 8752 | } | |
380 | |||
381 | 601 | HighFive::File _open(const std::string& filename) const { | |
382 |
2/2✓ Branch 0 taken 338 times.
✓ Branch 1 taken 115 times.
|
1015 | auto open_mode = _mode == read_only ? HighFive::File::ReadOnly |
383 |
2/2✓ Branch 0 taken 134 times.
✓ Branch 1 taken 204 times.
|
414 | : (_mode == overwrite ? HighFive::File::Overwrite |
384 | : HighFive::File::ReadWrite); | ||
385 |
2/2✓ Branch 1 taken 250 times.
✓ Branch 2 taken 203 times.
|
601 | if (Parallel::size(_comm) > 1) |
386 |
2/4✓ Branch 1 taken 250 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 250 times.
✗ Branch 5 not taken.
|
708 | return HighFive::File{filename, open_mode, Detail::parallel_file_access_props(_comm)}; |
387 | else | ||
388 | 247 | return HighFive::File{filename, open_mode}; | |
389 | } | ||
390 | |||
391 | template<Concepts::Scalar S, typename T = Detail::HighFiveDataType<S>> | ||
392 | 14504 | auto _prepare_dataset(HighFive::Group& group, | |
393 | const std::string& name, | ||
394 | const HighFive::DataSpace& space) { | ||
395 |
2/2✓ Branch 0 taken 1344 times.
✓ Branch 1 taken 5908 times.
|
14504 | if (_mode == overwrite) |
396 |
2/4✓ Branch 3 taken 1344 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 1344 times.
✗ Branch 7 not taken.
|
2688 | return std::make_pair(std::size_t{0}, group.createDataSet(name, space, HighFive::create_datatype<T>())); |
397 |
1/2✓ Branch 0 taken 5908 times.
✗ Branch 1 not taken.
|
11816 | else if (_mode == append) { |
398 |
2/2✓ Branch 1 taken 4528 times.
✓ Branch 2 taken 1380 times.
|
11816 | if (group.exist(name)) { |
399 |
1/2✓ Branch 2 taken 4528 times.
✗ Branch 3 not taken.
|
9056 | auto dataset = group.getDataSet(name); |
400 |
1/2✓ Branch 1 taken 4528 times.
✗ Branch 2 not taken.
|
9056 | auto out_dimensions = dataset.getDimensions(); |
401 |
1/2✓ Branch 1 taken 4528 times.
✗ Branch 2 not taken.
|
9056 | const auto in_dimensions = space.getDimensions(); |
402 | |||
403 |
3/6✓ Branch 1 taken 4528 times.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 4528 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 4528 times.
|
9056 | if (out_dimensions.size() < 1 || in_dimensions.size() < 1) |
404 | ✗ | throw ValueError("Cannot extend scalar datasets"); | |
405 | 9056 | if ( | |
406 |
1/2✓ Branch 1 taken 4528 times.
✗ Branch 2 not taken.
|
9056 | !std::ranges::equal( |
407 | 9056 | std::ranges::subrange(out_dimensions.begin() + 1, out_dimensions.end()), | |
408 |
1/2✗ Branch 4 not taken.
✓ Branch 5 taken 4528 times.
|
18112 | std::ranges::subrange(in_dimensions.begin() + 1, in_dimensions.end()) |
409 | ) | ||
410 | ) | ||
411 | ✗ | throw ValueError("Dataset extension requires the sub-dimensions to be equal"); | |
412 | |||
413 | 9056 | const std::size_t offset = out_dimensions[0]; | |
414 | 9056 | out_dimensions[0] += in_dimensions[0]; | |
415 |
1/2✓ Branch 1 taken 4528 times.
✗ Branch 2 not taken.
|
9056 | dataset.resize(out_dimensions); |
416 | 9056 | return std::make_pair(offset, std::move(dataset)); | |
417 | 9056 | } else { | |
418 |
1/2✓ Branch 1 taken 1380 times.
✗ Branch 2 not taken.
|
2760 | const auto init_dimensions = space.getDimensions(); |
419 |
1/2✗ Branch 1 not taken.
✓ Branch 2 taken 1380 times.
|
2760 | if (init_dimensions.size() < 1) |
420 | ✗ | throw ValueError("Scalars cannot be written in appended mode. Wrap them in std::array{scalar}"); | |
421 | |||
422 |
1/2✓ Branch 3 taken 1380 times.
✗ Branch 4 not taken.
|
5520 | const auto chunk_dimensions = std::vector<hsize_t>{init_dimensions.begin(), init_dimensions.end()}; |
423 |
1/2✓ Branch 1 taken 1380 times.
✗ Branch 2 not taken.
|
4140 | const auto max_dimensions = [&] () { |
424 | 1380 | auto tmp = init_dimensions; | |
425 | 1380 | tmp[0] *= HighFive::DataSpace::UNLIMITED; | |
426 | 1380 | return tmp; | |
427 | } (); | ||
428 | |||
429 |
1/2✓ Branch 1 taken 1380 times.
✗ Branch 2 not taken.
|
2760 | HighFive::DataSpace out_space(init_dimensions, max_dimensions); |
430 | 2760 | HighFive::DataSetCreateProps props; | |
431 |
2/4✓ Branch 1 taken 1380 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1380 times.
✗ Branch 5 not taken.
|
2760 | props.add(HighFive::Chunking(chunk_dimensions)); |
432 | return std::make_pair( | ||
433 | 5520 | std::size_t{0}, | |
434 |
2/4✓ Branch 2 taken 1380 times.
✗ Branch 3 not taken.
✓ Branch 5 taken 1380 times.
✗ Branch 6 not taken.
|
5520 | group.createDataSet(name, out_space, HighFive::create_datatype<T>(), props) |
435 | 2760 | ); | |
436 | 2760 | } | |
437 | } else { | ||
438 | ✗ | throw NotImplemented("Unknown file mode"); | |
439 | } | ||
440 | } | ||
441 | |||
442 | template<typename Values> | ||
443 | 6158 | void _write_to(HighFive::DataSet& dataset, | |
444 | const Values& values, | ||
445 | const Slice& slice, | ||
446 | const std::optional<HighFive::DataTransferProps> props = {}) { | ||
447 |
8/16✓ Branch 1 taken 684 times.
✓ Branch 2 taken 2395 times.
✓ Branch 6 taken 684 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 684 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 684 times.
✓ Branch 14 taken 2395 times.
✓ Branch 16 taken 684 times.
✓ Branch 17 taken 2395 times.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✗ Branch 22 not taken.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
|
12316 | props ? dataset.select(slice.offset, slice.count).write(values, *props) |
448 |
12/22✓ Branch 3 taken 2395 times.
✗ Branch 4 not taken.
✓ Branch 7 taken 2395 times.
✗ Branch 8 not taken.
✓ Branch 9 taken 2395 times.
✓ Branch 10 taken 684 times.
✓ Branch 12 taken 2395 times.
✓ Branch 13 taken 684 times.
✓ Branch 15 taken 2395 times.
✓ Branch 16 taken 684 times.
✓ Branch 18 taken 2395 times.
✓ Branch 19 taken 684 times.
✓ Branch 21 taken 684 times.
✓ Branch 22 taken 2395 times.
✗ Branch 23 not taken.
✗ Branch 24 not taken.
✗ Branch 26 not taken.
✗ Branch 27 not taken.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✗ Branch 32 not taken.
✗ Branch 33 not taken.
|
6158 | : dataset.select(slice.offset, slice.count).write(values); |
449 | 6158 | } | |
450 | |||
451 | template<Concepts::Scalar T> | ||
452 | 6574 | void _write_to(HighFive::DataSet& dataset, | |
453 | const T* buffer, | ||
454 | const Slice& slice, | ||
455 | const std::optional<HighFive::DataTransferProps> props = {}) { | ||
456 |
11/22✓ Branch 1 taken 1960 times.
✓ Branch 2 taken 1327 times.
✓ Branch 6 taken 1960 times.
✗ Branch 7 not taken.
✓ Branch 10 taken 1960 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1960 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1960 times.
✓ Branch 17 taken 1327 times.
✓ Branch 19 taken 1960 times.
✓ Branch 20 taken 1327 times.
✓ Branch 22 taken 1960 times.
✓ Branch 23 taken 1327 times.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 28 not taken.
✗ Branch 29 not taken.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✗ Branch 34 not taken.
✗ Branch 35 not taken.
|
13148 | props ? dataset.select(slice.offset, slice.count).write_raw(buffer, dataset.getDataType(), *props) |
457 |
15/28✓ Branch 3 taken 1327 times.
✗ Branch 4 not taken.
✓ Branch 7 taken 1327 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1327 times.
✗ Branch 11 not taken.
✓ Branch 12 taken 1327 times.
✓ Branch 13 taken 1960 times.
✓ Branch 15 taken 1327 times.
✓ Branch 16 taken 1960 times.
✓ Branch 18 taken 1327 times.
✓ Branch 19 taken 1960 times.
✓ Branch 21 taken 1327 times.
✓ Branch 22 taken 1960 times.
✓ Branch 24 taken 1327 times.
✓ Branch 25 taken 1960 times.
✓ Branch 27 taken 1960 times.
✓ Branch 28 taken 1327 times.
✗ Branch 29 not taken.
✗ Branch 30 not taken.
✗ Branch 32 not taken.
✗ Branch 33 not taken.
✗ Branch 35 not taken.
✗ Branch 36 not taken.
✗ Branch 38 not taken.
✗ Branch 39 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
|
6574 | : dataset.select(slice.offset, slice.count).write_raw(buffer, dataset.getDataType()); |
458 | 6574 | } | |
459 | |||
460 | template<typename Visitor, typename Source> | ||
461 | 17924 | decltype(auto) _visit_data(Visitor&& visitor, const Source& source) const { | |
462 |
1/2✓ Branch 1 taken 8962 times.
✗ Branch 2 not taken.
|
17924 | const auto datatype = source.getDataType(); |
463 |
3/4✓ Branch 1 taken 8962 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 113 times.
✓ Branch 4 taken 8849 times.
|
17924 | if (datatype.isFixedLenStr()) { |
464 | 226 | std::vector<std::string> pre_out; | |
465 |
1/3✓ Branch 1 taken 113 times.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
|
226 | source.read(pre_out); |
466 |
3/6✓ Branch 1 taken 113 times.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 113 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 113 times.
|
226 | if (pre_out.size() > 1 or pre_out.size() == 0) |
467 | ✗ | throw SizeError("Unexpected string array size"); | |
468 | |||
469 | 226 | std::string out = std::move(std::move(pre_out)[0]); | |
470 |
1/2✓ Branch 2 taken 113 times.
✗ Branch 3 not taken.
|
226 | MDLayout layout{{out.size()}}; |
471 |
2/4✓ Branch 3 taken 113 times.
✗ Branch 4 not taken.
✓ Branch 6 taken 113 times.
✗ Branch 7 not taken.
|
226 | return visitor(BufferField{std::move(out), std::move(layout)}); |
472 | 226 | } else { | |
473 |
2/4✓ Branch 1 taken 8849 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 3328 times.
✗ Branch 5 not taken.
|
44027 | return _to_precision(datatype).visit([&] <typename T> (const Precision<T>&) { |
474 |
116/2160✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 9 not taken.
✗ Branch 10 not taken.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✗ Branch 17 not taken.
✗ Branch 18 not taken.
✗ Branch 20 not taken.
✗ Branch 21 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 28 not taken.
✗ Branch 29 not taken.
✗ Branch 33 not taken.
✗ Branch 34 not taken.
✗ Branch 36 not taken.
✗ Branch 37 not taken.
✗ Branch 41 not taken.
✗ Branch 42 not taken.
✗ Branch 44 not taken.
✗ Branch 45 not taken.
✗ Branch 49 not taken.
✗ Branch 50 not taken.
✗ Branch 52 not taken.
✗ Branch 53 not taken.
✗ Branch 57 not taken.
✗ Branch 58 not taken.
✗ Branch 60 not taken.
✗ Branch 61 not taken.
✗ Branch 65 not taken.
✗ Branch 66 not taken.
✗ Branch 68 not taken.
✗ Branch 69 not taken.
✗ Branch 73 not taken.
✗ Branch 74 not taken.
✗ Branch 76 not taken.
✗ Branch 77 not taken.
✗ Branch 81 not taken.
✗ Branch 82 not taken.
✗ Branch 84 not taken.
✗ Branch 85 not taken.
✗ Branch 89 not taken.
✗ Branch 90 not taken.
✗ Branch 92 not taken.
✗ Branch 93 not taken.
✗ Branch 97 not taken.
✗ Branch 98 not taken.
✗ Branch 100 not taken.
✗ Branch 101 not taken.
✗ Branch 105 not taken.
✗ Branch 106 not taken.
✗ Branch 108 not taken.
✗ Branch 109 not taken.
✗ Branch 113 not taken.
✗ Branch 114 not taken.
✗ Branch 116 not taken.
✗ Branch 117 not taken.
✗ Branch 121 not taken.
✗ Branch 122 not taken.
✗ Branch 124 not taken.
✗ Branch 125 not taken.
✗ Branch 129 not taken.
✗ Branch 130 not taken.
✗ Branch 132 not taken.
✗ Branch 133 not taken.
✓ Branch 137 taken 56 times.
✗ Branch 138 not taken.
✓ Branch 140 taken 56 times.
✗ Branch 141 not taken.
✗ Branch 145 not taken.
✗ Branch 146 not taken.
✗ Branch 148 not taken.
✗ Branch 149 not taken.
✗ Branch 153 not taken.
✗ Branch 154 not taken.
✗ Branch 156 not taken.
✗ Branch 157 not taken.
✓ Branch 161 taken 107 times.
✗ Branch 162 not taken.
✓ Branch 164 taken 107 times.
✗ Branch 165 not taken.
✗ Branch 169 not taken.
✗ Branch 170 not taken.
✗ Branch 172 not taken.
✗ Branch 173 not taken.
✗ Branch 177 not taken.
✗ Branch 178 not taken.
✗ Branch 180 not taken.
✗ Branch 181 not taken.
✗ Branch 185 not taken.
✗ Branch 186 not taken.
✗ Branch 188 not taken.
✗ Branch 189 not taken.
✗ Branch 193 not taken.
✗ Branch 194 not taken.
✗ Branch 196 not taken.
✗ Branch 197 not taken.
✗ Branch 201 not taken.
✗ Branch 202 not taken.
✗ Branch 204 not taken.
✗ Branch 205 not taken.
✗ Branch 209 not taken.
✗ Branch 210 not taken.
✗ Branch 212 not taken.
✗ Branch 213 not taken.
✗ Branch 217 not taken.
✗ Branch 218 not taken.
✗ Branch 220 not taken.
✗ Branch 221 not taken.
✗ Branch 225 not taken.
✗ Branch 226 not taken.
✗ Branch 228 not taken.
✗ Branch 229 not taken.
✓ Branch 233 taken 658 times.
✗ Branch 234 not taken.
✓ Branch 236 taken 658 times.
✗ Branch 237 not taken.
✓ Branch 241 taken 2 times.
✗ Branch 242 not taken.
✓ Branch 244 taken 2 times.
✗ Branch 245 not taken.
✓ Branch 249 taken 2 times.
✗ Branch 250 not taken.
✓ Branch 252 taken 2 times.
✗ Branch 253 not taken.
✗ Branch 257 not taken.
✗ Branch 258 not taken.
✗ Branch 260 not taken.
✗ Branch 261 not taken.
✗ Branch 265 not taken.
✗ Branch 266 not taken.
✗ Branch 268 not taken.
✗ Branch 269 not taken.
✗ Branch 273 not taken.
✗ Branch 274 not taken.
✗ Branch 276 not taken.
✗ Branch 277 not taken.
✗ Branch 281 not taken.
✗ Branch 282 not taken.
✗ Branch 284 not taken.
✗ Branch 285 not taken.
✗ Branch 289 not taken.
✗ Branch 290 not taken.
✗ Branch 292 not taken.
✗ Branch 293 not taken.
✗ Branch 297 not taken.
✗ Branch 298 not taken.
✗ Branch 300 not taken.
✗ Branch 301 not taken.
✗ Branch 305 not taken.
✗ Branch 306 not taken.
✗ Branch 308 not taken.
✗ Branch 309 not taken.
✓ Branch 313 taken 665 times.
✗ Branch 314 not taken.
✓ Branch 316 taken 665 times.
✗ Branch 317 not taken.
✗ Branch 321 not taken.
✗ Branch 322 not taken.
✗ Branch 324 not taken.
✗ Branch 325 not taken.
✗ Branch 329 not taken.
✗ Branch 330 not taken.
✗ Branch 332 not taken.
✗ Branch 333 not taken.
✗ Branch 337 not taken.
✗ Branch 338 not taken.
✗ Branch 340 not taken.
✗ Branch 341 not taken.
✗ Branch 345 not taken.
✗ Branch 346 not taken.
✗ Branch 348 not taken.
✗ Branch 349 not taken.
✗ Branch 353 not taken.
✗ Branch 354 not taken.
✗ Branch 356 not taken.
✗ Branch 357 not taken.
✗ Branch 361 not taken.
✗ Branch 362 not taken.
✗ Branch 364 not taken.
✗ Branch 365 not taken.
✗ Branch 369 not taken.
✗ Branch 370 not taken.
✗ Branch 372 not taken.
✗ Branch 373 not taken.
✗ Branch 377 not taken.
✗ Branch 378 not taken.
✗ Branch 380 not taken.
✗ Branch 381 not taken.
✗ Branch 385 not taken.
✗ Branch 386 not taken.
✗ Branch 388 not taken.
✗ Branch 389 not taken.
✗ Branch 393 not taken.
✗ Branch 394 not taken.
✗ Branch 396 not taken.
✗ Branch 397 not taken.
✗ Branch 401 not taken.
✗ Branch 402 not taken.
✗ Branch 404 not taken.
✗ Branch 405 not taken.
✗ Branch 409 not taken.
✗ Branch 410 not taken.
✗ Branch 412 not taken.
✗ Branch 413 not taken.
✗ Branch 417 not taken.
✗ Branch 418 not taken.
✗ Branch 420 not taken.
✗ Branch 421 not taken.
✗ Branch 425 not taken.
✗ Branch 426 not taken.
✗ Branch 428 not taken.
✗ Branch 429 not taken.
✗ Branch 433 not taken.
✗ Branch 434 not taken.
✗ Branch 436 not taken.
✗ Branch 437 not taken.
✗ Branch 441 not taken.
✗ Branch 442 not taken.
✗ Branch 444 not taken.
✗ Branch 445 not taken.
✗ Branch 449 not taken.
✗ Branch 450 not taken.
✗ Branch 452 not taken.
✗ Branch 453 not taken.
✗ Branch 457 not taken.
✗ Branch 458 not taken.
✗ Branch 460 not taken.
✗ Branch 461 not taken.
✗ Branch 465 not taken.
✗ Branch 466 not taken.
✗ Branch 468 not taken.
✗ Branch 469 not taken.
✗ Branch 473 not taken.
✗ Branch 474 not taken.
✗ Branch 476 not taken.
✗ Branch 477 not taken.
✗ Branch 481 not taken.
✗ Branch 482 not taken.
✗ Branch 484 not taken.
✗ Branch 485 not taken.
✓ Branch 489 taken 615 times.
✗ Branch 490 not taken.
✓ Branch 492 taken 615 times.
✗ Branch 493 not taken.
✓ Branch 497 taken 30 times.
✗ Branch 498 not taken.
✓ Branch 500 taken 30 times.
✗ Branch 501 not taken.
✗ Branch 505 not taken.
✗ Branch 506 not taken.
✗ Branch 508 not taken.
✗ Branch 509 not taken.
✗ Branch 513 not taken.
✗ Branch 514 not taken.
✗ Branch 516 not taken.
✗ Branch 517 not taken.
✗ Branch 521 not taken.
✗ Branch 522 not taken.
✗ Branch 524 not taken.
✗ Branch 525 not taken.
✗ Branch 529 not taken.
✗ Branch 530 not taken.
✗ Branch 532 not taken.
✗ Branch 533 not taken.
✗ Branch 537 not taken.
✗ Branch 538 not taken.
✗ Branch 540 not taken.
✗ Branch 541 not taken.
✗ Branch 545 not taken.
✗ Branch 546 not taken.
✗ Branch 548 not taken.
✗ Branch 549 not taken.
✗ Branch 553 not taken.
✗ Branch 554 not taken.
✗ Branch 556 not taken.
✗ Branch 557 not taken.
✗ Branch 561 not taken.
✗ Branch 562 not taken.
✗ Branch 564 not taken.
✗ Branch 565 not taken.
✗ Branch 569 not taken.
✗ Branch 570 not taken.
✗ Branch 572 not taken.
✗ Branch 573 not taken.
✗ Branch 577 not taken.
✗ Branch 578 not taken.
✗ Branch 580 not taken.
✗ Branch 581 not taken.
✗ Branch 585 not taken.
✗ Branch 586 not taken.
✗ Branch 588 not taken.
✗ Branch 589 not taken.
✗ Branch 593 not taken.
✗ Branch 594 not taken.
✗ Branch 596 not taken.
✗ Branch 597 not taken.
✗ Branch 601 not taken.
✗ Branch 602 not taken.
✗ Branch 604 not taken.
✗ Branch 605 not taken.
✗ Branch 609 not taken.
✗ Branch 610 not taken.
✗ Branch 612 not taken.
✗ Branch 613 not taken.
✗ Branch 617 not taken.
✗ Branch 618 not taken.
✗ Branch 620 not taken.
✗ Branch 621 not taken.
✗ Branch 625 not taken.
✗ Branch 626 not taken.
✗ Branch 628 not taken.
✗ Branch 629 not taken.
✗ Branch 633 not taken.
✗ Branch 634 not taken.
✗ Branch 636 not taken.
✗ Branch 637 not taken.
✗ Branch 641 not taken.
✗ Branch 642 not taken.
✗ Branch 644 not taken.
✗ Branch 645 not taken.
✗ Branch 649 not taken.
✗ Branch 650 not taken.
✗ Branch 652 not taken.
✗ Branch 653 not taken.
✗ Branch 657 not taken.
✗ Branch 658 not taken.
✗ Branch 660 not taken.
✗ Branch 661 not taken.
✗ Branch 665 not taken.
✗ Branch 666 not taken.
✗ Branch 668 not taken.
✗ Branch 669 not taken.
✗ Branch 673 not taken.
✗ Branch 674 not taken.
✗ Branch 676 not taken.
✗ Branch 677 not taken.
✗ Branch 681 not taken.
✗ Branch 682 not taken.
✗ Branch 684 not taken.
✗ Branch 685 not taken.
✓ Branch 689 taken 98 times.
✗ Branch 690 not taken.
✓ Branch 692 taken 98 times.
✗ Branch 693 not taken.
✗ Branch 697 not taken.
✗ Branch 698 not taken.
✗ Branch 700 not taken.
✗ Branch 701 not taken.
✗ Branch 705 not taken.
✗ Branch 706 not taken.
✗ Branch 708 not taken.
✗ Branch 709 not taken.
✗ Branch 713 not taken.
✗ Branch 714 not taken.
✗ Branch 716 not taken.
✗ Branch 717 not taken.
✓ Branch 721 taken 2 times.
✗ Branch 722 not taken.
✓ Branch 724 taken 2 times.
✗ Branch 725 not taken.
✗ Branch 729 not taken.
✗ Branch 730 not taken.
✗ Branch 732 not taken.
✗ Branch 733 not taken.
✓ Branch 737 taken 4 times.
✗ Branch 738 not taken.
✓ Branch 740 taken 4 times.
✗ Branch 741 not taken.
✗ Branch 745 not taken.
✗ Branch 746 not taken.
✗ Branch 748 not taken.
✗ Branch 749 not taken.
✗ Branch 753 not taken.
✗ Branch 754 not taken.
✗ Branch 756 not taken.
✗ Branch 757 not taken.
✓ Branch 761 taken 440 times.
✗ Branch 762 not taken.
✓ Branch 764 taken 440 times.
✗ Branch 765 not taken.
✗ Branch 769 not taken.
✗ Branch 770 not taken.
✗ Branch 772 not taken.
✗ Branch 773 not taken.
✗ Branch 777 not taken.
✗ Branch 778 not taken.
✗ Branch 780 not taken.
✗ Branch 781 not taken.
✗ Branch 785 not taken.
✗ Branch 786 not taken.
✗ Branch 788 not taken.
✗ Branch 789 not taken.
✗ Branch 793 not taken.
✗ Branch 794 not taken.
✗ Branch 796 not taken.
✗ Branch 797 not taken.
✗ Branch 801 not taken.
✗ Branch 802 not taken.
✗ Branch 804 not taken.
✗ Branch 805 not taken.
✗ Branch 809 not taken.
✗ Branch 810 not taken.
✗ Branch 812 not taken.
✗ Branch 813 not taken.
✗ Branch 817 not taken.
✗ Branch 818 not taken.
✗ Branch 820 not taken.
✗ Branch 821 not taken.
✗ Branch 825 not taken.
✗ Branch 826 not taken.
✗ Branch 828 not taken.
✗ Branch 829 not taken.
✗ Branch 833 not taken.
✗ Branch 834 not taken.
✗ Branch 836 not taken.
✗ Branch 837 not taken.
✓ Branch 841 taken 496 times.
✗ Branch 842 not taken.
✓ Branch 844 taken 496 times.
✗ Branch 845 not taken.
✗ Branch 849 not taken.
✗ Branch 850 not taken.
✗ Branch 852 not taken.
✗ Branch 853 not taken.
✗ Branch 857 not taken.
✗ Branch 858 not taken.
✗ Branch 860 not taken.
✗ Branch 861 not taken.
✗ Branch 865 not taken.
✗ Branch 866 not taken.
✗ Branch 868 not taken.
✗ Branch 869 not taken.
✗ Branch 873 not taken.
✗ Branch 874 not taken.
✗ Branch 876 not taken.
✗ Branch 877 not taken.
✗ Branch 881 not taken.
✗ Branch 882 not taken.
✗ Branch 884 not taken.
✗ Branch 885 not taken.
✗ Branch 889 not taken.
✗ Branch 890 not taken.
✗ Branch 892 not taken.
✗ Branch 893 not taken.
✗ Branch 897 not taken.
✗ Branch 898 not taken.
✗ Branch 900 not taken.
✗ Branch 901 not taken.
✓ Branch 905 taken 59 times.
✗ Branch 906 not taken.
✓ Branch 908 taken 59 times.
✗ Branch 909 not taken.
✗ Branch 913 not taken.
✗ Branch 914 not taken.
✗ Branch 916 not taken.
✗ Branch 917 not taken.
✗ Branch 921 not taken.
✗ Branch 922 not taken.
✗ Branch 924 not taken.
✗ Branch 925 not taken.
✗ Branch 929 not taken.
✗ Branch 930 not taken.
✗ Branch 932 not taken.
✗ Branch 933 not taken.
✗ Branch 937 not taken.
✗ Branch 938 not taken.
✗ Branch 940 not taken.
✗ Branch 941 not taken.
✗ Branch 945 not taken.
✗ Branch 946 not taken.
✗ Branch 948 not taken.
✗ Branch 949 not taken.
✗ Branch 953 not taken.
✗ Branch 954 not taken.
✗ Branch 956 not taken.
✗ Branch 957 not taken.
✗ Branch 961 not taken.
✗ Branch 962 not taken.
✗ Branch 964 not taken.
✗ Branch 965 not taken.
✓ Branch 969 taken 4 times.
✗ Branch 970 not taken.
✓ Branch 972 taken 4 times.
✗ Branch 973 not taken.
✗ Branch 977 not taken.
✗ Branch 978 not taken.
✗ Branch 980 not taken.
✗ Branch 981 not taken.
✗ Branch 985 not taken.
✗ Branch 986 not taken.
✗ Branch 988 not taken.
✗ Branch 989 not taken.
✗ Branch 993 not taken.
✗ Branch 994 not taken.
✗ Branch 996 not taken.
✗ Branch 997 not taken.
✗ Branch 1001 not taken.
✗ Branch 1002 not taken.
✗ Branch 1004 not taken.
✗ Branch 1005 not taken.
✗ Branch 1009 not taken.
✗ Branch 1010 not taken.
✗ Branch 1012 not taken.
✗ Branch 1013 not taken.
✗ Branch 1017 not taken.
✗ Branch 1018 not taken.
✗ Branch 1020 not taken.
✗ Branch 1021 not taken.
✗ Branch 1025 not taken.
✗ Branch 1026 not taken.
✗ Branch 1028 not taken.
✗ Branch 1029 not taken.
✗ Branch 1033 not taken.
✗ Branch 1034 not taken.
✗ Branch 1036 not taken.
✗ Branch 1037 not taken.
✓ Branch 1041 taken 48 times.
✗ Branch 1042 not taken.
✓ Branch 1044 taken 48 times.
✗ Branch 1045 not taken.
✗ Branch 1049 not taken.
✗ Branch 1050 not taken.
✗ Branch 1052 not taken.
✗ Branch 1053 not taken.
✗ Branch 1057 not taken.
✗ Branch 1058 not taken.
✗ Branch 1060 not taken.
✗ Branch 1061 not taken.
✗ Branch 1065 not taken.
✗ Branch 1066 not taken.
✗ Branch 1068 not taken.
✗ Branch 1069 not taken.
✗ Branch 1073 not taken.
✗ Branch 1074 not taken.
✗ Branch 1076 not taken.
✗ Branch 1077 not taken.
✗ Branch 1081 not taken.
✗ Branch 1082 not taken.
✗ Branch 1084 not taken.
✗ Branch 1085 not taken.
✓ Branch 1089 taken 2 times.
✗ Branch 1090 not taken.
✓ Branch 1092 taken 2 times.
✗ Branch 1093 not taken.
✓ Branch 1097 taken 220 times.
✗ Branch 1098 not taken.
✓ Branch 1100 taken 220 times.
✗ Branch 1101 not taken.
✗ Branch 1105 not taken.
✗ Branch 1106 not taken.
✗ Branch 1108 not taken.
✗ Branch 1109 not taken.
✗ Branch 1113 not taken.
✗ Branch 1114 not taken.
✗ Branch 1116 not taken.
✗ Branch 1117 not taken.
✗ Branch 1121 not taken.
✗ Branch 1122 not taken.
✗ Branch 1124 not taken.
✗ Branch 1125 not taken.
✗ Branch 1129 not taken.
✗ Branch 1130 not taken.
✗ Branch 1132 not taken.
✗ Branch 1133 not taken.
✗ Branch 1137 not taken.
✗ Branch 1138 not taken.
✗ Branch 1140 not taken.
✗ Branch 1141 not taken.
✗ Branch 1145 not taken.
✗ Branch 1146 not taken.
✗ Branch 1148 not taken.
✗ Branch 1149 not taken.
✗ Branch 1153 not taken.
✗ Branch 1154 not taken.
✗ Branch 1156 not taken.
✗ Branch 1157 not taken.
✓ Branch 1161 taken 3 times.
✗ Branch 1162 not taken.
✓ Branch 1164 taken 3 times.
✗ Branch 1165 not taken.
✗ Branch 1169 not taken.
✗ Branch 1170 not taken.
✗ Branch 1172 not taken.
✗ Branch 1173 not taken.
✗ Branch 1177 not taken.
✗ Branch 1178 not taken.
✗ Branch 1180 not taken.
✗ Branch 1181 not taken.
✓ Branch 1185 taken 40 times.
✗ Branch 1186 not taken.
✓ Branch 1188 taken 40 times.
✗ Branch 1189 not taken.
✓ Branch 1193 taken 536 times.
✗ Branch 1194 not taken.
✓ Branch 1196 taken 536 times.
✗ Branch 1197 not taken.
✗ Branch 1201 not taken.
✗ Branch 1202 not taken.
✗ Branch 1204 not taken.
✗ Branch 1205 not taken.
✗ Branch 1209 not taken.
✗ Branch 1210 not taken.
✗ Branch 1212 not taken.
✗ Branch 1213 not taken.
✗ Branch 1217 not taken.
✗ Branch 1218 not taken.
✗ Branch 1220 not taken.
✗ Branch 1221 not taken.
✗ Branch 1225 not taken.
✗ Branch 1226 not taken.
✗ Branch 1228 not taken.
✗ Branch 1229 not taken.
✓ Branch 1233 taken 180 times.
✗ Branch 1234 not taken.
✓ Branch 1236 taken 180 times.
✗ Branch 1237 not taken.
✗ Branch 1241 not taken.
✗ Branch 1242 not taken.
✗ Branch 1244 not taken.
✗ Branch 1245 not taken.
✗ Branch 1249 not taken.
✗ Branch 1250 not taken.
✗ Branch 1252 not taken.
✗ Branch 1253 not taken.
✗ Branch 1257 not taken.
✗ Branch 1258 not taken.
✗ Branch 1260 not taken.
✗ Branch 1261 not taken.
✗ Branch 1265 not taken.
✗ Branch 1266 not taken.
✗ Branch 1268 not taken.
✗ Branch 1269 not taken.
✗ Branch 1273 not taken.
✗ Branch 1274 not taken.
✗ Branch 1276 not taken.
✗ Branch 1277 not taken.
✗ Branch 1281 not taken.
✗ Branch 1282 not taken.
✗ Branch 1284 not taken.
✗ Branch 1285 not taken.
✗ Branch 1289 not taken.
✗ Branch 1290 not taken.
✗ Branch 1292 not taken.
✗ Branch 1293 not taken.
✗ Branch 1297 not taken.
✗ Branch 1298 not taken.
✗ Branch 1300 not taken.
✗ Branch 1301 not taken.
✗ Branch 1305 not taken.
✗ Branch 1306 not taken.
✗ Branch 1308 not taken.
✗ Branch 1309 not taken.
✗ Branch 1313 not taken.
✗ Branch 1314 not taken.
✗ Branch 1316 not taken.
✗ Branch 1317 not taken.
✗ Branch 1321 not taken.
✗ Branch 1322 not taken.
✗ Branch 1324 not taken.
✗ Branch 1325 not taken.
✗ Branch 1329 not taken.
✗ Branch 1330 not taken.
✗ Branch 1332 not taken.
✗ Branch 1333 not taken.
✗ Branch 1337 not taken.
✗ Branch 1338 not taken.
✗ Branch 1340 not taken.
✗ Branch 1341 not taken.
✗ Branch 1345 not taken.
✗ Branch 1346 not taken.
✗ Branch 1348 not taken.
✗ Branch 1349 not taken.
✗ Branch 1353 not taken.
✗ Branch 1354 not taken.
✗ Branch 1356 not taken.
✗ Branch 1357 not taken.
✗ Branch 1361 not taken.
✗ Branch 1362 not taken.
✗ Branch 1364 not taken.
✗ Branch 1365 not taken.
✗ Branch 1369 not taken.
✗ Branch 1370 not taken.
✗ Branch 1372 not taken.
✗ Branch 1373 not taken.
✗ Branch 1377 not taken.
✗ Branch 1378 not taken.
✗ Branch 1380 not taken.
✗ Branch 1381 not taken.
✗ Branch 1385 not taken.
✗ Branch 1386 not taken.
✗ Branch 1388 not taken.
✗ Branch 1389 not taken.
✓ Branch 1393 taken 2 times.
✗ Branch 1394 not taken.
✓ Branch 1396 taken 2 times.
✗ Branch 1397 not taken.
✗ Branch 1401 not taken.
✗ Branch 1402 not taken.
✗ Branch 1404 not taken.
✗ Branch 1405 not taken.
✓ Branch 1409 taken 72 times.
✗ Branch 1410 not taken.
✓ Branch 1412 taken 72 times.
✗ Branch 1413 not taken.
✗ Branch 1417 not taken.
✗ Branch 1418 not taken.
✗ Branch 1420 not taken.
✗ Branch 1421 not taken.
✗ Branch 1425 not taken.
✗ Branch 1426 not taken.
✗ Branch 1428 not taken.
✗ Branch 1429 not taken.
✗ Branch 1433 not taken.
✗ Branch 1434 not taken.
✗ Branch 1436 not taken.
✗ Branch 1437 not taken.
✗ Branch 1441 not taken.
✗ Branch 1442 not taken.
✗ Branch 1444 not taken.
✗ Branch 1445 not taken.
✓ Branch 1449 taken 20 times.
✗ Branch 1450 not taken.
✓ Branch 1452 taken 20 times.
✗ Branch 1453 not taken.
✗ Branch 1457 not taken.
✗ Branch 1458 not taken.
✗ Branch 1460 not taken.
✗ Branch 1461 not taken.
✗ Branch 1465 not taken.
✗ Branch 1466 not taken.
✗ Branch 1468 not taken.
✗ Branch 1469 not taken.
✗ Branch 1473 not taken.
✗ Branch 1474 not taken.
✗ Branch 1476 not taken.
✗ Branch 1477 not taken.
✓ Branch 1481 taken 448 times.
✗ Branch 1482 not taken.
✓ Branch 1484 taken 448 times.
✗ Branch 1485 not taken.
✗ Branch 1489 not taken.
✗ Branch 1490 not taken.
✗ Branch 1492 not taken.
✗ Branch 1493 not taken.
✗ Branch 1497 not taken.
✗ Branch 1498 not taken.
✗ Branch 1500 not taken.
✗ Branch 1501 not taken.
✗ Branch 1505 not taken.
✗ Branch 1506 not taken.
✗ Branch 1508 not taken.
✗ Branch 1509 not taken.
✗ Branch 1513 not taken.
✗ Branch 1514 not taken.
✗ Branch 1516 not taken.
✗ Branch 1517 not taken.
✗ Branch 1521 not taken.
✗ Branch 1522 not taken.
✗ Branch 1524 not taken.
✗ Branch 1525 not taken.
✗ Branch 1529 not taken.
✗ Branch 1530 not taken.
✗ Branch 1532 not taken.
✗ Branch 1533 not taken.
✗ Branch 1537 not taken.
✗ Branch 1538 not taken.
✗ Branch 1540 not taken.
✗ Branch 1541 not taken.
✗ Branch 1545 not taken.
✗ Branch 1546 not taken.
✗ Branch 1548 not taken.
✗ Branch 1549 not taken.
✗ Branch 1553 not taken.
✗ Branch 1554 not taken.
✗ Branch 1556 not taken.
✗ Branch 1557 not taken.
✓ Branch 1561 taken 400 times.
✗ Branch 1562 not taken.
✓ Branch 1564 taken 400 times.
✗ Branch 1565 not taken.
✗ Branch 1569 not taken.
✗ Branch 1570 not taken.
✗ Branch 1572 not taken.
✗ Branch 1573 not taken.
✗ Branch 1577 not taken.
✗ Branch 1578 not taken.
✗ Branch 1580 not taken.
✗ Branch 1581 not taken.
✗ Branch 1585 not taken.
✗ Branch 1586 not taken.
✗ Branch 1588 not taken.
✗ Branch 1589 not taken.
✗ Branch 1593 not taken.
✗ Branch 1594 not taken.
✗ Branch 1596 not taken.
✗ Branch 1597 not taken.
✗ Branch 1601 not taken.
✗ Branch 1602 not taken.
✗ Branch 1604 not taken.
✗ Branch 1605 not taken.
✗ Branch 1609 not taken.
✗ Branch 1610 not taken.
✗ Branch 1612 not taken.
✗ Branch 1613 not taken.
✗ Branch 1617 not taken.
✗ Branch 1618 not taken.
✗ Branch 1620 not taken.
✗ Branch 1621 not taken.
✗ Branch 1625 not taken.
✗ Branch 1626 not taken.
✗ Branch 1628 not taken.
✗ Branch 1629 not taken.
✗ Branch 1633 not taken.
✗ Branch 1634 not taken.
✗ Branch 1636 not taken.
✗ Branch 1637 not taken.
✗ Branch 1641 not taken.
✗ Branch 1642 not taken.
✗ Branch 1644 not taken.
✗ Branch 1645 not taken.
✗ Branch 1649 not taken.
✗ Branch 1650 not taken.
✗ Branch 1652 not taken.
✗ Branch 1653 not taken.
✗ Branch 1657 not taken.
✗ Branch 1658 not taken.
✗ Branch 1660 not taken.
✗ Branch 1661 not taken.
✗ Branch 1665 not taken.
✗ Branch 1666 not taken.
✗ Branch 1668 not taken.
✗ Branch 1669 not taken.
✗ Branch 1673 not taken.
✗ Branch 1674 not taken.
✗ Branch 1676 not taken.
✗ Branch 1677 not taken.
✓ Branch 1681 taken 65 times.
✗ Branch 1682 not taken.
✓ Branch 1684 taken 65 times.
✗ Branch 1685 not taken.
✗ Branch 1689 not taken.
✗ Branch 1690 not taken.
✗ Branch 1692 not taken.
✗ Branch 1693 not taken.
✗ Branch 1697 not taken.
✗ Branch 1698 not taken.
✗ Branch 1700 not taken.
✗ Branch 1701 not taken.
✗ Branch 1705 not taken.
✗ Branch 1706 not taken.
✗ Branch 1708 not taken.
✗ Branch 1709 not taken.
✗ Branch 1713 not taken.
✗ Branch 1714 not taken.
✗ Branch 1716 not taken.
✗ Branch 1717 not taken.
✗ Branch 1721 not taken.
✗ Branch 1722 not taken.
✗ Branch 1724 not taken.
✗ Branch 1725 not taken.
✗ Branch 1729 not taken.
✗ Branch 1730 not taken.
✗ Branch 1732 not taken.
✗ Branch 1733 not taken.
✓ Branch 1737 taken 14 times.
✗ Branch 1738 not taken.
✓ Branch 1740 taken 14 times.
✗ Branch 1741 not taken.
✗ Branch 1745 not taken.
✗ Branch 1746 not taken.
✗ Branch 1748 not taken.
✗ Branch 1749 not taken.
✗ Branch 1753 not taken.
✗ Branch 1754 not taken.
✗ Branch 1756 not taken.
✗ Branch 1757 not taken.
✗ Branch 1761 not taken.
✗ Branch 1762 not taken.
✗ Branch 1764 not taken.
✗ Branch 1765 not taken.
✗ Branch 1769 not taken.
✗ Branch 1770 not taken.
✗ Branch 1772 not taken.
✗ Branch 1773 not taken.
✗ Branch 1777 not taken.
✗ Branch 1778 not taken.
✗ Branch 1780 not taken.
✗ Branch 1781 not taken.
✗ Branch 1785 not taken.
✗ Branch 1786 not taken.
✗ Branch 1788 not taken.
✗ Branch 1789 not taken.
✗ Branch 1793 not taken.
✗ Branch 1794 not taken.
✗ Branch 1796 not taken.
✗ Branch 1797 not taken.
✗ Branch 1801 not taken.
✗ Branch 1802 not taken.
✗ Branch 1804 not taken.
✗ Branch 1805 not taken.
✗ Branch 1809 not taken.
✗ Branch 1810 not taken.
✗ Branch 1812 not taken.
✗ Branch 1813 not taken.
✗ Branch 1817 not taken.
✗ Branch 1818 not taken.
✗ Branch 1820 not taken.
✗ Branch 1821 not taken.
✓ Branch 1825 taken 776 times.
✗ Branch 1826 not taken.
✓ Branch 1828 taken 776 times.
✗ Branch 1829 not taken.
✓ Branch 1833 taken 60 times.
✗ Branch 1834 not taken.
✓ Branch 1836 taken 60 times.
✗ Branch 1837 not taken.
✗ Branch 1841 not taken.
✗ Branch 1842 not taken.
✗ Branch 1844 not taken.
✗ Branch 1845 not taken.
✗ Branch 1849 not taken.
✗ Branch 1850 not taken.
✗ Branch 1852 not taken.
✗ Branch 1853 not taken.
✓ Branch 1857 taken 42 times.
✗ Branch 1858 not taken.
✓ Branch 1860 taken 42 times.
✗ Branch 1861 not taken.
✗ Branch 1865 not taken.
✗ Branch 1866 not taken.
✗ Branch 1868 not taken.
✗ Branch 1869 not taken.
✗ Branch 1873 not taken.
✗ Branch 1874 not taken.
✗ Branch 1876 not taken.
✗ Branch 1877 not taken.
✗ Branch 1881 not taken.
✗ Branch 1882 not taken.
✗ Branch 1884 not taken.
✗ Branch 1885 not taken.
✗ Branch 1889 not taken.
✗ Branch 1890 not taken.
✗ Branch 1892 not taken.
✗ Branch 1893 not taken.
✗ Branch 1897 not taken.
✗ Branch 1898 not taken.
✗ Branch 1900 not taken.
✗ Branch 1901 not taken.
✗ Branch 1905 not taken.
✗ Branch 1906 not taken.
✗ Branch 1908 not taken.
✗ Branch 1909 not taken.
✓ Branch 1913 taken 29 times.
✗ Branch 1914 not taken.
✓ Branch 1916 taken 29 times.
✗ Branch 1917 not taken.
✗ Branch 1921 not taken.
✗ Branch 1922 not taken.
✗ Branch 1924 not taken.
✗ Branch 1925 not taken.
✗ Branch 1929 not taken.
✗ Branch 1930 not taken.
✗ Branch 1932 not taken.
✗ Branch 1933 not taken.
✗ Branch 1937 not taken.
✗ Branch 1938 not taken.
✗ Branch 1940 not taken.
✗ Branch 1941 not taken.
✗ Branch 1945 not taken.
✗ Branch 1946 not taken.
✗ Branch 1948 not taken.
✗ Branch 1949 not taken.
✗ Branch 1953 not taken.
✗ Branch 1954 not taken.
✗ Branch 1956 not taken.
✗ Branch 1957 not taken.
✗ Branch 1961 not taken.
✗ Branch 1962 not taken.
✗ Branch 1964 not taken.
✗ Branch 1965 not taken.
✗ Branch 1969 not taken.
✗ Branch 1970 not taken.
✗ Branch 1972 not taken.
✗ Branch 1973 not taken.
✗ Branch 1977 not taken.
✗ Branch 1978 not taken.
✗ Branch 1980 not taken.
✗ Branch 1981 not taken.
✗ Branch 1985 not taken.
✗ Branch 1986 not taken.
✗ Branch 1988 not taken.
✗ Branch 1989 not taken.
✗ Branch 1993 not taken.
✗ Branch 1994 not taken.
✗ Branch 1996 not taken.
✗ Branch 1997 not taken.
✗ Branch 2001 not taken.
✗ Branch 2002 not taken.
✗ Branch 2004 not taken.
✗ Branch 2005 not taken.
✗ Branch 2009 not taken.
✗ Branch 2010 not taken.
✗ Branch 2012 not taken.
✗ Branch 2013 not taken.
✗ Branch 2017 not taken.
✗ Branch 2018 not taken.
✗ Branch 2020 not taken.
✗ Branch 2021 not taken.
✗ Branch 2025 not taken.
✗ Branch 2026 not taken.
✗ Branch 2028 not taken.
✗ Branch 2029 not taken.
✓ Branch 2033 taken 20 times.
✗ Branch 2034 not taken.
✓ Branch 2036 taken 20 times.
✗ Branch 2037 not taken.
✗ Branch 2041 not taken.
✗ Branch 2042 not taken.
✗ Branch 2044 not taken.
✗ Branch 2045 not taken.
✗ Branch 2049 not taken.
✗ Branch 2050 not taken.
✗ Branch 2052 not taken.
✗ Branch 2053 not taken.
✗ Branch 2057 not taken.
✗ Branch 2058 not taken.
✗ Branch 2060 not taken.
✗ Branch 2061 not taken.
✗ Branch 2065 not taken.
✗ Branch 2066 not taken.
✗ Branch 2068 not taken.
✗ Branch 2069 not taken.
✗ Branch 2073 not taken.
✗ Branch 2074 not taken.
✗ Branch 2076 not taken.
✗ Branch 2077 not taken.
✗ Branch 2081 not taken.
✗ Branch 2082 not taken.
✗ Branch 2084 not taken.
✗ Branch 2085 not taken.
✗ Branch 2089 not taken.
✗ Branch 2090 not taken.
✗ Branch 2092 not taken.
✗ Branch 2093 not taken.
✗ Branch 2097 not taken.
✗ Branch 2098 not taken.
✗ Branch 2100 not taken.
✗ Branch 2101 not taken.
✓ Branch 2105 taken 2 times.
✗ Branch 2106 not taken.
✓ Branch 2108 taken 2 times.
✗ Branch 2109 not taken.
✗ Branch 2113 not taken.
✗ Branch 2114 not taken.
✗ Branch 2116 not taken.
✗ Branch 2117 not taken.
✓ Branch 2121 taken 4 times.
✗ Branch 2122 not taken.
✓ Branch 2124 taken 4 times.
✗ Branch 2125 not taken.
✓ Branch 2129 taken 4 times.
✗ Branch 2130 not taken.
✓ Branch 2132 taken 4 times.
✗ Branch 2133 not taken.
✗ Branch 2137 not taken.
✗ Branch 2138 not taken.
✗ Branch 2140 not taken.
✗ Branch 2141 not taken.
✓ Branch 2145 taken 8 times.
✗ Branch 2146 not taken.
✓ Branch 2148 taken 8 times.
✗ Branch 2149 not taken.
✗ Branch 2153 not taken.
✗ Branch 2154 not taken.
✗ Branch 2156 not taken.
✗ Branch 2157 not taken.
✗ Branch 2161 not taken.
✗ Branch 2162 not taken.
✗ Branch 2164 not taken.
✗ Branch 2165 not taken.
✗ Branch 2169 not taken.
✗ Branch 2170 not taken.
✗ Branch 2172 not taken.
✗ Branch 2173 not taken.
✗ Branch 2177 not taken.
✗ Branch 2178 not taken.
✗ Branch 2180 not taken.
✗ Branch 2181 not taken.
✗ Branch 2185 not taken.
✗ Branch 2186 not taken.
✗ Branch 2188 not taken.
✗ Branch 2189 not taken.
✗ Branch 2193 not taken.
✗ Branch 2194 not taken.
✗ Branch 2196 not taken.
✗ Branch 2197 not taken.
✗ Branch 2201 not taken.
✗ Branch 2202 not taken.
✗ Branch 2204 not taken.
✗ Branch 2205 not taken.
✗ Branch 2209 not taken.
✗ Branch 2210 not taken.
✗ Branch 2212 not taken.
✗ Branch 2213 not taken.
✗ Branch 2217 not taken.
✗ Branch 2218 not taken.
✗ Branch 2220 not taken.
✗ Branch 2221 not taken.
✗ Branch 2225 not taken.
✗ Branch 2226 not taken.
✗ Branch 2228 not taken.
✗ Branch 2229 not taken.
✗ Branch 2233 not taken.
✗ Branch 2234 not taken.
✗ Branch 2236 not taken.
✗ Branch 2237 not taken.
✗ Branch 2241 not taken.
✗ Branch 2242 not taken.
✗ Branch 2244 not taken.
✗ Branch 2245 not taken.
✗ Branch 2249 not taken.
✗ Branch 2250 not taken.
✗ Branch 2252 not taken.
✗ Branch 2253 not taken.
✗ Branch 2257 not taken.
✗ Branch 2258 not taken.
✗ Branch 2260 not taken.
✗ Branch 2261 not taken.
✗ Branch 2265 not taken.
✗ Branch 2266 not taken.
✗ Branch 2268 not taken.
✗ Branch 2269 not taken.
✗ Branch 2273 not taken.
✗ Branch 2274 not taken.
✗ Branch 2276 not taken.
✗ Branch 2277 not taken.
✗ Branch 2281 not taken.
✗ Branch 2282 not taken.
✗ Branch 2284 not taken.
✗ Branch 2285 not taken.
✗ Branch 2289 not taken.
✗ Branch 2290 not taken.
✗ Branch 2292 not taken.
✗ Branch 2293 not taken.
✓ Branch 2297 taken 8 times.
✗ Branch 2298 not taken.
✓ Branch 2300 taken 8 times.
✗ Branch 2301 not taken.
✗ Branch 2305 not taken.
✗ Branch 2306 not taken.
✗ Branch 2308 not taken.
✗ Branch 2309 not taken.
✗ Branch 2313 not taken.
✗ Branch 2314 not taken.
✗ Branch 2316 not taken.
✗ Branch 2317 not taken.
✓ Branch 2321 taken 209 times.
✗ Branch 2322 not taken.
✓ Branch 2324 taken 209 times.
✗ Branch 2325 not taken.
✗ Branch 2329 not taken.
✗ Branch 2330 not taken.
✗ Branch 2332 not taken.
✗ Branch 2333 not taken.
✗ Branch 2337 not taken.
✗ Branch 2338 not taken.
✗ Branch 2340 not taken.
✗ Branch 2341 not taken.
✗ Branch 2345 not taken.
✗ Branch 2346 not taken.
✗ Branch 2348 not taken.
✗ Branch 2349 not taken.
✗ Branch 2353 not taken.
✗ Branch 2354 not taken.
✗ Branch 2356 not taken.
✗ Branch 2357 not taken.
✗ Branch 2361 not taken.
✗ Branch 2362 not taken.
✗ Branch 2364 not taken.
✗ Branch 2365 not taken.
✗ Branch 2369 not taken.
✗ Branch 2370 not taken.
✗ Branch 2372 not taken.
✗ Branch 2373 not taken.
✗ Branch 2377 not taken.
✗ Branch 2378 not taken.
✗ Branch 2380 not taken.
✗ Branch 2381 not taken.
✗ Branch 2385 not taken.
✗ Branch 2386 not taken.
✗ Branch 2388 not taken.
✗ Branch 2389 not taken.
✗ Branch 2393 not taken.
✗ Branch 2394 not taken.
✗ Branch 2396 not taken.
✗ Branch 2397 not taken.
✗ Branch 2401 not taken.
✗ Branch 2402 not taken.
✗ Branch 2404 not taken.
✗ Branch 2405 not taken.
✗ Branch 2409 not taken.
✗ Branch 2410 not taken.
✗ Branch 2412 not taken.
✗ Branch 2413 not taken.
✓ Branch 2417 taken 7 times.
✗ Branch 2418 not taken.
✓ Branch 2420 taken 7 times.
✗ Branch 2421 not taken.
✗ Branch 2425 not taken.
✗ Branch 2426 not taken.
✗ Branch 2428 not taken.
✗ Branch 2429 not taken.
✗ Branch 2433 not taken.
✗ Branch 2434 not taken.
✗ Branch 2436 not taken.
✗ Branch 2437 not taken.
✗ Branch 2441 not taken.
✗ Branch 2442 not taken.
✗ Branch 2444 not taken.
✗ Branch 2445 not taken.
✗ Branch 2449 not taken.
✗ Branch 2450 not taken.
✗ Branch 2452 not taken.
✗ Branch 2453 not taken.
✗ Branch 2457 not taken.
✗ Branch 2458 not taken.
✗ Branch 2460 not taken.
✗ Branch 2461 not taken.
✗ Branch 2465 not taken.
✗ Branch 2466 not taken.
✗ Branch 2468 not taken.
✗ Branch 2469 not taken.
✗ Branch 2473 not taken.
✗ Branch 2474 not taken.
✗ Branch 2476 not taken.
✗ Branch 2477 not taken.
✓ Branch 2481 taken 207 times.
✗ Branch 2482 not taken.
✓ Branch 2484 taken 207 times.
✗ Branch 2485 not taken.
✗ Branch 2489 not taken.
✗ Branch 2490 not taken.
✗ Branch 2492 not taken.
✗ Branch 2493 not taken.
✗ Branch 2497 not taken.
✗ Branch 2498 not taken.
✗ Branch 2500 not taken.
✗ Branch 2501 not taken.
✗ Branch 2505 not taken.
✗ Branch 2506 not taken.
✗ Branch 2508 not taken.
✗ Branch 2509 not taken.
✗ Branch 2513 not taken.
✗ Branch 2514 not taken.
✗ Branch 2516 not taken.
✗ Branch 2517 not taken.
✓ Branch 2521 taken 4 times.
✗ Branch 2522 not taken.
✓ Branch 2524 taken 4 times.
✗ Branch 2525 not taken.
✗ Branch 2529 not taken.
✗ Branch 2530 not taken.
✗ Branch 2532 not taken.
✗ Branch 2533 not taken.
✓ Branch 2537 taken 8 times.
✗ Branch 2538 not taken.
✓ Branch 2540 taken 8 times.
✗ Branch 2541 not taken.
✗ Branch 2545 not taken.
✗ Branch 2546 not taken.
✗ Branch 2548 not taken.
✗ Branch 2549 not taken.
✗ Branch 2553 not taken.
✗ Branch 2554 not taken.
✗ Branch 2556 not taken.
✗ Branch 2557 not taken.
✗ Branch 2561 not taken.
✗ Branch 2562 not taken.
✗ Branch 2564 not taken.
✗ Branch 2565 not taken.
✗ Branch 2569 not taken.
✗ Branch 2570 not taken.
✗ Branch 2572 not taken.
✗ Branch 2573 not taken.
✗ Branch 2577 not taken.
✗ Branch 2578 not taken.
✗ Branch 2580 not taken.
✗ Branch 2581 not taken.
✗ Branch 2585 not taken.
✗ Branch 2586 not taken.
✗ Branch 2588 not taken.
✗ Branch 2589 not taken.
✗ Branch 2593 not taken.
✗ Branch 2594 not taken.
✗ Branch 2596 not taken.
✗ Branch 2597 not taken.
✗ Branch 2601 not taken.
✗ Branch 2602 not taken.
✗ Branch 2604 not taken.
✗ Branch 2605 not taken.
✗ Branch 2609 not taken.
✗ Branch 2610 not taken.
✗ Branch 2612 not taken.
✗ Branch 2613 not taken.
✗ Branch 2617 not taken.
✗ Branch 2618 not taken.
✗ Branch 2620 not taken.
✗ Branch 2621 not taken.
✗ Branch 2625 not taken.
✗ Branch 2626 not taken.
✗ Branch 2628 not taken.
✗ Branch 2629 not taken.
✗ Branch 2633 not taken.
✗ Branch 2634 not taken.
✗ Branch 2636 not taken.
✗ Branch 2637 not taken.
✗ Branch 2641 not taken.
✗ Branch 2642 not taken.
✗ Branch 2644 not taken.
✗ Branch 2645 not taken.
✗ Branch 2649 not taken.
✗ Branch 2650 not taken.
✗ Branch 2652 not taken.
✗ Branch 2653 not taken.
✗ Branch 2657 not taken.
✗ Branch 2658 not taken.
✗ Branch 2660 not taken.
✗ Branch 2661 not taken.
✓ Branch 2665 taken 118 times.
✗ Branch 2666 not taken.
✓ Branch 2668 taken 118 times.
✗ Branch 2669 not taken.
✗ Branch 2673 not taken.
✗ Branch 2674 not taken.
✗ Branch 2676 not taken.
✗ Branch 2677 not taken.
✗ Branch 2681 not taken.
✗ Branch 2682 not taken.
✗ Branch 2684 not taken.
✗ Branch 2685 not taken.
✗ Branch 2689 not taken.
✗ Branch 2690 not taken.
✗ Branch 2692 not taken.
✗ Branch 2693 not taken.
✗ Branch 2697 not taken.
✗ Branch 2698 not taken.
✗ Branch 2700 not taken.
✗ Branch 2701 not taken.
✗ Branch 2705 not taken.
✗ Branch 2706 not taken.
✗ Branch 2708 not taken.
✗ Branch 2709 not taken.
✗ Branch 2713 not taken.
✗ Branch 2714 not taken.
✗ Branch 2716 not taken.
✗ Branch 2717 not taken.
✗ Branch 2721 not taken.
✗ Branch 2722 not taken.
✗ Branch 2724 not taken.
✗ Branch 2725 not taken.
✓ Branch 2729 taken 8 times.
✗ Branch 2730 not taken.
✓ Branch 2732 taken 8 times.
✗ Branch 2733 not taken.
✗ Branch 2737 not taken.
✗ Branch 2738 not taken.
✗ Branch 2740 not taken.
✗ Branch 2741 not taken.
✗ Branch 2745 not taken.
✗ Branch 2746 not taken.
✗ Branch 2748 not taken.
✗ Branch 2749 not taken.
✗ Branch 2753 not taken.
✗ Branch 2754 not taken.
✗ Branch 2756 not taken.
✗ Branch 2757 not taken.
✗ Branch 2761 not taken.
✗ Branch 2762 not taken.
✗ Branch 2764 not taken.
✗ Branch 2765 not taken.
✗ Branch 2769 not taken.
✗ Branch 2770 not taken.
✗ Branch 2772 not taken.
✗ Branch 2773 not taken.
✗ Branch 2777 not taken.
✗ Branch 2778 not taken.
✗ Branch 2780 not taken.
✗ Branch 2781 not taken.
✗ Branch 2785 not taken.
✗ Branch 2786 not taken.
✗ Branch 2788 not taken.
✗ Branch 2789 not taken.
✗ Branch 2793 not taken.
✗ Branch 2794 not taken.
✗ Branch 2796 not taken.
✗ Branch 2797 not taken.
✗ Branch 2801 not taken.
✗ Branch 2802 not taken.
✗ Branch 2804 not taken.
✗ Branch 2805 not taken.
✗ Branch 2809 not taken.
✗ Branch 2810 not taken.
✗ Branch 2812 not taken.
✗ Branch 2813 not taken.
✗ Branch 2817 not taken.
✗ Branch 2818 not taken.
✗ Branch 2820 not taken.
✗ Branch 2821 not taken.
✗ Branch 2825 not taken.
✗ Branch 2826 not taken.
✗ Branch 2828 not taken.
✗ Branch 2829 not taken.
✗ Branch 2833 not taken.
✗ Branch 2834 not taken.
✗ Branch 2836 not taken.
✗ Branch 2837 not taken.
✗ Branch 2841 not taken.
✗ Branch 2842 not taken.
✗ Branch 2844 not taken.
✗ Branch 2845 not taken.
✗ Branch 2849 not taken.
✗ Branch 2850 not taken.
✗ Branch 2852 not taken.
✗ Branch 2853 not taken.
✗ Branch 2857 not taken.
✗ Branch 2858 not taken.
✗ Branch 2860 not taken.
✗ Branch 2861 not taken.
✓ Branch 2865 taken 96 times.
✗ Branch 2866 not taken.
✓ Branch 2868 taken 96 times.
✗ Branch 2869 not taken.
✗ Branch 2873 not taken.
✗ Branch 2874 not taken.
✗ Branch 2876 not taken.
✗ Branch 2877 not taken.
✗ Branch 2881 not taken.
✗ Branch 2882 not taken.
✗ Branch 2884 not taken.
✗ Branch 2885 not taken.
✗ Branch 2889 not taken.
✗ Branch 2890 not taken.
✗ Branch 2892 not taken.
✗ Branch 2893 not taken.
✗ Branch 2897 not taken.
✗ Branch 2898 not taken.
✗ Branch 2900 not taken.
✗ Branch 2901 not taken.
✗ Branch 2905 not taken.
✗ Branch 2906 not taken.
✗ Branch 2908 not taken.
✗ Branch 2909 not taken.
✓ Branch 2913 taken 356 times.
✗ Branch 2914 not taken.
✓ Branch 2916 taken 356 times.
✗ Branch 2917 not taken.
✗ Branch 2921 not taken.
✗ Branch 2922 not taken.
✗ Branch 2924 not taken.
✗ Branch 2925 not taken.
✗ Branch 2929 not taken.
✗ Branch 2930 not taken.
✗ Branch 2932 not taken.
✗ Branch 2933 not taken.
✗ Branch 2937 not taken.
✗ Branch 2938 not taken.
✗ Branch 2940 not taken.
✗ Branch 2941 not taken.
✗ Branch 2945 not taken.
✗ Branch 2946 not taken.
✗ Branch 2948 not taken.
✗ Branch 2949 not taken.
✗ Branch 2953 not taken.
✗ Branch 2954 not taken.
✗ Branch 2956 not taken.
✗ Branch 2957 not taken.
✗ Branch 2961 not taken.
✗ Branch 2962 not taken.
✗ Branch 2964 not taken.
✗ Branch 2965 not taken.
✗ Branch 2969 not taken.
✗ Branch 2970 not taken.
✗ Branch 2972 not taken.
✗ Branch 2973 not taken.
✓ Branch 2977 taken 4 times.
✗ Branch 2978 not taken.
✓ Branch 2980 taken 4 times.
✗ Branch 2981 not taken.
✗ Branch 2985 not taken.
✗ Branch 2986 not taken.
✗ Branch 2988 not taken.
✗ Branch 2989 not taken.
✗ Branch 2993 not taken.
✗ Branch 2994 not taken.
✗ Branch 2996 not taken.
✗ Branch 2997 not taken.
✗ Branch 3001 not taken.
✗ Branch 3002 not taken.
✗ Branch 3004 not taken.
✗ Branch 3005 not taken.
✗ Branch 3009 not taken.
✗ Branch 3010 not taken.
✗ Branch 3012 not taken.
✗ Branch 3013 not taken.
✓ Branch 3017 taken 976 times.
✗ Branch 3018 not taken.
✓ Branch 3020 taken 976 times.
✗ Branch 3021 not taken.
✗ Branch 3025 not taken.
✗ Branch 3026 not taken.
✗ Branch 3028 not taken.
✗ Branch 3029 not taken.
✗ Branch 3033 not taken.
✗ Branch 3034 not taken.
✗ Branch 3036 not taken.
✗ Branch 3037 not taken.
✗ Branch 3041 not taken.
✗ Branch 3042 not taken.
✗ Branch 3044 not taken.
✗ Branch 3045 not taken.
✗ Branch 3049 not taken.
✗ Branch 3050 not taken.
✗ Branch 3052 not taken.
✗ Branch 3053 not taken.
✓ Branch 3057 taken 288 times.
✗ Branch 3058 not taken.
✓ Branch 3060 taken 288 times.
✗ Branch 3061 not taken.
✗ Branch 3065 not taken.
✗ Branch 3066 not taken.
✗ Branch 3068 not taken.
✗ Branch 3069 not taken.
✗ Branch 3073 not taken.
✗ Branch 3074 not taken.
✗ Branch 3076 not taken.
✗ Branch 3077 not taken.
✗ Branch 3081 not taken.
✗ Branch 3082 not taken.
✗ Branch 3084 not taken.
✗ Branch 3085 not taken.
✗ Branch 3089 not taken.
✗ Branch 3090 not taken.
✗ Branch 3092 not taken.
✗ Branch 3093 not taken.
✗ Branch 3097 not taken.
✗ Branch 3098 not taken.
✗ Branch 3100 not taken.
✗ Branch 3101 not taken.
✗ Branch 3105 not taken.
✗ Branch 3106 not taken.
✗ Branch 3108 not taken.
✗ Branch 3109 not taken.
✗ Branch 3113 not taken.
✗ Branch 3114 not taken.
✗ Branch 3116 not taken.
✗ Branch 3117 not taken.
✗ Branch 3121 not taken.
✗ Branch 3122 not taken.
✗ Branch 3124 not taken.
✗ Branch 3125 not taken.
✗ Branch 3129 not taken.
✗ Branch 3130 not taken.
✗ Branch 3132 not taken.
✗ Branch 3133 not taken.
✗ Branch 3137 not taken.
✗ Branch 3138 not taken.
✗ Branch 3140 not taken.
✗ Branch 3141 not taken.
✗ Branch 3145 not taken.
✗ Branch 3146 not taken.
✗ Branch 3148 not taken.
✗ Branch 3149 not taken.
✗ Branch 3153 not taken.
✗ Branch 3154 not taken.
✗ Branch 3156 not taken.
✗ Branch 3157 not taken.
✗ Branch 3161 not taken.
✗ Branch 3162 not taken.
✗ Branch 3164 not taken.
✗ Branch 3165 not taken.
✗ Branch 3169 not taken.
✗ Branch 3170 not taken.
✗ Branch 3172 not taken.
✗ Branch 3173 not taken.
✗ Branch 3177 not taken.
✗ Branch 3178 not taken.
✗ Branch 3180 not taken.
✗ Branch 3181 not taken.
✗ Branch 3185 not taken.
✗ Branch 3186 not taken.
✗ Branch 3188 not taken.
✗ Branch 3189 not taken.
✗ Branch 3193 not taken.
✗ Branch 3194 not taken.
✗ Branch 3196 not taken.
✗ Branch 3197 not taken.
✗ Branch 3201 not taken.
✗ Branch 3202 not taken.
✗ Branch 3204 not taken.
✗ Branch 3205 not taken.
✗ Branch 3209 not taken.
✗ Branch 3210 not taken.
✗ Branch 3212 not taken.
✗ Branch 3213 not taken.
✗ Branch 3217 not taken.
✗ Branch 3218 not taken.
✗ Branch 3220 not taken.
✗ Branch 3221 not taken.
✗ Branch 3225 not taken.
✗ Branch 3226 not taken.
✗ Branch 3228 not taken.
✗ Branch 3229 not taken.
✗ Branch 3233 not taken.
✗ Branch 3234 not taken.
✗ Branch 3236 not taken.
✗ Branch 3237 not taken.
✗ Branch 3241 not taken.
✗ Branch 3242 not taken.
✗ Branch 3244 not taken.
✗ Branch 3245 not taken.
✗ Branch 3249 not taken.
✗ Branch 3250 not taken.
✗ Branch 3252 not taken.
✗ Branch 3253 not taken.
✗ Branch 3257 not taken.
✗ Branch 3258 not taken.
✗ Branch 3260 not taken.
✗ Branch 3261 not taken.
✗ Branch 3265 not taken.
✗ Branch 3266 not taken.
✗ Branch 3268 not taken.
✗ Branch 3269 not taken.
✗ Branch 3273 not taken.
✗ Branch 3274 not taken.
✗ Branch 3276 not taken.
✗ Branch 3277 not taken.
✗ Branch 3281 not taken.
✗ Branch 3282 not taken.
✗ Branch 3284 not taken.
✗ Branch 3285 not taken.
✗ Branch 3289 not taken.
✗ Branch 3290 not taken.
✗ Branch 3292 not taken.
✗ Branch 3293 not taken.
✗ Branch 3297 not taken.
✗ Branch 3298 not taken.
✗ Branch 3300 not taken.
✗ Branch 3301 not taken.
✗ Branch 3305 not taken.
✗ Branch 3306 not taken.
✗ Branch 3308 not taken.
✗ Branch 3309 not taken.
✗ Branch 3313 not taken.
✗ Branch 3314 not taken.
✗ Branch 3316 not taken.
✗ Branch 3317 not taken.
✗ Branch 3321 not taken.
✗ Branch 3322 not taken.
✗ Branch 3324 not taken.
✗ Branch 3325 not taken.
✗ Branch 3329 not taken.
✗ Branch 3330 not taken.
✗ Branch 3332 not taken.
✗ Branch 3333 not taken.
✗ Branch 3337 not taken.
✗ Branch 3338 not taken.
✗ Branch 3340 not taken.
✗ Branch 3341 not taken.
✗ Branch 3345 not taken.
✗ Branch 3346 not taken.
✗ Branch 3348 not taken.
✗ Branch 3349 not taken.
✗ Branch 3353 not taken.
✗ Branch 3354 not taken.
✗ Branch 3356 not taken.
✗ Branch 3357 not taken.
✗ Branch 3361 not taken.
✗ Branch 3362 not taken.
✗ Branch 3364 not taken.
✗ Branch 3365 not taken.
✗ Branch 3369 not taken.
✗ Branch 3370 not taken.
✗ Branch 3372 not taken.
✗ Branch 3373 not taken.
✗ Branch 3377 not taken.
✗ Branch 3378 not taken.
✗ Branch 3380 not taken.
✗ Branch 3381 not taken.
✗ Branch 3385 not taken.
✗ Branch 3386 not taken.
✗ Branch 3388 not taken.
✗ Branch 3389 not taken.
✗ Branch 3393 not taken.
✗ Branch 3394 not taken.
✗ Branch 3396 not taken.
✗ Branch 3397 not taken.
✗ Branch 3401 not taken.
✗ Branch 3402 not taken.
✗ Branch 3404 not taken.
✗ Branch 3405 not taken.
✗ Branch 3409 not taken.
✗ Branch 3410 not taken.
✗ Branch 3412 not taken.
✗ Branch 3413 not taken.
✗ Branch 3417 not taken.
✗ Branch 3418 not taken.
✗ Branch 3420 not taken.
✗ Branch 3421 not taken.
✗ Branch 3425 not taken.
✗ Branch 3426 not taken.
✗ Branch 3428 not taken.
✗ Branch 3429 not taken.
✗ Branch 3433 not taken.
✗ Branch 3434 not taken.
✗ Branch 3436 not taken.
✗ Branch 3437 not taken.
✗ Branch 3441 not taken.
✗ Branch 3442 not taken.
✗ Branch 3444 not taken.
✗ Branch 3445 not taken.
✗ Branch 3449 not taken.
✗ Branch 3450 not taken.
✗ Branch 3452 not taken.
✗ Branch 3453 not taken.
✗ Branch 3457 not taken.
✗ Branch 3458 not taken.
✗ Branch 3460 not taken.
✗ Branch 3461 not taken.
✗ Branch 3465 not taken.
✗ Branch 3466 not taken.
✗ Branch 3468 not taken.
✗ Branch 3469 not taken.
✗ Branch 3473 not taken.
✗ Branch 3474 not taken.
✗ Branch 3476 not taken.
✗ Branch 3477 not taken.
✗ Branch 3481 not taken.
✗ Branch 3482 not taken.
✗ Branch 3484 not taken.
✗ Branch 3485 not taken.
✗ Branch 3489 not taken.
✗ Branch 3490 not taken.
✗ Branch 3492 not taken.
✗ Branch 3493 not taken.
✗ Branch 3497 not taken.
✗ Branch 3498 not taken.
✗ Branch 3500 not taken.
✗ Branch 3501 not taken.
✓ Branch 3505 taken 45 times.
✗ Branch 3506 not taken.
✓ Branch 3508 taken 45 times.
✗ Branch 3509 not taken.
✗ Branch 3513 not taken.
✗ Branch 3514 not taken.
✗ Branch 3516 not taken.
✗ Branch 3517 not taken.
✗ Branch 3521 not taken.
✗ Branch 3522 not taken.
✗ Branch 3524 not taken.
✗ Branch 3525 not taken.
✗ Branch 3529 not taken.
✗ Branch 3530 not taken.
✗ Branch 3532 not taken.
✗ Branch 3533 not taken.
✗ Branch 3537 not taken.
✗ Branch 3538 not taken.
✗ Branch 3540 not taken.
✗ Branch 3541 not taken.
✗ Branch 3545 not taken.
✗ Branch 3546 not taken.
✗ Branch 3548 not taken.
✗ Branch 3549 not taken.
✗ Branch 3553 not taken.
✗ Branch 3554 not taken.
✗ Branch 3556 not taken.
✗ Branch 3557 not taken.
✓ Branch 3561 taken 16 times.
✗ Branch 3562 not taken.
✓ Branch 3564 taken 16 times.
✗ Branch 3565 not taken.
✗ Branch 3569 not taken.
✗ Branch 3570 not taken.
✗ Branch 3572 not taken.
✗ Branch 3573 not taken.
✗ Branch 3577 not taken.
✗ Branch 3578 not taken.
✗ Branch 3580 not taken.
✗ Branch 3581 not taken.
✗ Branch 3585 not taken.
✗ Branch 3586 not taken.
✗ Branch 3588 not taken.
✗ Branch 3589 not taken.
✗ Branch 3593 not taken.
✗ Branch 3594 not taken.
✗ Branch 3596 not taken.
✗ Branch 3597 not taken.
✗ Branch 3601 not taken.
✗ Branch 3602 not taken.
✗ Branch 3604 not taken.
✗ Branch 3605 not taken.
✗ Branch 3609 not taken.
✗ Branch 3610 not taken.
✗ Branch 3612 not taken.
✗ Branch 3613 not taken.
✗ Branch 3617 not taken.
✗ Branch 3618 not taken.
✗ Branch 3620 not taken.
✗ Branch 3621 not taken.
✗ Branch 3625 not taken.
✗ Branch 3626 not taken.
✗ Branch 3628 not taken.
✗ Branch 3629 not taken.
✗ Branch 3633 not taken.
✗ Branch 3634 not taken.
✗ Branch 3636 not taken.
✗ Branch 3637 not taken.
✗ Branch 3641 not taken.
✗ Branch 3642 not taken.
✗ Branch 3644 not taken.
✗ Branch 3645 not taken.
✗ Branch 3649 not taken.
✗ Branch 3650 not taken.
✗ Branch 3652 not taken.
✗ Branch 3653 not taken.
✗ Branch 3657 not taken.
✗ Branch 3658 not taken.
✗ Branch 3660 not taken.
✗ Branch 3661 not taken.
✗ Branch 3665 not taken.
✗ Branch 3666 not taken.
✗ Branch 3668 not taken.
✗ Branch 3669 not taken.
✗ Branch 3673 not taken.
✗ Branch 3674 not taken.
✗ Branch 3676 not taken.
✗ Branch 3677 not taken.
✓ Branch 3681 taken 48 times.
✗ Branch 3682 not taken.
✓ Branch 3684 taken 48 times.
✗ Branch 3685 not taken.
✗ Branch 3689 not taken.
✗ Branch 3690 not taken.
✗ Branch 3692 not taken.
✗ Branch 3693 not taken.
✗ Branch 3697 not taken.
✗ Branch 3698 not taken.
✗ Branch 3700 not taken.
✗ Branch 3701 not taken.
✗ Branch 3705 not taken.
✗ Branch 3706 not taken.
✗ Branch 3708 not taken.
✗ Branch 3709 not taken.
✗ Branch 3713 not taken.
✗ Branch 3714 not taken.
✗ Branch 3716 not taken.
✗ Branch 3717 not taken.
✗ Branch 3721 not taken.
✗ Branch 3722 not taken.
✗ Branch 3724 not taken.
✗ Branch 3725 not taken.
✗ Branch 3729 not taken.
✗ Branch 3730 not taken.
✗ Branch 3732 not taken.
✗ Branch 3733 not taken.
✓ Branch 3737 taken 18 times.
✗ Branch 3738 not taken.
✓ Branch 3740 taken 18 times.
✗ Branch 3741 not taken.
✗ Branch 3745 not taken.
✗ Branch 3746 not taken.
✗ Branch 3748 not taken.
✗ Branch 3749 not taken.
✗ Branch 3753 not taken.
✗ Branch 3754 not taken.
✗ Branch 3756 not taken.
✗ Branch 3757 not taken.
✗ Branch 3761 not taken.
✗ Branch 3762 not taken.
✗ Branch 3764 not taken.
✗ Branch 3765 not taken.
✗ Branch 3769 not taken.
✗ Branch 3770 not taken.
✗ Branch 3772 not taken.
✗ Branch 3773 not taken.
✗ Branch 3777 not taken.
✗ Branch 3778 not taken.
✗ Branch 3780 not taken.
✗ Branch 3781 not taken.
✗ Branch 3785 not taken.
✗ Branch 3786 not taken.
✗ Branch 3788 not taken.
✗ Branch 3789 not taken.
✗ Branch 3793 not taken.
✗ Branch 3794 not taken.
✗ Branch 3796 not taken.
✗ Branch 3797 not taken.
✗ Branch 3801 not taken.
✗ Branch 3802 not taken.
✗ Branch 3804 not taken.
✗ Branch 3805 not taken.
✗ Branch 3809 not taken.
✗ Branch 3810 not taken.
✗ Branch 3812 not taken.
✗ Branch 3813 not taken.
✗ Branch 3817 not taken.
✗ Branch 3818 not taken.
✗ Branch 3820 not taken.
✗ Branch 3821 not taken.
✗ Branch 3825 not taken.
✗ Branch 3826 not taken.
✗ Branch 3828 not taken.
✗ Branch 3829 not taken.
✗ Branch 3833 not taken.
✗ Branch 3834 not taken.
✗ Branch 3836 not taken.
✗ Branch 3837 not taken.
✗ Branch 3841 not taken.
✗ Branch 3842 not taken.
✗ Branch 3844 not taken.
✗ Branch 3845 not taken.
✗ Branch 3849 not taken.
✗ Branch 3850 not taken.
✗ Branch 3852 not taken.
✗ Branch 3853 not taken.
✗ Branch 3857 not taken.
✗ Branch 3858 not taken.
✗ Branch 3860 not taken.
✗ Branch 3861 not taken.
✗ Branch 3865 not taken.
✗ Branch 3866 not taken.
✗ Branch 3868 not taken.
✗ Branch 3869 not taken.
✗ Branch 3873 not taken.
✗ Branch 3874 not taken.
✗ Branch 3876 not taken.
✗ Branch 3877 not taken.
✗ Branch 3881 not taken.
✗ Branch 3882 not taken.
✗ Branch 3884 not taken.
✗ Branch 3885 not taken.
✗ Branch 3889 not taken.
✗ Branch 3890 not taken.
✗ Branch 3892 not taken.
✗ Branch 3893 not taken.
✗ Branch 3897 not taken.
✗ Branch 3898 not taken.
✗ Branch 3900 not taken.
✗ Branch 3901 not taken.
✗ Branch 3905 not taken.
✗ Branch 3906 not taken.
✗ Branch 3908 not taken.
✗ Branch 3909 not taken.
✗ Branch 3913 not taken.
✗ Branch 3914 not taken.
✗ Branch 3916 not taken.
✗ Branch 3917 not taken.
✗ Branch 3921 not taken.
✗ Branch 3922 not taken.
✗ Branch 3924 not taken.
✗ Branch 3925 not taken.
✗ Branch 3929 not taken.
✗ Branch 3930 not taken.
✗ Branch 3932 not taken.
✗ Branch 3933 not taken.
✗ Branch 3937 not taken.
✗ Branch 3938 not taken.
✗ Branch 3940 not taken.
✗ Branch 3941 not taken.
✗ Branch 3945 not taken.
✗ Branch 3946 not taken.
✗ Branch 3948 not taken.
✗ Branch 3949 not taken.
✗ Branch 3953 not taken.
✗ Branch 3954 not taken.
✗ Branch 3956 not taken.
✗ Branch 3957 not taken.
✗ Branch 3961 not taken.
✗ Branch 3962 not taken.
✗ Branch 3964 not taken.
✗ Branch 3965 not taken.
✗ Branch 3969 not taken.
✗ Branch 3970 not taken.
✗ Branch 3972 not taken.
✗ Branch 3973 not taken.
✗ Branch 3977 not taken.
✗ Branch 3978 not taken.
✗ Branch 3980 not taken.
✗ Branch 3981 not taken.
✗ Branch 3985 not taken.
✗ Branch 3986 not taken.
✗ Branch 3988 not taken.
✗ Branch 3989 not taken.
✗ Branch 3993 not taken.
✗ Branch 3994 not taken.
✗ Branch 3996 not taken.
✗ Branch 3997 not taken.
✗ Branch 4001 not taken.
✗ Branch 4002 not taken.
✗ Branch 4004 not taken.
✗ Branch 4005 not taken.
✗ Branch 4009 not taken.
✗ Branch 4010 not taken.
✗ Branch 4012 not taken.
✗ Branch 4013 not taken.
✗ Branch 4017 not taken.
✗ Branch 4018 not taken.
✗ Branch 4020 not taken.
✗ Branch 4021 not taken.
✗ Branch 4025 not taken.
✗ Branch 4026 not taken.
✗ Branch 4028 not taken.
✗ Branch 4029 not taken.
✗ Branch 4033 not taken.
✗ Branch 4034 not taken.
✗ Branch 4036 not taken.
✗ Branch 4037 not taken.
✗ Branch 4041 not taken.
✗ Branch 4042 not taken.
✗ Branch 4044 not taken.
✗ Branch 4045 not taken.
✗ Branch 4049 not taken.
✗ Branch 4050 not taken.
✗ Branch 4052 not taken.
✗ Branch 4053 not taken.
✗ Branch 4057 not taken.
✗ Branch 4058 not taken.
✗ Branch 4060 not taken.
✗ Branch 4061 not taken.
✗ Branch 4065 not taken.
✗ Branch 4066 not taken.
✗ Branch 4068 not taken.
✗ Branch 4069 not taken.
✗ Branch 4073 not taken.
✗ Branch 4074 not taken.
✗ Branch 4076 not taken.
✗ Branch 4077 not taken.
✗ Branch 4081 not taken.
✗ Branch 4082 not taken.
✗ Branch 4084 not taken.
✗ Branch 4085 not taken.
✗ Branch 4089 not taken.
✗ Branch 4090 not taken.
✗ Branch 4092 not taken.
✗ Branch 4093 not taken.
✗ Branch 4097 not taken.
✗ Branch 4098 not taken.
✗ Branch 4100 not taken.
✗ Branch 4101 not taken.
✗ Branch 4105 not taken.
✗ Branch 4106 not taken.
✗ Branch 4108 not taken.
✗ Branch 4109 not taken.
✗ Branch 4113 not taken.
✗ Branch 4114 not taken.
✗ Branch 4116 not taken.
✗ Branch 4117 not taken.
✗ Branch 4121 not taken.
✗ Branch 4122 not taken.
✗ Branch 4124 not taken.
✗ Branch 4125 not taken.
✗ Branch 4129 not taken.
✗ Branch 4130 not taken.
✗ Branch 4132 not taken.
✗ Branch 4133 not taken.
✗ Branch 4137 not taken.
✗ Branch 4138 not taken.
✗ Branch 4140 not taken.
✗ Branch 4141 not taken.
✓ Branch 4145 taken 96 times.
✗ Branch 4146 not taken.
✓ Branch 4148 taken 96 times.
✗ Branch 4149 not taken.
✗ Branch 4153 not taken.
✗ Branch 4154 not taken.
✗ Branch 4156 not taken.
✗ Branch 4157 not taken.
✗ Branch 4161 not taken.
✗ Branch 4162 not taken.
✗ Branch 4164 not taken.
✗ Branch 4165 not taken.
✗ Branch 4169 not taken.
✗ Branch 4170 not taken.
✗ Branch 4172 not taken.
✗ Branch 4173 not taken.
✗ Branch 4177 not taken.
✗ Branch 4178 not taken.
✗ Branch 4180 not taken.
✗ Branch 4181 not taken.
✗ Branch 4185 not taken.
✗ Branch 4186 not taken.
✗ Branch 4188 not taken.
✗ Branch 4189 not taken.
✗ Branch 4193 not taken.
✗ Branch 4194 not taken.
✗ Branch 4196 not taken.
✗ Branch 4197 not taken.
✗ Branch 4201 not taken.
✗ Branch 4202 not taken.
✗ Branch 4204 not taken.
✗ Branch 4205 not taken.
✗ Branch 4209 not taken.
✗ Branch 4210 not taken.
✗ Branch 4212 not taken.
✗ Branch 4213 not taken.
✗ Branch 4217 not taken.
✗ Branch 4218 not taken.
✗ Branch 4220 not taken.
✗ Branch 4221 not taken.
✗ Branch 4225 not taken.
✗ Branch 4226 not taken.
✗ Branch 4228 not taken.
✗ Branch 4229 not taken.
✗ Branch 4233 not taken.
✗ Branch 4234 not taken.
✗ Branch 4236 not taken.
✗ Branch 4237 not taken.
✓ Branch 4241 taken 8 times.
✗ Branch 4242 not taken.
✓ Branch 4244 taken 8 times.
✗ Branch 4245 not taken.
✗ Branch 4249 not taken.
✗ Branch 4250 not taken.
✗ Branch 4252 not taken.
✗ Branch 4253 not taken.
✗ Branch 4257 not taken.
✗ Branch 4258 not taken.
✗ Branch 4260 not taken.
✗ Branch 4261 not taken.
✗ Branch 4265 not taken.
✗ Branch 4266 not taken.
✗ Branch 4268 not taken.
✗ Branch 4269 not taken.
✗ Branch 4273 not taken.
✗ Branch 4274 not taken.
✗ Branch 4276 not taken.
✗ Branch 4277 not taken.
✗ Branch 4281 not taken.
✗ Branch 4282 not taken.
✗ Branch 4284 not taken.
✗ Branch 4285 not taken.
✗ Branch 4289 not taken.
✗ Branch 4290 not taken.
✗ Branch 4292 not taken.
✗ Branch 4293 not taken.
✗ Branch 4297 not taken.
✗ Branch 4298 not taken.
✗ Branch 4300 not taken.
✗ Branch 4301 not taken.
✓ Branch 4305 taken 96 times.
✗ Branch 4306 not taken.
✓ Branch 4308 taken 96 times.
✗ Branch 4309 not taken.
✗ Branch 4313 not taken.
✗ Branch 4314 not taken.
✗ Branch 4316 not taken.
✗ Branch 4317 not taken.
|
14370 | return visitor(_read_buffer_field<T>(source)); |
475 |
1/2✓ Branch 1 taken 5521 times.
✗ Branch 2 not taken.
|
17698 | }); |
476 | } | ||
477 | 17924 | } | |
478 | |||
479 | 18851 | DynamicPrecision _to_precision(const HighFive::DataType& datatype) const { | |
480 |
6/6✓ Branch 1 taken 4794 times.
✓ Branch 2 taken 6756 times.
✓ Branch 4 taken 2670 times.
✓ Branch 5 taken 2124 times.
✓ Branch 6 taken 2670 times.
✓ Branch 7 taken 8880 times.
|
18851 | if (datatype.getClass() == HighFive::DataTypeClass::Float && datatype.getSize() == 8) |
481 | 4287 | return float64; | |
482 |
5/6✓ Branch 1 taken 2124 times.
✓ Branch 2 taken 6756 times.
✓ Branch 4 taken 2124 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 2124 times.
✓ Branch 7 taken 6756 times.
|
14564 | else if (datatype.getClass() == HighFive::DataTypeClass::Float && datatype.getSize() == 4) |
483 | 3396 | return float32; | |
484 |
5/6✓ Branch 1 taken 6756 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 397 times.
✓ Branch 5 taken 6359 times.
✓ Branch 6 taken 397 times.
✓ Branch 7 taken 6359 times.
|
11168 | else if (datatype.getClass() == HighFive::DataTypeClass::Integer && datatype.getSize() == 1) |
485 | 651 | return int8; | |
486 |
3/6✓ Branch 1 taken 6359 times.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✓ Branch 5 taken 6359 times.
✗ Branch 6 not taken.
✓ Branch 7 taken 6359 times.
|
10517 | else if (datatype.getClass() == HighFive::DataTypeClass::Integer && datatype.getSize() == 2) |
487 | ✗ | return int16; | |
488 |
5/6✓ Branch 1 taken 6359 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1732 times.
✓ Branch 5 taken 4627 times.
✓ Branch 6 taken 1732 times.
✓ Branch 7 taken 4627 times.
|
10517 | else if (datatype.getClass() == HighFive::DataTypeClass::Integer && datatype.getSize() == 4) |
489 | 2853 | return int32; | |
490 |
3/6✓ Branch 1 taken 4627 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 4627 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 4627 times.
✗ Branch 7 not taken.
|
7664 | else if (datatype.getClass() == HighFive::DataTypeClass::Integer && datatype.getSize() == 8) |
491 | 7664 | return int64; | |
492 | ✗ | else if (datatype.isVariableStr()) | |
493 | ✗ | return Precision<char>{}; | |
494 | ✗ | else if (datatype.isFixedLenStr()) | |
495 | ✗ | return Precision<char>{}; | |
496 | ✗ | throw NotImplemented("Could not determine data set precision"); | |
497 | } | ||
498 | |||
499 | template<Concepts::Scalar S, typename Source> | ||
500 | 17698 | auto _read_buffer_field(const Source& source) const { | |
501 |
2/4✓ Branch 1 taken 8849 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8849 times.
✗ Branch 5 not taken.
|
17698 | auto dims = source.getMemSpace().getDimensions(); |
502 |
4/6✓ Branch 1 taken 34 times.
✓ Branch 2 taken 8815 times.
✓ Branch 4 taken 34 times.
✗ Branch 5 not taken.
✓ Branch 8 taken 8815 times.
✗ Branch 9 not taken.
|
17698 | MDLayout layout = dims.empty() ? MDLayout{{1}} : MDLayout{std::move(dims)}; |
503 |
2/4✓ Branch 1 taken 8849 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 8849 times.
✗ Branch 5 not taken.
|
17698 | std::vector<Detail::HighFiveDataType<S>> out(layout.number_of_entries()); |
504 |
2/3✓ Branch 2 taken 229 times.
✓ Branch 3 taken 8620 times.
✗ Branch 4 not taken.
|
17698 | source.read_raw(out.data()); |
505 |
1/2✓ Branch 3 taken 8849 times.
✗ Branch 4 not taken.
|
35396 | return BufferField<S>(std::move(out), std::move(layout)); |
506 | 17698 | } | |
507 | |||
508 | 10912 | HighFive::Group _get_group(const std::string& group_name) { | |
509 |
2/2✓ Branch 1 taken 10262 times.
✓ Branch 2 taken 650 times.
|
10912 | return _file.exist(group_name) ? _file.getGroup(group_name) : _file.createGroup(group_name); |
510 | } | ||
511 | |||
512 | 1500 | void _clear_attribute(const std::string& name, const std::string& group) { | |
513 |
4/6✓ Branch 1 taken 1500 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1500 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 660 times.
✓ Branch 8 taken 840 times.
|
1500 | if (_get_group(group).hasAttribute(name)) |
514 |
2/4✓ Branch 1 taken 660 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 660 times.
✗ Branch 5 not taken.
|
660 | _get_group(group).deleteAttribute(name); |
515 | 1500 | } | |
516 | |||
517 | Communicator _comm; | ||
518 | Mode _mode; | ||
519 | HighFive::File _file; | ||
520 | }; | ||
521 | |||
522 | } // namespace GridFormat::HDF5 | ||
523 | |||
524 | #endif // GRIDFORMAT_HAVE_HIGH_FIVE | ||
525 | #endif // GRIDFORMAT_COMMON_HDF5_HPP_ | ||
526 |