mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-22 22:40:02 +02:00

* exposing receiver thread ids to client Co-authored-by: Erik Frojdh <erik.frojdh@gmail.com>
360 lines
13 KiB
C++
360 lines
13 KiB
C++
#pragma once
|
|
#include "container_utils.h"
|
|
#include "logger.h"
|
|
#include "network_utils.h"
|
|
#include "receiver_defs.h"
|
|
class GeneralData;
|
|
class Listener;
|
|
class DataProcessor;
|
|
class DataStreamer;
|
|
class Fifo;
|
|
class slsDetectorDefs;
|
|
|
|
#include <atomic>
|
|
#include <exception>
|
|
#include <map>
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
class Implementation : private virtual slsDetectorDefs {
|
|
public:
|
|
Implementation(const detectorType d);
|
|
virtual ~Implementation();
|
|
|
|
/**************************************************
|
|
* *
|
|
* Configuration Parameters *
|
|
* *
|
|
* ************************************************/
|
|
|
|
void setDetectorType(const detectorType d);
|
|
int *getMultiDetectorSize() const;
|
|
void setMultiDetectorSize(const int *size);
|
|
int getDetectorPositionId() const;
|
|
void setDetectorPositionId(const int id);
|
|
std::string getDetectorHostname() const;
|
|
void setDetectorHostname(const std::string &c);
|
|
bool getSilentMode() const;
|
|
void setSilentMode(const bool i);
|
|
uint32_t getFifoDepth() const;
|
|
void setFifoDepth(const uint32_t i);
|
|
frameDiscardPolicy getFrameDiscardPolicy() const;
|
|
void setFrameDiscardPolicy(const frameDiscardPolicy i);
|
|
bool getFramePaddingEnable() const;
|
|
void setFramePaddingEnable(const bool i);
|
|
void setThreadIds(const pid_t parentTid, const pid_t tcpTid);
|
|
std::array<pid_t, NUM_RX_THREAD_IDS> getThreadIds() const;
|
|
|
|
/**************************************************
|
|
* *
|
|
* File Parameters *
|
|
* *
|
|
* ************************************************/
|
|
fileFormat getFileFormat() const;
|
|
void setFileFormat(slsDetectorDefs::fileFormat f);
|
|
std::string getFilePath() const;
|
|
/* check for existence */
|
|
void setFilePath(const std::string &c);
|
|
std::string getFileName() const;
|
|
void setFileName(const std::string &c);
|
|
uint64_t getFileIndex() const;
|
|
void setFileIndex(const uint64_t i);
|
|
bool getFileWriteEnable() const;
|
|
void setFileWriteEnable(const bool b);
|
|
bool getMasterFileWriteEnable() const;
|
|
void setMasterFileWriteEnable(const bool b);
|
|
bool getOverwriteEnable() const;
|
|
void setOverwriteEnable(const bool b);
|
|
uint32_t getFramesPerFile() const;
|
|
/* 0 means infinite */
|
|
void setFramesPerFile(const uint32_t i);
|
|
|
|
/**************************************************
|
|
* *
|
|
* Acquisition *
|
|
* *
|
|
* ************************************************/
|
|
runStatus getStatus() const;
|
|
uint64_t getFramesCaught() const;
|
|
uint64_t getAcquisitionIndex() const;
|
|
int getProgress() const;
|
|
std::vector<uint64_t> getNumMissingPackets() const;
|
|
void startReceiver();
|
|
void setStoppedFlag(bool stopped);
|
|
void stopReceiver();
|
|
void startReadout();
|
|
void shutDownUDPSockets();
|
|
void closeFiles();
|
|
void restreamStop();
|
|
|
|
/**************************************************
|
|
* *
|
|
* Network Configuration (UDP) *
|
|
* *
|
|
* ************************************************/
|
|
int getNumberofUDPInterfaces() const;
|
|
/* [Jungfrau] */
|
|
void setNumberofUDPInterfaces(const int n);
|
|
std::string getEthernetInterface() const;
|
|
void setEthernetInterface(const std::string &c);
|
|
std::string getEthernetInterface2() const;
|
|
/* [Jungfrau] */
|
|
void setEthernetInterface2(const std::string &c);
|
|
uint32_t getUDPPortNumber() const;
|
|
void setUDPPortNumber(const uint32_t i);
|
|
uint32_t getUDPPortNumber2() const;
|
|
/* [Eiger][Jungfrau] */
|
|
void setUDPPortNumber2(const uint32_t i);
|
|
int64_t getUDPSocketBufferSize() const;
|
|
void setUDPSocketBufferSize(const int64_t s);
|
|
int64_t getActualUDPSocketBufferSize() const;
|
|
|
|
/**************************************************
|
|
* *
|
|
* ZMQ Streaming Parameters (ZMQ) *
|
|
* *
|
|
* ************************************************/
|
|
bool getDataStreamEnable() const;
|
|
void setDataStreamEnable(const bool enable);
|
|
uint32_t getStreamingFrequency() const;
|
|
/* 0 for timer */
|
|
void setStreamingFrequency(const uint32_t freq);
|
|
uint32_t getStreamingTimer() const;
|
|
void setStreamingTimer(const uint32_t time_in_ms);
|
|
uint32_t getStreamingPort() const;
|
|
void setStreamingPort(const uint32_t i);
|
|
sls::IpAddr getStreamingSourceIP() const;
|
|
void setStreamingSourceIP(const sls::IpAddr ip);
|
|
std::map<std::string, std::string> getAdditionalJsonHeader() const;
|
|
void setAdditionalJsonHeader(const std::map<std::string, std::string> &c);
|
|
std::string getAdditionalJsonParameter(const std::string &key) const;
|
|
void setAdditionalJsonParameter(const std::string &key,
|
|
const std::string &value);
|
|
|
|
/**************************************************
|
|
* *
|
|
* Detector Parameters *
|
|
* *
|
|
* ************************************************/
|
|
void updateTotalNumberOfFrames();
|
|
uint64_t getNumberOfFrames() const;
|
|
void setNumberOfFrames(const uint64_t i);
|
|
uint64_t getNumberOfTriggers() const;
|
|
void setNumberOfTriggers(const uint64_t i);
|
|
uint64_t getNumberOfBursts() const;
|
|
/** [Gottthard2] */
|
|
void setNumberOfBursts(const uint64_t i);
|
|
int getNumberOfAdditionalStorageCells() const;
|
|
/** [Jungfrau] */
|
|
void setNumberOfAdditionalStorageCells(const int i);
|
|
/** [Mythen3] */
|
|
void setNumberOfGates(const int i);
|
|
timingMode getTimingMode() const;
|
|
void setTimingMode(const timingMode i);
|
|
burstMode getBurstMode() const;
|
|
/** [Gottthard2] */
|
|
void setBurstMode(const burstMode i);
|
|
uint64_t getAcquisitionTime() const;
|
|
void setAcquisitionTime(const uint64_t i);
|
|
/** [Mythen3] */
|
|
void updateAcquisitionTime();
|
|
/** [Mythen3] */
|
|
void setAcquisitionTime1(const uint64_t i);
|
|
/** [Mythen3] */
|
|
void setAcquisitionTime2(const uint64_t i);
|
|
/** [Mythen3] */
|
|
void setAcquisitionTime3(const uint64_t i);
|
|
/** [Mythen3] */
|
|
void setGateDelay1(const uint64_t i);
|
|
/** [Mythen3] */
|
|
void setGateDelay2(const uint64_t i);
|
|
/** [Mythen3] */
|
|
void setGateDelay3(const uint64_t i);
|
|
uint64_t getAcquisitionPeriod() const;
|
|
void setAcquisitionPeriod(const uint64_t i);
|
|
uint64_t getSubExpTime() const;
|
|
/* [Eiger] */
|
|
void setSubExpTime(const uint64_t i);
|
|
uint64_t getSubPeriod() const;
|
|
/* [Eiger] */
|
|
void setSubPeriod(const uint64_t i);
|
|
uint32_t getNumberofAnalogSamples() const;
|
|
/**[Ctb][Moench] */
|
|
void setNumberofAnalogSamples(const uint32_t i);
|
|
uint32_t getNumberofDigitalSamples() const;
|
|
/**[Ctb] */
|
|
void setNumberofDigitalSamples(const uint32_t i);
|
|
int getNumberofCounters() const;
|
|
void setNumberofCounters(const int i);
|
|
uint32_t getDynamicRange() const;
|
|
void setDynamicRange(const uint32_t i);
|
|
ROI getROI() const;
|
|
/* [Gotthard] */
|
|
void setROI(ROI arg);
|
|
bool getTenGigaEnable() const;
|
|
/* [Eiger][Ctb] */
|
|
void setTenGigaEnable(const bool b);
|
|
int getFlippedDataX() const;
|
|
void setFlippedDataX(int enable = -1);
|
|
bool getQuad() const;
|
|
/* [Eiger] */
|
|
void setQuad(const bool b);
|
|
bool getActivate() const;
|
|
/** [Eiger] If deactivated, receiver will create dummy data if deactivated
|
|
* padding is enabled (as it will receive nothing from detector) */
|
|
bool setActivate(const bool enable);
|
|
bool getDeactivatedPadding() const;
|
|
/* [Eiger] */
|
|
bool setDeactivatedPadding(const bool enable);
|
|
int getReadNLines() const;
|
|
/* [Eiger] */
|
|
void setReadNLines(const int value);
|
|
readoutMode getReadoutMode() const;
|
|
/* [Ctb] */
|
|
void setReadoutMode(const readoutMode f);
|
|
uint32_t getADCEnableMask() const;
|
|
/* [Ctb][Moench] */
|
|
void setADCEnableMask(const uint32_t mask);
|
|
uint32_t getTenGigaADCEnableMask() const;
|
|
/* [Ctb][Moench] */
|
|
void setTenGigaADCEnableMask(const uint32_t mask);
|
|
std::vector<int> getDbitList() const;
|
|
/* [Ctb] */
|
|
void setDbitList(const std::vector<int> v);
|
|
int getDbitOffset() const;
|
|
/* [Ctb] */
|
|
void setDbitOffset(const int s);
|
|
|
|
/**************************************************
|
|
* *
|
|
* Callbacks *
|
|
* *
|
|
* ************************************************/
|
|
void registerCallBackStartAcquisition(int (*func)(std::string, std::string,
|
|
uint64_t, uint32_t,
|
|
void *),
|
|
void *arg);
|
|
void registerCallBackAcquisitionFinished(void (*func)(uint64_t, void *),
|
|
void *arg);
|
|
void registerCallBackRawDataReady(void (*func)(char *, char *, uint32_t,
|
|
void *),
|
|
void *arg);
|
|
void registerCallBackRawDataModifyReady(void (*func)(char *, char *,
|
|
uint32_t &, void *),
|
|
void *arg);
|
|
|
|
private:
|
|
void DeleteMembers();
|
|
void InitializeMembers();
|
|
void SetLocalNetworkParameters();
|
|
void SetThreadPriorities();
|
|
void SetupFifoStructure();
|
|
|
|
void ResetParametersforNewAcquisition();
|
|
void CreateUDPSockets();
|
|
void SetupWriter();
|
|
void StartRunning();
|
|
|
|
/**************************************************
|
|
* *
|
|
* Class Members *
|
|
* *
|
|
* ************************************************/
|
|
|
|
// config parameters
|
|
int numThreads;
|
|
detectorType myDetectorType;
|
|
int numDet[MAX_DIMENSIONS];
|
|
int detID;
|
|
std::string detHostname;
|
|
bool silentMode;
|
|
uint32_t fifoDepth;
|
|
frameDiscardPolicy frameDiscardMode;
|
|
bool framePadding;
|
|
pid_t parentThreadId;
|
|
pid_t tcpThreadId;
|
|
|
|
// file parameters
|
|
fileFormat fileFormatType;
|
|
std::string filePath;
|
|
std::string fileName;
|
|
uint64_t fileIndex;
|
|
bool fileWriteEnable;
|
|
bool masterFileWriteEnable;
|
|
bool overwriteEnable;
|
|
uint32_t framesPerFile;
|
|
|
|
// acquisition
|
|
std::atomic<runStatus> status;
|
|
bool stoppedFlag;
|
|
|
|
// network configuration (UDP)
|
|
int numUDPInterfaces;
|
|
std::vector<std::string> eth;
|
|
std::vector<uint32_t> udpPortNum;
|
|
int64_t udpSocketBufferSize;
|
|
int64_t actualUDPSocketBufferSize;
|
|
|
|
// zmq parameters
|
|
bool dataStreamEnable;
|
|
uint32_t streamingFrequency;
|
|
uint32_t streamingTimerInMs;
|
|
uint32_t streamingPort;
|
|
sls::IpAddr streamingSrcIP;
|
|
std::map<std::string, std::string> additionalJsonHeader;
|
|
|
|
// detector parameters
|
|
uint64_t numberOfTotalFrames;
|
|
uint64_t numberOfFrames;
|
|
uint64_t numberOfTriggers;
|
|
uint64_t numberOfBursts;
|
|
int numberOfAdditionalStorageCells;
|
|
int numberOfGates;
|
|
timingMode timingMode;
|
|
burstMode burstMode;
|
|
uint64_t acquisitionPeriod;
|
|
uint64_t acquisitionTime;
|
|
uint64_t acquisitionTime1;
|
|
uint64_t acquisitionTime2;
|
|
uint64_t acquisitionTime3;
|
|
uint64_t gateDelay1;
|
|
uint64_t gateDelay2;
|
|
uint64_t gateDelay3;
|
|
uint64_t subExpTime;
|
|
uint64_t subPeriod;
|
|
uint64_t numberOfAnalogSamples;
|
|
uint64_t numberOfDigitalSamples;
|
|
int numberOfCounters;
|
|
uint32_t dynamicRange;
|
|
ROI roi;
|
|
bool tengigaEnable;
|
|
int flippedDataX;
|
|
bool quadEnable;
|
|
bool activated;
|
|
bool deactivatedPaddingEnable;
|
|
int numLinesReadout;
|
|
readoutMode readoutType;
|
|
uint32_t adcEnableMaskOneGiga;
|
|
uint32_t adcEnableMaskTenGiga;
|
|
std::vector<int> ctbDbitList;
|
|
int ctbDbitOffset;
|
|
int ctbAnalogDataBytes;
|
|
|
|
// callbacks
|
|
int (*startAcquisitionCallBack)(std::string, std::string, uint64_t,
|
|
uint32_t, void *);
|
|
void *pStartAcquisition;
|
|
void (*acquisitionFinishedCallBack)(uint64_t, void *);
|
|
void *pAcquisitionFinished;
|
|
void (*rawDataReadyCallBack)(char *, char *, uint32_t, void *);
|
|
void (*rawDataModifyReadyCallBack)(char *, char *, uint32_t &, void *);
|
|
void *pRawDataReady;
|
|
|
|
// class objects
|
|
GeneralData *generalData;
|
|
std::vector<std::unique_ptr<Listener>> listener;
|
|
std::vector<std::unique_ptr<DataProcessor>> dataProcessor;
|
|
std::vector<std::unique_ptr<DataStreamer>> dataStreamer;
|
|
std::vector<std::unique_ptr<Fifo>> fifo;
|
|
};
|