Files
Jungfraujoch/writer/HDF5DataFile.h
leonarski_f d315506633 * Enhancements for XFEL
* Enhancements for EIGER
* Writer is more flexible and capable of handling DECTRIS data
2024-03-05 20:41:47 +01:00

59 lines
1.4 KiB
C++

// Copyright (2019-2023) Paul Scherrer Institute
#ifndef HDF5DATAFILE_H
#define HDF5DATAFILE_H
#include <queue>
#include <string>
#include <chrono>
#include "HDF5Objects.h"
#include "../common/SpotToSave.h"
#include "../frame_serialize/JFJochMessages.h"
#include "HDF5DataFilePluginAzInt.h"
#include "HDF5DataFilePluginMX.h"
#include "HDF5DataFilePluginXFEL.h"
#include "HDF5DataFilePluginJUNGFRAU.h"
struct HDF5DataFileStatistics {
std::string filename;
size_t max_image_number;
uint64_t total_images;
};
class HDF5DataFile {
std::string filename;
std::unique_ptr<HDF5File> data_file = nullptr;
std::unique_ptr<HDF5DataSet> data_set = nullptr;
std::vector<std::unique_ptr<HDF5DataFilePlugin>> plugins;
size_t xpixel;
size_t ypixel;
size_t max_image_number;
size_t nimages;
std::string image_units;
std::vector<uint64_t> timestamp;
std::vector<uint32_t> exptime;
std::chrono::time_point<std::chrono::system_clock> last_flush;
std::chrono::microseconds swmr_flush_period = std::chrono::seconds(5);
void CreateFile(const DataMessage& msg);
void SetupSWMRFile(const DataMessage& msg);
public:
HDF5DataFile(const std::string& name, const std::vector<float>& rad_int_bin_to_q, size_t max_spots = 0);
~HDF5DataFile();
void Write(const DataMessage& msg, uint64_t image_number);
HDF5DataFileStatistics GetStatistics() const;
size_t GetNumImages() const;
};
#endif //HDF5DATAFILE_H