Files
Jungfraujoch/common/ROIMap.cpp
T
leonarski_f bb9f5c715f
Build Packages / build:rpm (ubuntu2204_nocuda) (push) Successful in 9m55s
Build Packages / build:rpm (rocky8_nocuda) (push) Successful in 10m28s
Build Packages / build:rpm (ubuntu2404_nocuda) (push) Successful in 8m56s
Build Packages / build:rpm (rocky9_nocuda) (push) Successful in 11m47s
Build Packages / build:rpm (rocky8_sls9) (push) Successful in 13m7s
Build Packages / build:rpm (ubuntu2204) (push) Successful in 12m31s
Build Packages / build:rpm (rocky8) (push) Successful in 12m59s
Build Packages / build:rpm (rocky9) (push) Successful in 14m5s
Build Packages / build:rpm (rocky9_sls9) (push) Successful in 15m30s
Build Packages / Generate python client (push) Successful in 1m18s
Build Packages / Build documentation (push) Successful in 1m3s
Build Packages / Create release (push) Has been skipped
Build Packages / build:rpm (ubuntu2404) (push) Successful in 10m8s
Build Packages / XDS test (durin plugin) (push) Successful in 9m16s
Build Packages / XDS test (neggia plugin) (push) Successful in 7m59s
Build Packages / XDS test (JFJoch plugin) (push) Successful in 9m12s
Build Packages / DIALS test (push) Successful in 11m44s
Build Packages / Unit tests (push) Successful in 1h23m8s
v1.0.0-rc.135 (#44)
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.

* Multiple small bug fixes scattered across the whole code base. (detected with GPT-5.4)
* jfjoch_viewer: Improve image render performance

Reviewed-on: #44
Co-authored-by: Filip Leonarski <filip.leonarski@psi.ch>
Co-committed-by: Filip Leonarski <filip.leonarski@psi.ch>
2026-04-16 11:59:59 +02:00

93 lines
2.5 KiB
C++

// SPDX-FileCopyrightText: 2024 Filip Leonarski, Paul Scherrer Institute <filip.leonarski@psi.ch>
// SPDX-License-Identifier: GPL-3.0-only
#include "ROIMap.h"
#include "JFJochException.h"
std::vector<uint16_t> ROIMap::GetROIMap(const DiffractionGeometry &geom, size_t xpixel, size_t ypixel) const {
std::vector<uint16_t> map(xpixel * ypixel, 0);
std::vector<float> resolution_map(xpixel * ypixel, 0);
if (!rois.azimuthal.empty()) {
for (int y = 0; y < ypixel; y++) {
for (int x = 0; x < xpixel; x++) {
resolution_map[y * xpixel + x] = geom.PxlToRes(static_cast<float>(x), static_cast<float>(y));
}
}
}
uint16_t roi_id = 0;
for (const auto & box : rois.boxes) {
box.MarkROI(map, roi_id, xpixel, ypixel, resolution_map);
roi_id++;
}
for (const auto & circle : rois.circles) {
circle.MarkROI(map, roi_id, xpixel, ypixel, resolution_map);
roi_id++;
}
for (const auto &az : rois.azimuthal) {
az.MarkROI(map, roi_id, xpixel, ypixel, resolution_map);
roi_id++;
}
return map;
}
std::map<std::string, uint16_t> ROIMap::GetROINameMap() const {
std::map<std::string, uint16_t> roi_name_map;
uint16_t roi_id = 0;
for (auto & box : rois.boxes) {
roi_name_map[box.GetName()] = roi_id;
roi_id++;
}
for (auto & circle : rois.circles) {
roi_name_map[circle.GetName()] = roi_id;
roi_id++;
}
for (auto & az : rois.azimuthal) {
roi_name_map[az.GetName()] = roi_id;
roi_id++;
}
return roi_name_map;
}
void ROIMap::SetROI(const ROIDefinition &input) {
if (input.boxes.size() + input.circles.size() + input.azimuthal.size() > roi_limit)
throw JFJochException(JFJochExceptionCategory::ArrayOutOfBounds, "Limit of box ROIs exceeded");
rois = input;
}
const ROIDefinition &ROIMap::GetROIDefinition() const {
return rois;
}
bool ROIMap::empty() const {
return rois.boxes.empty() && rois.circles.empty() && rois.azimuthal.empty();
}
size_t ROIMap::size() const {
return rois.boxes.size() + rois.circles.size() + rois.azimuthal.size();
}
std::vector<ROIConfig> ROIMap::ExportMetadata() const {
std::vector<ROIConfig> ret;
for (auto &r : rois.boxes)
ret.emplace_back(r.ExportMetadata());
for (auto &r : rois.circles)
ret.emplace_back(r.ExportMetadata());
for (auto &r : rois.azimuthal)
ret.emplace_back(r.ExportMetadata());
return ret;
}