30 lines
1.1 KiB
C++
30 lines
1.1 KiB
C++
// Copyright (2019-2022) Paul Scherrer Institute
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
#ifndef JUNGFRAUJOCH_JFCONVERSION_H
|
|
#define JUNGFRAUJOCH_JFCONVERSION_H
|
|
|
|
#include <cstddef>
|
|
#include "JFModuleGainCalibration.h"
|
|
#include "JFModulePedestal.h"
|
|
|
|
class JFConversion {
|
|
public:
|
|
virtual void Setup(const JFModuleGainCalibration &gain_calibration,
|
|
const JFModulePedestal &pedestal_g0,
|
|
const JFModulePedestal &pedestal_g1,
|
|
const JFModulePedestal &pedestal_g2,
|
|
double energy) = 0;
|
|
|
|
virtual void ConvertPacket(int16_t* dest, const uint16_t* source, uint16_t packet_number) = 0;
|
|
void Convert(int16_t* dest, const uint16_t* source) {
|
|
for (int i = 0; i < 128; i++)
|
|
ConvertPacket(dest + i * 4 * RAW_MODULE_COLS, source + i * 4 * RAW_MODULE_COLS, i);
|
|
}
|
|
|
|
virtual void ConvertAdjustGeom(int16_t* dest, const uint16_t* source, int64_t slow_dir_step,
|
|
int64_t fast_dir_step, int64_t offset) = 0;
|
|
};
|
|
|
|
#endif //JUNGFRAUJOCH_JFCONVERSION_H
|