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
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
71 lines
2.3 KiB
C++
71 lines
2.3 KiB
C++
// SPDX-FileCopyrightText: 2025 Filip Leonarski, Paul Scherrer Institute <filip.leonarski@psi.ch>
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
#include "DarkMaskSettings.h"
|
|
#include "JFJochException.h"
|
|
#include <cmath>
|
|
#include "Definitions.h"
|
|
|
|
#define check_max(param, val, max) if ((val) > (max)) throw JFJochException(JFJochExceptionCategory::InputParameterAboveMax, param)
|
|
#define check_min(param, val, min) if ((val) < (min)) throw JFJochException(JFJochExceptionCategory::InputParameterBelowMin, param)
|
|
#define check_finite(param, val) if (!std::isfinite(val)) throw JFJochException(JFJochExceptionCategory::InputParameterInvalid, param)
|
|
|
|
DarkMaskSettings::DarkMaskSettings()
|
|
: number_of_frames(1000),
|
|
frame_time(DARK_MASK_FRAME_TIME),
|
|
threshold_keV(3.5f),
|
|
max_frames_with_counts(10),
|
|
max_counts(1) {
|
|
}
|
|
|
|
DarkMaskSettings &DarkMaskSettings::NumberOfFrames(int64_t input) {
|
|
check_min("Number of frames", input, 0); // zero is allowed, as in case of pedestal == disabled
|
|
number_of_frames = input;
|
|
return *this;
|
|
}
|
|
|
|
DarkMaskSettings &DarkMaskSettings::FrameTime(std::chrono::nanoseconds input) {
|
|
check_min("Frame time for dark images for mask [ns]", input.count(), 1);
|
|
frame_time = input;
|
|
return *this;
|
|
}
|
|
|
|
DarkMaskSettings &DarkMaskSettings::Threshold_keV(float input) {
|
|
check_finite("Dark mask settings: threshold [keV]", input);
|
|
check_min("Dark mask settings: threshold", input, 2.7);
|
|
threshold_keV = input;
|
|
return *this;
|
|
}
|
|
|
|
DarkMaskSettings &DarkMaskSettings::MaxFramesWithCounts(int64_t input) {
|
|
check_min("Max allowed frames with signal in dark images for mask", input, 0);
|
|
max_frames_with_counts = input;
|
|
return *this;
|
|
}
|
|
|
|
DarkMaskSettings &DarkMaskSettings::MaxCounts(int64_t input) {
|
|
check_min("Max allowed counts in dark images for mask", input, 0);
|
|
max_counts = input;
|
|
return *this;
|
|
}
|
|
|
|
int64_t DarkMaskSettings::GetNumberOfFrames() const {
|
|
return number_of_frames;
|
|
}
|
|
|
|
std::chrono::nanoseconds DarkMaskSettings::GetFrameTime() const {
|
|
return frame_time;
|
|
}
|
|
|
|
float DarkMaskSettings::GetThreshold_keV() const {
|
|
return threshold_keV;
|
|
}
|
|
|
|
int64_t DarkMaskSettings::GetMaxFramesWithCounts() const {
|
|
return max_frames_with_counts;
|
|
}
|
|
|
|
int64_t DarkMaskSettings::GetMaxCounts() const {
|
|
return max_counts;
|
|
}
|