Belle II Software
release-08-01-10
|
This module provides a high-level display to show which ECLCollectors have channels with various type of issues See https://indico.belle2.org/event/10116/contributions/66837/attachments/23993/35443/2023.09.06_ecl.dqm.status_mikhail.remnev.pdf. More...
#include <DQMHistAnalysisECLSummary.h>
Classes | |
struct | dbr_sts_long_array |
structure to get an array of long values from EPICS More... | |
struct | ECLAlarmType |
Definition for different ECL alarm types. More... | |
Public Types | |
enum | EStatus { c_StatusTooFew = 0 , c_StatusDefault = 1 , c_StatusGood = 2 , c_StatusWarning = 3 , c_StatusError = 4 } |
Status flag of histogram/canvas. More... | |
enum | EStatusColor { c_ColorTooFew = kGray , c_ColorDefault = kWhite , c_ColorGood = kGreen , c_ColorWarning = kYellow , c_ColorError = kRed } |
Status colors of histogram/canvas (corresponding to status) More... | |
typedef std::map< std::string, HistObject > | HistList |
The type of list of histograms. | |
typedef std::map< std::string, MonitoringObject * > | MonObjList |
The type of list of MonitoringObjects. | |
typedef std::map< std::string, HistDelta * > | DeltaList |
The type of list of delta settings and histograms. | |
typedef std::map< std::string, bool > | CanvasUpdatedList |
The type of list of canvas updated status. | |
enum | EModulePropFlags { c_Input = 1 , c_Output = 2 , c_ParallelProcessingCertified = 4 , c_HistogramManager = 8 , c_InternalSerializer = 16 , c_TerminateInAllProcesses = 32 , c_DontCollectStatistics = 64 } |
Each module can be tagged with property flags, which indicate certain features of the module. More... | |
typedef ModuleCondition::EAfterConditionPath | EAfterConditionPath |
Forward the EAfterConditionPath definition from the ModuleCondition. | |
Public Member Functions | |
DQMHistAnalysisECLSummaryModule () | |
< derived from DQMHistAnalysisModule class. More... | |
~DQMHistAnalysisECLSummaryModule () | |
Destructor. | |
void | initialize () override final |
Initialize the module. | |
void | beginRun () override final |
Call when a run begins. | |
void | event () override final |
Event processor. | |
void | endRun () override final |
Call when a run ends. | |
void | terminate () override final |
Terminate. | |
std::map< int, int > | getSuspiciousChannels (TH1 *hist, double total_events, const std::vector< std::vector< short > > &neighbours, double max_deviation, bool occupancy_histogram) |
Get outlier channels, ones with values (occupancy, errors, etc) that are much higher than the values of their neghbours. More... | |
void | setRunType (std::string &t) |
Set the Run Type. More... | |
void | setEventProcessed (int e) |
Set the number of processed events. More... | |
TCanvas * | findCanvas (TString cname) |
Find canvas by name. More... | |
TH1 * | findHistInCanvas (const std::string &hname) |
Find histogram in corresponding canvas. More... | |
double | getSigma68 (TH1 *h) const |
Helper function to compute half of the central interval covering 68% of a distribution. More... | |
void | clearCanvases (void) |
Clear content of all Canvases. | |
TH1 * | getDelta (const std::string &fullname, int n=0, bool onlyIfUpdated=true) |
Get Delta histogram. More... | |
TH1 * | getDelta (const std::string &dirname, const std::string &histname, int n=0, bool onlyIfUpdated=true) |
Get Delta histogram. More... | |
void | addDeltaPar (const std::string &dirname, const std::string &histname, HistDelta::EDeltaType t, int p, unsigned int a=1) |
Add Delta histogram parameters. More... | |
bool | hasDeltaPar (const std::string &dirname, const std::string &histname) |
Check if Delta histogram parameters exist for histogram. More... | |
void | UpdateCanvas (std::string name, bool updated=true) |
Mark canvas as updated (or not) More... | |
void | UpdateCanvas (TCanvas *canvas, bool updated=true) |
Mark canvas as updated (or not) More... | |
void | ExtractRunType (std::vector< TH1 * > &hs) |
Extract Run Type from histogram title, called from input module. | |
void | ExtractEvent (std::vector< TH1 * > &hs) |
Extract event processed from daq histogram, called from input module. | |
int | registerEpicsPV (std::string pvname, std::string keyname="", bool update_pvs=true) |
EPICS related Functions. More... | |
void | setEpicsPV (std::string keyname, double value) |
Write value to a EPICS PV. More... | |
void | setEpicsPV (std::string keyname, int value) |
Write value to a EPICS PV. More... | |
void | setEpicsPV (int index, double value) |
Write value to a EPICS PV. More... | |
void | setEpicsPV (int index, int value) |
Write value to a EPICS PV. More... | |
void | setEpicsStringPV (std::string keyname, std::string value) |
Write string to a EPICS PV. More... | |
void | setEpicsStringPV (int index, std::string value) |
Write string to a EPICS PV. More... | |
double | getEpicsPV (std::string keyname) |
Read value from a EPICS PV. More... | |
double | getEpicsPV (int index) |
Read value from a EPICS PV. More... | |
std::string | getEpicsStringPV (std::string keyname, bool &status) |
Read value from a EPICS PV. More... | |
std::string | getEpicsStringPV (int index, bool &status) |
Read value from a EPICS PV. More... | |
int | updateEpicsPVs (float timeout) |
Update all EPICS PV (flush to network) More... | |
chid | getEpicsPVChID (std::string keyname) |
Get EPICS PV Channel Id. More... | |
chid | getEpicsPVChID (int index) |
Get EPICS PV Channel Id. More... | |
bool | requestLimitsFromEpicsPVs (chid id, double &lowerAlarm, double &lowerWarn, double &upperWarn, double &upperAlarm) |
Get Alarm Limits from EPICS PV. More... | |
bool | requestLimitsFromEpicsPVs (std::string keyname, double &lowerAlarm, double &lowerWarn, double &upperWarn, double &upperAlarm) |
Get Alarm Limits from EPICS PV. More... | |
bool | requestLimitsFromEpicsPVs (int index, double &lowerAlarm, double &lowerWarn, double &upperWarn, double &upperAlarm) |
Get Alarm Limits from EPICS PV. More... | |
void | setUseEpics (bool flag) |
Setter for EPICS usage. More... | |
void | setUseEpicsReadOnly (bool flag) |
Setter EPICS flag in read only mode. More... | |
bool | getUseEpics (void) |
Getter for EPICS usage. More... | |
bool | getUseEpicsReadOnly (void) |
Getter EPICS flag in read only mode. More... | |
void | cleanupEpicsPVs (void) |
Unsubscribe from EPICS PVs on terminate. | |
std::string & | getPVPrefix (void) |
get global Prefix for EPICS PVs More... | |
void | setPVPrefix (std::string &prefix) |
set global Prefix for EPICS PVs More... | |
EStatus | makeStatus (bool enough, bool warn_flag, bool error_flag) |
Helper function to judge the status for coloring and EPICS. More... | |
void | colorizeCanvas (TCanvas *canvas, EStatus status) |
Helper function for Canvas colorization. More... | |
EStatusColor | getStatusColor (EStatus status) |
Return color for canvas state. More... | |
void | checkPVStatus (void) |
Check the status of all PVs and report if disconnected or not found. | |
void | printPVStatus (chid pv, bool onlyError=true) |
check the status of a PVs and report if disconnected or not found More... | |
std::vector< std::string > | StringSplit (const std::string &s, const char delim) |
Helper function for string token split. More... | |
virtual std::vector< std::string > | getFileNames (bool outputFiles) |
Return a list of output filenames for this modules. More... | |
const std::string & | getName () const |
Returns the name of the module. More... | |
const std::string & | getType () const |
Returns the type of the module (i.e. More... | |
const std::string & | getPackage () const |
Returns the package this module is in. | |
const std::string & | getDescription () const |
Returns the description of the module. | |
void | setName (const std::string &name) |
Set the name of the module. More... | |
void | setPropertyFlags (unsigned int propertyFlags) |
Sets the flags for the module properties. More... | |
LogConfig & | getLogConfig () |
Returns the log system configuration. | |
void | setLogConfig (const LogConfig &logConfig) |
Set the log system configuration. | |
void | setLogLevel (int logLevel) |
Configure the log level. | |
void | setDebugLevel (int debugLevel) |
Configure the debug messaging level. | |
void | setAbortLevel (int abortLevel) |
Configure the abort log level. | |
void | setLogInfo (int logLevel, unsigned int logInfo) |
Configure the printed log information for the given level. More... | |
void | if_value (const std::string &expression, const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End) |
Add a condition to the module. More... | |
void | if_false (const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End) |
A simplified version to add a condition to the module. More... | |
void | if_true (const std::shared_ptr< Path > &path, EAfterConditionPath afterConditionPath=EAfterConditionPath::c_End) |
A simplified version to set the condition of the module. More... | |
bool | hasCondition () const |
Returns true if at least one condition was set for the module. | |
const ModuleCondition * | getCondition () const |
Return a pointer to the first condition (or nullptr, if none was set) | |
const std::vector< ModuleCondition > & | getAllConditions () const |
Return all set conditions for this module. | |
bool | evalCondition () const |
If at least one condition was set, it is evaluated and true returned if at least one condition returns true. More... | |
std::shared_ptr< Path > | getConditionPath () const |
Returns the path of the last true condition (if there is at least one, else reaturn a null pointer). More... | |
Module::EAfterConditionPath | getAfterConditionPath () const |
What to do after the conditional path is finished. More... | |
std::vector< std::shared_ptr< Path > > | getAllConditionPaths () const |
Return all condition paths currently set (no matter if the condition is true or not). | |
bool | hasProperties (unsigned int propertyFlags) const |
Returns true if all specified property flags are available in this module. More... | |
bool | hasUnsetForcedParams () const |
Returns true and prints error message if the module has unset parameters which the user has to set in the steering file. | |
const ModuleParamList & | getParamList () const |
Return module param list. | |
template<typename T > | |
ModuleParam< T > & | getParam (const std::string &name) const |
Returns a reference to a parameter. More... | |
bool | hasReturnValue () const |
Return true if this module has a valid return value set. | |
int | getReturnValue () const |
Return the return value set by this module. More... | |
std::shared_ptr< PathElement > | clone () const override |
Create an independent copy of this module. More... | |
std::shared_ptr< boost::python::list > | getParamInfoListPython () const |
Returns a python list of all parameters. More... | |
Static Public Member Functions | |
static HistList & | getHistList () |
Get the list of the histograms. More... | |
static const MonObjList & | getMonObjList () |
Get the list of MonitoringObjects. More... | |
static const DeltaList & | getDeltaList () |
Get the list of the delta histograms. More... | |
static const CanvasUpdatedList & | getCanvasUpdatedList () |
Get the list of the canvas update status. More... | |
static const std::string & | getRunType (void) |
Get the Run Type. More... | |
static int | getEventProcessed (void) |
Get the number of processed events. More... | |
static TH1 * | findHist (const std::string &histname, bool onlyIfUpdated=false) |
Get histogram from list (no other search). More... | |
static TH1 * | findHist (const std::string &dirname, const std::string &histname, bool onlyIfUpdated=false) |
Find histogram. More... | |
static TH1 * | findHistInFile (TFile *file, const std::string &histname) |
Find histogram in specific TFile (e.g. More... | |
static MonitoringObject * | findMonitoringObject (const std::string &objName) |
Find MonitoringObject. More... | |
static bool | addHist (const std::string &dirname, const std::string &histname, TH1 *h) |
Add histogram. More... | |
static MonitoringObject * | getMonitoringObject (const std::string &histname) |
Get MonitoringObject with given name (new object is created if non-existing) More... | |
static void | initHistListBeforeEvent (void) |
Reset the list of histograms. | |
static void | clearHistList (void) |
Clears the list of histograms. | |
static void | exposePythonAPI () |
Exposes methods of the Module class to Python. | |
Protected Member Functions | |
virtual void | def_initialize () |
Wrappers to make the methods without "def_" prefix callable from Python. More... | |
virtual void | def_beginRun () |
Wrapper method for the virtual function beginRun() that has the implementation to be used in a call from Python. | |
virtual void | def_event () |
Wrapper method for the virtual function event() that has the implementation to be used in a call from Python. | |
virtual void | def_endRun () |
This method can receive that the current run ends as a call from the Python side. More... | |
virtual void | def_terminate () |
Wrapper method for the virtual function terminate() that has the implementation to be used in a call from Python. | |
void | setDescription (const std::string &description) |
Sets the description of the module. More... | |
void | setType (const std::string &type) |
Set the module type. More... | |
template<typename T > | |
void | addParam (const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue) |
Adds a new parameter to the module. More... | |
template<typename T > | |
void | addParam (const std::string &name, T ¶mVariable, const std::string &description) |
Adds a new enforced parameter to the module. More... | |
void | setReturnValue (int value) |
Sets the return value for this module as integer. More... | |
void | setReturnValue (bool value) |
Sets the return value for this module as bool. More... | |
void | setParamList (const ModuleParamList ¶ms) |
Replace existing parameter list. | |
Private Member Functions | |
std::pair< int, ECLAlarmType > | getAlarmByName (std::string name) |
Returns index of the specific alarm type and detailed information. | |
void | updateAlarmConfig () |
Set alarm limits in DQM based on EPICS PV limits. | |
bool | getMaskedChannels (std::map< std::string, dbr_sts_long_array > &mask_info) |
Get the array of masked channels for each type of alarm case monitored by this module. | |
std::vector< std::vector< int > > | updateAlarmCounts (bool update_mirabelle=false) |
Calculate and return number of problems per crate for all alarm categories. More... | |
std::map< int, int > | getChannelsWithOccupancyProblems () |
std::map< int, int > | getChannelsWithChi2Problems () |
void | drawGrid (TH2 *hist) |
Draw grid with TLine primitives for the specified histogram. | |
std::list< ModulePtr > | getModules () const override |
no submodules, return empty list | |
std::string | getPathString () const override |
return the module name. | |
void | setParamPython (const std::string &name, const boost::python::object &pyObj) |
Implements a method for setting boost::python objects. More... | |
void | setParamPythonDict (const boost::python::dict &dictionary) |
Implements a method for reading the parameter values from a boost::python dictionary. More... | |
Private Attributes | |
std::string | m_pvPrefix |
Prefix to use for PVs registered by this module. More... | |
bool | m_useChannelMask |
If true, mask Cell IDs based on DQM:ECL:channels_info:{alarm_type} PV info. | |
double | m_maxDeviationForOccupancy |
The higher this parameter, the larger differences in occupancy are allowed for adjacent channels. | |
double | m_maxDeviationForChi2 |
The higher this parameter, the larger differences in the number of hits with bad chi2 are allowed for adjacent channels. | |
bool | m_onlyIfUpdated |
If true (default), update EPICS PVs only if there were changes in the histograms. | |
std::vector< ECLAlarmType > | m_ecl_alarms |
Different alarms monitored in h_channels_summary. | |
std::map< std::string, std::set< int > > | m_mask |
List of masked Cell IDs for each alarm type. | |
double | m_total_events = 0 |
Number of events with ECL data in the current run. | |
TH2F * | h_channels_summary = nullptr |
Summarized information about ECL channels. | |
TCanvas * | c_channels_summary = nullptr |
TCanvas for ECL alarms regarding suspicious channels. | |
TExec * | m_ecl_style = nullptr |
Special object to specify style parameters. | |
TExec * | m_default_style = nullptr |
Special object to revert changes done by ecl_style. | |
ECL::ECLChannelMapper | m_mapper |
Object to map ECL crystal ID to ECL crate ID. | |
ECL::ECLNeighbours | m_neighbours_obj |
Object to get ECL crystal neighbours. | |
TCanvas * | c_occupancy = nullptr |
ECL occupancy histogram with highlighted suspicious channels. | |
TCanvas * | c_bad_chi2 = nullptr |
ECL bad chi2 histogram with highlighted suspicious channels. | |
TH1F * | h_bad_occ_overlay = nullptr |
Overlay to indicate bad channels on occupancy histogram. | |
TH1F * | h_bad_chi2_overlay = nullptr |
Overlay to indicate bad channels on chi2 histogram. | |
TH1F * | h_bad_occ_overlay_green = nullptr |
Overlay to indicate masked bad channels on occupancy histogram. | |
TH1F * | h_bad_chi2_overlay_green = nullptr |
Overlay to indicate masked bad channels on chi2 histogram. | |
MonitoringObject * | m_monObj = nullptr |
MiraBelle monitoring object. | |
std::string | m_name |
The name of the module, saved as a string (user-modifiable) | |
std::string | m_type |
The type of the module, saved as a string. | |
std::string | m_package |
Package this module is found in (may be empty). | |
std::string | m_description |
The description of the module. | |
unsigned int | m_propertyFlags |
The properties of the module as bitwise or (with |) of EModulePropFlags. | |
LogConfig | m_logConfig |
The log system configuration of the module. | |
ModuleParamList | m_moduleParamList |
List storing and managing all parameter of the module. | |
bool | m_hasReturnValue |
True, if the return value is set. | |
int | m_returnValue |
The return value. | |
std::vector< ModuleCondition > | m_conditions |
Module condition, only non-null if set. | |
Static Private Attributes | |
static const int | c_max_masked_channels = 200 |
Size of an array with masked channels. | |
static HistList | s_histList |
The list of Histograms. | |
static MonObjList | s_monObjList |
The list of MonitoringObjects. | |
static DeltaList | s_deltaList |
The list of Delta Histograms and settings. | |
static CanvasUpdatedList | s_canvasUpdatedList |
The list of canvas updated status. | |
static int | s_eventProcessed = 0 |
Number of Events processed to fill histograms. More... | |
static std::string | s_runType = "" |
The Run type. | |
static bool | m_useEpics = false |
Flag if to use EPICS do not set by yourself, use EpicsEnable module to set. | |
static bool | m_epicsReadOnly |
Flag if to use EPICS in ReadOnly mode (for reading limits) do not set by yourself, use EpicsEnable module to set. More... | |
static std::string | m_PVPrefix = "TEST:" |
The Prefix for EPICS PVs. | |
This module provides a high-level display to show which ECLCollectors have channels with various type of issues See https://indico.belle2.org/event/10116/contributions/66837/attachments/23993/35443/2023.09.06_ecl.dqm.status_mikhail.remnev.pdf.
Definition at line 38 of file DQMHistAnalysisECLSummary.h.
|
inherited |
Each module can be tagged with property flags, which indicate certain features of the module.
Enumerator | |
---|---|
c_Input | This module is an input module (reads data). |
c_Output | This module is an output module (writes data). |
c_ParallelProcessingCertified | This module can be run in parallel processing mode safely (All I/O must be done through the data store, in particular, the module must not write any files.) |
c_HistogramManager | This module is used to manage histograms accumulated by other modules. |
c_InternalSerializer | This module is an internal serializer/deserializer for parallel processing. |
c_TerminateInAllProcesses | When using parallel processing, call this module's terminate() function in all processes(). This will also ensure that there is exactly one process (single-core if no parallel modules found) or at least one input, one main and one output process. |
c_DontCollectStatistics | No statistics is collected for this module. |
|
inherited |
Status flag of histogram/canvas.
Definition at line 45 of file DQMHistAnalysis.h.
|
inherited |
Status colors of histogram/canvas (corresponding to status)
Definition at line 56 of file DQMHistAnalysis.h.
< derived from DQMHistAnalysisModule class.
Constructor.
Definition at line 27 of file DQMHistAnalysisECLSummary.cc.
|
inherited |
Add Delta histogram parameters.
dirname | directory |
histname | name of histogram |
t | type of delta histogramming |
p | numerical parameter depnding on type, e.g. number of entries |
a | amount of histograms in the past |
Definition at line 68 of file DQMHistAnalysis.cc.
|
staticinherited |
Add histogram.
dirname | The name of the directory. |
histname | The name of the histogram. |
h | The TH1 pointer for the histogram. |
Definition at line 46 of file DQMHistAnalysis.cc.
|
overridevirtualinherited |
Create an independent copy of this module.
Note that parameters are shared, so changing them on a cloned module will also affect the original module.
Implements PathElement.
|
inherited |
Helper function for Canvas colorization.
canvas | Canvas to change |
status | status to color |
Definition at line 668 of file DQMHistAnalysis.cc.
|
inlineprotectedvirtualinherited |
|
inlineprotectedvirtualinherited |
Wrappers to make the methods without "def_" prefix callable from Python.
Overridden in PyModule. Wrapper method for the virtual function initialize() that has the implementation to be used in a call from Python.
Reimplemented in PyModule.
|
inherited |
If at least one condition was set, it is evaluated and true returned if at least one condition returns true.
If no condition or result value was defined, the method returns false. Otherwise, the condition is evaluated and true returned, if at least one condition returns true. To speed up the evaluation, the condition strings were already parsed in the method if_value().
|
inherited |
Find canvas by name.
cname | Name of the canvas |
Definition at line 128 of file DQMHistAnalysis.cc.
|
staticinherited |
Find histogram.
dirname | The name of the directory. |
histname | The name of the histogram. |
onlyIfUpdated | req only updated hists, return nullptr otherwise |
Definition at line 156 of file DQMHistAnalysis.cc.
|
staticinherited |
Get histogram from list (no other search).
histname | The name of the histogram (incl dir). |
onlyIfUpdated | req only updated hists, return nullptr otherwise |
Definition at line 142 of file DQMHistAnalysis.cc.
|
inherited |
Find histogram in corresponding canvas.
hname | Name of the histogram (dir+name) |
Definition at line 164 of file DQMHistAnalysis.cc.
|
staticinherited |
Find histogram in specific TFile (e.g.
ref file).
file | The TFile to search. |
histname | The name of the histogram, can incl directory |
Definition at line 190 of file DQMHistAnalysis.cc.
|
staticinherited |
Find MonitoringObject.
objName | The name of the MonitoringObject. |
Definition at line 211 of file DQMHistAnalysis.cc.
|
inherited |
|
inlinestaticinherited |
Get the list of the canvas update status.
Definition at line 165 of file DQMHistAnalysis.h.
|
private |
Definition at line 545 of file DQMHistAnalysisECLSummary.cc.
|
private |
Definition at line 523 of file DQMHistAnalysisECLSummary.cc.
|
inherited |
|
inherited |
Get Delta histogram.
dirname | directory |
histname | name of histogram |
n | index of delta histogram, 0 is most recent one |
onlyIfUpdated | req only updated deltas, return nullptr otherwise |
Definition at line 91 of file DQMHistAnalysis.cc.
|
inherited |
Get Delta histogram.
fullname | directory+name of histogram |
n | index of delta histogram, 0 is most recent one |
onlyIfUpdated | req only updated deltas, return nullptr otherwise |
Definition at line 102 of file DQMHistAnalysis.cc.
|
inlinestaticinherited |
Get the list of the delta histograms.
Definition at line 159 of file DQMHistAnalysis.h.
|
inherited |
Read value from a EPICS PV.
index | index of PV |
Definition at line 440 of file DQMHistAnalysis.cc.
|
inherited |
Read value from a EPICS PV.
keyname | key name (or full PV name) of PV |
Definition at line 415 of file DQMHistAnalysis.cc.
|
inherited |
Get EPICS PV Channel Id.
index | index of PV |
Definition at line 533 of file DQMHistAnalysis.cc.
|
inherited |
Get EPICS PV Channel Id.
keyname | key name (or full PV name) of PV |
Definition at line 519 of file DQMHistAnalysis.cc.
|
inherited |
Read value from a EPICS PV.
index | index of PV |
status | return status (true on success) |
Definition at line 492 of file DQMHistAnalysis.cc.
|
inherited |
Read value from a EPICS PV.
keyname | key name (or full PV name) of PV |
status | return status (true on success) |
Definition at line 465 of file DQMHistAnalysis.cc.
|
inlinestaticinherited |
Get the number of processed events.
(Attention, asynch histogram updates!)
Definition at line 177 of file DQMHistAnalysis.h.
|
inlinevirtualinherited |
Return a list of output filenames for this modules.
This will be called when basf2 is run with "--dry-run" if the module has set either the c_Input or c_Output properties.
If the parameter outputFiles
is false (for modules with c_Input) the list of input filenames should be returned (if any). If outputFiles
is true (for modules with c_Output) the list of output files should be returned (if any).
If a module has sat both properties this member is called twice, once for each property.
The module should return the actual list of requested input or produced output filenames (including handling of input/output overrides) so that the grid system can handle input/output files correctly.
This function should return the same value when called multiple times. This is especially important when taking the input/output overrides from Environment as they get consumed when obtained so the finalized list of output files should be stored for subsequent calls.
Reimplemented in RootOutputModule, StorageRootOutputModule, and RootInputModule.
|
inlinestaticinherited |
Get the list of the histograms.
Definition at line 147 of file DQMHistAnalysis.h.
|
staticinherited |
Get MonitoringObject with given name (new object is created if non-existing)
histname | name of MonitoringObject to get |
Definition at line 112 of file DQMHistAnalysis.cc.
|
inlinestaticinherited |
Get the list of MonitoringObjects.
Definition at line 153 of file DQMHistAnalysis.h.
|
inlineinherited |
Returns the name of the module.
This can be changed via e.g. set_name() in the steering file to give more useful names if there is more than one module of the same type.
For identifying the type of a module, using getType() (or type() in Python) is recommended.
|
inherited |
Returns a python list of all parameters.
Each item in the list consists of the name of the parameter, a string describing its type, a python list of all default values and the description of the parameter.
|
inlineinherited |
get global Prefix for EPICS PVs
Definition at line 514 of file DQMHistAnalysis.h.
|
inlineinherited |
Return the return value set by this module.
This value is only meaningful if hasReturnValue() is true
|
inlinestaticinherited |
|
inherited |
Helper function to compute half of the central interval covering 68% of a distribution.
This quantity is an alternative to the standard deviation.
h | histogram |
Definition at line 225 of file DQMHistAnalysis.cc.
|
inherited |
Return color for canvas state.
status | canvas status |
Definition at line 641 of file DQMHistAnalysis.cc.
std::map< int, int > getSuspiciousChannels | ( | TH1 * | hist, |
double | total_events, | ||
const std::vector< std::vector< short > > & | neighbours, | ||
double | max_deviation, | ||
bool | occupancy_histogram | ||
) |
Get outlier channels, ones with values (occupancy, errors, etc) that are much higher than the values of their neghbours.
hist | Histogram that is used to search for outliers |
total_events | Total events in the run (after filter) |
neighbours | vector [Cell ID - 1] -> [vector of neighbours' Cell IDs] |
max_deviation | Maximum acceptable deviation (relative) from the expected value |
occupancy_histogram | If true, search for dead/cold/hot channels, otherwise search for bad_chi2 channels |
Cell IDs correspond to the range of [1, 8736].
Definition at line 577 of file DQMHistAnalysisECLSummary.cc.
|
inherited |
|
inlineinherited |
|
inlineinherited |
Getter EPICS flag in read only mode.
Definition at line 503 of file DQMHistAnalysis.h.
|
inherited |
Check if Delta histogram parameters exist for histogram.
dirname | directory |
histname | name of histogram |
Definition at line 80 of file DQMHistAnalysis.cc.
|
inherited |
|
inherited |
A simplified version to add a condition to the module.
Please note that successive calls of this function will add more than one condition to the module. If more than one condition results in true, only the last of them will be used.
Please be careful: Avoid creating cyclic paths, e.g. by linking a condition to a path which is processed before the path where this module is located in.
It is equivalent to the if_value() method, using the expression "<1". This method is meant to be used together with the setReturnValue(bool value) method.
path | Shared pointer to the Path which will be executed if the return value is false. |
afterConditionPath | What to do after executing 'path'. |
|
inherited |
A simplified version to set the condition of the module.
Please note that successive calls of this function will add more than one condition to the module. If more than one condition results in true, only the last of them will be used.
Please be careful: Avoid creating cyclic paths, e.g. by linking a condition to a path which is processed before the path where this module is located in.
It is equivalent to the if_value() method, using the expression ">=1". This method is meant to be used together with the setReturnValue(bool value) method.
path | Shared pointer to the Path which will be executed if the return value is true. |
afterConditionPath | What to do after executing 'path'. |
|
inherited |
Add a condition to the module.
Please note that successive calls of this function will add more than one condition to the module. If more than one condition results in true, only the last of them will be used.
See https://confluence.desy.de/display/BI/Software+ModCondTut or ModuleCondition for a description of the syntax.
Please be careful: Avoid creating cyclic paths, e.g. by linking a condition to a path which is processed before the path where this module is located in.
expression | The expression of the condition. |
path | Shared pointer to the Path which will be executed if the condition is evaluated to true. |
afterConditionPath | What to do after executing 'path'. |
|
inherited |
Helper function to judge the status for coloring and EPICS.
enough | enough events for judging |
warn_flag | outside of expected range |
error_flag | outside of warning range |
Definition at line 623 of file DQMHistAnalysis.cc.
|
inherited |
check the status of a PVs and report if disconnected or not found
pv | the chid of the PV to check |
onlyError | print only if in error condition (default) |
Definition at line 690 of file DQMHistAnalysis.cc.
|
inherited |
EPICS related Functions.
Register a PV with its name and a key name
If you register large number of PVs at once, consider setting update_pvs = false and explicitly running updateEpicsPVs()
pvname | full PV name |
keyname | key name for easier access |
update_pvs | if true, update all PVs (flush network) after new PV is registered |
Definition at line 306 of file DQMHistAnalysis.cc.
|
inherited |
Get Alarm Limits from EPICS PV.
id | Channel ID |
&lowerAlarm | return low Alarm limit (lolo) if set, not changed otherwise |
&lowerWarn | return low Warning limit (low) if set, not changed otherwise |
&upperWarn | return upper Warning limit (high) if set, not changed otherwise |
&upperAlarm | return upper Alarm limit (hihi) if set, not changed otherwise |
Definition at line 586 of file DQMHistAnalysis.cc.
|
inherited |
Get Alarm Limits from EPICS PV.
index | index of PV |
&lowerAlarm | return low Alarm limit (lolo) if set, not changed otherwise |
&lowerWarn | return low Warning limit (low) if set, not changed otherwise |
&upperWarn | return upper Warning limit (high) if set, not changed otherwise |
&upperAlarm | return upper Alarm limit (hihi) if set, not changed otherwise |
Definition at line 580 of file DQMHistAnalysis.cc.
|
inherited |
Get Alarm Limits from EPICS PV.
keyname | key name (or full PV name) of PV |
&lowerAlarm | return low Alarm limit (lolo) if set, not changed otherwise |
&lowerWarn | return low Warning limit (low) if set, not changed otherwise |
&upperWarn | return upper Warning limit (high) if set, not changed otherwise |
&upperAlarm | return upper Alarm limit (hihi) if set, not changed otherwise |
Definition at line 574 of file DQMHistAnalysis.cc.
|
protectedinherited |
|
inherited |
Write value to a EPICS PV.
index | index of PV |
value | value to write |
Definition at line 377 of file DQMHistAnalysis.cc.
|
inherited |
Write value to a EPICS PV.
index | index of PV |
value | value to write |
Definition at line 389 of file DQMHistAnalysis.cc.
|
inherited |
Write value to a EPICS PV.
keyname | key name (or full PV name) of PV |
value | value to write |
Definition at line 335 of file DQMHistAnalysis.cc.
|
inherited |
Write value to a EPICS PV.
keyname | key name (or full PV name) of PV |
value | value to write |
Definition at line 347 of file DQMHistAnalysis.cc.
|
inherited |
Write string to a EPICS PV.
index | index of PV |
value | string to write |
Definition at line 401 of file DQMHistAnalysis.cc.
|
inherited |
Write string to a EPICS PV.
keyname | key name (or full PV name) of PV |
value | string to write |
Definition at line 359 of file DQMHistAnalysis.cc.
|
inlineinherited |
Set the number of processed events.
(Attention, asynch histogram updates!)
Definition at line 189 of file DQMHistAnalysis.h.
|
inherited |
Configure the printed log information for the given level.
logLevel | The log level (one of LogConfig::ELogLevel) |
logInfo | What kind of info should be printed? ORed combination of LogConfig::ELogInfo flags. |
|
inlineinherited |
|
privateinherited |
Implements a method for setting boost::python objects.
The method supports the following types: list, dict, int, double, string, bool The conversion of the python object to the C++ type and the final storage of the parameter value is done in the ModuleParam class.
name | The unique name of the parameter. |
pyObj | The object which should be converted and stored as the parameter value. |
|
privateinherited |
Implements a method for reading the parameter values from a boost::python dictionary.
The key of the dictionary has to be the name of the parameter and the value has to be of one of the supported parameter types.
dictionary | The python dictionary from which the parameter values are read. |
|
inherited |
|
inlineinherited |
set global Prefix for EPICS PVs
prefix | Prefix to set |
Definition at line 520 of file DQMHistAnalysis.h.
|
protectedinherited |
Sets the return value for this module as bool.
The bool value is saved as an integer with the convention 1 meaning true and 0 meaning false. The value can be used in the steering file to divide the analysis chain into several paths.
value | The value of the return value. |
|
protectedinherited |
|
inlineinherited |
|
protectedinherited |
|
inlineinherited |
|
inlineinherited |
Setter EPICS flag in read only mode.
flag | set read only |
Definition at line 491 of file DQMHistAnalysis.h.
|
inherited |
Helper function for string token split.
s | String to split |
delim | delimiter |
Definition at line 234 of file DQMHistAnalysis.cc.
|
private |
Calculate and return number of problems per crate for all alarm categories.
Definition at line 371 of file DQMHistAnalysisECLSummary.cc.
|
inherited |
Mark canvas as updated (or not)
name | name of Canvas |
updated | was updated |
Definition at line 271 of file DQMHistAnalysis.cc.
|
inherited |
Mark canvas as updated (or not)
canvas | Canvas from which to take the name for update |
updated | was updated |
Definition at line 276 of file DQMHistAnalysis.cc.
|
inherited |
Update all EPICS PV (flush to network)
timeout | maximum time until timeout in s |
Definition at line 547 of file DQMHistAnalysis.cc.
|
staticprivateinherited |
Flag if to use EPICS in ReadOnly mode (for reading limits) do not set by yourself, use EpicsEnable module to set.
Definition at line 127 of file DQMHistAnalysis.h.
|
private |
Prefix to use for PVs registered by this module.
DQM framework will also prepend either 'TEST:' or 'DQM:' prefix.
Definition at line 131 of file DQMHistAnalysisECLSummary.h.
|
inlinestaticprivateinherited |
Number of Events processed to fill histograms.
Attention: histograms are updates asynchronously Thus the number for a specific histogram may be lower or higher. If you need precise number, you must fill it in the histogram itself (e.g. underflow bin)
Definition at line 110 of file DQMHistAnalysis.h.