mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-20 02:40:03 +02:00
675 lines
19 KiB
C++
675 lines
19 KiB
C++
#pragma once
|
|
/************************************************
|
|
* @file GeneralData.h
|
|
* @short abstract for setting/getting properties of detector data
|
|
***********************************************/
|
|
/**
|
|
*@short abstract for setting/getting properties of detector data
|
|
*/
|
|
|
|
#include "sls_receiver_defs.h"
|
|
#include "receiver_defs.h"
|
|
|
|
#include <math.h> //ceil
|
|
#include <vector>
|
|
|
|
|
|
class GeneralData {
|
|
|
|
public:
|
|
|
|
/** DetectorType */
|
|
slsReceiverDefs::detectorType myDetectorType;
|
|
|
|
/** Number of Pixels in x axis */
|
|
uint32_t nPixelsX;
|
|
|
|
/** Number of Pixels in y axis */
|
|
uint32_t nPixelsY;
|
|
|
|
/** emptybuffer (mainly for jungfrau) */
|
|
uint32_t emptyHeader;
|
|
|
|
/** Size of header in Packet */
|
|
uint32_t headerSizeinPacket;
|
|
|
|
/** Size of just data in 1 packet (in bytes) */
|
|
uint32_t dataSize;
|
|
|
|
/** Size of 1 packet (in bytes) */
|
|
uint32_t packetSize;
|
|
|
|
/** Number of packets in an image (for each listening UDP port) */
|
|
uint32_t packetsPerFrame;
|
|
|
|
/** Image size (in bytes, for each listening UDP port) */
|
|
uint32_t imageSize;
|
|
|
|
/** Frame Number Mask */
|
|
uint64_t frameIndexMask;
|
|
|
|
/** Frame Index Offset */
|
|
uint32_t frameIndexOffset;
|
|
|
|
/** Packet Index Mask */
|
|
uint32_t packetIndexMask;
|
|
|
|
/** Packet Index Offset */
|
|
uint32_t packetIndexOffset;
|
|
|
|
/** Max Frames per binary file */
|
|
uint32_t maxFramesPerFile;
|
|
|
|
/** Header size of data saved into fifo buffer at a time*/
|
|
uint32_t fifoBufferHeaderSize;
|
|
|
|
/** Default Fifo depth */
|
|
uint32_t defaultFifoDepth;
|
|
|
|
/** Threads per receiver */
|
|
uint32_t threadsPerReceiver;
|
|
|
|
/** Size of a header packet */
|
|
uint32_t headerPacketSize;
|
|
|
|
/** Streaming (for ROI - mainly short Gotthard) - Number of Pixels in x axis */
|
|
uint32_t nPixelsXComplete;
|
|
|
|
/** Streaming (for ROI - mainly short Gotthard) - Number of Pixels in y axis */
|
|
uint32_t nPixelsYComplete;
|
|
|
|
/** Streaming (for ROI - mainly short Gotthard) - Image size (in bytes) */
|
|
uint32_t imageSizeComplete;
|
|
|
|
/** if standard header implemented in firmware */
|
|
bool standardheader;
|
|
|
|
/** default udp socket buffer size */
|
|
uint32_t defaultUdpSocketBufferSize;
|
|
|
|
|
|
|
|
|
|
/** Cosntructor */
|
|
GeneralData():
|
|
myDetectorType(slsReceiverDefs::GENERIC),
|
|
nPixelsX(0),
|
|
nPixelsY(0),
|
|
emptyHeader(0),
|
|
headerSizeinPacket(0),
|
|
dataSize(0),
|
|
packetSize(0),
|
|
packetsPerFrame(0),
|
|
imageSize(0),
|
|
frameIndexMask(0),
|
|
frameIndexOffset(0),
|
|
packetIndexMask(0),
|
|
packetIndexOffset(0),
|
|
maxFramesPerFile(0),
|
|
fifoBufferHeaderSize(0),
|
|
defaultFifoDepth(0),
|
|
threadsPerReceiver(1),
|
|
headerPacketSize(0),
|
|
nPixelsXComplete(0),
|
|
nPixelsYComplete(0),
|
|
imageSizeComplete(0),
|
|
standardheader(false),
|
|
defaultUdpSocketBufferSize(RECEIVE_SOCKET_BUFFER_SIZE)
|
|
{};
|
|
|
|
/** Destructor */
|
|
virtual ~GeneralData(){};
|
|
|
|
/**
|
|
* Get Header Infomation (frame number, packet number)
|
|
* @param index thread index for debugging purposes
|
|
* @param packetData pointer to data
|
|
* @param frameNumber frame number
|
|
* @param packetNumber packet number
|
|
*/
|
|
virtual void GetHeaderInfo(int index, char* packetData, uint64_t& frameNumber, uint32_t& packetNumber) const
|
|
{
|
|
frameNumber = ((uint32_t)(*((uint32_t*)(packetData))));
|
|
frameNumber++;
|
|
packetNumber = frameNumber&packetIndexMask;
|
|
frameNumber = (frameNumber & frameIndexMask) >> frameIndexOffset;
|
|
}
|
|
|
|
/**
|
|
* Get Header Infomation (frame number, packet number)
|
|
* @param index thread index for debugging purposes
|
|
* @param packetData pointer to data
|
|
* @param dynamicRange dynamic range to assign subframenumber if 32 bit mode
|
|
* @param frameNumber frame number
|
|
* @param packetNumber packet number
|
|
* @param subFrameNumber sub frame number if applicable
|
|
* @param bunchId bunch id
|
|
*/
|
|
virtual void GetHeaderInfo(int index, char* packetData, uint32_t dynamicRange,
|
|
uint64_t& frameNumber, uint32_t& packetNumber, uint32_t& subFrameNumber, uint64_t& bunchId) const
|
|
{
|
|
subFrameNumber = -1;
|
|
bunchId = -1;
|
|
frameNumber = ((uint32_t)(*((uint32_t*)(packetData))));
|
|
frameNumber++;
|
|
packetNumber = frameNumber&packetIndexMask;
|
|
frameNumber = (frameNumber & frameIndexMask) >> frameIndexOffset;
|
|
}
|
|
|
|
/**
|
|
* Set ROI
|
|
* @param i ROI
|
|
*/
|
|
virtual void SetROI(std::vector<slsReceiverDefs::ROI> i) {
|
|
cprintf(RED,"This is a generic function that should be overloaded by a derived class\n");
|
|
};
|
|
|
|
/**
|
|
* Get Adc configured
|
|
* @param index thread index for debugging purposes
|
|
* @param i pointer to a vector of ROI pointers
|
|
* @returns adc configured
|
|
*/
|
|
virtual const int GetAdcConfigured(int index, std::vector<slsReceiverDefs::ROI>* i) const{
|
|
cprintf(RED,"This is a generic function that should be overloaded by a derived class\n");
|
|
return 0;
|
|
};
|
|
|
|
/**
|
|
* Setting dynamic range changes member variables
|
|
* @param dr dynamic range
|
|
* @param tgEnable true if 10GbE is enabled, else false
|
|
*/
|
|
virtual void SetDynamicRange(int dr, bool tgEnable) {
|
|
cprintf(RED,"This is a generic function that should be overloaded by a derived class\n");
|
|
};
|
|
|
|
/**
|
|
* Setting ten giga enable changes member variables
|
|
* @param tgEnable true if 10GbE is enabled, else false
|
|
* @param dr dynamic range
|
|
*/
|
|
virtual void SetTenGigaEnable(bool tgEnable, int dr) {
|
|
cprintf(RED,"This is a generic function that should be overloaded by a derived class\n");
|
|
};
|
|
|
|
/**
|
|
* Setting packets per frame changes member variables
|
|
* @param ns number of samples
|
|
* @param nroich number of channels in roi
|
|
*/
|
|
virtual void setNumberofSamples(const uint64_t ns, uint32_t nroich) {
|
|
cprintf(RED,"This is a generic function that should be overloaded by a derived class\n");
|
|
};
|
|
|
|
/**
|
|
* Enable Gap Pixels changes member variables
|
|
* @param enable true if gap pixels enable, else false
|
|
*/
|
|
virtual void SetGapPixelsEnable(bool b, int dr) {
|
|
cprintf(RED,"This is a generic function that should be overloaded by a derived class\n");
|
|
};
|
|
|
|
|
|
/**
|
|
* Print all variables
|
|
*/
|
|
virtual void Print() const {
|
|
FILE_LOG(logDEBUG) << "\n\nDetector Data Variables:";
|
|
FILE_LOG(logDEBUG) << "myDetectorType: " << slsReceiverDefs::getDetectorType(myDetectorType);
|
|
FILE_LOG(logDEBUG) << "Pixels X: " << nPixelsX;
|
|
FILE_LOG(logDEBUG) << "Pixels Y: " << nPixelsY;
|
|
FILE_LOG(logDEBUG) << "Empty Header: " << emptyHeader;
|
|
FILE_LOG(logDEBUG) << "Header Size in Packet: " << headerSizeinPacket;
|
|
FILE_LOG(logDEBUG) << "Data Size: " << dataSize;
|
|
FILE_LOG(logDEBUG) << "Packet Size: " << packetSize;
|
|
FILE_LOG(logDEBUG) << "Packets per Frame: " << packetsPerFrame;
|
|
FILE_LOG(logDEBUG) << "Image Size: " << imageSize;
|
|
FILE_LOG(logDEBUG) << "Frame Index Mask: " << frameIndexMask;
|
|
FILE_LOG(logDEBUG) << "Frame Index Offset: " << frameIndexOffset;
|
|
FILE_LOG(logDEBUG) << "Packet Index Mask: " << packetIndexMask;
|
|
FILE_LOG(logDEBUG) << "Packet Index Offset: " << packetIndexOffset;
|
|
FILE_LOG(logDEBUG) << "Max Frames Per File: " << maxFramesPerFile;
|
|
FILE_LOG(logDEBUG) << "Fifo Buffer Header Size: " << fifoBufferHeaderSize;
|
|
FILE_LOG(logDEBUG) << "Default Fifo Depth: " << defaultFifoDepth;
|
|
FILE_LOG(logDEBUG) << "Threads Per Receiver: " << threadsPerReceiver;
|
|
FILE_LOG(logDEBUG) << "Header Packet Size: " << headerPacketSize;
|
|
FILE_LOG(logDEBUG) << "Complete Pixels X: " << nPixelsXComplete;
|
|
FILE_LOG(logDEBUG) << "Complete Pixels Y: " << nPixelsYComplete;
|
|
FILE_LOG(logDEBUG) << "Complete Image Size: " << imageSizeComplete;
|
|
FILE_LOG(logDEBUG) << "Standard Header: " << standardheader;
|
|
FILE_LOG(logDEBUG) << "UDP Socket Buffer Size: " << defaultUdpSocketBufferSize;
|
|
};
|
|
};
|
|
|
|
|
|
class GotthardData : public GeneralData {
|
|
|
|
private:
|
|
const static int nChip = 10;
|
|
const static int nChan = 128;
|
|
const static int nChipsPerAdc = 2;
|
|
public:
|
|
|
|
/** Constructor */
|
|
GotthardData(){
|
|
myDetectorType = slsReceiverDefs::GOTTHARD;
|
|
nPixelsX = 1280;
|
|
nPixelsY = 1;
|
|
headerSizeinPacket = 4;
|
|
dataSize = 1280;
|
|
packetSize = GOTTHARD_PACKET_SIZE;
|
|
packetsPerFrame = 2;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
frameIndexMask = 0xFFFFFFFE;
|
|
frameIndexOffset = 1;
|
|
packetIndexMask = 1;
|
|
maxFramesPerFile = MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 50000;
|
|
};
|
|
|
|
|
|
/**
|
|
* Get Header Infomation (frame number, packet number)
|
|
* @param index thread index for debugging purposes
|
|
* @param packetData pointer to data
|
|
* @param frameNumber frame number
|
|
* @param packetNumber packet number
|
|
*/
|
|
virtual void GetHeaderInfo(int index, char* packetData, uint64_t& frameNumber, uint32_t& packetNumber) const
|
|
{
|
|
if (nPixelsX == 1280) {
|
|
frameNumber = ((uint32_t)(*((uint32_t*)(packetData))));
|
|
frameNumber++;
|
|
packetNumber = frameNumber&packetIndexMask;
|
|
frameNumber = (frameNumber & frameIndexMask) >> frameIndexOffset;
|
|
} else {
|
|
frameNumber = ((uint32_t)(*((uint32_t*)(packetData))));
|
|
packetNumber = 0;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get Header Infomation (frame number, packet number)
|
|
* @param index thread index for debugging purposes
|
|
* @param packetData pointer to data
|
|
* @param dynamicRange dynamic range to assign subframenumber if 32 bit mode
|
|
* @param frameNumber frame number
|
|
* @param packetNumber packet number
|
|
* @param subFrameNumber sub frame number if applicable
|
|
* @param bunchId bunch id
|
|
*/
|
|
virtual void GetHeaderInfo(int index, char* packetData, uint32_t dynamicRange,
|
|
uint64_t& frameNumber, uint32_t& packetNumber, uint32_t& subFrameNumber, uint64_t& bunchId) const
|
|
{
|
|
if (nPixelsX == 1280) {
|
|
subFrameNumber = -1;
|
|
bunchId = -1;
|
|
frameNumber = ((uint32_t)(*((uint32_t*)(packetData))));
|
|
frameNumber++;
|
|
packetNumber = frameNumber&packetIndexMask;
|
|
frameNumber = (frameNumber & frameIndexMask) >> frameIndexOffset;
|
|
} else {
|
|
subFrameNumber = -1;
|
|
bunchId = -1;
|
|
frameNumber = ((uint32_t)(*((uint32_t*)(packetData))));
|
|
packetNumber = 0;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Set ROI
|
|
* @param i ROI
|
|
*/
|
|
virtual void SetROI(std::vector<slsReceiverDefs::ROI> i) {
|
|
// all adcs
|
|
if(!i.size()) {
|
|
nPixelsX = 1280;
|
|
dataSize = 1280;
|
|
packetSize = GOTTHARD_PACKET_SIZE;
|
|
packetsPerFrame = 2;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
frameIndexMask = 0xFFFFFFFE;
|
|
frameIndexOffset = 1;
|
|
packetIndexMask = 1;
|
|
maxFramesPerFile = MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 50000;
|
|
nPixelsXComplete = 0;
|
|
nPixelsYComplete = 0;
|
|
imageSizeComplete = 0;
|
|
}
|
|
|
|
// single adc
|
|
else {
|
|
nPixelsX = 256;
|
|
dataSize = 512;
|
|
packetSize = 518;
|
|
packetsPerFrame = 1;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
frameIndexMask = 0xFFFFFFFF;
|
|
frameIndexOffset = 0;
|
|
packetIndexMask = 0;
|
|
maxFramesPerFile = SHORT_MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 25000;
|
|
nPixelsXComplete = 1280;
|
|
nPixelsYComplete = 1;
|
|
imageSizeComplete = 1280 * 2;
|
|
}
|
|
};
|
|
|
|
/**
|
|
* Get Adc configured
|
|
* @param index thread index for debugging purposes
|
|
* @param i pointer to a vector of ROI
|
|
* @returns adc configured
|
|
*/
|
|
virtual const int GetAdcConfigured(int index, std::vector<slsReceiverDefs::ROI>* i) const{
|
|
int adc = -1;
|
|
// single adc
|
|
if(i->size()) {
|
|
// gotthard can have only one adc per detector enabled (or all)
|
|
// so just looking at the first roi is enough (more not possible at the moment)
|
|
|
|
//if its for 1 adc or general
|
|
if ((i->at(0).xmin == 0) && (i->at(0).xmax == nChip * nChan))
|
|
adc = -1;
|
|
else {
|
|
//adc = mid value/numchans also for only 1 roi
|
|
adc = ((((i->at(0).xmax) + (i->at(0).xmin))/2)/
|
|
(nChan * nChipsPerAdc));
|
|
if((adc < 0) || (adc > 4)) {
|
|
FILE_LOG(logWARNING) << index << ": Deleting ROI. "
|
|
"Adc value should be between 0 and 4";
|
|
adc = -1;
|
|
}
|
|
}
|
|
}
|
|
FILE_LOG(logINFO) << "Adc Configured: " << adc;
|
|
return adc;
|
|
};
|
|
|
|
|
|
};
|
|
|
|
|
|
class PropixData : public GeneralData {
|
|
|
|
private:
|
|
|
|
/**bytes per pixel for calculating image size */
|
|
const static uint32_t bytesPerPixel = 2;
|
|
|
|
public:
|
|
|
|
/** Constructor */
|
|
PropixData(){
|
|
myDetectorType = slsReceiverDefs::PROPIX;
|
|
nPixelsX = 22;
|
|
nPixelsY = 22;
|
|
headerSizeinPacket = 4;
|
|
dataSize = 1280;
|
|
packetSize = 1286;
|
|
packetsPerFrame = 2; //not really
|
|
imageSize = nPixelsX*nPixelsY*bytesPerPixel;
|
|
frameIndexMask = 0xFFFFFFFE;
|
|
frameIndexOffset = 1;
|
|
packetIndexMask = 1;
|
|
maxFramesPerFile = MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 50000;
|
|
};
|
|
};
|
|
|
|
|
|
class Moench02Data : public GeneralData {
|
|
|
|
public:
|
|
|
|
/** Bytes Per Adc */
|
|
const static uint32_t bytesPerAdc = (40*2);
|
|
|
|
/** Constructor */
|
|
Moench02Data(){
|
|
myDetectorType = slsReceiverDefs::MOENCH;
|
|
nPixelsX = 160;
|
|
nPixelsY = 160;
|
|
headerSizeinPacket = 4;
|
|
dataSize = 1280;
|
|
packetSize = 1286;
|
|
packetsPerFrame = 40;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
frameIndexMask = 0xFFFFFF00;
|
|
frameIndexOffset = 8;
|
|
packetIndexMask = 0xFF;
|
|
maxFramesPerFile = MOENCH_MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 2500;
|
|
};
|
|
|
|
/**
|
|
* Print all variables
|
|
*/
|
|
void Print() const {
|
|
GeneralData::Print();
|
|
FILE_LOG(logINFO) << "Bytes Per Adc: " << bytesPerAdc;
|
|
}
|
|
};
|
|
|
|
|
|
class Moench03Data : public GeneralData {
|
|
|
|
public:
|
|
|
|
/** Constructor */
|
|
Moench03Data(){
|
|
myDetectorType = slsReceiverDefs::MOENCH;
|
|
nPixelsX = 400;
|
|
nPixelsY = 400;
|
|
headerSizeinPacket = 22;
|
|
dataSize = 8192;
|
|
packetSize = headerSizeinPacket + dataSize;
|
|
packetsPerFrame = 40;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
frameIndexMask = 0xFFFFFFFF;
|
|
frameIndexOffset = (6+8);
|
|
packetIndexMask = 0xFFFFFFFF;
|
|
maxFramesPerFile = JFRAU_MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 2500;
|
|
};
|
|
};
|
|
|
|
|
|
class JCTBData : public GeneralData {
|
|
|
|
|
|
private:
|
|
/** Structure of an jungfrau ctb packet header */
|
|
typedef struct {
|
|
unsigned char emptyHeader[6];
|
|
unsigned char reserved[4];
|
|
unsigned char packetNumber[1];
|
|
unsigned char frameNumber[3];
|
|
unsigned char bunchid[8];
|
|
} jfrauctb_packet_header_t;
|
|
|
|
public:
|
|
|
|
|
|
|
|
/** Bytes Per Adc */
|
|
const static uint32_t bytesPerAdc = 2;
|
|
|
|
/** Constructor */
|
|
JCTBData(){
|
|
myDetectorType = slsReceiverDefs::JUNGFRAUCTB;
|
|
nPixelsX = 400;
|
|
nPixelsY = 400;
|
|
headerSizeinPacket = 22;
|
|
dataSize = 8192;
|
|
packetSize = headerSizeinPacket + dataSize;
|
|
packetsPerFrame = 1;
|
|
imageSize = nPixelsX * nPixelsY * 2;
|
|
frameIndexMask = 0xFFFFFF;
|
|
maxFramesPerFile = JFCTB_MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 2500;
|
|
};
|
|
|
|
/**
|
|
* Get Header Infomation (frame number, packet number)
|
|
* @param index thread index for debugging purposes
|
|
* @param packetData pointer to data
|
|
* @param frameNumber frame number
|
|
* @param packetNumber packet number
|
|
*/
|
|
virtual void GetHeaderInfo(int index, char* packetData, uint64_t& frameNumber, uint32_t& packetNumber) const {
|
|
jfrauctb_packet_header_t* header = (jfrauctb_packet_header_t*)(packetData);
|
|
frameNumber = (uint64_t)((*( (uint32_t*) header->frameNumber)) & frameIndexMask);
|
|
packetNumber = (uint32_t)(*( (uint8_t*) header->packetNumber));
|
|
}
|
|
|
|
/**
|
|
* Get Header Infomation (frame number, packet number)
|
|
* @param index thread index for debugging purposes
|
|
* @param packetData pointer to data
|
|
* @param dynamicRange dynamic range to assign subframenumber if 32 bit mode
|
|
* @param frameNumber frame number * @param packetNumber packet number
|
|
* @param subFrameNumber sub frame number if applicable
|
|
* @param bunchId bunch id
|
|
*/
|
|
void GetHeaderInfo(int index, char* packetData, uint32_t dynamicRange,
|
|
uint64_t& frameNumber, uint32_t& packetNumber, uint32_t& subFrameNumber, uint64_t& bunchId) const {
|
|
subFrameNumber = -1;
|
|
jfrauctb_packet_header_t* header = (jfrauctb_packet_header_t*)(packetData);
|
|
frameNumber = (uint64_t)((*( (uint32_t*) header->frameNumber)) & frameIndexMask);
|
|
packetNumber = (uint32_t)(*( (uint8_t*) header->packetNumber));
|
|
bunchId = (*((uint64_t*) header->bunchid));
|
|
}
|
|
|
|
/**
|
|
* Setting packets per frame changes member variables
|
|
* @param ns number of samples
|
|
* @param nroich number of channels in roi
|
|
*/
|
|
void setNumberofSamples(const uint64_t ns, uint32_t nroich) {
|
|
packetsPerFrame = ceil(double(2 * (nroich ? nroich : 32) * ns) / dataSize);
|
|
nPixelsY = (ns * 2) / 25;/* depends on nroich also?? */
|
|
imageSize = nPixelsX * nPixelsY * 2;
|
|
};
|
|
|
|
/**
|
|
* Print all variables
|
|
*/
|
|
void Print() const {
|
|
GeneralData::Print();
|
|
FILE_LOG(logINFO) << "Bytes Per Adc: " << bytesPerAdc;
|
|
}
|
|
};
|
|
|
|
|
|
class JungfrauData : public GeneralData {
|
|
|
|
public:
|
|
|
|
/** Constructor */
|
|
JungfrauData(){
|
|
myDetectorType = slsReceiverDefs::JUNGFRAU;
|
|
nPixelsX = (256*4);
|
|
nPixelsY = 512;
|
|
emptyHeader = 6;
|
|
headerSizeinPacket = emptyHeader + sizeof(slsReceiverDefs::sls_detector_header);
|
|
dataSize = 8192;
|
|
packetSize = headerSizeinPacket + dataSize;
|
|
packetsPerFrame = 128;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
maxFramesPerFile = JFRAU_MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 2500;
|
|
standardheader = true;
|
|
defaultUdpSocketBufferSize = (2000 * 1024 * 1024);
|
|
};
|
|
|
|
};
|
|
|
|
|
|
class EigerData : public GeneralData {
|
|
|
|
public:
|
|
|
|
/** Constructor */
|
|
EigerData(){
|
|
myDetectorType = slsReceiverDefs::EIGER;
|
|
nPixelsX = (256*2);
|
|
nPixelsY = 256;
|
|
headerSizeinPacket = sizeof(slsReceiverDefs::sls_detector_header);
|
|
dataSize = 1024;
|
|
packetSize = headerSizeinPacket + dataSize;
|
|
packetsPerFrame = 256;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
maxFramesPerFile = EIGER_MAX_FRAMES_PER_FILE;
|
|
fifoBufferHeaderSize= FIFO_HEADER_NUMBYTES + sizeof(slsReceiverDefs::sls_receiver_header);
|
|
defaultFifoDepth = 100;
|
|
threadsPerReceiver = 2;
|
|
headerPacketSize = 40;
|
|
standardheader = true;
|
|
};
|
|
|
|
/**
|
|
* Setting dynamic range changes member variables
|
|
* @param dr dynamic range
|
|
* @param tgEnable true if 10GbE is enabled, else false
|
|
*/
|
|
void SetDynamicRange(int dr, bool tgEnable) {
|
|
packetsPerFrame = (tgEnable ? 4 : 16) * dr;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
}
|
|
|
|
/**
|
|
* Setting ten giga enable changes member variables
|
|
* @param tgEnable true if 10GbE is enabled, else false
|
|
* @param dr dynamic range
|
|
*/
|
|
void SetTenGigaEnable(bool tgEnable, int dr) {
|
|
dataSize = (tgEnable ? 4096 : 1024);
|
|
packetSize = headerSizeinPacket + dataSize;
|
|
packetsPerFrame = (tgEnable ? 4 : 16) * dr;
|
|
imageSize = dataSize*packetsPerFrame;
|
|
};
|
|
|
|
/**
|
|
* Enable Gap Pixels changes member variables
|
|
* @param enable true if gap pixels enable, else false
|
|
* @param dr dynamic range
|
|
*/
|
|
void SetGapPixelsEnable(bool b, int dr) {
|
|
if (dr == 4)
|
|
b = 0;
|
|
switch((int)b) {
|
|
case 1:
|
|
nPixelsX = (256 * 2) + 3;
|
|
nPixelsY = 256 + 1;
|
|
imageSize = nPixelsX * nPixelsY * ((dr > 16) ? 4 : // 32 bit
|
|
((dr > 8) ? 2 : // 16 bit
|
|
((dr > 4) ? 1 : // 8 bit
|
|
0.5))); // 4 bit
|
|
break;
|
|
default:
|
|
nPixelsX = (256*2);
|
|
nPixelsY = 256;
|
|
imageSize = nPixelsX * nPixelsY * ((dr > 16) ? 4 : // 32 bit
|
|
((dr > 8) ? 2 : // 16 bit
|
|
((dr > 4) ? 1 : // 8 bit
|
|
0.5))); // 4 bit
|
|
break;
|
|
}
|
|
};
|
|
|
|
|
|
};
|
|
|