aqnwb 0.3.0
Loading...
Searching...
No Matches
HDF5IO.hpp
Go to the documentation of this file.
1#pragma once
2
3#include <iostream>
4#include <memory>
5#include <string>
6
7#include <H5Opublic.h>
8
9#include "Types.hpp"
10#include "io/BaseIO.hpp"
11#include "io/ReadIO.hpp"
12
13namespace H5
14{
15class DataSet;
16class Attribute;
17class H5File;
18class DataType;
19class Exception;
20class CommonFG;
21class PredType;
22class DataSpace;
23} // namespace H5
24
29namespace AQNWB::IO::HDF5
30{
31
32class HDF5RecordingData; // forward declaration
33
38class HDF5IO : public BaseIO
39{
40public:
50 explicit HDF5IO(const std::string& fileName,
51 const bool disableSWMRMode = false);
52
56 ~HDF5IO() override;
57
62 Status open() override;
63
69 Status open(FileMode mode) override;
70
75 Status close() override;
76
81 Status flush() override;
82
91 StorageObjectType getStorageObjectType(std::string path) const override;
92
106 AQNWB::IO::DataBlockGeneric readDataset(const std::string& dataPath,
107 const SizeArray& start = {},
108 const SizeArray& count = {},
109 const SizeArray& stride = {},
110 const SizeArray& block = {}) override;
111
126 const std::string& dataPath) const override;
127
134 std::string readReferenceAttribute(
135 const std::string& dataPath) const override;
136
147 const void* data,
148 const std::string& path,
149 const std::string& name,
150 const SizeType& size = 1) override;
151
160 Status createAttribute(const std::string& data,
161 const std::string& path,
162 const std::string& name,
163 const bool overwrite = false) override;
164
175 Status createAttribute(const std::vector<std::string>& data,
176 const std::string& path,
177 const std::string& name,
178 const bool overwrite = false) override;
179
187 Status createReferenceAttribute(const std::string& referencePath,
188 const std::string& path,
189 const std::string& name) override;
190
196 Status createGroup(const std::string& path) override;
197
207 Status createLink(const std::string& path,
208 const std::string& reference) override;
209
216 Status createStringDataSet(const std::string& path,
217 const std::string& value) override;
218
225 Status createStringDataSet(const std::string& path,
226 const std::vector<std::string>& values) override;
227
236 const std::string& path,
237 const std::vector<std::string>& references) override;
238
243 Status startRecording() override;
244
249 Status stopRecording() override;
250
257 bool canModifyObjects() override;
258
267 std::unique_ptr<IO::BaseRecordingData> createArrayDataSet(
268 const IO::BaseArrayDataSetConfig& config,
269 const std::string& path) override;
270
276 std::shared_ptr<IO::BaseRecordingData> getDataSet(
277 const std::string& path) override;
278
284 SizeArray getStorageObjectShape(const std::string& path) const override;
285
293 SizeArray getStorageObjectChunking(const std::string& path) const override;
294
302 BaseDataType getStorageObjectDataType(const std::string& path) const override;
303
310 bool objectExists(const std::string& path) const override;
311
320 bool attributeExists(const std::string& path) const override;
321
340 virtual std::vector<std::pair<std::string, StorageObjectType>>
341 getStorageObjects(const std::string& path,
342 const StorageObjectType& objectType =
343 StorageObjectType::Undefined) const override;
344
351 H5O_type_t getH5ObjectType(const std::string& path) const;
352
363 static H5::DataType getNativeType(IO::BaseDataType type);
364
373 static IO::BaseDataType getBaseDataType(const H5::DataType& nativeType);
374
384 static H5::DataType getH5Type(IO::BaseDataType type);
385
386protected:
392 Status createGroupIfDoesNotExist(const std::string& path) override;
393
394private:
412 template<typename T, typename HDF5TYPE>
413 std::vector<T> readDataHelper(const HDF5TYPE& dataSource,
414 size_t numElements,
415 const H5::DataSpace& memspace,
416 const H5::DataSpace& dataspace) const;
417
435 template<typename T, typename HDF5TYPE>
436 std::vector<T> readDataHelper(const HDF5TYPE& dataSource,
437 size_t numElements) const;
438
451 template<typename HDF5TYPE>
452 std::vector<std::string> readStringDataHelper(
453 const HDF5TYPE& dataSource,
454 size_t numElements,
455 const H5::DataSpace& memspace,
456 const H5::DataSpace& dataspace) const;
457
473 template<typename HDF5TYPE>
474 std::vector<std::string> readStringDataHelper(const HDF5TYPE& dataSource,
475 size_t numElements) const;
476
477 std::unique_ptr<H5::Attribute> getAttribute(const std::string& path) const;
478
490
494 std::unique_ptr<H5::H5File> m_file;
495
501};
502
503} // namespace AQNWB::IO::HDF5
AQNWB::Types::StorageObjectType StorageObjectType
Definition BaseIO.hpp:20
AQNWB::Types::Status Status
Definition BaseIO.hpp:21
AQNWB::Types::SizeArray SizeArray
Definition BaseIO.hpp:22
AQNWB::Types::SizeType SizeType
Definition Channel.hpp:8
Base class for array dataset configuration.
Definition BaseIO.hpp:205
Represents a base data type.
Definition BaseIO.hpp:47
BaseIO(const std::string &filename)
Constructor for the BaseIO class.
Definition BaseIO.cpp:149
Generic structure to hold type-erased data and shape.
Definition ReadIO.hpp:34
std::shared_ptr< IO::BaseRecordingData > getDataSet(const std::string &path) override
Returns a pointer to a dataset at a given path.
Definition HDF5IO.cpp:1301
Status stopRecording() override
Stops the recording process.
Definition HDF5IO.cpp:1087
SizeArray getStorageObjectChunking(const std::string &path) const override
Gets the chunking configuration of a dataset.
Definition HDF5IO.cpp:1223
bool m_disableSWMRMode
When set true, then do not switch to SWMR mode when starting the recording.
Definition HDF5IO.hpp:500
Status createGroup(const std::string &path) override
Creates a new group in the file.
Definition HDF5IO.cpp:930
static IO::BaseDataType getBaseDataType(const H5::DataType &nativeType)
Returns the BaseDataType for a given HDF5 native data type.
Definition HDF5IO.cpp:1493
Status createLink(const std::string &path, const std::string &reference) override
Creates a soft link to another location in the file.
Definition HDF5IO.cpp:962
std::string readReferenceAttribute(const std::string &dataPath) const override
Reads a reference attribute and returns the path to the referenced object.
Definition HDF5IO.cpp:322
Status createReferenceDataSet(const std::string &path, const std::vector< std::string > &references) override
Creates a dataset that holds an array of references to groups within the file.
Definition HDF5IO.cpp:982
bool attributeExists(const std::string &path) const override
Checks whether an Attribute exists at the location in the file.
Definition HDF5IO.cpp:1131
virtual std::vector< std::pair< std::string, StorageObjectType > > getStorageObjects(const std::string &path, const StorageObjectType &objectType=StorageObjectType::Undefined) const override
Gets the list of storage objects (groups, datasets, attributes) inside a group.
Definition HDF5IO.cpp:1138
BaseDataType getStorageObjectDataType(const std::string &path) const override
Gets the BaseDataType of a dataset or attribute.
Definition HDF5IO.cpp:1256
StorageObjectType getStorageObjectType(std::string path) const override
Get the storage type (Group, Dataset, Attribute) of the object at path.
Definition HDF5IO.cpp:156
AQNWB::IO::DataBlockGeneric readAttribute(const std::string &dataPath) const override
Reads a attribute and determines the data type.
Definition HDF5IO.cpp:385
Status createAttribute(const IO::BaseDataType &type, const void *data, const std::string &path, const std::string &name, const SizeType &size=1) override
Creates an attribute at a given location in the file.
Definition HDF5IO.cpp:701
Status startRecording() override
Start SWMR write to start recording process.
Definition HDF5IO.cpp:1072
std::unique_ptr< H5::Attribute > getAttribute(const std::string &path) const
Definition HDF5IO.cpp:123
std::vector< std::string > readStringDataHelper(const HDF5TYPE &dataSource, size_t numElements, const H5::DataSpace &memspace, const H5::DataSpace &dataspace) const
Reads a variable-length string from an HDF5 dataset or attribute.
Definition HDF5IO.cpp:216
SizeArray getStorageObjectShape(const std::string &path) const override
Returns the size of the dataset or attribute for each dimension.
Definition HDF5IO.cpp:1195
std::unique_ptr< IO::BaseRecordingData > createArrayDataSet(const IO::BaseArrayDataSetConfig &config, const std::string &path) override
Creates an extendable dataset with the given configuration and path.
Definition HDF5IO.cpp:1324
Status createReferenceAttribute(const std::string &referencePath, const std::string &path, const std::string &name) override
Sets an object reference attribute for a given location in the file.
Definition HDF5IO.cpp:890
Status close() override
Closes the file.
Definition HDF5IO.cpp:94
bool canModifyObjects() override
Checks whether the file is in a mode where objects can be added or deleted. Note, this does not apply...
Definition HDF5IO.cpp:1102
HDF5IO(const std::string &fileName, const bool disableSWMRMode=false)
Constructor for the HDF5IO class that takes a file name as input.
Definition HDF5IO.cpp:24
H5O_type_t getH5ObjectType(const std::string &path) const
Returns the HDF5 type of object at a given path.
Definition HDF5IO.cpp:1417
AQNWB::IO::DataBlockGeneric readDataset(const std::string &dataPath, const SizeArray &start={}, const SizeArray &count={}, const SizeArray &stride={}, const SizeArray &block={}) override
Reads a dataset or attribute and determines the data type.
Definition HDF5IO.cpp:517
Status createStringDataSet(const std::string &path, const std::string &value) override
Creates a non-modifiable dataset with a string value.
Definition HDF5IO.cpp:1029
static H5::DataType getH5Type(IO::BaseDataType type)
Returns the HDF5 data type for a given base data type.
Definition HDF5IO.cpp:1536
bool objectExists(const std::string &path) const override
Checks whether a Dataset, Group, or Link already exists at the location in the file.
Definition HDF5IO.cpp:1121
std::vector< T > readDataHelper(const HDF5TYPE &dataSource, size_t numElements, const H5::DataSpace &memspace, const H5::DataSpace &dataspace) const
Reads data from an HDF5 dataset or attribute into a vector of the appropriate type.
Definition HDF5IO.cpp:184
Status closeFileImpl()
Non-virtual helper that performs the actual HDF5 file close.
Definition HDF5IO.cpp:100
static H5::DataType getNativeType(IO::BaseDataType type)
Returns the HDF5 native data type for a given base data type.
Definition HDF5IO.cpp:1442
Status open() override
Opens an existing file or creates a new file for writing.
Definition HDF5IO.cpp:47
Status flush() override
Flush data to disk.
Definition HDF5IO.cpp:117
Status createGroupIfDoesNotExist(const std::string &path) override
Creates a new group if it does not exist.
Definition HDF5IO.cpp:948
~HDF5IO() override
Destructor.
Definition HDF5IO.cpp:30
std::unique_ptr< H5::H5File > m_file
Unique pointer to the HDF5 file for reading.
Definition HDF5IO.hpp:494
Namespace for all components of the HDF5 I/O backend.
FileMode
The access mode for the file.
Definition BaseIO.hpp:173
Definition HDF5IO.hpp:14