Files
Jungfraujoch/common/DetectorSettings.h
T
leonarski_f 4878318c27
Build Packages / Unit tests (push) Successful in 1h17m4s
Build Packages / Generate python client (push) Successful in 1m24s
Build Packages / build:rpm (rocky8_nocuda) (push) Successful in 12m34s
Build Packages / build:rpm (rocky9_nocuda) (push) Successful in 12m37s
Build Packages / build:rpm (ubuntu2404_nocuda) (push) Successful in 11m11s
Build Packages / build:rpm (ubuntu2204_nocuda) (push) Successful in 12m4s
Build Packages / build:rpm (rocky8_sls9) (push) Successful in 11m59s
Build Packages / build:rpm (rocky9_sls9) (push) Successful in 13m4s
Build Packages / build:rpm (rocky8) (push) Successful in 13m12s
Build Packages / XDS test (durin plugin) (push) Successful in 9m57s
Build Packages / build:rpm (ubuntu2404) (push) Successful in 11m52s
Build Packages / build:rpm (ubuntu2204) (push) Successful in 12m30s
Build Packages / build:rpm (rocky9) (push) Successful in 13m59s
Build Packages / Build documentation (push) Successful in 1m7s
Build Packages / XDS test (neggia plugin) (push) Successful in 9m24s
Build Packages / Create release (push) Has been skipped
Build Packages / XDS test (JFJoch plugin) (push) Successful in 9m54s
Build Packages / DIALS test (push) Successful in 13m14s
v1.0.0-rc.139 (#49)
This is an UNSTABLE release. The release has significant modifications and bug fixes, if things go wrong, it is better to revert to 1.0.0-rc.132.

* jfjoch_broker: Further reduce startup time for DECTRIS detectors by selectively modifying SIMPLON parameters on `/start`
* jfjoch_broker: Further reduce startup time for DECTRIS detectors by not setting beam center and detector distance via SIMPLON API on '/start'
* jfjoch_broker: Add an extra message to ZeroMQ puller ready to monitor Lite worklow preparation time
* jfjoch_broker: Image buffer configuration is postponed for Lite receiver flow till start message is received
* jfjoch_broker: Use nanoseconds internally for frame/image/readout time
* jfjoch_broker: Extra messages added for receiver operation (to be removed after debugging finished)
* jfojch_broker: Improve profiling of different data analysis steps
* jfjoch_broker: Record integration reflection count
* jfjoch_broker: Fix bug where ZeroMQ preview frequency was confusing time units (micro vs. milliseconds)
* jfjoch_broker: Fix bug where '/wait_till_done' got deadlocked
* jfjoch_writer: Fix confusion between NaN and zero in floating-point datasets

**Breaking changes**: detector definition is now using nanoseconds to define minimum frame time, minimum count time and readout time.

Reviewed-on: #49
2026-04-29 09:50:50 +02:00

83 lines
3.6 KiB
C++

// SPDX-FileCopyrightText: 2024 Filip Leonarski, Paul Scherrer Institute <filip.leonarski@psi.ch>
// SPDX-License-Identifier: GPL-3.0-only
#ifndef JFJOCH_DETECTORSETTINGS_H
#define JFJOCH_DETECTORSETTINGS_H
#include <cstdint>
#include <chrono>
#include <optional>
#include "DarkMaskSettings.h"
#include "../common/Definitions.h"
enum class DetectorTiming {Auto, Trigger, Burst, Gated};
class DetectorSettings {
std::chrono::nanoseconds frame_time_pedestalG1G2 = FRAME_TIME_PEDE_G1G2;
bool internal_fpga_packet_generator = false;
int64_t internal_fpga_packet_generator_images = 1;
int64_t storage_cells = 1;
int64_t storage_cell_start = 15;
std::chrono::nanoseconds storage_cell_delay = MIN_STORAGE_CELL_DELAY;
std::chrono::nanoseconds detector_delay = std::chrono::nanoseconds{0};
int64_t pedestal_g0_frames = 0;
int64_t pedestal_g1_frames = 0;
int64_t pedestal_g2_frames = 0;
bool use_gain_hg0 = false;
bool fix_gain_g1 = false;
std::chrono::nanoseconds frame_time = std::chrono::microseconds{500};
std::optional<std::chrono::nanoseconds> count_time;
int64_t pedestal_min_image_count = PEDESTAL_MIN_IMAGE_COUNT;
std::optional<float> eiger_threshold_keV;
std::optional<int64_t> eiger_bitwidth;
DetectorTiming timing = DetectorTiming::Trigger;
public:
DetectorSettings& InternalGeneratorEnable(bool input);
DetectorSettings& InternalGeneratorImages(int64_t input);
DetectorSettings& StorageCells(int64_t input);
DetectorSettings& StorageCellStart(int64_t input);
DetectorSettings& StorageCellDelay(const std::chrono::nanoseconds &input);
DetectorSettings& DetectorDelay(const std::chrono::nanoseconds &input);
DetectorSettings& PedestalG0Frames(int64_t input);
DetectorSettings& PedestalG1Frames(int64_t input);
DetectorSettings& PedestalG2Frames(int64_t input);
DetectorSettings& UseGainHG0(bool input);
DetectorSettings& FixGainG1(bool input);
DetectorSettings& FrameTime(const std::chrono::nanoseconds& input);
DetectorSettings& FrameTime(const std::chrono::nanoseconds& input,
const std::chrono::nanoseconds &count_time);
DetectorSettings& PedestalMinImageCount(uint32_t input);
DetectorSettings& EigerThreshold_keV(const std::optional<float> &input);
DetectorSettings& Timing(DetectorTiming input);
DetectorSettings& EigerBitDepth(const std::optional<int64_t> &input);
[[nodiscard]] bool IsInternalGeneratorEnable() const;
[[nodiscard]] int64_t GetInternalGeneratorImages() const;
[[nodiscard]] int64_t GetStorageCells() const;
[[nodiscard]] int64_t GetStorageCellStart() const;
[[nodiscard]] std::chrono::nanoseconds GetStorageCellDelay() const;
[[nodiscard]] std::chrono::nanoseconds GetDetectorDelay() const;
[[nodiscard]] int64_t GetPedestalG0Frames() const;
[[nodiscard]] int64_t GetPedestalG1Frames() const;
[[nodiscard]] int64_t GetPedestalG2Frames() const;
[[nodiscard]] bool IsUseGainHG0() const;
[[nodiscard]] bool IsFixGainG1() const;
[[nodiscard]] std::chrono::nanoseconds GetFrameTime() const;
[[nodiscard]] std::optional<std::chrono::nanoseconds> GetCountTime() const;
[[nodiscard]] std::chrono::nanoseconds GetFrameTimePedestalG1G2() const;
[[nodiscard]] uint32_t GetPedestalMinImageCount() const;
[[nodiscard]] std::optional<float> GetEigerThreshold_keV() const;
[[nodiscard]] std::optional<int64_t> GetEigerBitDepth() const;
[[nodiscard]] DetectorTiming GetTiming() const;
[[nodiscard]] bool NeedsJUNGFRAURecalibration(const DetectorSettings& other) const;
};
#endif //JFJOCH_DETECTORSETTINGS_H