#ifndef ANALYZER_H #define ANALYZER_H #include #include #include #include #include #include #include #include #include #include "macro.h" #include "ClassDigitizer.h" #include "CustomThreads.h" #include "CustomWidgets.h" #include "MultiBuilder.h" #include "ClassInfluxDB.h" #include "math.h" /************************************** This class is for, obviously, Online analysis. It provides essential event building, histograms, and filling. This is the mother of all other derivative analysis class. derivative class should define the SetUpCanvas() and UpdateHistogram(); ***************************************/ #include "Histogram1D.h" #include "Histogram2D.h" //^============================================== //^============================================== class Analyzer : public QMainWindow{ Q_OBJECT public: Analyzer(Digitizer ** digi, unsigned int nDigi, QMainWindow * parent = nullptr); virtual ~Analyzer(); virtual void SetUpCanvas(); MultiBuilder * GetEventBuilder() { return mb;} void RedefineEventBuilder(std::vector idList); void SetBackwardBuild(bool TF, int maxNumEvent = 100) { isBuildBackward = TF; maxNumEventBuilt = maxNumEvent;} double RandomGauss(double mean, double sigma); public slots: void StartThread(); void StopThread(); virtual void UpdateHistograms(); // where event-building, analysis, and ploting private slots: protected: QGridLayout * layout; void BuildEvents(bool verbose = false); void SetUpdateTimeInSec(double sec = 1.0) {waitTimeinSec = sec; buildTimerThread->SetWaitTimeinSec(waitTimeinSec);} InfluxDB * influx; std::string dataBaseName; private: Digitizer ** digi; unsigned short nDigi; Data ** dataList; std::vector typeList; std::vector snList; double waitTimeinSec; MultiBuilder * mb; bool isBuildBackward; int maxNumEventBuilt; TimingThread * buildTimerThread; }; #endif