14 #include <dqm/analysis/modules/DQMHistAnalysisDeltaEpicsMonObjExample.h>
23 REG_MODULE(DQMHistAnalysisDeltaEpicsMonObjExample);
29 DQMHistAnalysisDeltaEpicsMonObjExampleModule::DQMHistAnalysisDeltaEpicsMonObjExampleModule()
33 setDescription(
"Example module for using delta histogramming and sending values to EPICS");
39 B2DEBUG(1,
"DQMHistAnalysisDeltaEpicsMonObjExample: Constructor done.");
51 B2DEBUG(1,
"DQMHistAnalysisDeltaEpicsMonObjExample: initialized.");
90 B2DEBUG(1,
"DQMHistAnalysisDeltaEpicsMonObjExample: beginRun called.");
121 B2DEBUG(1,
"DQMHistAnalysisDeltaEpicsMonObjExample: endRun called.");
129 B2DEBUG(1,
"DQMHistAnalysisDeltaEpicsMonObjExample: event called.");
135 double data_mean = 0.0;
136 double data_width = 0.0;
160 data_mean = hist->GetMean();
161 data_width = hist->GetRMS();
174 double y1 = hist->GetMaximum();
175 double y2 = hist->GetMinimum();
176 auto ym = y1 + (y1 - y2) * 0.05;
181 auto yn = y2 + (y1 - y2) * 0.05;
194 switch (data_alarm) {
208 m_canvas->Pad()->SetFillColor(color);
241 B2DEBUG(1,
"DQMHistAnalysisDeltaEpicsMonObjExample: terminate called");
void terminate(void) override final
This method is called at the end of the event processing.
double m_widthUpperWarn
alarm limits from PV
TLine * m_meanUpperAlarmLine
TLine for alarm limits.
TLine * m_meanLowerAlarmLine
TLine for alarm limits.
double m_meanUpperAlarm
alarm limits from PV
void initialize(void) override final
Initializer.
std::string m_histogramName
name of histogram
void endRun(void) override final
Called when run ends.
std::string m_pvPrefix
prefix for EPICS PVs
TCanvas * m_canvas
Final Canvas.
MonitoringObject * m_monObj
Monitoring Object.
double m_widthUpperAlarm
alarm limits from PV
std::string m_histogramDirectoryName
name of histogram directory
TLine * m_meanLowerWarnLine
TLine for alarm limits.
double m_meanLowerWarn
alarm limits from PV
~DQMHistAnalysisDeltaEpicsMonObjExampleModule()
Destructor.
double m_meanLowerAlarm
alarm limits from PV
TLine * m_meanUpperWarnLine
TLine for alarm limits.
double m_meanUpperWarn
alarm limits from PV
void beginRun(void) override final
Called when entering a new run.
void event(void) override final
This method is called for each event.
void doHistAnalysis(bool forMiraBelle=false)
Do the actual processing.
The base class for the histogram analysis module.
int registerEpicsPV(std::string pvname, std::string keyname="", bool update_pvs=true)
EPICS related Functions.
void addDeltaPar(const std::string &dirname, const std::string &histname, HistDelta::EDeltaType t, int p, unsigned int a=1)
Add Delta histogram parameters.
TH1 * getDelta(const std::string &fullname, int n=0, bool onlyIfUpdated=true)
Get Delta histogram.
void setEpicsPV(std::string keyname, double value)
Write value to a EPICS PV.
void UpdateCanvas(std::string name, bool updated=true)
Mark canvas as updated (or not)
static MonitoringObject * getMonitoringObject(const std::string &histname)
Get MonitoringObject with given name (new object is created if non-existing)
bool requestLimitsFromEpicsPVs(chid id, double &lowerAlarm, double &lowerWarn, double &upperWarn, double &upperAlarm)
Get Alarm Limits from EPICS PV.
int updateEpicsPVs(float timeout)
Update all EPICS PV (flush to network)
void setDescription(const std::string &description)
Sets the description of the module.
void setVariable(const std::string &var, float val, float upErr=-1., float dwErr=-1)
set value to float variable (new variable is made if not yet existing)
void addCanvas(TCanvas *canv)
Add Canvas to monitoring object.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
Abstract base class for different kinds of events.