26 lines
941 B
C++
26 lines
941 B
C++
// Copyright (2019-2023) Paul Scherrer Institute
|
|
|
|
#ifndef JUNGFRAUJOCH_RADIALINTEGRATIONMAPPINGFPGA_H
|
|
#define JUNGFRAUJOCH_RADIALINTEGRATIONMAPPINGFPGA_H
|
|
|
|
#include <vector>
|
|
#include <cstdint>
|
|
#include "../common/DiffractionExperiment.h"
|
|
|
|
class RadialIntegrationMappingFPGA {
|
|
const double low_q, high_q, q_spacing;
|
|
std::vector<float> bin_to_q;
|
|
std::vector<float> solid_angle_corr;
|
|
std::vector<uint16_t> pixel_to_bin;
|
|
uint16_t max_bin_number;
|
|
public:
|
|
explicit RadialIntegrationMappingFPGA(const DiffractionExperiment& experiment, uint16_t data_stream);
|
|
[[nodiscard]] uint16_t GetBinNumber() const;
|
|
[[nodiscard]] const std::vector<uint16_t> &GetPixelToBinMapping() const;
|
|
[[nodiscard]] const std::vector<float> &GetBinToQ() const;
|
|
[[nodiscard]] const std::vector<float> &GetSolidAngleCorr() const;
|
|
[[nodiscard]] double QToBin(double q) const;
|
|
};
|
|
|
|
#endif //JUNGFRAUJOCH_RADIALINTEGRATIONMAPPINGFPGA_H
|