2024-01-19 17:07:41 +01:00
|
|
|
#ifndef EVENTBUILDER_H
|
|
|
|
#define EVENTBUILDER_H
|
|
|
|
|
|
|
|
#include <QObject>
|
|
|
|
#include <QVector>
|
|
|
|
#include <QList>
|
|
|
|
#include <QFile>
|
|
|
|
#include <QThread>
|
|
|
|
#include <QMutex>
|
|
|
|
#include <QMutexLocker>
|
2024-02-01 18:45:41 +01:00
|
|
|
#include <QQueue>
|
|
|
|
#include <QWaitCondition>
|
2024-01-19 17:07:41 +01:00
|
|
|
//#include "hw.h"
|
|
|
|
#include "datareceiver.h"
|
|
|
|
#include "histogram.h"
|
2024-02-01 18:45:41 +01:00
|
|
|
#include <immintrin.h> // Include for Intel Intrinsics
|
|
|
|
#include <emmintrin.h> // Include for SSE2
|
2024-01-19 17:07:41 +01:00
|
|
|
|
|
|
|
//The event builder will constantly keep some data in the buffers to enable synchronization of the devices. So:
|
|
|
|
#define EVB_MIN_BUFFER_OCCUPANCY (RECEIVER_BUFFER_SIZE / 8) //the EVB will wait until so much data is in each device buffer
|
|
|
|
#define EVB_MAX_BUFFER_OCCUPANCY (RECEIVER_BUFFER_SIZE / 2) //or so much in at least one
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class EventBuilder : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
2024-02-01 18:45:41 +01:00
|
|
|
explicit EventBuilder( QObject *parent = 0);
|
2024-01-19 17:07:41 +01:00
|
|
|
~EventBuilder();
|
|
|
|
|
|
|
|
void addSource(DataReceiver *source);
|
|
|
|
void deleteSources();
|
|
|
|
void startLogging(QString filename);
|
|
|
|
void stopLogging();
|
|
|
|
int isLogging();
|
|
|
|
void startTakingHistos(int sample_count);
|
|
|
|
void stopTakingHistos();
|
|
|
|
QVector<Histogram> &getHistos();
|
|
|
|
QVector<BufferData> getLastFrame();
|
|
|
|
QVector<BufferData> getNewFrame(); //as getLastFrame(), but ensures that the frame is new, i.e. no frame will be read twice
|
|
|
|
void recalculateChannels(); //recalculate baseAddresses
|
|
|
|
void setChannelCount(int sensor_nr, int nr_channels);
|
|
|
|
signals:
|
|
|
|
void sigInit();
|
|
|
|
void sigDeinit();
|
|
|
|
void sigStartLogging();
|
|
|
|
void sigStopLogging();
|
|
|
|
void sigStartTakingHistos(int);
|
|
|
|
void sigStopTakingHistos();
|
|
|
|
|
|
|
|
void sigHistoCompleted(); //this is a public signal which can be used to notify user that the histo is ready
|
2024-02-01 18:45:41 +01:00
|
|
|
// Define a signal to notify when postdata is updated
|
|
|
|
void dataReady(const QByteArray& data); // Define a signal for data readiness
|
2024-01-19 17:07:41 +01:00
|
|
|
public slots:
|
|
|
|
void onNewData(DataReceiver *receiver);
|
2024-02-01 18:45:41 +01:00
|
|
|
// Add a public slot to receive and store data
|
|
|
|
void receiveData(const QByteArray &data);
|
|
|
|
|
|
|
|
|
|
|
|
// Add a method to get data from the queue
|
|
|
|
QByteArray getNextData();
|
|
|
|
|
|
|
|
|
2024-01-19 17:07:41 +01:00
|
|
|
protected:
|
|
|
|
int checkBufferOccupancies();
|
|
|
|
int findLowestId();
|
|
|
|
void logDataToFile();
|
|
|
|
void init(); //run after moving to thread
|
|
|
|
void deinit();
|
|
|
|
|
|
|
|
QThread thread;
|
|
|
|
QSemaphore initSemaphore;
|
|
|
|
|
|
|
|
QVector<DataReceiver*> receivers;
|
|
|
|
|
|
|
|
QVector<BufferData> currentFrame;
|
2024-02-01 18:45:41 +01:00
|
|
|
signed short * copy_sensor_data;
|
2024-01-19 17:07:41 +01:00
|
|
|
QVector<BufferData> backgroundFrame;
|
|
|
|
|
|
|
|
QVector<BufferData> lastFrame;
|
|
|
|
|
|
|
|
QVector<Histogram> histograms;
|
|
|
|
int histogramSamplesToTake = 0;
|
|
|
|
|
|
|
|
QVector<unsigned short> baseAddresses; //base channel numbers for receivers
|
|
|
|
QVector<unsigned short> channelCounts; //and numbers of channels
|
|
|
|
unsigned short totalChannels; //we like unsigned shorts to put them directly into the data file
|
|
|
|
unsigned short totalBoards;
|
|
|
|
|
|
|
|
QMutex lastFrameMutex;
|
|
|
|
QSemaphore newDataSemaphore;
|
|
|
|
int nrReceivers;
|
|
|
|
QString logFileName;
|
|
|
|
QFile logFile;
|
|
|
|
int loggingData = 0;
|
|
|
|
protected slots:
|
|
|
|
void onInit();
|
|
|
|
void onDeinit();
|
|
|
|
void onStartLogging();
|
|
|
|
void onStopLogging();
|
|
|
|
void onStartTakingHistos(int sample_count);
|
|
|
|
void onStopTakingHistos();
|
|
|
|
private:
|
2024-02-01 18:45:41 +01:00
|
|
|
long long int frame_counter = 0;
|
2024-01-19 17:07:41 +01:00
|
|
|
double intensity = 0.0;
|
|
|
|
double position = 0.0;
|
|
|
|
double focus = 0.0;
|
2024-02-01 18:45:41 +01:00
|
|
|
QQueue<QByteArray> dataQueue;
|
|
|
|
QMutex mutex;
|
|
|
|
QWaitCondition dataAvailable;
|
2024-01-19 17:07:41 +01:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // EVENTBUILDER_H
|