Files
Jungfraujoch/jungfrau/JFConversionFloatingPoint.h
Filip Leonarski 1757d42182 Initial commit
Signed-off-by: Filip Leonarski <filip.leonarski@psi.ch>
2023-04-06 11:17:59 +02:00

33 lines
1.1 KiB
C++

// Copyright (2019-2022) Paul Scherrer Institute
// SPDX-License-Identifier: GPL-3.0-or-later
#ifndef JUNGFRAUJOCH_JFCONVERSIONFLOATINGPOINT_H
#define JUNGFRAUJOCH_JFCONVERSIONFLOATINGPOINT_H
#include "JFConversion.h"
class JFConversionFloatingPoint : public JFConversion {
std::vector<uint16_t> pedestal_g0;
std::vector<uint16_t> pedestal_g1;
std::vector<uint16_t> pedestal_g2;
std::vector<float> gain_g0;
std::vector<float> gain_g1;
std::vector<float> gain_g2;
void ConvertLine(int16_t *dest, const uint16_t *source, int line);
public:
JFConversionFloatingPoint();
void Setup(const JFModuleGainCalibration &gain_calibration,
const JFModulePedestal &pedestal_g0,
const JFModulePedestal &pedestal_g1,
const JFModulePedestal &pedestal_g2,
double energy) override;
void ConvertPacket(int16_t* dest, const uint16_t* source, uint16_t packet_number) override;
void ConvertFP(float *dest, const uint16_t *source);
void ConvertAdjustGeom(int16_t *dest, const uint16_t *source, int64_t line_shift) override;
};
#endif //JUNGFRAUJOCH_JFCONVERSIONFLOATINGPOINT_H