v1.0.0-rc.36

This commit is contained in:
2025-05-05 19:32:22 +02:00
parent 759243d1bf
commit 040cf08386
333 changed files with 22724 additions and 15251 deletions

View File

@@ -7,42 +7,90 @@
#include "JFJochException.h"
#include "NetworkAddressConvert.h"
DetectorSetup::DetectorSetup(const DetectorGeometry &in_geometry)
: DetectorSetup(in_geometry, DetectorType::JUNGFRAU, "Detector", std::vector<std::string>()) {}
DetectorSetup::DetectorSetup(const DetectorGeometryFixed &geom, DetectorType detector_type,
const std::string &description, const std::vector<std::string> &det_modules_hostname)
: DetectorSetup(std::make_shared<DetectorGeometryFixed>(geom),
detector_type, description, det_modules_hostname) {
switch (detector_type) {
case DetectorType::DECTRIS:
break;
default:
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Detector not compatible with fixed geometry");
}
}
DetectorSetup::DetectorSetup(const DetectorGeometry &in_geometry, DetectorType in_detector_type)
: DetectorSetup(in_geometry, in_detector_type, "Detector", std::vector<std::string>()) {}
DetectorSetup::DetectorSetup(const DetectorGeometry &in_geometry,
DetectorSetup::DetectorSetup(const DetectorGeometryModular &geom, DetectorType detector_type,
const std::string &description, const std::vector<std::string> &det_modules_hostname)
: DetectorSetup(std::make_shared<DetectorGeometryModular>(geom),
detector_type, description, det_modules_hostname) {
switch (detector_type) {
case DetectorType::EIGER:
case DetectorType::JUNGFRAU:
break;
default:
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Detector not compatible with modular geometry");
}
}
DetectorSetup::DetectorSetup(std::shared_ptr<DetectorGeometry> in_geometry,
DetectorType in_detector_type,
const std::string &in_description,
const std::vector<std::string> &in_det_modules_hostname) :
geometry(in_geometry),
geometry(std::move(in_geometry)),
description(in_description),
det_modules_hostname(in_det_modules_hostname),
detector_type(in_detector_type) {
detector_type(in_detector_type),
read_out_time(0),
min_frame_time(std::chrono::milliseconds(1)),
min_count_time(std::chrono::microseconds(MIN_COUNT_TIME_IN_US)) {
if (description.empty())
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Detector description cannot be empty");
switch (detector_type) {
case DetectorType::EIGER:
high_voltage = 150;
read_out_time = std::chrono::microseconds(3);
if (!det_modules_hostname.empty() && (2 * geometry.GetModulesNum() != det_modules_hostname.size()))
if (!det_modules_hostname.empty() && (2 * geometry->GetModulesNum() != det_modules_hostname.size()))
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Mismatch between number of modules in detector geometry and hostname (For EIGER - one module = 2 hostnames)");
break;
case DetectorType::JUNGFRAU:
high_voltage = 120;
bit_depth_readout = 16;
read_out_time = std::chrono::microseconds(20);
if (!det_modules_hostname.empty() && (geometry.GetModulesNum() != det_modules_hostname.size()))
if (!det_modules_hostname.empty() && (geometry->GetModulesNum() != det_modules_hostname.size()))
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Mismatch between number of modules in detector geometry and hostname");
break;
case DetectorType::DECTRIS:
high_voltage = 0;
bit_depth_readout = 16;
bit_depth_image = 16;
read_out_time = std::chrono::microseconds(0);
if (!det_modules_hostname.empty() && ( det_modules_hostname.size() != 1))
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Just one address need to be provided for DECTRIS detector");
break;
default:
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid, "Detector not supported");
}
}
DetectorSetup &DetectorSetup::Description(const std::string &input) {
if (input.empty())
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Detector description cannot be empty");
description = input;
return *this;
}
const DetectorGeometry &DetectorSetup::GetGeometry() const {
return geometry;
return *geometry;
}
const std::vector<std::string> &DetectorSetup::GetDetectorModuleHostname() const {
@@ -50,7 +98,7 @@ const std::vector<std::string> &DetectorSetup::GetDetectorModuleHostname() const
}
uint64_t DetectorSetup::GetModulesNum() const {
return geometry.GetModulesNum();
return geometry->GetModulesNum();
}
std::string DetectorSetup::GetDescription() const {
@@ -81,7 +129,7 @@ void DetectorSetup::LoadGain(const std::vector<std::string> &filenames) {
DetectorSetup &DetectorSetup::UDPInterfaceCount(int64_t input) {
if ((input != 1) && (input != 2))
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Only 1 and 2 are supported as UDP interface count");
"Only 1 and 2 are supported as UDP interface count");
udp_interface_count = input;
return *this;
}
@@ -111,6 +159,14 @@ DetectorSetup &DetectorSetup::PixelSize_um(float input) {
return *this;
}
DetectorSetup &DetectorSetup::Geometry(const DetectorGeometryFixed &input) {
if (detector_type != DetectorType::DECTRIS)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"PSI detector geometry cannot be updated during operation");
geometry = std::make_shared<DetectorGeometryFixed>(input);
return *this;
}
DetectorSetup &DetectorSetup::TxDelay(const std::vector<int64_t> &v) {
if (!v.empty() && (v.size() != GetModulesNum()))
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
@@ -207,9 +263,9 @@ DetectorSetup &DetectorSetup::ModuleSync(bool input) {
}
DetectorSetup & DetectorSetup::ReadOutTime(std::chrono::microseconds input) {
if (input.count() <= 0)
if (input.count() < 0)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Read out time has to be more than zero");
"Read out time has to be non-negative");
read_out_time = input;
return *this;
}
@@ -226,6 +282,8 @@ std::chrono::microseconds DetectorSetup::GetMinFrameTime() const {
if (GetUDPInterfaceCount() == 1)
return std::chrono::microseconds(MIN_FRAME_TIME_JUNGFRAU_HALF_SPEED_IN_US);
return std::chrono::microseconds(MIN_FRAME_TIME_JUNGFRAU_FULL_SPEED_IN_US);
case DetectorType::DECTRIS:
return min_frame_time;
default:
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Detector not supported");
@@ -233,5 +291,138 @@ std::chrono::microseconds DetectorSetup::GetMinFrameTime() const {
}
std::chrono::microseconds DetectorSetup::GetMinCountTime() const {
return std::chrono::microseconds(MIN_COUNT_TIME_IN_US);
return min_count_time;
}
DetectorSetup &DetectorSetup::MinCountTime(std::chrono::microseconds input) {
min_count_time = input;
return *this;
}
DetectorSetup &DetectorSetup::MinFrameTime(std::chrono::microseconds input) {
min_frame_time = input;
return *this;
}
DetectorSetup &DetectorSetup::BitDepthImage(int64_t input) {
if (GetDetectorType() != DetectorType::DECTRIS)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Bit depth image can be only changed for DECTRIS detector");
switch (input) {
case 8:
case 16:
case 32:
bit_depth_image = input;
return *this;
default:
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Bit depth image can be only 8, 16 or 32");
}
}
DetectorSetup &DetectorSetup::BitDepthReadout(int64_t input) {
if (GetDetectorType() != DetectorType::DECTRIS)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Bit depth readout can be only changed for DECTRIS detector");
switch (input) {
case 8:
case 12:
case 16:
case 32:
bit_depth_readout = input;
return *this;
default:
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Bit depth readout can be only 8, 12, 16 or 32");
}
}
std::optional<int64_t> DetectorSetup::GetBitDepthReadout() const {
return bit_depth_readout;
}
std::optional<int64_t> DetectorSetup::GetBitDepthImage() const {
return bit_depth_image;
}
std::string DetectorSetup::GetDECTRISStream2Addr() const {
if (GetDetectorType() != DetectorType::DECTRIS)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Stream2 only possible for DECTRIS systems");
if (det_modules_hostname.size() != 1)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Stream2 address not defined");
return "tcp://" + det_modules_hostname[0] + ":" + std::to_string(SimplonStream2Port);
}
float DetectorSetup::GetMinThreshold_keV() const {
return min_energy_threshold_keV;
}
DetectorSetup &DetectorSetup::MinThreshold_keV(float input) {
if (input <= 0.0f)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Min threshold must be positive number");
min_energy_threshold_keV = input;
return *this;
}
DetectorSetup &DetectorSetup::SaturationLimit(std::optional<int64_t> input) {
if (input && input <= 0)
throw JFJochException(JFJochExceptionCategory::InputParameterInvalid,
"Saturation limit must be positive number");
saturation_limit = input;
return *this;
}
std::optional<int64_t> DetectorSetup::GetSaturationLimit() const {
return saturation_limit;
}
DetectorSetup &DetectorSetup::DECTRISROI(const std::string &input) {
dectris_roi = input;
return *this;
}
std::string DetectorSetup::GetDECTRISROI() const {
if (dectris_roi.empty())
return "disabled";
return dectris_roi;
}
DetectorSetup DetJF4M(const std::string &description, const std::vector<std::string> &det_modules_hostname) {
return DetJF(8, 2, 8, 36, true, description, det_modules_hostname);
}
DetectorSetup DetJF9M(const std::string &description, const std::vector<std::string> &det_modules_hostname) {
return DetJF(18, 3, 8, 36, true, description, det_modules_hostname);
}
DetectorSetup DetJF(int32_t nmodules, int32_t horizontal_stacking, int32_t gap_x, int32_t gap_y, bool mirror_y,
const std::string &description, const std::vector<std::string> &det_modules_hostname) {
return DetJF(DetectorGeometryModular(nmodules, horizontal_stacking, gap_x, gap_y, mirror_y),
description, det_modules_hostname);
}
DetectorSetup DetJF(const DetectorGeometryModular &geom, const std::string &description,
const std::vector<std::string> &det_modules_hostname) {
return {geom, DetectorType::JUNGFRAU, description, det_modules_hostname};
}
DetectorSetup DetEIGER(int32_t nmodules, int32_t horizontal_stacking, int32_t gap_x, int32_t gap_y, bool mirror_y,
const std::string &description, const std::vector<std::string> &det_modules_hostname) {
return DetEIGER(DetectorGeometryModular(nmodules, horizontal_stacking, gap_x, gap_y, mirror_y),
description, det_modules_hostname);
}
DetectorSetup DetEIGER(const DetectorGeometryModular &geom, const std::string &description,
const std::vector<std::string> &det_modules_hostname) {
return {geom, DetectorType::EIGER, description, det_modules_hostname};
}
DetectorSetup DetDECTRIS(int64_t width, int64_t height, const std::string &description, const std::string &addr) {
if (addr.empty())
return {DetectorGeometryFixed(width, height), DetectorType::DECTRIS, description, {}};
else
return {DetectorGeometryFixed(width, height), DetectorType::DECTRIS, description, {addr}};
}