52 for (
const auto &
s : labels) {
65 bool desc,
bool formulas)
66 : fname(file), timeChunk(chunking),
67 enableDescriptions(desc), enableFormula(formulas),
73 H5::Exception::dontPrint();
86 dumpCount > 0 ? H5F_ACC_RDWR : H5F_ACC_TRUNC);
115 }
catch (
const H5::FileIException&
e) {
117 }
catch (
const H5::GroupIException&
e) {
127 assert(!
path.empty());
137 hsize_t fdims[1] = { 0, };
152 warn_once(
"HDF5 stat files don't support distributions.\n");
158 warn_once(
"HDF5 stat files don't support vector distributions.\n");
167 hsize_t fdims[3] = { 0, info.
x, info.
y };
168 H5::DataSet data_set =
appendStat(info, 3, fdims, info.
cvec.data());
197 warn_once(
"HDF5 stat files don't support sparse histograms.\n");
207 hsize_t fdims[2] = { 0, vr.size() };
208 H5::DataSet data_set =
appendStat(info, 2, fdims, vr.data());
224 H5::Group group =
path.top();
225 H5::DataSet data_set;
226 H5::DataSpace fspace;
233 data_set = group.openDataSet(info.
name);
234 data_set.extend(dims);
235 fspace = data_set.getSpace();
239 H5::DSetCreatPropList props;
243 std::copy(dims, dims + rank, max_dims.begin());
244 max_dims[0] = H5S_UNLIMITED;
248 std::copy(dims, dims + rank, chunk_dims.begin());
250 props.setChunk(rank, chunk_dims.data());
255 fspace = H5::DataSpace(rank, dims, max_dims.data());
257 data_set = group.createDataSet(info.
name,
258 H5::PredType::NATIVE_DOUBLE, fspace, props);
259 }
catch (
const H5::Exception &
e) {
260 std::string
err =
"Failed creating H5::DataSet " + info.
name +
"; ";
261 err +=
e.getDetailMsg() +
" in " +
e.getFuncName();
263 throw std::runtime_error(
err);
273 H5::DataSpace mspace(rank, dims);
277 fspace.selectHyperslab(H5S_SELECT_SET, dims, foffset.data());
278 data_set.write(
data, H5::PredType::NATIVE_DOUBLE, mspace, fspace);
287 H5::StrType
type(H5::PredType::C_S1, H5T_VARIABLE);
288 hsize_t dims[1] = { values.size(), };
289 H5::DataSpace space(1, dims);
290 H5::Attribute attribute = loc.createAttribute(
name,
type, space);
291 attribute.write(
type, values.data());
299 for (
int i = 0;
i < values.size(); ++
i)
300 cstrs[
i] = values[
i].c_str();
307 const std::string &value)
309 H5::StrType
type(H5::PredType::C_S1, value.length() + 1);
310 hsize_t dims[1] = { 1, };
311 H5::DataSpace space(1, dims);
312 H5::Attribute attribute = loc.createAttribute(
name,
type, space);
313 attribute.write(
type, value.c_str());
319 hsize_t dims[1] = { 1, };
320 H5::DataSpace space(1, dims);
321 H5::Attribute attribute = loc.createAttribute(
322 name, H5::PredType::NATIVE_DOUBLE, space);
323 attribute.write(H5::PredType::NATIVE_DOUBLE, &value);
327 std::unique_ptr<Output>
328 initHDF5(
const std::string &filename,
unsigned chunking,
329 bool desc,
bool formulas)
331 return std::unique_ptr<Output>(