ATLAS Offline Software
Loading...
Searching...
No Matches
CscCalibMonToolPed Class Reference

Class for monitoring pedestal calibration results. More...

#include <CscCalibMonToolPed.h>

Inheritance diagram for CscCalibMonToolPed:
Collaboration diagram for CscCalibMonToolPed:

Public Types

enum  Interval_t {
  file = 0 , eventsBlock , lumiBlock , lowStat ,
  medStat , higStat , run , fill ,
  all
}
 An enumeration describing how detailed a particular monitoring object is. More...
enum  MgmtAttr_t { ATTRIB_MANAGED = 0 , ATTRIB_UNMANAGED = 1 , ATTRIB_X_VS_LB = 2 }
 An enumeration describing how the class handles the histogram. More...

Public Member Functions

 CscCalibMonToolPed (const std::string &type, const std::string &name, const IInterface *parent)
 Constructor.
 ~CscCalibMonToolPed ()
 Destructor.
StatusCode initialize ()
 initialize function.
StatusCode finalize ()
 finalize function.
StatusCode bookHistograms ()
 Books all histograms not retrieved driectly from CscCalcPed.
virtual StatusCode fillHistograms (const EventContext &ctx)
 Standard function for a ManagedMonitorToolBase.
virtual StatusCode procHistograms ()
 At end of run this processes the calibration results and fills the histograms.
virtual StatusCode checkHists (bool fromFinalise)
 Standard function for a ManagedMonitorToolBase.
virtual StreamNameFcnstreamNameFunction ()
 Returns the function object that converts logical paramters into a physical stream name.
virtual StatusCode bookHists ()
 Calls bookHists( true, true, true ) and initializes lumiBlock and run numbers.
virtual StatusCode fillHists (const EventContext &ctx)
 Calls fillHists( bool, bool, bool ); if an eventBlock,lumiBlock, or run has turned over, calls procHists( bool, bool, bool ) and bookHists( bool, bool, bool ).
virtual StatusCode finalHists ()
 Calls procHists( true, true, true ).
virtual StatusCode bookHistogramsRecurrent ()
 An inheriting class should either override this function, bookHists() or bookHistograms().
virtual void setMonManager (AthenaMonManager *manager)
 Takes a pointer to a managing object to get information from it when needed.
virtual StatusCode regHist (TH1 *h, const std::string &system, Interval_t interval, MgmtAttr_t histo_mgmt=ATTRIB_MANAGED, const std::string &chain="", const std::string &merge="")
 Registers a TH1 (including TH2, TH3, and TProfile) to be included in the output stream using logical parameters that describe the histogram.
virtual StatusCode regHist (TH1 *h, const MonGroup &group)
 Registers a TH1 (including TH2, TH3, and TProfile) to be included in the output stream using logical parameters that describe the histogram.
virtual StatusCode getHist (TH1 *&h, const std::string &hName, const std::string &system, Interval_t interval)
 Returns a TH1 via the pointer passed as the first argument.
virtual StatusCode getHist (TH1 *&h, const std::string &hName, const MonGroup &group)
 Returns a TH1 via the pointer passed as the first argument.
virtual StatusCode getHist (TH2 *&h, const std::string &hName, const std::string &system, Interval_t interval)
 Returns a TH2 via the pointer passed as the first argument.
virtual StatusCode getHist (TH2 *&h, const std::string &hName, const MonGroup &group)
 Returns a TH2 via the pointer passed as the first argument.
virtual StatusCode regEfficiency (TEfficiency *e, const MonGroup &group)
 Registers a TEfficiency to be included in the output stream using logical parameters that describe the plot.
virtual StatusCode regGraph (TGraph *g, const std::string &system, Interval_t interval, MgmtAttr_t histo_mgmt=ATTRIB_MANAGED, const std::string &chain="", const std::string &merge="")
 Registers a TGraph to be included in the output stream using logical parameters that describe the graph.
virtual StatusCode regGraph (TGraph *g, const MonGroup &group)
 Registers a TGraph to be included in the output stream using logical parameters that describe the graph.
virtual StatusCode regTree (TTree *t, const std::string &system, Interval_t interval, MgmtAttr_t histo_mgmt=ATTRIB_MANAGED, const std::string &chain="", const std::string &merge="")
 Registers a TTree to be included in the output stream using logical parameters that describe it.
virtual StatusCode regTree (TTree *t, const MonGroup &group)
 Registers a TTree to be included in the output stream using logical parameters that describe it.
virtual StatusCode writeAndDelete (TH1 *h, const MonGroup &group)
 Write out histogram and delete it.
virtual StatusCode deregHist (TH1 *h)
 De-registers a TH1 from the THistSvc, but does NOT delete the object.
virtual StatusCode deregGraph (TGraph *g)
 De-registers a TGraph from the THistSvc, but does NOT delete the object.
virtual StatusCode deregObject (const std::string &objName, const std::string &system, Interval_t interval)
 De-registers a TObject from the THistSvc, but does NOT delete the object.
virtual StatusCode deregObject (const std::string &objName, const MonGroup &group)
 De-registers a TObject from the THistSvc, but does NOT delete the object.
virtual StatusCode setupOutputStreams (std::vector< std::string > Mapping=std::vector< std::string >())
 This implementation does nothing—streams in this class should be managed by the AthenaMonManager.
virtual StatusCode runStat ()
 This implementation does nothing; equivalent functionality may be provided by procHists( true, true, true ).
virtual bool preSelector ()
virtual float lbAverageInteractionsPerCrossing (const EventContext &ctx) const
 Average mu, i.e.
virtual float lbInteractionsPerCrossing (const EventContext &ctx) const
 Instantaneous number of interactions, i.e.
virtual float lbAverageLuminosity (const EventContext &ctx) const
 Average luminosity (in ub-1 s-1 => 10^30 cm-2 s-1).
virtual float lbLuminosityPerBCID (const EventContext &ctx) const
 Instantaneous luminosity.
virtual double lbDuration (const EventContext &ctx) const
 Luminosity block time (in seconds).
virtual float lbAverageLivefraction (const EventContext &ctx) const
 Average luminosity livefraction.
virtual float livefractionPerBCID (const EventContext &ctx) const
 Livefraction per bunch crossing ID.
virtual double lbLumiWeight (const EventContext &ctx) const
 Average Integrated Luminosity Live Fraction.
 MMTB_DEPRECATED (newLowStatInterval)
 MMTB_DEPRECATED (newMedStatInterval)
 MMTB_DEPRECATED (newHigStatInterval)
 MMTB_DEPRECATED (newLowStat)
 MMTB_DEPRECATED (newLumiBlock)
 MMTB_DEPRECATED (newRun)
 MMTB_DEPRECATED (newEventsBlock)
 MMTB_DEPRECATED (endOfEventsBlock)
 MMTB_DEPRECATED (endOfLowStat)
 MMTB_DEPRECATED (endOfLumiBlock)
 MMTB_DEPRECATED (endOfRun)
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysInitialize () override
 Perform system initialization for an algorithm.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const

Static Public Member Functions

static std::string intervalEnumToString (Interval_t interval)
 Converts a LevelOfDetail_t to a string of the same name.
static Interval_t intervalStringToEnum (const std::string &str)
 Converts a string to the corresponding Interval_t.
static const InterfaceID & interfaceID ()

Protected Types

typedef std::map< std::string, OutputMetadata * > MDMap_t

Protected Member Functions

virtual StatusCode bookHistCollection (HistCollection *histCollection, const std::string &dataTypeName, const std::string &dataTypeTitle, const std::string &categoryName, const std::string &categoryTitle, const std::string &axisLabel, int numBins, float lowBound, float highBound, const std::string &parDir="", uint16_t toSkip=0)
 Initializes the histograms in a histCollection and books them.
virtual StatusCode bookLayHists (const std::string &histTypeDir, const std::string &parTypeDir, std::vector< TH1F * > &vector, const std::string &namePrefix, const std::string &titlePrefix, const std::string &xaxis, const std::string &yaxis, bool chanView=true, bool ignoreY=false, unsigned int numBins=100, float lowBound=0, float highbound=100)
 Books a vector of histograms where each one corresponds to a layer of the CSC secbers.
virtual StatusCode bookChamHists (const std::string &histTypeDir, const std::string &parTypeDir, std::vector< TH1F * > &histVector, const std::string &namePrefix, const std::string &titlePrefix, const std::string &xaxis="", const std::string &yaxis="", bool chanView=true, bool ignoreY=false, unsigned int numBins=100, float lowBound=0, float highbound=100)
 Books a vector of histograms where each one corresponds to a secber of the CSC secbers.
virtual StatusCode procParameter (const CscCalibResultCollection *parVals, ProcSetupInfo *simpleSet)
 Processors a parameter type.
virtual StatusCode copyDataToHists (HistCollection *histCollection)
 Fills the histograms in the histCollection based on the data in the std::vector in the HistCollection.
virtual int getLayIndex (int measuresPhi, int stationEta, int sector, int layer)
 produces a unique number for every layer in the detector
virtual int getChamIndex (int measuresPhi, int stationEta, int sector)
 Produces a unique number for every secber in the detector.
virtual int getSector (int stationPhi, int stationSize)
 Produces a sector number from the phi and size of a station.
std::string getEndCap (int eta)
 Gets the letter endcap (A or C) for a given eta index (1,-1).
std::string getGeoPath (int eta=-9999, int sector=-9999, int wireLayer=-9999, int measuresPhi=-9999, int channel=-9999)
 getGeoPath creates a directory structure for a histogram based upon where it is in the CSC geometry.
std::string getFullPath (const std::string &geoPath, const std::string &histTypeDir, const std::string &parTypeDir)
 Geo path creates a directory structure for a histogram based upon its geoPath, the hist type dir (spectrum of values, per-channel values, etc), and the parTypeDir (pedestal, etc).
StatusCode regManagedHistograms (std::vector< MgmtParams< TH1 > > &templateHistograms)
StatusCode regManagedGraphs (std::vector< MgmtParams< TGraph > > &templateGraphs)
StatusCode regManagedTrees (std::vector< MgmtParams< TTree > > &templateTrees)
StatusCode regManagedEfficiencies (std::vector< MgmtParams< TEfficiency > > &templateEfficiencies)
StatusCode parseList (const std::string &, std::vector< std::string > &)
void updateTriggersForGroups (std::vector< std::string > &)
StatusCode registerMetadata (const std::string &streamName, const std::string &hName, const MonGroup &group)
StatusCode THistSvc_deReg_fixTGraph (TFile *file, TGraph *theGraph, std::string &directoryName)
 Fixes THistSvc->deReg(obj) when obj is TGraph instance.
unsigned int get_nEvents () const
long get_procNEventsProp () const
virtual bool trigChainsArePassed (std::vector< std::string > &)
virtual StreamNameFcngetNewStreamNameFcn () const
bool newLowStatIntervalFlag () const
 Flag functions allowing clients to determine when to book new and process old histograms; values are updated by fillHists() based on counting lumiBlocks, and are correctly set when fillHistograms(), bookHistograms() and procHistograms() are called.
bool newMedStatIntervalFlag () const
bool newHigStatIntervalFlag () const
bool newLowStatFlag () const
bool newLumiBlockFlag () const
bool newRunFlag () const
bool newEventsBlockFlag () const
bool endOfEventsBlockFlag () const
bool endOfLowStatFlag () const
bool endOfLumiBlockFlag () const
bool endOfRunFlag () const
void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed.

Protected Attributes

unsigned int m_maxHashId {}
unsigned int m_maxChamId {}
unsigned int m_numBad {}
unsigned int m_expectedChamberLayer {}
bool m_makeHashHists {}
 Data output options.
bool m_makeAllChan1dHists {}
bool m_makeAllChan2dHists {}
bool m_makeLayHists {}
bool m_makeLaySummHists {}
bool m_makeChamProfs {}
bool m_makeChamSummHists {}
bool m_makeChamHists {}
bool m_doAllDetailed {}
bool m_doBadDetailed {}
int m_maxDetailedChannels {}
 To keep track of channels that should have more data printed to root file.
bool * m_detailedHashIds {}
bool m_onlyExpectPrecisionHashIds {}
 Hash Ids one would expect to be in calibration data.
std::set< int > m_expectedHashIdsAll
std::set< int > m_expectedHashIdsPrec
std::string m_hashName
 Naming info.
std::string m_hashTitle
std::string m_allChan1dName
std::string m_allChan1dTitle
std::string m_allChan2dName
std::string m_allChan2dTitle
std::string m_chamProfName
std::string m_chamProfTitle
std::string m_layHistName
std::string m_layHistTitle
std::string m_chamSummHistName
std::string m_chamSummHistTitle
std::string m_chamHistName
std::string m_chamHistTitle
std::string m_laySummHistName
std::string m_laySummHistTitle
int m_histCol {}
 Hist colors.
int m_histColAlert {}
std::string m_generic_path_csccalibmonitoring
 Path of histograms.
std::string m_hashPath
std::string m_allChan2dPath
std::string m_chamProfPath
std::string m_layHistPath
std::string m_chamSummHistPath
std::string m_laySummHistPath
DataVector< MonGroup > * m_monGroupVec {}
 Keeps track of MonGroups.
std::map< std::string, MonGroup * > m_monGroupMap
std::string m_calibResultKey
 Calibration result storegate key.
ServiceHandle< Muon::IMuonIdHelperSvcm_idHelperSvc {this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"}
SG::ReadCondHandleKey< CscCondDbDatam_readKey {this, "ReadKey", "CscCondDbData", "Key of CscCondDbData"}
 Access to COOL database.
bool m_doStatDb {}
HistCollectionm_statDbColl {}
std::map< Interval_t, std::vector< MgmtParams< TH1 > > > m_templateHistograms
std::map< Interval_t, std::vector< MgmtParams< TGraph > > > m_templateGraphs
std::map< Interval_t, std::vector< MgmtParams< TTree > > > m_templateTrees
std::map< Interval_t, std::vector< MgmtParams< TEfficiency > > > m_templateEfficiencies
std::vector< std::string > m_vTrigChainNames
std::vector< std::string > m_vTrigGroupNames
MDMap_t m_metadataMap
AthenaMonManagerm_manager
std::string m_managerNameProp
std::string m_fileKey
std::string m_dataTypeStr
std::string m_environmentStr
unsigned int m_detailLevel
AthenaMonManager::DataType_t m_dataType
AthenaMonManager::Environment_t m_environment
StreamNameFcnm_streamNameFcn
ServiceHandle< ITHistSvc > m_THistSvc
PublicToolHandle< Trig::ITrigDecisionToolm_trigDecTool {this, "TrigDecisionTool",""}
PublicToolHandle< ITriggerTranslatorToolm_trigTranslator {this,"TriggerTranslatorTool",""}
ToolHandleArray< IDQFilterToolm_DQFilterTools {this,"FilterTools",{}}
long m_procNEventsProp
std::string m_path
long m_preScaleProp
std::string m_triggerChainProp
std::string m_triggerGroupProp
bool m_useTrigger
unsigned int m_lastLumiBlock
unsigned int m_lastRun
int m_lastLowStatInterval
int m_lastMedStatInterval
int m_lastHigStatInterval
unsigned int m_nEvents
unsigned int m_nEventsIgnoreTrigger
unsigned int m_nLumiBlocks
bool m_haveClearedLastEventBlock

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

virtual StatusCode handleParameter (const CscCalibResultCollection *parVals)
 handleParameter sets things up for the base class procParameter.
virtual StatusCode postProc ()
 postProc does some post processing work after the main parameter histograms are filled
void genThreshold (HistCollection *pedColl, HistCollection *noiseColl, HistCollection *tholdColl, float multiplier)
void makeErrorReport ()
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

TH1F * m_h_pedMissingChannels
 Histograms that simply histogram all entries for a value.
float m_pedMaxDiff
 Allowed deviations from COOL data.
float m_noiseMaxDiff
float m_rmsMaxDiff
float m_f001MaxDiff
float m_onlTHoldBreachMax
float m_chi2Max
 Allowed maximum values.
int m_minAmpHistEntries
 Allowed number of entries.
std::string m_allGoodFileName
 name of file indicating all is well
std::string m_statusReportName
 Status report name.
std::string m_statusReportPrefix
 Status report prefix.
bool m_doBitCorrelations
 DO bit correlation plots?
int m_pedBadBin
 Bin in m_h_numBen corresponding to each type of data.
int m_noiseBadBin
int m_rmsBadBin
int m_f001BadBin
int m_nEntriesBadBin
int m_chi2BadBin
int m_missingBadBin
int m_onlTHoldBreachBadBin
std::string m_histKey
 Samples.
TH1I * m_h_numBad
 Stores number of channels that are bad in several categories.
HistCollectionm_pedNewColl
 HistCollections.
HistCollectionm_pedOldColl
HistCollectionm_pedDiffColl
HistCollectionm_noiseNewColl
HistCollectionm_noiseOldColl
HistCollectionm_noiseDiffColl
HistCollectionm_chi2Coll
HistCollectionm_rmsNewColl
HistCollectionm_rmsOldColl
HistCollectionm_rmsDiffColl
HistCollectionm_f001NewColl
HistCollectionm_f001OldColl
HistCollectionm_f001DiffColl
HistCollectionm_onlTHoldBreachColl
HistCollectionm_nEntriesColl
HistCollectionm_tholdDiffColl
HistCollectionm_maxBitCorrColl
TH2I * m_h2_rmsVnoiseEta
TH2I * m_h2_rmsVnoisePhi
bool m_doRmsVNoise
bool m_newLowStatInterval
bool m_newMedStatInterval
bool m_newHigStatInterval
bool m_newLowStat
bool m_newLumiBlock
bool m_newRun
bool m_newEventsBlock
bool m_endOfEventsBlock
bool m_endOfLowStat
bool m_endOfLumiBlock
bool m_endOfRun
SG::ReadCondHandleKey< LuminosityCondDatam_lumiDataKey {this,"LuminosityCondDataKey","LuminosityCondData","SG Key of LuminosityCondData object"}
SG::ReadCondHandleKey< LBDurationCondDatam_lbDurationDataKey {this,"LBDurationCondDataKey","LBDurationCondData","SG Key of LBDurationCondData object"}
SG::ReadCondHandleKey< TrigLiveFractionCondDatam_trigLiveFractionDataKey {this,"TrigLiveFractionCondDataKey","TrigLiveFractionCondData","SG Key of TrigLiveFractionCondData object"}
bool m_bookHistogramsInitial
bool m_useLumi
float m_defaultLBDuration
std::set< Interval_tm_supportedIntervalsForRebooking
Impm_d
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default).
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default).
std::vector< SG::VarHandleKeyArray * > m_vhka
bool m_varHandleArraysDeclared

Detailed Description

Class for monitoring pedestal calibration results.

This class monitors pedestals and noises created from CscCalcPed.cxx in the CscCalibAlgs package. It produces numerous histograms to illustrate the results. It runs during the finalize stage of the job. The info it looks at includes: -The pedestals and noises (sigma). -Pedestals and noises stored in COOL -Difference between these values -Chi^2 of pedestal fit

CscCalibMonToolBase provides the basis for much of the operation of this class. Generally, the program flow osciallates between base class functions and CscCalibMonToolPed functions.

Definition at line 35 of file CscCalibMonToolPed.h.

Member Typedef Documentation

◆ MDMap_t

typedef std::map<std::string,OutputMetadata*> ManagedMonitorToolBase::MDMap_t
protectedinherited

Definition at line 827 of file ManagedMonitorToolBase.h.

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< AlgTool > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Member Enumeration Documentation

◆ Interval_t

An enumeration describing how detailed a particular monitoring object is.

summary: used to summarize the state of the system

runstat: same as summary

shift: used to flag potential problems

expert: essential for diagnosing problems identified by shift-level objects

debug: useful for standalone debugging, but not for routine monitoring; not essential for diagnosing problems during normal running

transient: too detailed to ever be written; always summarized by the user by means of another object An enumeration describing the interval over which a particular monitoring object is filled (i.e., interval over which the method Fill(...) is called). This information may be stored with the monitoring object if an application is only able to partially fill the object (i.e., a job sees only part of a run or fill). This information may be ignored in some running Environments. The 'fill' interval corresponds to a fill of the LHC. The 'all' interval corresponds to all available data. The 'lumiBlock' and 'fill' intervals are only valid for the 'collisions' DataType_t.

Enumerator
file 
eventsBlock 
lumiBlock 
lowStat 
medStat 
higStat 
run 
fill 
all 

Definition at line 114 of file ManagedMonitorToolBase.h.

◆ MgmtAttr_t

An enumeration describing how the class handles the histogram.

attrib_unmanaged: histograms with this attribute will not be rebooked automatically and must be managed by the user code.

attrib_x_is_lb: indicates that the x-axis of the histogram is the luminosity block number and that the histogram should be rebooked as necessary if the current LB exceeds the range.

Enumerator
ATTRIB_MANAGED 
ATTRIB_UNMANAGED 
ATTRIB_X_VS_LB 

Definition at line 131 of file ManagedMonitorToolBase.h.

Constructor & Destructor Documentation

◆ CscCalibMonToolPed()

CscCalibMonToolPed::CscCalibMonToolPed ( const std::string & type,
const std::string & name,
const IInterface * parent )

Constructor.

Definition at line 16 of file CscCalibMonToolPed.cxx.

17 :
18 CscCalibMonToolBase(type, name, parent),
20 m_pedBadBin(1),
22 m_rmsBadBin(3),
23 m_f001BadBin(4),
25 m_chi2BadBin(6),
28 m_h_numBad(nullptr),
29 m_pedNewColl(nullptr),
30 m_pedOldColl(nullptr),
31 m_pedDiffColl(nullptr),
32 m_noiseNewColl(nullptr),
33 m_noiseOldColl(nullptr),
34 m_noiseDiffColl(nullptr),
35 m_chi2Coll(nullptr),
36 m_rmsNewColl(nullptr),
37 m_rmsOldColl(nullptr),
38 m_rmsDiffColl(nullptr),
39 m_f001NewColl(nullptr),
40 m_f001OldColl(nullptr),
41 m_f001DiffColl(nullptr),
42 m_onlTHoldBreachColl(nullptr),
43 m_nEntriesColl(nullptr),
44 m_tholdDiffColl(nullptr),
45 m_maxBitCorrColl(nullptr),
46 m_h2_rmsVnoiseEta(nullptr),
47 m_h2_rmsVnoisePhi(nullptr)
48{
49 declareProperty("MaxPedDiff",m_pedMaxDiff=2.0);
50 declareProperty("MaxNoiseDiff",m_noiseMaxDiff = 5.0);
51 declareProperty("MaxChi2_NDF",m_chi2Max = 800);
52 declareProperty("MaxRMSDiff",m_rmsMaxDiff = 5);
53 declareProperty("MaxF001Diff", m_f001MaxDiff = 5);
54 declareProperty("MaxOnlTHoldBreachesPerChannel", m_onlTHoldBreachMax = 400);
55 declareProperty("PedAmpHistKey", m_histKey = "cscPedCalibReport");
56 declareProperty("DoRmsVNoise", m_doRmsVNoise = false);
57 declareProperty("MinAmpHistEntries", m_minAmpHistEntries = 4000);
58 declareProperty("AlwaysPrintErrorReport",m_allGoodFileName = "AllCalibMonGood");
59 declareProperty("StatusReportFileName", m_statusReportName = "PedReport.txt");
60 declareProperty("StatusReportPrefix", m_statusReportPrefix = "");
61
62 declareProperty("DoBitCorrelations", m_doBitCorrelations = false);
63
64
65 //Although this can be declared in the base class, we give a default here
66 if(m_calibResultKey == "")
67 m_calibResultKey = "CscCalibResultPed"; //Determines what CscCalibMonToolBase will pull out of TDS
68
69
70
71 /*##From CscCalibMonToolBase.cxx, for reference.
72 declareProperty("MakeHashValueHist",m_makeHashHist=true);
73 declareProperty("MakeLayerValueHists",m_makeLayerHists=false);
74 declareProperty("DetailedResultHashIds",m_detailedHashIds);
75 */
76
77}
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
std::string m_calibResultKey
Calibration result storegate key.
CscCalibMonToolBase(const std::string &type, const std::string &name, const IInterface *parent)
constructor
TH1F * m_h_pedMissingChannels
Histograms that simply histogram all entries for a value.
int m_pedBadBin
Bin in m_h_numBen corresponding to each type of data.
HistCollection * m_pedOldColl
int m_minAmpHistEntries
Allowed number of entries.
HistCollection * m_chi2Coll
std::string m_statusReportPrefix
Status report prefix.
std::string m_histKey
Samples.
HistCollection * m_rmsDiffColl
HistCollection * m_rmsOldColl
float m_chi2Max
Allowed maximum values.
HistCollection * m_maxBitCorrColl
HistCollection * m_f001OldColl
HistCollection * m_noiseDiffColl
HistCollection * m_pedDiffColl
HistCollection * m_rmsNewColl
HistCollection * m_f001DiffColl
bool m_doBitCorrelations
DO bit correlation plots?
TH1I * m_h_numBad
Stores number of channels that are bad in several categories.
HistCollection * m_noiseNewColl
HistCollection * m_pedNewColl
HistCollections.
HistCollection * m_f001NewColl
std::string m_allGoodFileName
name of file indicating all is well
HistCollection * m_onlTHoldBreachColl
HistCollection * m_nEntriesColl
HistCollection * m_tholdDiffColl
float m_pedMaxDiff
Allowed deviations from COOL data.
HistCollection * m_noiseOldColl
std::string m_statusReportName
Status report name.

◆ ~CscCalibMonToolPed()

CscCalibMonToolPed::~CscCalibMonToolPed ( )
inline

Destructor.

Definition at line 45 of file CscCalibMonToolPed.h.

45{};

Member Function Documentation

◆ bookChamHists()

StatusCode CscCalibMonToolBase::bookChamHists ( const std::string & histTypeDir,
const std::string & parTypeDir,
std::vector< TH1F * > & histVector,
const std::string & namePrefix,
const std::string & titlePrefix,
const std::string & xaxis = "",
const std::string & yaxis = "",
bool chanView = true,
bool ignoreY = false,
unsigned int numBins = 100,
float lowBound = 0,
float highbound = 100 )
protectedvirtualinherited

Books a vector of histograms where each one corresponds to a secber of the CSC secbers.

Parameters
histTypeDirThe subdirectory where the histogram type should be stored (e.g "layerOverview")
parTypeDirThe subdirectory where the parameter type (e.g ped, noise,etc)
namePrefixSomething to put in front of the name. Rest is based on secber.
titlePrefixString to append to the front of the title. Rest is based on secber.
xaxisTitle for x-axis.
yaxisTitle for y-axis.
chanViewIf true, x-axis num-bins will be number of channels of a given layer. numbins, highBound, and lowBound will be ignored.
ignoreYDo not initialize histograms from the transverse direction.
numBinsnumber of bins for each histoto
lowBoundlower bound for histogram x-axis
highBoundhigher bound for histogram x-axis

Definition at line 547 of file CscCalibMonToolBase.cxx.

552{
553 //When doing channel view (i.e. one value per channel, also refered to as SectorView)
554 //we use pre-defined nbins, lower bound, and upper bound for histograms for obvious reasons
555 static const int chanViewNBinsX = 800;
556 static const double chanViewLowBoundX = .5;
557 static const double chanViewHighBoundX = 800.5;
558
559 static const int chanViewNBinsY = 200;
560 static const double chanViewLowBoundY = .5;
561 static const double chanViewHighBoundY = 200.5;
562
563
564 //Book a set of channel view histograms.
565 //unsigned int numStrips;
566 int stationSize, stationPhi, stationEta, sector;
567 std::string stationName;
568 std::string orientationName = "prec";
569 std::string orientationTitle = "Precision Direction";
570
571 int numHists = (ignoreY) ? 32 : 64; //32 chambers, 2 orientations
572 histVector.resize(numHists,nullptr);
573
574 const std::vector<Identifier> & ids = m_idHelperSvc->cscIdHelper().idVector();
575
576 for(const auto & thisChamberId:ids)
577 {
578 IdentifierHash chamHash;
579 m_idHelperSvc->cscIdHelper().get_module_hash(thisChamberId,chamHash);
580 ATH_MSG_DEBUG( "Booking histograms for chamber with hash " << (int)chamHash );
581
582 stationSize = m_idHelperSvc->cscIdHelper().stationName(thisChamberId); //50
583 stationPhi = m_idHelperSvc->cscIdHelper().stationPhi(thisChamberId);
584 stationEta = m_idHelperSvc->cscIdHelper().stationEta(thisChamberId);
585 sector = getSector(stationPhi,stationSize);
586
587 for(unsigned int orientationItr = 0; orientationItr < 2; orientationItr++)
588 {
589 if(orientationItr ==1)
590 {
591 if(ignoreY)
592 continue; //skip non precision strips.
593 orientationName = "trans";
594 orientationTitle = "Transverse Direction";
595 if(chanView){
596 numBins = chanViewNBinsY;
597 lowBound = chanViewLowBoundY;
598 highBound = chanViewHighBoundY;
599 }
600 }
601 else
602 {
603 orientationName = "prec";
604 orientationTitle = "Precision Direction";
605 if(chanView){
606 numBins = chanViewNBinsX;
607 lowBound = chanViewLowBoundX;
608 highBound = chanViewHighBoundX;
609 }
610 }
611
612 std::stringstream nameStream;
613 nameStream.setf(std::ios::right, std::ios::adjustfield);
614 nameStream << namePrefix << "_" << orientationName << "_eta_"
615 << ((stationEta == 1) ? "1" : "0") << "_sector_"
616 << std::setw(2) << std::setfill('0')
617 << sector ;
618
619 std::stringstream titleStream;
620
621 titleStream << titlePrefix << ", " << orientationTitle
622 << ", Eta " << stationEta
623 << ", Sector " << sector;
624
625 TH1F* hist = new TH1F(nameStream.str().c_str(), titleStream.str().c_str()
626 ,numBins, lowBound, highBound);
627 hist->GetXaxis()->SetTitle(xaxis.c_str());
628 hist->GetYaxis()->SetTitle(yaxis.c_str());
629 hist->SetFillColor(m_histCol);
630
631 int chamIndex = getChamIndex(orientationItr,stationEta,sector);
632
633 ATH_MSG_DEBUG( "Registering histogram with name "
634 << hist->GetName() << " and chamIndex " << chamIndex );
635
636 histVector[chamIndex] = hist;
637
638 std::string path = getFullPath(getGeoPath(stationEta,sector), histTypeDir, parTypeDir);
639
640 MonGroup monGroup( this, path ,run, ATTRIB_MANAGED);
641 if (!monGroup.regHist(hist).isSuccess())
642 {
643 ATH_MSG_WARNING("monGroup.regHist(hist) failed for "<< path );
644 }
645 }//End orientation loop
646 }//End chamber loop
647 ATH_MSG_DEBUG( "Exiting bookChamHists" );
648 return StatusCode::SUCCESS;
649}//end bookChamHists
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc
virtual int getSector(int stationPhi, int stationSize)
Produces a sector number from the phi and size of a station.
std::string getGeoPath(int eta=-9999, int sector=-9999, int wireLayer=-9999, int measuresPhi=-9999, int channel=-9999)
getGeoPath creates a directory structure for a histogram based upon where it is in the CSC geometry.
virtual int getChamIndex(int measuresPhi, int stationEta, int sector)
Produces a unique number for every secber in the detector.
std::string getFullPath(const std::string &geoPath, const std::string &histTypeDir, const std::string &parTypeDir)
Geo path creates a directory structure for a histogram based upon its geoPath, the hist type dir (spe...
A container of information describing a monitoring object.
constexpr uint8_t stationPhi
station Phi 1 to 8
path
python interpreter configuration --------------------------------------—
Definition athena.py:130
monGroup(analysis_chain)
TH1F(name, title, nxbins, bins_par2, bins_par3=None, path='', **kwargs)

◆ bookHistCollection()

StatusCode CscCalibMonToolBase::bookHistCollection ( HistCollection * histCollection,
const std::string & dataTypeName,
const std::string & dataTypeTitle,
const std::string & categoryName,
const std::string & categoryTitle,
const std::string & axisLabel,
int numBins,
float lowBound,
float highBound,
const std::string & parDir = "",
uint16_t toSkip = 0 )
protectedvirtualinherited

Initializes the histograms in a histCollection and books them.

This and the other booking function are used to enforce a central naming convention to the histograms. The Name parameters are strings that will be input into the names of the historams, and the Title parameters into the titles.

Parameters
dataTypeNameindicates the dataType, like pedestal, noise, etc.
dataTypeTitleindicates the dataType, like pedestal,noise, etc.
categoryNameindicates a category. Useful to specify new or COOL data.
categoryTitleindicates a category. Useful to specify new or COOL data.
axisLabelWhat the axis corresponding to the data type should be named. The other axis is determined depending on histogram type.
numBinsFor those histograms whose x-axis is the datatype, and not channels or similar.
lowBoundFor those histograms whose x-axis is the datatype, and not channels or similar.
highBoundFor those histograms whose x-axis is the datatype, and not channels or similar.
parDiris a parDirectory to store the resulting histograms in.
toSkipis a bit word that specifies when to allow certain histograms

Definition at line 138 of file CscCalibMonToolBase.cxx.

142{
143 //toSkip bitmask:
144 //00000000 do all
145 //00000001 skip all channels hash view
146 //00000010 skip chamberAverage
147 //00000100 skip layer overview
148 //00001000 skip sector summary
149 //00010000 skip layer summary
150 //00100000 skip AllChannels 1d view
151 //00100000 skip AllChannels 2d view
152 //01000000 skip csc spectra
153 //10000000 skip sector overview
154
155 //Make sure last character isn't a "/"
156 std::string endDir = "";
157 if(parDir != "")
158 endDir = "/" + parDir;
159
160 //Some universal directories
161 std::string allChambersDirectory = "/GeneralCscHists";
162
163 //Set directory structure used by CscCalibMonToolBase
164 /*
165 m_hashPath = m_generic_path_csccalibmonitoring + allChambersDirectory + "/AllChanHash" + endDir;
166 m_allChan2dPath = m_generic_path_csccalibmonitoring + allChambersDirectory + "/AllChan2d" + endDir;
167 m_chamProfPath = m_generic_path_csccalibmonitoring + allChambersDirectory + "/SectorProfiles" + endDir;
168 m_layHistPath = m_generic_path_csccalibmonitoring + "/EXPERT/" + parDir + "Layers";
169 m_chamSummHistPath = m_generic_path_csccalibmonitoring + "/EXPERT/" + parDir + "ChamberValueSpectrum";
170 m_laySummHistPath = m_generic_path_csccalibmonitoring + "/EXPERT/" + parDir + "LayerValueSpectrum";
171 */
172 bool allGood = true;
173
174
175 std::string nameStart = dataTypeName;
176 if(categoryName != "" )
177 nameStart += "_" + categoryName;
178
179 std::string titleStart = categoryTitle + " " + dataTypeTitle;
180 std::string yaxis= "", xaxis = "";
181
182 ATH_MSG_DEBUG( "In bookHistCollection for " << nameStart << " series." );
183
184 if(!((toSkip>>6) &0x1)){
185 histCollection->cscSpec.resize(2,nullptr);
186 for(int measuresPhi =0; measuresPhi <=1; measuresPhi++) {
187 std::string name = "h_" + nameStart+ "_" + (measuresPhi ? "phi" : "eta") + "_spectrum" ;
188 std::string title = titleStart +" " + (measuresPhi ? "Phi Strips" : "Eta Strips") + " spectrum";
189 TH1F * specHist = new TH1F(name.c_str(), title.c_str(), numBins, lowBound, highBound);
190 specHist->GetYaxis()->SetTitle("Counts");
191 specHist->GetXaxis()->SetTitle(axisLabel.c_str());
192 std::string specPath = getFullPath( getGeoPath(), "OverviewSpectra", parDir);
193 MonGroup monGroup( this, specPath, run, ATTRIB_MANAGED);
194 StatusCode sc = monGroup.regHist(specHist);
195
196 specHist->SetFillColor(m_histCol);
197
198 if(!sc.isSuccess())
199 {
200 ATH_MSG_ERROR( "failed to register " << name );
201 allGood = false;
202 }
203 else
204 histCollection->cscSpec[measuresPhi] = specHist;
205 }
206
207
208 }
209
210 if(m_makeHashHists && !(toSkip & 0x1))
211 {
212 std::string name = "h_" + nameStart + "_" + m_hashName;
213 std::string title = categoryTitle + " " + dataTypeTitle + " " + m_hashTitle;
214 yaxis = axisLabel;
215 xaxis = "Channel Hash ID";
216 TH1F * hashHist = new TH1F(name.c_str(), title.c_str(), m_maxHashId+1,0,m_maxHashId+1);
217 hashHist->GetXaxis()->SetTitle(xaxis.c_str());
218 hashHist->GetYaxis()->SetTitle(yaxis.c_str());
219 hashHist->SetFillColor(m_histCol);
220
221 std::string hashPath = getFullPath( getGeoPath(), "FullViewHash", parDir);
222 MonGroup monGroup( this, hashPath, run, ATTRIB_MANAGED);
223 ATH_MSG_DEBUG( "Registering " << name );
224 if (!monGroup.regHist(hashHist).isSuccess())
225 {
226 ATH_MSG_ERROR( "failed to register " << name );
227 allGood = false;
228 }
229 else
230 histCollection->hashHist = hashHist;
231
232 }
233 //All channels 1d view
234 if(m_makeAllChan1dHists && !((toSkip>>6) & 0x1))
235 {
236
237 std::string name = "h_" + nameStart + "_" + m_allChan1dName;
238 std::string title = categoryTitle + " " + dataTypeTitle + " " + m_allChan1dTitle;
239 yaxis = axisLabel;
240 xaxis = "Chamber";
241 int nxbins = 26146;// 4 layers, 192 channels each, with 32 chambers + 2 "extra" chambers"
242 float nxmin = -16; // -1 (for EC)
243 float nxmax = 16; // 1 (for EA)
244
245 TH1F * allChan1dHistX = new TH1F((name+"X").c_str(), (title+ " - Precision strips").c_str(),
246 nxbins,nxmin,nxmax);
247 allChan1dHistX->GetXaxis()->SetTitle(xaxis.c_str());
248 allChan1dHistX->GetYaxis()->SetTitle(yaxis.c_str());
249
250 std::string allChan1dPath = getFullPath( getGeoPath(), "FullView1d", parDir);
251 MonGroup monGroup( this, allChan1dPath, run, ATTRIB_MANAGED );
252 ATH_MSG_DEBUG( "Registering " << name );
253 if (!monGroup.regHist(allChan1dHistX).isSuccess())
254 {
255 ATH_MSG_ERROR( "failed to register " << name );
256 allGood = false;
257 }
258 else
259 histCollection->allChan1dHistX = allChan1dHistX;
260
261 nxbins = 6562;
262
263 TH1F * allChan1dHistY = new TH1F((name+"Y").c_str(), (title + " - Transverse strips").c_str(),
264 nxbins,nxmin,nxmax);
265 allChan1dHistY->GetXaxis()->SetTitle(xaxis.c_str());
266 allChan1dHistY->GetYaxis()->SetTitle(yaxis.c_str());
267
268 ATH_MSG_DEBUG( "Registering " << name );
269 if (!monGroup.regHist(allChan1dHistY).isSuccess())
270 {
271 ATH_MSG_ERROR( "failed to register " << name );
272 allGood = false;
273 }
274 else
275 histCollection->allChan1dHistY = allChan1dHistY;
276
277
278 }
279
280 //All channels 2d view
281 if(m_makeAllChan2dHists && !((toSkip>>6) & 0x1))
282 {
283
284 std::string name = "h_" + nameStart + "_" + m_allChan2dName;
285 std::string title = categoryTitle + " " + dataTypeTitle + " " + m_allChan2dTitle;
286 //yaxis = "sector + 0.2 * (layer - 1) + 0.1";
287 yaxis = "Sector/Layer";
288 xaxis = "Strip Number (Negative for Transverse Strips)";
289
290 int nxbins ;
291 float nxmin;
292 float nxmax;
293 int nybins ;
294 float nymin;
295 float nymax;
296 if(histCollection->ignoreY){
297 nxbins = 193; // 192 bins for precision + 1 extra
298 nxmin = 0.; // -1 -> -48 (for transverse)
299 nxmax = 193.; // 1 -> 192 (for precision)
300 nybins = 175; // 32 chambers (16 per side x 5 layers per chamber) + 5 extra
301 nymin = -17.; //
302 nymax = 18.; //
303 }
304 else{
305 nxbins = 242; // 192 bins for precision, 48 for transverse strips + 2 extra
306 nxmin = -49.; // -1 -> -48 (for transverse)
307 nxmax = 193.; // 1 -> 192 (for precision)
308 nybins = 175; // 32 chambers (16 per side x 5 layers per chamber) + 5 extra
309 nymin = -17.; //
310 nymax = 18.; //
311 }
312
313 TH2F * allChan2dHist = new TH2F(name.c_str(), title.c_str(),
314 nxbins,nxmin,nxmax,nybins,nymin,nymax);
315 allChan2dHist->GetXaxis()->SetTitle(xaxis.c_str());
316 allChan2dHist->GetYaxis()->SetTitle(yaxis.c_str());
317
318 std::string allChan2dPath = getFullPath( getGeoPath(), "FullView2d", parDir);
319 MonGroup monGroup( this, allChan2dPath, run, ATTRIB_MANAGED);
320 ATH_MSG_DEBUG( "Registering " << name );
321 if (!monGroup.regHist(allChan2dHist).isSuccess())
322 {
323 ATH_MSG_ERROR( "failed to register " << name );
324 allGood = false;
325 }
326 else
327 histCollection->allChan2dHist = allChan2dHist;
328
329 }
330
331 if(m_makeChamProfs && !((toSkip >> 1) & 0x1) )
332 {
333 std::string name = "h_" + nameStart + "_" + m_chamProfName;
334 std::string title = titleStart + " " + m_chamProfTitle;
335 yaxis = "Average " + axisLabel;
336 xaxis = "Sector * eta";
337 int numSectors = 16;
338 TProfile * chamProf= new TProfile(name.c_str(), title.c_str(),
339 numSectors + 1, -16, 17); //hard coding these because its annoying otherwise
340 chamProf->GetXaxis()->SetTitle(xaxis.c_str());
341 chamProf->GetYaxis()->SetTitle(yaxis.c_str());
342
343 ATH_MSG_DEBUG( "Registering " << name );
344 std::string path = getFullPath( getGeoPath(), "Profiles", parDir);
345 MonGroup monGroup( this, path, run, ATTRIB_MANAGED);
346 if (!monGroup.regHist(chamProf).isSuccess())
347 {
348 ATH_MSG_ERROR( "failed to register " << name );
349 allGood = false;
350 }
351 else
352 histCollection->chamProf = chamProf;
353 }
354 if(m_makeLayHists && !((toSkip >> 2) & 0x1) )
355 {
356 std::string namePrefix = nameStart + "_" + m_layHistName;
357 std::string titlePrefix = titleStart + " " + m_layHistTitle;
358 yaxis = axisLabel;
359 xaxis = "Channel";
360
361 ATH_MSG_DEBUG( "Registering set with prefix" << namePrefix );
362 histCollection->layHistVect.clear();
363 if (!bookLayHists("LayerView", parDir, histCollection->layHistVect,namePrefix, titlePrefix, "Channel", xaxis
364 ,true, histCollection->ignoreY).isSuccess())
365 {
366 ATH_MSG_ERROR( "failed to register " << namePrefix << " (layer histograms) " );
367 allGood = false;
368 }
369 }
370
371 if(m_makeChamSummHists && !((toSkip >> 3) & 0x1) )
372 {
373 std::string namePrefix = nameStart + "_" + m_chamSummHistName;
374 std::string titlePrefix = titleStart + " " + m_chamSummHistTitle;
375 yaxis = "";
376 xaxis = axisLabel;
377
378 ATH_MSG_DEBUG( "Registering set with prefix" << namePrefix );
379 histCollection->chamSummVect.clear();
380 if (!bookChamHists("SecSpectrum", parDir,histCollection->chamSummVect,namePrefix, titlePrefix, xaxis,yaxis,
381 false,histCollection->ignoreY,numBins,lowBound,highBound).isSuccess())
382 {
383 ATH_MSG_ERROR( "failed to register " << namePrefix
384 << " (chamber summary histograms) " );
385 allGood = false;
386 }
387 }
388
389 if(m_makeChamHists && !((toSkip >> 7) & 0x1) )
390 {
391 std::string namePrefix = nameStart + "_" + m_chamHistName;
392 std::string titlePrefix = titleStart + " " + m_chamHistTitle;
393 yaxis = "";
394 xaxis = axisLabel;
395
396 ATH_MSG_DEBUG( "Registering set with prefix" << namePrefix );
397 histCollection->chamHistVect.clear();
398 if (!bookChamHists("SectorView", parDir,histCollection->chamHistVect,namePrefix, titlePrefix, xaxis,yaxis,
399 true,histCollection->ignoreY).isSuccess())
400 {
401 ATH_MSG_ERROR( "failed to register " << namePrefix
402 << " (chamber summary histograms) " );
403 allGood = false;
404 }
405 }
406
407 if(m_makeLaySummHists && !((toSkip >> 4) & 0x1) )
408 {
409 std::string namePrefix = nameStart + "_" + m_laySummHistName;
410 std::string titlePrefix = titleStart + " " + m_laySummHistTitle;
411 yaxis = "";
412 xaxis = axisLabel;
413
414 ATH_MSG_DEBUG( "Registering set with prefix" << namePrefix );
415 histCollection->laySummVect.clear();
416 if (!bookLayHists("LaySpectrum", parDir, histCollection->laySummVect,
417 namePrefix, titlePrefix, xaxis,yaxis,
418 false,histCollection->ignoreY,numBins,lowBound,highBound).isSuccess())
419 {
420 ATH_MSG_ERROR( " Failed to register " << namePrefix << " (Layer summary hists) " );
421 allGood = false;
422 }
423 }
424 if(allGood)
425 return StatusCode::SUCCESS;
426 else
427 return StatusCode::FAILURE;
428}//end bookHistCollection
#define ATH_MSG_ERROR(x)
static Double_t sc
std::string m_hashName
Naming info.
virtual StatusCode bookLayHists(const std::string &histTypeDir, const std::string &parTypeDir, std::vector< TH1F * > &vector, const std::string &namePrefix, const std::string &titlePrefix, const std::string &xaxis, const std::string &yaxis, bool chanView=true, bool ignoreY=false, unsigned int numBins=100, float lowBound=0, float highbound=100)
Books a vector of histograms where each one corresponds to a layer of the CSC secbers.
virtual StatusCode bookChamHists(const std::string &histTypeDir, const std::string &parTypeDir, std::vector< TH1F * > &histVector, const std::string &namePrefix, const std::string &titlePrefix, const std::string &xaxis="", const std::string &yaxis="", bool chanView=true, bool ignoreY=false, unsigned int numBins=100, float lowBound=0, float highbound=100)
Books a vector of histograms where each one corresponds to a secber of the CSC secbers.
bool m_makeHashHists
Data output options.
::StatusCode StatusCode
StatusCode definition for legacy code.
bool allGood
Loop over the SDOs & Digits.
TH2F(name, title, nxbins, bins_par2, bins_par3, bins_par4, bins_par5=None, bins_par6=None, path='', **kwargs)

◆ bookHistograms()

StatusCode CscCalibMonToolPed::bookHistograms ( )
virtual

Books all histograms not retrieved driectly from CscCalcPed.

Reimplemented from CscCalibMonToolBase.

Definition at line 108 of file CscCalibMonToolPed.cxx.

109{
110 if (!CscCalibMonToolBase::bookHistograms().isSuccess())
111 {
112 ATH_MSG_WARNING( "CscCalibMonToolPed : in bookHistograms()" );
113 }
114 ATH_MSG_DEBUG( "CscCalibMonToolPed : in bookHistograms()" );
115
116 //declare a group of histograms
117
118 if (newRunFlag())
119 {
120 m_monGroupVec = new DataVector<MonGroup>;
121
122 std::string geoPath = getGeoPath();
123 std::string path = getFullPath(geoPath, "Misc", "");
124 MonGroup monGroup( this, path, run, ATTRIB_MANAGED );
125
126 std::string name,title,xaxis,yaxis;
127 int highbound,lowbound,nbins;
128
129 //num bad histograms
130 name = "h_csc_calib_numSignificant";
131 title = "Number of significant results.";
132 xaxis = "Catagory";
133 yaxis = "Num channels with bad value.";
134 lowbound = 1;
135 highbound = 8;
136 m_h_numBad = new TH1I(name.c_str(),title.c_str(),highbound-lowbound+1,lowbound,highbound+1);
137 m_h_numBad->GetYaxis()->SetTitle(yaxis.c_str());
138 m_h_numBad->GetXaxis()->SetTitle(xaxis.c_str());
139 std::stringstream pedBinTitle; pedBinTitle << "#Delta ped > " << m_pedMaxDiff;
140 m_h_numBad->GetXaxis()->SetBinLabel(m_pedBadBin, pedBinTitle.str().c_str());
141 std::stringstream noiseBinTitle; noiseBinTitle << "#Delta noise > "<< m_noiseMaxDiff;
142 m_h_numBad->GetXaxis()->SetBinLabel(m_noiseBadBin, noiseBinTitle.str().c_str());
143 std::stringstream rmsBinTitle; rmsBinTitle << "#Delta RMS > " << m_rmsMaxDiff;
144 m_h_numBad->GetXaxis()->SetBinLabel(m_rmsBadBin, rmsBinTitle.str().c_str());
145 std::stringstream f001BinTitle; f001BinTitle << "#Delta F001 > " << m_f001MaxDiff;
146 m_h_numBad->GetXaxis()->SetBinLabel(m_f001BadBin, f001BinTitle.str().c_str());
147 std::stringstream statisticsBinTitle; statisticsBinTitle << "N Entries < " << m_minAmpHistEntries;
148 m_h_numBad->GetXaxis()->SetBinLabel(m_nEntriesBadBin, statisticsBinTitle.str().c_str());
149 std::stringstream chiBinTitle; chiBinTitle << "#frac{#chi^{2}}{ndf} > " << m_chi2Max;
150 m_h_numBad->GetXaxis()->SetBinLabel(m_chi2BadBin,chiBinTitle.str().c_str());
151 m_h_numBad->GetXaxis()->SetBinLabel(m_missingBadBin,"Missing channels ");
152 m_h_numBad->GetXaxis()->SetBinLabel(m_onlTHoldBreachBadBin, "Onl THold Breaches");
153 m_h_numBad->SetFillColor(m_histColAlert);
154 monGroup.regHist(m_h_numBad).ignore();
155
156
157 name = "h_csc_calib_pedMissingChannels";
158 title = "Channels Missing Data From Pedestal Run.";
159 xaxis = "Channel (Hash ID)";
160 yaxis = "Number of Parameter Types Missing";
161 lowbound = 0;
162 highbound = m_maxHashId +1;
163 nbins = m_maxHashId +1;
164 m_h_pedMissingChannels = new TH1F(name.c_str(), title.c_str(), nbins,lowbound,highbound);
165 m_h_pedMissingChannels->GetXaxis()->SetTitle(xaxis.c_str());
166 m_h_pedMissingChannels->GetYaxis()->SetTitle(yaxis.c_str());
168 monGroup.regHist(m_h_pedMissingChannels).ignore();
169
170 //Set naming parameters for datatypes
171 std::string pedDataName = "ped";
172 std::string pedDataTitle = "Pedestals";
173 std::string pedSubDir = "Ped";
174
175 std::string noiseDataName = "noise";
176 std::string noiseDataTitle = "Noise (ped sigma)";
177 std::string noiseSubDir = "Noise";
178
179 std::string chi2DataName = "chi2";
180 std::string chi2DataTitle = "Chi^2/ndf for Pedestal Gaussian Fit";
181 std::string chi2SubDir = "Chi2";
182
183 std::string rmsDataName = "rms";
184 std::string rmsDataTitle = "RMS from gaussian distribution";
185 std::string rmsSubDir = "RMS";
186
187 std::string f001DataName = "f001";
188 std::string f001DataTitle = "F001";
189 std::string f001SubDir = "F001";
190
191 std::string onlTHoldBreachDataName = "onlTHoldBreach";
192 std::string onlTHoldBreachDataTitle = "Online Threshold Breaches";
193 std::string onlTHoldBreachSubDir = "OnlTHoldBreaches";
194
195 std::string nEntriesDataName = "nEntries";
196 std::string nEntriesDataTitle = "Number of Entries from Pedestal Amplitude Hist";
197 std::string nEntriesSubDir = "NumEntries";
198
199 std::string maxBitCorrDataName = "maxBitCorr";
200 std::string maxBitCorrDataTitle = "Maximimum Bit Correlation";
201 std::string maxBitCorrSubDir = "MaxBitCorr";
202
203
204 //Set naming parameters for histogram category names
205 std::string newCatName = "new";
206 std::string newCatTitle = "New";
207
208 std::string oldCatName = "old";
209 std::string oldCatTitle = "COOL";
210
211 std::string diffCatName = "diff";
212 std::string diffCatTitle = "Change of ";
213
214 //axis info
215 std::string pedAxisLabel = "Pedestal Mean (ADC counts)";
216 std::string pedDiffAxisLabel = "Pedestal Difference (ADC counts)";
217 int pedNumBins =300;
218 float pedLowBound = 1900;
219 float pedHighBound = 2200;
220
221 std::string noiseAxisLabel = "Pedestal Noise (ADC counts)";
222 std::string noiseDiffAxisLabel = "Noise Difference (ADC counts)";
223 int noiseNumBins = 300;
224 float noiseLowBound = 0;
225 float noiseHighBound = 30;
226
227 std::string chi2AxisLabel = "Chi^2/ndf";
228 int chi2NumBins = 500;
229 float chi2LowBound = 0;
230 float chi2HighBound = 500;
231
232 std::string rmsAxisLabel = "RMS (ADC Counts)";
233 std::string rmsDiffAxisLabel = "RMS Difference (ADC Counts)";
234 int rmsNumBins = 300;
235 float rmsLowBound =0;
236 float rmsHighBound = 30;
237
238 std::string f001AxisLabel = "F001 (ADC)";
239 std::string f001DiffAxisLabel = "F001 Difference (ADC)";
240 int f001NumBins = 350;
241 float f001LowBound =1950;
242 float f001HighBound = 2300;
243
244 std::string nEntriesAxisLabel = "Number of Entries";
245 int nEntriesNumBins = 20;
246 float nEntriesLowBound = 0;
247 float nEntriesHighBound = 10000;
248 uint16_t nEntriesHistMask = 0x3F; //only do overall spectra and 2d view
249
250 std::string maxBitCorrAxisLabel = "Correlation";
251 int maxBitCorrNumBins = 300;
252 float maxBitCorrLowBound = -3;
253 float maxBitCorrHighBound = 3;
254 //Subdirectory this will be stored in:
255
256 //Initialize histogram collections
257 //Each colleciton contains all of the "views" for one particular set of data
258 m_pedNewColl = new HistCollection(m_maxHashId +1, m_maxHashId +1); //New Pedestals
259 m_pedOldColl = new HistCollection(m_maxHashId +1); //Last pedestals
260 m_pedDiffColl = new HistCollection(m_maxHashId +1); //Difference
261
265
267
271
275
277
279
280
282
285
286
287 //initialize, name, and book histograms in histogram collections:
288
289 ATH_MSG_DEBUG( "Registering pedNewColl" );
290 ATH_CHECK( bookHistCollection(m_pedNewColl, pedDataName, pedDataTitle, newCatName, newCatTitle,
291 pedAxisLabel, pedNumBins, pedLowBound, pedHighBound, pedSubDir) );
292
293 ATH_MSG_DEBUG( "Registering pedOldColl" );
294 ATH_CHECK( bookHistCollection(m_pedOldColl, pedDataName, pedDataTitle, oldCatName, oldCatTitle,
295 pedAxisLabel, pedNumBins, pedLowBound, pedHighBound, pedSubDir) );
296
297 ATH_MSG_DEBUG( "Registering pedDiffColl" );
298 ATH_CHECK( bookHistCollection(m_pedDiffColl, pedDataName, pedDataTitle, diffCatName, diffCatTitle,
299 pedDiffAxisLabel, 100, -2, 2, pedSubDir) );
300
301 ATH_MSG_DEBUG( "Registering noiseNewColl" );
302 ATH_CHECK( bookHistCollection(m_noiseNewColl, noiseDataName, noiseDataTitle, newCatName,
303 newCatTitle, noiseAxisLabel, noiseNumBins, noiseLowBound, noiseHighBound, noiseSubDir) );
304
305 ATH_MSG_DEBUG( "Registering noiseOldColl" );
306 ATH_CHECK( bookHistCollection(m_noiseOldColl, noiseDataName, noiseDataTitle, oldCatName,
307 oldCatTitle, noiseAxisLabel, 100, -2, 2, noiseSubDir) );
308
309 ATH_MSG_DEBUG( "Registering noiseDiffColl" );
310 ATH_CHECK( bookHistCollection(m_noiseDiffColl, noiseDataName, noiseDataTitle, diffCatName,
311 diffCatTitle, noiseDiffAxisLabel, noiseNumBins, -1*noiseHighBound, noiseHighBound,noiseSubDir) );
312
313 ATH_MSG_DEBUG( "Registering rmsNewColl" );
314 ATH_CHECK( bookHistCollection(m_rmsNewColl, rmsDataName, rmsDataTitle, newCatName,
315 newCatTitle, rmsAxisLabel, rmsNumBins, rmsLowBound, rmsHighBound, rmsSubDir) );
316
317 ATH_MSG_DEBUG( "Registering rmsOldColl" );
318 ATH_CHECK( bookHistCollection(m_rmsOldColl, rmsDataName, rmsDataTitle, oldCatName,
319 oldCatTitle, rmsAxisLabel, rmsNumBins, rmsLowBound, rmsHighBound, rmsSubDir) );
320
321 ATH_MSG_DEBUG( "Registering rmsDiffColl" );
322 ATH_CHECK( bookHistCollection(m_rmsDiffColl, rmsDataName, rmsDataTitle, diffCatName,
323 diffCatTitle, rmsDiffAxisLabel, rmsNumBins, -1*rmsHighBound, rmsHighBound,rmsSubDir) );
324
325 ATH_MSG_DEBUG( "Registering f001NewColl" );
326 ATH_CHECK( bookHistCollection(m_f001NewColl, f001DataName, f001DataTitle, newCatName,
327 newCatTitle, f001AxisLabel, f001NumBins, f001LowBound, f001HighBound, f001SubDir) );
328
329 ATH_MSG_DEBUG( "Registering f001OldColl" );
330 ATH_CHECK( bookHistCollection(m_f001OldColl, f001DataName, f001DataTitle, oldCatName,
331 oldCatTitle, f001AxisLabel, 100, -2, 2, f001SubDir) );
332
333 ATH_MSG_DEBUG( "Registering f001DiffColl" );
334 ATH_CHECK( bookHistCollection(m_f001DiffColl, f001DataName, f001DataTitle, diffCatName,
335 diffCatTitle, f001DiffAxisLabel, 60, -30, 30, f001SubDir) );
336
337 ATH_MSG_DEBUG( "Registering onlTHoldBreachColl" );
338 ATH_CHECK( bookHistCollection(m_onlTHoldBreachColl, onlTHoldBreachDataName, onlTHoldBreachDataTitle, "",
339 "" , "Number of Online THold Breachs", 100, 0, 1000, onlTHoldBreachSubDir) );
340
341 ATH_MSG_DEBUG( "Registering Num Entries" );
342 ATH_CHECK( bookHistCollection(m_nEntriesColl, nEntriesDataName, nEntriesDataTitle, "",
343 "", nEntriesAxisLabel, nEntriesNumBins, nEntriesLowBound, nEntriesHighBound, nEntriesSubDir, nEntriesHistMask) );
344
345 ATH_CHECK( bookHistCollection(m_chi2Coll, chi2DataName, chi2DataTitle, "", "",
346 chi2AxisLabel, chi2NumBins, chi2LowBound, chi2HighBound, chi2SubDir) );
347
348 ATH_CHECK( bookHistCollection(m_tholdDiffColl, "thold", "Threshold", diffCatName, diffCatTitle, "#Delta{}Threshold", 500, -10, 10, "THold") );
349
351 ATH_CHECK( bookHistCollection(m_maxBitCorrColl, maxBitCorrDataName, maxBitCorrDataTitle,
352 "", "", maxBitCorrAxisLabel, maxBitCorrNumBins, maxBitCorrLowBound,
353 maxBitCorrHighBound, maxBitCorrSubDir) );
354 }
355 }//end if newRun
356
357 return StatusCode::SUCCESS;
358}//end bookHistograms
#define ATH_CHECK
Evaluate an expression and check for errors.
DataVector< MonGroup > * m_monGroupVec
Keeps track of MonGroups.
virtual StatusCode bookHistCollection(HistCollection *histCollection, const std::string &dataTypeName, const std::string &dataTypeTitle, const std::string &categoryName, const std::string &categoryTitle, const std::string &axisLabel, int numBins, float lowBound, float highBound, const std::string &parDir="", uint16_t toSkip=0)
Initializes the histograms in a histCollection and books them.
virtual StatusCode bookHistograms()
Standard function for a ManagedMonitorToolBase.
setWord1 uint16_t
Contains an array with data on a per-channel basis, as well as various histograms that give different...

◆ bookHistogramsRecurrent()

StatusCode ManagedMonitorToolBase::bookHistogramsRecurrent ( )
virtualinherited

An inheriting class should either override this function, bookHists() or bookHistograms().

Reimplemented in ManagedMonitorToolTest, MdtVsRpcRawDataValAlg, and MdtVsTgcRawDataValAlg.

Definition at line 1285 of file ManagedMonitorToolBase.cxx.

1287{
1288 if( m_newEventsBlock ) { }
1289 if( m_newLumiBlock ) { }
1290 if( m_newRun ) { }
1291
1292 return StatusCode::SUCCESS;
1293}

◆ bookHists()

StatusCode ManagedMonitorToolBase::bookHists ( )
virtualinherited

Calls bookHists( true, true, true ) and initializes lumiBlock and run numbers.

Implements IMonitorToolBase.

Definition at line 730 of file ManagedMonitorToolBase.cxx.

732{
733 // The Run/LumiBlock numbers are not set when beginRun() is called. Therefore,
734 // book histograms on the first call to fillHists(), which is called from execute().
735 return StatusCode::SUCCESS;
736}

◆ bookLayHists()

StatusCode CscCalibMonToolBase::bookLayHists ( const std::string & histTypeDir,
const std::string & parTypeDir,
std::vector< TH1F * > & vector,
const std::string & namePrefix,
const std::string & titlePrefix,
const std::string & xaxis,
const std::string & yaxis,
bool chanView = true,
bool ignoreY = false,
unsigned int numBins = 100,
float lowBound = 0,
float highbound = 100 )
protectedvirtualinherited

Books a vector of histograms where each one corresponds to a layer of the CSC secbers.

Parameters
histTypeDirThe subdirectory where the histogram type should be stored (e.g "layerOverview")
parTypeDirThe subdirectory where the parameter type (e.g ped, noise,etc)
namePrefixSomething to put in front of the name. Rest is based on layer.
titlePrefixString to append to the front of the title. Rest is based on layer.
xaxisTitle for x-axis.
yaxisTitle for y-axis.
chanViewIf true, x-axis num-bins will be number of channels of a given layer. numbins, highBound, and lowBound will be ignored.
ignoreYDo not initialize histograms from the transverse direction.
numBinsnumber of bins for each histoto
lowBoundlower bound for histogram x-axis
highBoundhigher bound for histogram x-axis

Definition at line 431 of file CscCalibMonToolBase.cxx.

436{
437 //Book a set of histograms, one for each layer.
438 //chanView = true ignores numBins and bounds and makes x-axis based on channel ids
439 //ignore Y = true skips transverse direction strips
440
441 //unsigned int numStrips;
442 int stationSize, stationPhi, stationEta, sector;
443 std::string stationName;
444 std::string orientationName = "prec";
445 std::string orientationTitle = "Precision Direction";
446
447 int numHists = 32 * ( (ignoreY) ? 4 : 8);
448 histVector.resize(numHists,nullptr);
449
450 ATH_MSG_DEBUG( "Allocated space for " << numHists << " histograms" );
451
452 const std::vector<Identifier> & ids = m_idHelperSvc->cscIdHelper().idVector();
453 for(const auto & thisChamberId:ids)
454 {
455 IdentifierHash chamHash;
456 m_idHelperSvc->cscIdHelper().get_module_hash(thisChamberId,chamHash);
457 ATH_MSG_DEBUG( "Booking histograms for chamber with hash " << (int)chamHash );
458
459 stationSize = m_idHelperSvc->cscIdHelper().stationName(thisChamberId);
460 stationName = m_idHelperSvc->cscIdHelper().stationNameString(stationSize);
461 stationPhi = m_idHelperSvc->cscIdHelper().stationPhi(thisChamberId);
462 stationEta = m_idHelperSvc->cscIdHelper().stationEta(thisChamberId);
463 sector = getSector(stationPhi,stationSize);
464 for(unsigned int orientationItr = 0; orientationItr < 2; orientationItr++)
465 {
466 if(orientationItr ==1)
467 {
468 if(ignoreY) //skip non precision strips
469 continue;
470 if(chanView) //Base bin labels on orientation
471 {
472 numBins = 48;
473 highBound = 49;
474 lowBound = 1;
475 }
476 orientationName = "trans";
477 orientationTitle = "Transverse Direction";
478 }
479 else
480 {
481 if(chanView)
482 {
483 numBins = 192;
484 highBound = 193;
485 lowBound = 1;
486 }
487 orientationName = "prec";
488 orientationTitle = "Precision Direction";
489 }
490
491 for(unsigned int layItr = 1; layItr <= 4; layItr++)
492 {
493 ATH_MSG_VERBOSE( "Storing a hist on orientation " << orientationItr
494 << " With highbound/lowbound/nbins "
495 << highBound << "/" << lowBound << "/" << numBins );
496
497 std::stringstream nameStream;
498 nameStream.setf(std::ios::right, std::ios::adjustfield);
499 nameStream << namePrefix;
500 nameStream << "_" << orientationName << "_eta_";
501 nameStream << ((stationEta == 1) ? "1" : "0");
502 nameStream << "_sector_" << std::setw(2) << std::setfill('0') << sector;
503 nameStream << "_layer_" << layItr;
504
505 std::stringstream titleStream;
506 titleStream << titlePrefix << ", " << orientationTitle;
507 titleStream << ", Sector " << sector;
508 titleStream <<", Eta " << stationEta;
509 titleStream << ", Layer " << layItr;
510
511 ATH_MSG_VERBOSE( "Storing " << nameStream.str() << " with title "
512 << titleStream.str() << "On orientation " << orientationItr << " With highbound/lowbound/nbins " << highBound << "/" << lowBound << "/" << numBins );
513
514 TH1F* hist = new TH1F(nameStream.str().c_str(), titleStream.str().c_str(),
515 numBins, lowBound, highBound);
516 hist->GetXaxis()->SetTitle(xaxis.c_str());
517 hist->GetYaxis()->SetTitle(yaxis.c_str());
518 hist->SetFillColor(m_histCol);
519
520 int layIndex = getLayIndex(orientationItr,stationEta,sector,layItr);
521
522 //Lets
523 std::string geoPath = getGeoPath(stationEta, sector, layItr, orientationItr);
524 std::string path = getFullPath(geoPath, histTypeDir, parDir);
525 MonGroup monGroup( this, path ,run, ATTRIB_MANAGED);
526
527
528 if(!monGroup.regHist(hist).isSuccess())
529 {
530 ATH_MSG_FATAL( "Failed to register " << nameStream.str()
531 << " with layIndex" << layIndex );
532 return StatusCode::FAILURE;
533 }
534 else
535 {
536 ATH_MSG_DEBUG( "Succesfully registered histogram with layIndex "
537 << layIndex <<" and name " << hist->GetName() );
538 histVector[layIndex] = hist;
539 }
540 }//end layer loop
541 }//End orientation loop
542 }//End chamber loop
543 return StatusCode::SUCCESS;
544}//end bookLayHists
#define ATH_MSG_FATAL(x)
#define ATH_MSG_VERBOSE(x)
virtual int getLayIndex(int measuresPhi, int stationEta, int sector, int layer)
produces a unique number for every layer in the detector

◆ checkHists()

StatusCode CscCalibMonToolBase::checkHists ( bool fromFinalise)
virtualinherited

Standard function for a ManagedMonitorToolBase.

Not used. Just expected to be here

Reimplemented from ManagedMonitorToolBase.

Definition at line 745 of file CscCalibMonToolBase.cxx.

746{
747
748 ATH_MSG_DEBUG( "CscCalibMonToolBase : in checkHists()" );
749
750 return StatusCode::SUCCESS;
751}

◆ copyDataToHists()

StatusCode CscCalibMonToolBase::copyDataToHists ( HistCollection * histCollection)
protectedvirtualinherited

Fills the histograms in the histCollection based on the data in the std::vector in the HistCollection.

Definition at line 890 of file CscCalibMonToolBase.cxx.

891{
892
893 //Determine what histograms we'll make:
894 bool doSpec = true; //(histCollection->cscSpec != NULL);
895 bool doHash = (histCollection->hashHist != nullptr && m_makeHashHists);
896 bool doAllChan1d = (histCollection->allChan1dHistX != nullptr && histCollection->allChan1dHistY != nullptr && m_makeAllChan1dHists);
897 bool doAllChan2d = (histCollection->allChan2dHist != nullptr && m_makeAllChan2dHists);
898 bool doLayChan = (!histCollection->layHistVect.empty() && m_makeLayHists);
899 bool doLaySummary = (!histCollection->laySummVect.empty() && m_makeLaySummHists);
900 bool doChamAvg = (histCollection->chamProf != nullptr && m_makeChamProfs);
901 bool doChamChan = (!histCollection->chamSummVect.empty() && m_makeChamHists);
902 bool doChamSummary = (!histCollection->chamSummVect.empty() && m_makeChamSummHists);
903 bool doErrors = (histCollection->errors.size() != 0); //Changed to a vector, so this
904 // is best way to check at moment
905
906 ATH_MSG_DEBUG( "Copying data to hist collection, doing: All Channels (hash view):"
907 << (int)doHash
908 << "All Channels (1d view) " << (int)doHash
909 << "All Channels (2d view) " << (int)doHash
910 << " layer overview " << (int)doLayChan
911 << " layer spectrum " << (int)doLaySummary
912 << " sector prof " << (int)doChamAvg
913 << " chamber overview " << (int)doChamChan
914 << " chamber spectrum " << (int)doChamSummary
915 );
916
917 //For shorter lines:
918 std::vector<float> & data = histCollection->data;
919 std::vector<float> & errors = histCollection->errors;
920
921 //Loop through all channels, and copy relevant data from channel to histogram.
922 const std::vector<Identifier> & ids = m_idHelperSvc->cscIdHelper().idVector();
923 for(const auto & thisChamberId:ids)
924 {
925 IdentifierHash chamHash;
926 m_idHelperSvc->cscIdHelper().get_module_hash(thisChamberId,chamHash);
927 ATH_MSG_DEBUG( "Copying data to histograms for chamber with hash" << (int)chamHash );
928
929 unsigned int stationSize = m_idHelperSvc->cscIdHelper().stationName(thisChamberId); //51 = large, 50 = small
930
931 unsigned int stationPhi = m_idHelperSvc->cscIdHelper().stationPhi(thisChamberId);
932 int stationEta = m_idHelperSvc->cscIdHelper().stationEta(thisChamberId);
933 unsigned int sector = getSector(stationPhi,stationSize);
934 int sectorIndex = sector * stationEta; //Histogram will go from -16 to +16. Bin 0 ignored.
935
936
937
938 std::vector<Identifier> stripVect;
939 m_idHelperSvc->cscIdHelper().idChannels(thisChamberId,stripVect);
940
941 for(const auto & thisStrip:stripVect)
942 {
943 unsigned int chamberLayer = m_idHelperSvc->cscIdHelper().chamberLayer(thisStrip);
944 if(chamberLayer != 2)
945 continue;
946 int measuresPhi = m_idHelperSvc->cscIdHelper().measuresPhi(thisStrip);
947 if(histCollection->ignoreY && measuresPhi)
948 continue;
949
950 IdentifierHash stripHash;
951 m_idHelperSvc->cscIdHelper().get_channel_hash(thisStrip,stripHash);
952 unsigned int layer = m_idHelperSvc->cscIdHelper().wireLayer(thisStrip);
953 unsigned int strip = m_idHelperSvc->cscIdHelper().strip(thisStrip);
954 float secLayer = (((float)stationEta*sector) + 0.2 * ((float)layer - 1) + 0.1);
955 float datum = data.at(stripHash);
956
957 ATH_MSG_VERBOSE( "Filling all chan for sector: " << sector
958 << "\tlayer: " << layer << "\tstationEta: " << stationEta
959 << "\tsecLayer: " << secLayer
960 << "\tdata: " << datum );
961
962 if(doSpec) {
963 histCollection->cscSpec[measuresPhi]->Fill(datum);
964 }
965 if(doHash)
966 {
967 //copy data array directly to hash histogram with all channels
968 histCollection->hashHist->Fill(stripHash,datum);
969 }
970
971 if(doAllChan1d)
972 {
973 ATH_MSG_VERBOSE( "Filling 1d chan for sector: " << sector
974 << "\tlayer: " << layer << "\tstationEta: " << stationEta
975 << "\tsecLayer: " << secLayer
976 << "\tdata: " << datum );
977 if(measuresPhi){
978
979 double modifiedStripNum =
980 (stationEta *sector)
981 + (layer-1)*.25
982 + ((strip-1) * .25 /(48))
983 ;
984
985 ATH_MSG_VERBOSE( "Modified strip num: " << modifiedStripNum );
986 //copy data array directly to 1d histogram with all channels
987 histCollection->allChan1dHistY->Fill(
988 modifiedStripNum, datum);
989 } else {
990 double modifiedStripNum =
991 (stationEta *sector)
992 + (layer-1)*.25
993 + ((strip-1) * .25 /(192 ))
994 ;
995
996 //copy data array directly to 1d histogram with all channels
997 histCollection->allChan1dHistX->Fill(
998 modifiedStripNum, datum);
999 }
1000 }
1001
1002 if(doAllChan2d)
1003 {
1004 ATH_MSG_VERBOSE( "Filling 2d chan for sector: " << sector
1005 << "\tlayer: " << layer << "\tstationEta: " << stationEta
1006 << "\tsecLayer: " << secLayer
1007 << "\tdata: " << datum );
1008
1009 //copy data array directly to 2d histogram with all channels
1010 int modifiedStripNum = static_cast<int>(strip) * (measuresPhi ? -1 : 1);
1011 histCollection->allChan2dHist->Fill(
1012 modifiedStripNum, secLayer, std::abs(datum));
1013 }
1014
1015 int layIndex = getLayIndex(measuresPhi,stationEta,sector,layer);
1016 int chamIndex = getChamIndex(measuresPhi,stationEta,sector);
1017 if(doLayChan)
1018 {
1019 //Copy values from data array for this layer to layer histogram
1020 histCollection->layHistVect[layIndex]->SetBinContent(strip,datum);
1021 if(doErrors)
1022 histCollection->layHistVect[layIndex]->SetBinError(strip,errors.at(stripHash));
1023 }
1024 if(doLaySummary)
1025 {
1026 //Histogram values for this layer
1027 histCollection->laySummVect[layIndex]->Fill(datum);
1028
1029 }
1030 if(doChamAvg)
1031 {
1032 //Keeps track of average value for each chamber.
1033 histCollection->chamProf->Fill(sectorIndex,datum);
1034 }
1035 if(doChamSummary)
1036 {
1037 //histogram values for this chamber
1038 histCollection->chamSummVect[chamIndex]->Fill(datum);
1039 }
1040 if(doChamChan)
1041 {
1042 int shiftedStrip = strip + (layer-1)*( measuresPhi ? 50 : 200);
1043 //Copy values from data array for this chamber to chamber histogram
1044 histCollection->chamHistVect[chamIndex]->SetBinContent(shiftedStrip,datum);
1045 if(doErrors)
1046 histCollection->chamHistVect[chamIndex]->SetBinError(shiftedStrip,errors.at(stripHash));
1047 }
1048 }//end strip loop
1049 }//end chamber loop
1050
1051 //probably should put this in its own function at some point
1052
1053 return StatusCode::SUCCESS;
1054}
char data[hepevt_bytes_allocation_ATLAS]
Definition HepEvt.cxx:11
@ layer
Definition HitInfo.h:79

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T, V, H > & hndl,
const SG::VarHandleKeyType &  )
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }

◆ declareProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( Gaudi::Property< T, V, H > & t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ deregGraph()

StatusCode ManagedMonitorToolBase::deregGraph ( TGraph * g)
virtualinherited

De-registers a TGraph from the THistSvc, but does NOT delete the object.

Definition at line 1624 of file ManagedMonitorToolBase.cxx.

1626{
1627 return m_THistSvc->deReg( g );
1628}
ServiceHandle< ITHistSvc > m_THistSvc

◆ deregHist()

StatusCode ManagedMonitorToolBase::deregHist ( TH1 * h)
virtualinherited

De-registers a TH1 from the THistSvc, but does NOT delete the object.

Definition at line 1616 of file ManagedMonitorToolBase.cxx.

1618{
1619 return m_THistSvc->deReg( h );
1620}

◆ deregObject() [1/2]

StatusCode ManagedMonitorToolBase::deregObject ( const std::string & objName,
const MonGroup & group )
virtualinherited

De-registers a TObject from the THistSvc, but does NOT delete the object.

(NB: LightWeight histograms are not even registered until readout).

Definition at line 1642 of file ManagedMonitorToolBase.cxx.

1644{
1645 std::string streamName = streamNameFunction()->getStreamName( this, group, objName );
1646 return m_THistSvc->deReg( streamName );
1647}
virtual std::string getStreamName(const ManagedMonitorToolBase *tool, const MonGroup &group, const std::string &objName, bool usePreviousInterval=false)=0
A function that converts a MonGroup of logical parameters into a physical output stream name.
virtual StreamNameFcn * streamNameFunction()
Returns the function object that converts logical paramters into a physical stream name.

◆ deregObject() [2/2]

StatusCode ManagedMonitorToolBase::deregObject ( const std::string & objName,
const std::string & system,
Interval_t interval )
virtualinherited

De-registers a TObject from the THistSvc, but does NOT delete the object.

(NB: LightWeight histograms are not even registered until readout).

Definition at line 1632 of file ManagedMonitorToolBase.cxx.

1635{
1636 MonGroup group( this, system, interval );
1637 return deregObject( objName, group );
1638}
virtual StatusCode deregObject(const std::string &objName, const std::string &system, Interval_t interval)
De-registers a TObject from the THistSvc, but does NOT delete the object.

◆ detStore()

const ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< AlgTool > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

◆ endOfEventsBlockFlag()

bool ManagedMonitorToolBase::endOfEventsBlockFlag ( ) const
inlineprotectedinherited

Definition at line 795 of file ManagedMonitorToolBase.h.

◆ endOfLowStatFlag()

bool ManagedMonitorToolBase::endOfLowStatFlag ( ) const
inlineprotectedinherited

Definition at line 796 of file ManagedMonitorToolBase.h.

◆ endOfLumiBlockFlag()

bool ManagedMonitorToolBase::endOfLumiBlockFlag ( ) const
inlineprotectedinherited

Definition at line 797 of file ManagedMonitorToolBase.h.

◆ endOfRunFlag()

bool ManagedMonitorToolBase::endOfRunFlag ( ) const
inlineprotectedinherited

Definition at line 798 of file ManagedMonitorToolBase.h.

◆ evtStore()

ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase & ExtraDeps)
protectedinherited

Add StoreName to extra input/output deps as needed.

use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given

◆ fillHistograms()

StatusCode CscCalibMonToolBase::fillHistograms ( const EventContext & ctx)
virtualinherited

Standard function for a ManagedMonitorToolBase.

Not used. For most ManagedMonitorToolBase classes, this would do event-by-event filling of histograms. However we let algorithms in CscCalibAlgs do this for us.

Reimplemented from ManagedMonitorToolBase.

Definition at line 700 of file CscCalibMonToolBase.cxx.

701{
702
703 ATH_MSG_DEBUG( "CscCalibMonToolBase :: in fillHistograms()" );
704
705 return StatusCode::SUCCESS;
706}//end fillHistograms

◆ fillHists()

StatusCode ManagedMonitorToolBase::fillHists ( const EventContext & ctx)
virtualinherited

Calls fillHists( bool, bool, bool ); if an eventBlock,lumiBlock, or run has turned over, calls procHists( bool, bool, bool ) and bookHists( bool, bool, bool ).

Implements IMonitorToolBase.

Definition at line 740 of file ManagedMonitorToolBase.cxx.

742{
743
744 if (m_d->m_warnAboutMissingInitialize) {
745 m_d->m_warnAboutMissingInitialize = false;
746 msg(MSG::WARNING) << "ManagedMonitorToolBase::initialize() never called from reimplementation!" << endmsg;
747 }
748
749
750 bool isNewEventsBlock = ( m_procNEventsProp > 0 && ((m_nEvents % m_procNEventsProp) == 1) && m_haveClearedLastEventBlock );
751 if (isNewEventsBlock) m_haveClearedLastEventBlock = false;
752
753 m_newLowStat = false;
754 m_newLumiBlock = false;
755 m_newRun = false;
756 newLowStat = false;
757 newLumiBlock = false;
758 newRun = false;
759
760 m_newLowStatInterval = false;
761 m_newMedStatInterval = false;
762 m_newHigStatInterval = false;
763 newLowStatInterval = false;
764 newMedStatInterval = false;
765 newHigStatInterval = false;
766
767 m_useTrigger = ( (m_triggerChainProp != "" || m_triggerGroupProp != "") && (!m_trigDecTool.empty()) );
768
769 if( m_manager != 0 ) {
770 m_newLumiBlock = ( (m_lastLumiBlock != m_manager->lumiBlockNumber()) || m_manager->forkedProcess());
771 m_newRun = ( m_lastRun != m_manager->runNumber() );
772 newLumiBlock = m_newLumiBlock;
773 newRun = m_newRun;
774
775 if(m_newRun) {
776 m_newLumiBlock = true;
777 newLumiBlock = m_newLumiBlock;
778 isNewEventsBlock = true;
779 }
780
781 m_newEventsBlock = isNewEventsBlock;
782 newEventsBlock = m_newEventsBlock;
783
784 if( m_newLumiBlock ) {
785 // check if a new LB interval has started
786 // lowest lumiBlockNumber() is 1
787 // m_lastLowStatInterval is -1 initially
788 int currentLB = m_manager->lumiBlockNumber();
789 int LBsLowStat = m_manager->getLBsLowStat();
790 int LBsMedStat = m_manager->getLBsMedStat();
791 int LBsHigStat = m_manager->getLBsHigStat();
792
793 if( LBsLowStat*LBsMedStat*LBsHigStat == 0) {
794 msg(MSG::WARNING) << "zero LBs requested for interval" << endmsg;
795 }
796 else {
797 if( ((currentLB-1)/LBsLowStat) != m_lastLowStatInterval ) m_newLowStatInterval = true;
798 if( ((currentLB-1)/LBsMedStat) != m_lastMedStatInterval ) m_newMedStatInterval = true;
799 if( ((currentLB-1)/LBsHigStat) != m_lastHigStatInterval ) m_newHigStatInterval = true;
800 newLowStatInterval = m_newLowStatInterval;
801 newMedStatInterval = m_newHigStatInterval;
802 newHigStatInterval = m_newHigStatInterval;
803 }
804 }
805
806 // Allow inheriting classes the option of using the lastLumiBloc/lastRun values
807 // before updating them
808 }
809
810
811 StatusCode sc0( StatusCode::SUCCESS );
812 StatusCode sc1( StatusCode::SUCCESS );
813 StatusCode sc2( StatusCode::SUCCESS );
814 StatusCode sc3( StatusCode::SUCCESS );
815
816 // Set end of LowStat, LumiBlock and Run variables
817 // These are needed to be used in procHistograms().
822 endOfEventsBlock = m_newEventsBlock;
823 endOfLowStat = m_newLowStatInterval;
824 endOfLumiBlock = m_newLumiBlock;
826
827 // just duplicates m_newLowStatInterval
829 newLowStat = m_newLowStatInterval;
830
832 ATH_MSG_DEBUG("Interval transition processing");
833 // Process histograms from the previous lumiBlock/run
834 if( m_nEvents != 1 ) {
835 m_d->benchPreProcHistograms();
836 sc0 = procHistograms();
837 m_d->benchPostProcHistograms();
838 }
839 // Re-book new histograms
840 m_d->benchPreBookHistograms();
841
843 sc1 = bookHistograms();
845 } else {
846 std::vector<Interval_t> intervals_to_process;
847 if (m_newEventsBlock) intervals_to_process.push_back(eventsBlock);
848 if (m_newLumiBlock) intervals_to_process.push_back(lumiBlock);
849 if (m_newLowStatInterval) intervals_to_process.push_back(lowStat);
850 if (m_newRun) intervals_to_process.push_back(run);
851 for (const auto interval: intervals_to_process) {
853 sc1 = regManagedGraphs(m_templateGraphs[interval]);
854 sc1 = regManagedTrees(m_templateTrees[interval]);
855 }
856 }
857 for (const auto& interval: std::vector<Interval_t>{ eventsBlock, lumiBlock, lowStat, run }) {
858 for (const auto& it: m_templateHistograms[interval]) {
859 // is histogram too small in x axis for LB range?
860 if (it.m_group.histo_mgmt() == ATTRIB_X_VS_LB) {
861 //ATH_MSG_WARNING("We are rebinning for " << it.m_templateHist->GetName());
862 while ( it.m_templateHist->GetXaxis()->GetXmax() <= AthenaMonManager::lumiBlockNumber() ) {
863 it.m_templateHist->LabelsInflate("X");
864 }
865 }
866 }
867 for (auto& it: m_templateEfficiencies[interval]) {
868 if (it.m_group.histo_mgmt() == ATTRIB_X_VS_LB) {
869 // get the underlying passed and total TH1's from the TEfficiency
870 TH1* passedHist = it.m_templateHist->GetCopyPassedHisto();
871 TH1* totalHist = it.m_templateHist->GetCopyTotalHisto();
872 // inflate them until they exceed the lumi-block number
873 while (passedHist->GetXaxis()->GetXmax() <= AthenaMonManager::lumiBlockNumber() ) {
874 passedHist->LabelsInflate("X");
875 totalHist->LabelsInflate("X");
876 }
877 // Replace them in the TEfficiency. First one has force ("f") option, since the
878 // histograms will not be consistent. This is corrected in the next line, so we
879 // do check for consistency then.
880 it.m_templateHist->SetPassedHistogram(*passedHist, "f");
881 it.m_templateHist->SetTotalHistogram(*totalHist, " ");
882 delete passedHist; // not owned by THistSvc, so need to be deleted.
883 delete totalHist;
884 }
885 }
886 }
887
888 if (auto streamname = dynamic_cast<OfflineStream*>(streamNameFunction())) {
889 streamname->updateRunLB();
890 }
891
893
894 m_d->benchPostBookHistograms();
895
896 }//end if new RUN/LB/Block
897
898 // check filters
899 bool filterresult(true);
900 if (! m_DQFilterTools.empty()) {
901 ToolHandleArray<IDQFilterTool>::const_iterator ifilter(m_DQFilterTools.begin()), filterend(m_DQFilterTools.end());
902 for (; filterresult && (ifilter != filterend);
903 ++ifilter) {
904 filterresult = (filterresult && (*ifilter)->accept(ctx));
905 }
906 }
907
908
909 // ...and fill as normal
910 if(filterresult &&
914 ATH_MSG_DEBUG("Passed trigger, presumably");
915 m_d->benchPreFillHistograms();
916 fillHistograms(ctx).ignore();
918 m_d->benchPostFillHistograms();
919 ++m_nEvents;
920 } else { ATH_MSG_DEBUG("Failed trigger, presumably"); }
921
923 if( m_newLumiBlock && (m_nEventsIgnoreTrigger != 1) ) {
925 }
926 if( m_manager != 0 ) {
927 m_lastRun = m_manager->runNumber();
928 if( m_newLumiBlock ) {
929 m_lastLumiBlock = m_manager->lumiBlockNumber();
930
931 int LBsLowStat = m_manager->getLBsLowStat();
932 int LBsMedStat = m_manager->getLBsMedStat();
933 int LBsHigStat = m_manager->getLBsHigStat();
934 if( LBsLowStat*LBsMedStat*LBsHigStat > 0) {
938 }
939 }
940 }
941
942 return StatusCode::SUCCESS;
943}
#define endmsg
MsgStream & msg() const
static unsigned int lumiBlockNumber()
StatusCode regManagedTrees(std::vector< MgmtParams< TTree > > &templateTrees)
ToolHandleArray< IDQFilterTool > m_DQFilterTools
virtual StatusCode fillHistograms(const EventContext &ctx)
An inheriting class should either override this function or fillHists().
virtual StatusCode bookHistogramsRecurrent()
An inheriting class should either override this function, bookHists() or bookHistograms().
std::vector< std::string > m_vTrigGroupNames
std::map< Interval_t, std::vector< MgmtParams< TH1 > > > m_templateHistograms
PublicToolHandle< Trig::ITrigDecisionTool > m_trigDecTool
StatusCode regManagedGraphs(std::vector< MgmtParams< TGraph > > &templateGraphs)
std::map< Interval_t, std::vector< MgmtParams< TGraph > > > m_templateGraphs
virtual StatusCode bookHistograms()
An inheriting class should either override this function or bookHists().
std::vector< std::string > m_vTrigChainNames
std::map< Interval_t, std::vector< MgmtParams< TTree > > > m_templateTrees
std::map< Interval_t, std::vector< MgmtParams< TEfficiency > > > m_templateEfficiencies
virtual StatusCode procHistograms()
An inheriting class should either override this function or finalHists().
StatusCode regManagedHistograms(std::vector< MgmtParams< TH1 > > &templateHistograms)
virtual bool trigChainsArePassed(std::vector< std::string > &)

◆ finalHists()

StatusCode ManagedMonitorToolBase::finalHists ( )
virtualinherited

Calls procHists( true, true, true ).

Implements IMonitorToolBase.

Definition at line 1255 of file ManagedMonitorToolBase.cxx.

1257{
1258
1259 // This assumes that the end of a file will naturally end a run, which is not always true.
1260 // A merging application run afterwards should be able to put parts of a run together.
1261 if( m_nEvents != 1 ) {
1262 m_d->benchPreProcHistograms();
1263
1264 // Set end flags for the LowStat, LumiBlock and Run variables.
1265 // This is needed to be used in the procHistograms method below.
1266 m_endOfEventsBlock = true;
1267 m_endOfLowStat = true;
1268 m_endOfLumiBlock = true;
1269 m_endOfRun = true;
1270 endOfEventsBlock = true;
1271 endOfLowStat = true;
1272 endOfLumiBlock = true;
1273 endOfRun = true;
1274
1276
1277 m_d->benchPostProcHistograms();
1278 return sc;
1279 }
1280 return StatusCode::SUCCESS;
1281}

◆ finalize()

StatusCode CscCalibMonToolPed::finalize ( )
virtual

finalize function.

Calls base class's finalize function.

Reimplemented from CscCalibMonToolBase.

Definition at line 89 of file CscCalibMonToolPed.cxx.

90{
91 delete m_pedNewColl;
92 delete m_pedOldColl;
93 delete m_pedDiffColl;
94 delete m_noiseNewColl;
95 delete m_noiseOldColl;
96 delete m_noiseDiffColl;
97 delete m_rmsNewColl;
98 delete m_rmsOldColl;
99 delete m_rmsDiffColl;
100 delete m_f001NewColl;
101 delete m_f001OldColl;
102 delete m_f001DiffColl;
103 delete m_chi2Coll;
104
106}
virtual StatusCode finalize()
deletes private members

◆ genThreshold()

void CscCalibMonToolPed::genThreshold ( HistCollection * pedColl,
HistCollection * noiseColl,
HistCollection * tholdColl,
float multiplier )
private

Definition at line 511 of file CscCalibMonToolPed.cxx.

511 {
512 for(unsigned int chanItr = 0 ; chanItr <= m_maxHashId; chanItr++) {
513 tholdColl->data[chanItr] = pedColl->data[chanItr] + multiplier*noiseColl->data[chanItr];
514 }
515}

◆ get_nEvents()

unsigned int ManagedMonitorToolBase::get_nEvents ( ) const
inlineprotectedinherited

Definition at line 693 of file ManagedMonitorToolBase.h.

693 {
694 return m_nEvents;
695 }

◆ get_procNEventsProp()

long ManagedMonitorToolBase::get_procNEventsProp ( ) const
inlineprotectedinherited

Definition at line 697 of file ManagedMonitorToolBase.h.

697 {
698 return m_procNEventsProp;
699 }

◆ getChamIndex()

int CscCalibMonToolBase::getChamIndex ( int measuresPhi,
int stationEta,
int sector )
protectedvirtualinherited

Produces a unique number for every secber in the detector.

Definition at line 1065 of file CscCalibMonToolBase.cxx.

1066{
1067 int chamIndex = measuresPhi*32
1068 + ((stationEta ==1) ? 16 : 0)
1069 + (sector-1);
1070 return( chamIndex);
1071}

◆ getEndCap()

std::string CscCalibMonToolBase::getEndCap ( int eta)
protectedinherited

Gets the letter endcap (A or C) for a given eta index (1,-1).

Definition at line 1085 of file CscCalibMonToolBase.cxx.

1086{
1087 if(eta ==1)
1088 return "A";
1089 if(eta == -1)
1090 return "C";
1091 return "ERROR";
1092}
Scalar eta() const
pseudorapidity method

◆ getFullPath()

std::string CscCalibMonToolBase::getFullPath ( const std::string & geoPath,
const std::string & histTypeDir,
const std::string & parTypeDir )
protectedinherited

Geo path creates a directory structure for a histogram based upon its geoPath, the hist type dir (spectrum of values, per-channel values, etc), and the parTypeDir (pedestal, etc).

This provides a centralized, consistent way of generating the paths

Definition at line 1185 of file CscCalibMonToolBase.cxx.

1186{
1187 std::stringstream ss;
1188
1190
1191 if(histTypeDir != "")
1192 ss << "/" << histTypeDir;
1193
1194 if(parTypeDir != "")
1195 ss << "/" << parTypeDir;
1196
1197 return ss.str();
1198}
static Double_t ss
std::string m_generic_path_csccalibmonitoring
Path of histograms.

◆ getGeoPath()

std::string CscCalibMonToolBase::getGeoPath ( int eta = -9999,
int sector = -9999,
int wireLayer = -9999,
int measuresPhi = -9999,
int channel = -9999 )
protectedinherited

getGeoPath creates a directory structure for a histogram based upon where it is in the CSC geometry.

The user fills the data down as far as they like. For example, just filling in eta and sector will provide a path for a sector-wide histogram. This provides a centralized location to change the layout of the root output file.

Definition at line 1098 of file CscCalibMonToolBase.cxx.

1099{
1100 std::stringstream ss;
1101
1102 static const std::string histStr = "/_hists";
1103 static const std::string errorDir = "/ERROR";
1104
1105 ss << std::setfill('0');//so we can have uniform numbers
1106
1107
1108 if( eta == -9999 ) //CSC Wide
1109 {
1110 ss << "/CscOverview";
1111 return ss.str();
1112 }
1113
1114 std::string endCap = getEndCap(eta);
1115 if(endCap == "ERROR")
1116 {
1117 ATH_MSG_ERROR( "Eta " << eta << " is invalid. " );
1118 return errorDir;
1119 }
1120
1121 ss << "/EndCap" << endCap;
1122
1123 if(sector == -9999) //Endcap Histogram
1124 {
1125 ss << histStr;
1126 return ss.str();
1127 }
1128
1129 if(sector <1 || sector > 16)
1130 {
1131 ATH_MSG_ERROR( "Sector " << sector << " is invalid. " );
1132 return errorDir;
1133 }
1134
1135 ss << "/Sector" << std::setw(2) << sector;
1136
1137 if(wireLayer == -9999)//Sector (chamber) wide histrogram
1138 {
1139 ss << histStr;
1140 return ss.str();
1141 }
1142
1143 if(wireLayer < 1 || wireLayer > 4)
1144 {
1145 ATH_MSG_ERROR( "WireLayer " << wireLayer << " is invalid." );
1146 return errorDir;
1147 }
1148
1149 ss << "/Layer" << wireLayer;
1150
1151 if(measuresPhi == -9999)//Layer wide histrogram
1152 {
1153 ss << histStr;
1154 return ss.str();
1155 }
1156
1157 if(measuresPhi < 0 || measuresPhi > 1)
1158 {
1159 ATH_MSG_ERROR( "MeasuresPhi " << measuresPhi << " is invalid." );
1160 return errorDir;
1161 }
1162
1163 ss << (measuresPhi ? "/Phi" : "/Eta");
1164 if(channel == -9999) //LayerDirection wide histogram
1165 {
1166 /* Channel histograms don't work (too much memory used by meta data tree), so layer is now our most detailed channel. No need for histStr.
1167 ss << histStr;*/
1168 return ss.str();
1169 }
1170
1171 if( channel < 1 || (measuresPhi && channel > 48) || (!measuresPhi && channel > 192))
1172 {
1173 ATH_MSG_ERROR( "Channel " << channel << " is invalid for a " << (measuresPhi ? "phi layers" : "eta layer") );
1174 return errorDir;
1175 }
1176
1177
1178 ss << "/Channel" << std::setw( measuresPhi ? 2 : 3 ) << channel;
1179
1180 return ss.str();
1181}//end getGeoPath
std::string getEndCap(int eta)
Gets the letter endcap (A or C) for a given eta index (1,-1).

◆ getHist() [1/4]

StatusCode ManagedMonitorToolBase::getHist ( TH1 *& h,
const std::string & hName,
const MonGroup & group )
virtualinherited

Returns a TH1 via the pointer passed as the first argument.

The histogram name, without the leading path or stream name, must be given as the second argument.

Definition at line 1418 of file ManagedMonitorToolBase.cxx.

1420{
1421 std::string streamName = streamNameFunction()->getStreamName( this, group, hName );
1422 return m_THistSvc->getHist( streamName, h );
1423}

◆ getHist() [2/4]

StatusCode ManagedMonitorToolBase::getHist ( TH1 *& h,
const std::string & hName,
const std::string & system,
Interval_t interval )
virtualinherited

Returns a TH1 via the pointer passed as the first argument.

The histogram name, without the leading path or stream name, must be given as the second argument.

Definition at line 1408 of file ManagedMonitorToolBase.cxx.

1411{
1412 MonGroup group( this, system, interval );
1413 return getHist( h, hName, group );
1414}
virtual StatusCode getHist(TH1 *&h, const std::string &hName, const std::string &system, Interval_t interval)
Returns a TH1 via the pointer passed as the first argument.

◆ getHist() [3/4]

StatusCode ManagedMonitorToolBase::getHist ( TH2 *& h,
const std::string & hName,
const MonGroup & group )
virtualinherited

Returns a TH2 via the pointer passed as the first argument.

The histogram name, without the leading path or stream name, must be given as the second argument.

Definition at line 1437 of file ManagedMonitorToolBase.cxx.

1439{
1440 std::string streamName = streamNameFunction()->getStreamName( this, group, hName );
1441 return m_THistSvc->getHist( streamName, h );
1442}

◆ getHist() [4/4]

StatusCode ManagedMonitorToolBase::getHist ( TH2 *& h,
const std::string & hName,
const std::string & system,
Interval_t interval )
virtualinherited

Returns a TH2 via the pointer passed as the first argument.

The histogram name, without the leading path or stream name, must be given as the second argument.

Definition at line 1427 of file ManagedMonitorToolBase.cxx.

1430{
1431 MonGroup group( this, system, interval );
1432 return getHist( h, hName, group );
1433}

◆ getLayIndex()

int CscCalibMonToolBase::getLayIndex ( int measuresPhi,
int stationEta,
int sector,
int layer )
protectedvirtualinherited

produces a unique number for every layer in the detector

Definition at line 1056 of file CscCalibMonToolBase.cxx.

1057{
1058 int layIndex = measuresPhi*32*4
1059 + ((stationEta ==1) ? 16*4 : 0)
1060 + (sector-1)*4
1061 + layer -1;
1062 return layIndex;
1063}

◆ getNewStreamNameFcn()

ManagedMonitorToolBase::StreamNameFcn * ManagedMonitorToolBase::getNewStreamNameFcn ( ) const
protectedvirtualinherited

Definition at line 2156 of file ManagedMonitorToolBase.cxx.

2158{
2159 StreamNameFcn* fcn(0);
2160
2161 switch( m_environment ) {
2163 fcn = new NoOutputStream();
2164 break;
2166 fcn = new OnlineStream();
2167 break;
2169 fcn = new DefaultStream( m_fileKey );
2170 break;
2176 default:
2178 }
2179
2180 return fcn;
2181}
A function-object base class allowing the specific implementation of getStreamName to be decided at r...
AthenaMonManager::Environment_t m_environment
AthenaMonManager::DataType_t m_dataType

◆ getSector()

int CscCalibMonToolBase::getSector ( int stationPhi,
int stationSize )
protectedvirtualinherited

Produces a sector number from the phi and size of a station.

Definition at line 1073 of file CscCalibMonToolBase.cxx.

1074{
1075 //stationSize : 50 = CSS, 51 = CSL
1076 //Sector 1 : large with athena's stationPhi = 1 (onlinePhi = 0)
1077 //Sector 2 : small with athenas stationPhi = 1 (onlinePhi = 0)
1078 //Sector 3 : large with athenas stationPhi = 2 (onlinePhi = 1)
1079 //etc...
1080 return(2*stationPhi + 50 - stationSize);
1081 //return(2*stationPhi + stationSize - 51);
1082}

◆ handleParameter()

StatusCode CscCalibMonToolPed::handleParameter ( const CscCalibResultCollection * parVals)
privatevirtual

handleParameter sets things up for the base class procParameter.

It makes decisions based on the parameter being passed in parVals on how to handle the data It then copies the arrays generated from procParameter to all the appropriate histograms

Parameters
parValsValues for a particular parameter

Reimplemented from CscCalibMonToolBase.

Definition at line 362 of file CscCalibMonToolPed.cxx.

363{
364 ATH_MSG_DEBUG( "CscCalibMonToolPed : in procParameter()" );
365
366 //The whole point of this funciton is to pass the correct histograms and setup info
367 //to CsccalibMonToolBase::procParameter. To organize this, we store the setup info into
368 //these structs:
369 ProcSetupInfo ProcParameterInput;
370
371
372 //--setup for this parameter
373 //We will specify :
374 //name of database parameter if we want to compare with datbase value
375 //otherwise we provide expeted value to compare with
376 //we also provide handles to all the arrays and values procParameter uses, such as the list
377 //of expected hash ids.
378 if(!parVals)
379 {
380 ATH_MSG_FATAL("Blank parval passed to handle parameter");
381 return StatusCode::FAILURE;
382 }
383 std::string parName = parVals->parName();
384 if(parName == "ped")
385 {
386 ProcParameterInput.dbName = parVals->parName();
387 ProcParameterInput.badHist = m_h_numBad;
388 ProcParameterInput.badBin = m_pedBadBin;
389 ProcParameterInput.maxDiff = m_pedMaxDiff;
390 ProcParameterInput.chi2BadBin = m_chi2BadBin;
391 ProcParameterInput.chi2Max = m_chi2Max;
392 ProcParameterInput.doChi2 = true;
393 ProcParameterInput.vals = &(m_pedNewColl->data);
394 ProcParameterInput.errors = &(m_pedNewColl->errors);
395 ProcParameterInput.oldVals =& (m_pedOldColl->data);
396 ProcParameterInput.diffs = &(m_pedDiffColl->data);
397 ProcParameterInput.chi2s = &(m_chi2Coll->data);
398 ProcParameterInput.expectedChannels = m_expectedHashIdsAll;
399 }
400 else if (parName == "noise")
401 {
402 ProcParameterInput.dbName = parVals->parName();
403 ProcParameterInput.badHist = m_h_numBad;
404 ProcParameterInput.badBin = m_noiseBadBin;
405 ProcParameterInput.maxDiff = m_noiseMaxDiff;
406 ProcParameterInput.missingBadBin = m_missingBadBin;
407 ProcParameterInput.missingChans = m_h_pedMissingChannels;
408 ProcParameterInput.doChi2 = false;
409 ProcParameterInput.vals = &(m_noiseNewColl->data);
410 ProcParameterInput.errors = &(m_noiseNewColl->errors);
411 ProcParameterInput.oldVals = &(m_noiseOldColl->data);
412 ProcParameterInput.diffs = &(m_noiseDiffColl->data);
413 ProcParameterInput.expectedChannels = m_expectedHashIdsAll;
414 }
415 else if (parName == "rms")
416 {
417 ProcParameterInput.dbName = parVals->parName();
418 ProcParameterInput.badHist = m_h_numBad;
419 ProcParameterInput.badBin = m_rmsBadBin;
420 ProcParameterInput.maxDiff = m_rmsMaxDiff;
421 ProcParameterInput.missingBadBin = m_missingBadBin;
422 ProcParameterInput.missingChans = m_h_pedMissingChannels;
423 ProcParameterInput.doChi2 = false;
424 ProcParameterInput.vals = &(m_rmsNewColl->data);
425 ProcParameterInput.errors = &(m_rmsNewColl->errors);
426 ProcParameterInput.oldVals = &(m_rmsOldColl->data);
427 ProcParameterInput.diffs = &(m_rmsDiffColl->data);
428 ProcParameterInput.expectedChannels = m_expectedHashIdsAll;
429 }
430 else if (parName == "f001")
431 {
432 ProcParameterInput.dbName = parVals->parName();
433 ProcParameterInput.badHist = m_h_numBad;
434 ProcParameterInput.badBin = m_f001BadBin;
435 ProcParameterInput.maxDiff = m_f001MaxDiff;
436 ProcParameterInput.missingBadBin = m_missingBadBin;
437 ProcParameterInput.missingChans = m_h_pedMissingChannels;
438 ProcParameterInput.doChi2 = false;
439 ProcParameterInput.vals = &(m_f001NewColl->data);
440 ProcParameterInput.errors = &(m_f001NewColl->errors);
441 ProcParameterInput.oldVals = &(m_f001OldColl->data);
442 ProcParameterInput.diffs = &(m_f001DiffColl->data);
443 ProcParameterInput.expectedChannels = m_expectedHashIdsAll;
444 }
445 else if (parName == "OnlTHoldBreaches"){
446 //How many samples failed the online threshold test of f001 +2*RMS
447 //(f001 and RMS read from a file from online configuration db)
448 //ProcParameterInput.dbName = parVals->parName();
449 ProcParameterInput.badHist = m_h_numBad;
450 ProcParameterInput.badBin = m_onlTHoldBreachBadBin;
451 ProcParameterInput.expectedVal = 0; //expect 0 f001
452 ProcParameterInput.maxDiff = m_onlTHoldBreachMax;
453 ProcParameterInput.missingBadBin = m_missingBadBin;
454 ProcParameterInput.missingChans = m_h_pedMissingChannels;
455 ProcParameterInput.doChi2 = false;
456 ProcParameterInput.vals = &(m_onlTHoldBreachColl->data);
457 ProcParameterInput.errors = &(m_onlTHoldBreachColl->errors);
458 //ProcParameterInput.oldVals = &(m_onlTHoldBreachColl->data);
459 //ProcParameterInput.diffs = &(m_onlTHoldBreachColl->data);
460 ProcParameterInput.expectedChannels = m_expectedHashIdsAll;
461 }
462 else
463 {
464 ATH_MSG_INFO( "CscCalibMonToolPed : Did not recognize parameter name "
465 << parName << ". This is usually ok." );
466 return StatusCode::SUCCESS;
467 }
468
469 //Process data in parVals according to setting in ProcParameterInput. This includes:
470 // -Copying data from parVals to ProcParameterInput.vals (i.e. the HistCollection)
471 // -Checking for missing channels
472 // -Look for deviations from expected values for each channel
473 if(!procParameter(parVals,&ProcParameterInput).isSuccess())
474 {
475 ATH_MSG_FATAL( "CscCalibMonToolPed : Failed to process parameter "
476 << parName );
477 return StatusCode::FAILURE;
478 }
479
480 if(parName == "ped")
481 {
486 }
487 if(parName == "noise")
488 {
492 }
493 if(parName == "rms")
494 {
498 }
499 if(parName == "f001")
500 {
504 }
505 if(parName == "OnlTHoldBreaches"){
507 }
508 return StatusCode::SUCCESS;
509}
#define ATH_MSG_INFO(x)
std::set< int > m_expectedHashIdsAll
virtual StatusCode copyDataToHists(HistCollection *histCollection)
Fills the histograms in the histCollection based on the data in the std::vector in the HistCollection...
virtual StatusCode procParameter(const CscCalibResultCollection *parVals, ProcSetupInfo *simpleSet)
Processors a parameter type.
const std::string & parName() const
the identify of this collection
Contains info to be passed to procParameter.

◆ initialize()

StatusCode CscCalibMonToolPed::initialize ( )
virtual

initialize function.

Calls base class's initialize function.

Reimplemented from CscCalibMonToolBase.

Definition at line 79 of file CscCalibMonToolPed.cxx.

80{
82
83 m_generic_path_csccalibmonitoring = "MUON_CSC_PED";
84
85 return sc;
86}
virtual StatusCode initialize()
initializes services, tools, etc.

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< AlgTool > >::inputHandles ( ) const
overridevirtualinherited

Return this algorithm's input handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ interfaceID()

const InterfaceID & IMonitorToolBase::interfaceID ( )
inlinestaticinherited

Definition at line 30 of file IMonitorToolBase.h.

30{ return IID_IMonitorToolBase; }
static const InterfaceID IID_IMonitorToolBase("IMonitorToolBase", 1, 0)

◆ intervalEnumToString()

std::string ManagedMonitorToolBase::intervalEnumToString ( Interval_t interval)
staticinherited

Converts a LevelOfDetail_t to a string of the same name.

Converts a string to the corresponding LevelOfDetail_t. Converts a Interval_t to a string of the same name.

Definition at line 536 of file ManagedMonitorToolBase.cxx.

538{
539 std::string str("file");
540
541 switch( interval ) {
542 case all:
543 str = "all";
544 break;
545 case fill:
546 str = "fill";
547 break;
548 case run:
549 str = "run";
550 break;
551 case lowStat:
552 str = "lowStat";
553 break;
554 case medStat:
555 str = "medStat";
556 break;
557 case higStat:
558 str = "higStat";
559 break;
560 case lumiBlock:
561 str = "lumiBlock";
562 break;
563 case eventsBlock:
564 str = "eventsBlock";
565 break;
566 case file:
567 str = "file";
568 break;
569 default:
570 str = "unknown";
571 }
572
573 return str;
574}

◆ intervalStringToEnum()

ManagedMonitorToolBase::Interval_t ManagedMonitorToolBase::intervalStringToEnum ( const std::string & str)
staticinherited

Converts a string to the corresponding Interval_t.

Definition at line 578 of file ManagedMonitorToolBase.cxx.

580{
581 std::string lcstr( strToLower(str) );
582
583 if( lcstr == "all" )
584 return all;
585 else if( lcstr == "fill" )
586 return fill;
587 else if( lcstr == "run" )
588 return run;
589 else if( lcstr == "lowStat" )
590 return lowStat;
591 else if( lcstr == "medStat" )
592 return medStat;
593 else if( lcstr == "higStat" )
594 return higStat;
595 else if( lcstr == "lumiBlock" )
596 return lumiBlock;
597 else if( lcstr == "eventsBlock" )
598 return eventsBlock;
599 else if( lcstr == "file" )
600 return file;
601
602 if( Imp::s_svcLocator ) {
603 SmartIF<IMessageSvc> ms{Imp::s_svcLocator.load()->service( "MessageSvc" )};
604 if( ms.isValid() ) {
605 MsgStream log( ms, "ManagedMonitorToolBase::intervalStringToEnum()" );
606 log << MSG::WARNING << "Unknown ManagedMonitorToolBase::Interval_t \""
607 << str << "\", returning \"file\"" << endmsg;
608 }
609 }
610
611 return file;
612}
static std::atomic< ISvcLocator * > s_svcLocator

◆ lbAverageInteractionsPerCrossing()

float ManagedMonitorToolBase::lbAverageInteractionsPerCrossing ( const EventContext & ctx) const
virtualinherited

Average mu, i.e.

<mu>

Definition at line 1692 of file ManagedMonitorToolBase.cxx.

1694{
1695 if (!m_lumiDataKey.empty()) {
1696 SG::ReadCondHandle<LuminosityCondData> lumi (m_lumiDataKey, ctx);
1697 return lumi->lbAverageInteractionsPerCrossing();
1698 } else {
1699 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! lbAverageInteractionsPerCrossing() can't work properly! ");
1700 ATH_MSG_DEBUG("Warning: lbAverageInteractionsPerCrossing() - luminosity tools are not retrieved or turned on (i.e. EnableLumi = False)");
1701 return -1.0;
1702 }
1703 // not reached
1704}
SG::ReadCondHandleKey< LuminosityCondData > m_lumiDataKey

◆ lbAverageLivefraction()

float ManagedMonitorToolBase::lbAverageLivefraction ( const EventContext & ctx) const
virtualinherited

Average luminosity livefraction.

Definition at line 1761 of file ManagedMonitorToolBase.cxx.

1763{
1765 return 1.0;
1766
1767 if (!m_trigLiveFractionDataKey.empty()) {
1768 SG::ReadCondHandle<TrigLiveFractionCondData> live (m_trigLiveFractionDataKey, ctx);
1769 return live->lbAverageLiveFraction();
1770 } else {
1771 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! lbAverageLivefraction() can't work properly! ");
1772 ATH_MSG_DEBUG("Warning: lbAverageLivefraction() - luminosity not availble (i.e. EnableLumi = False)");
1773 return -1.0;
1774 }
1775 // not reached
1776}
SG::ReadCondHandleKey< TrigLiveFractionCondData > m_trigLiveFractionDataKey

◆ lbAverageLuminosity()

float ManagedMonitorToolBase::lbAverageLuminosity ( const EventContext & ctx) const
virtualinherited

Average luminosity (in ub-1 s-1 => 10^30 cm-2 s-1).

Definition at line 1728 of file ManagedMonitorToolBase.cxx.

1730{
1731 if (!m_lumiDataKey.empty()) {
1732 SG::ReadCondHandle<LuminosityCondData> lumi (m_lumiDataKey, ctx);
1733 return lumi->lbAverageLuminosity();
1734 } else {
1735 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! lbAverageLuminosity() can't work properly! ");
1736 ATH_MSG_DEBUG("Warning: lbAverageLuminosity() - luminosity tools are not retrieved or turned on (i.e. EnableLumi = False)");
1737 return -1.0;
1738 }
1739 // not reached
1740}

◆ lbDuration()

double ManagedMonitorToolBase::lbDuration ( const EventContext & ctx) const
virtualinherited

Luminosity block time (in seconds).

Definition at line 1815 of file ManagedMonitorToolBase.cxx.

1817{
1819 return m_defaultLBDuration;
1820 }
1821 if (!m_lbDurationDataKey.empty()) {
1822 SG::ReadCondHandle<LBDurationCondData> dur (m_lbDurationDataKey, ctx);
1823 return dur->lbDuration();
1824 } else {
1825 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! lbDuration() can't work properly! ");
1826 ATH_MSG_DEBUG("Warning: lbDuration() - luminosity tools are not retrieved or turned on (i.e. EnableLumi = False)");
1827 return m_defaultLBDuration;
1828 }
1829 // not reached
1830}
SG::ReadCondHandleKey< LBDurationCondData > m_lbDurationDataKey

◆ lbInteractionsPerCrossing()

float ManagedMonitorToolBase::lbInteractionsPerCrossing ( const EventContext & ctx) const
virtualinherited

Instantaneous number of interactions, i.e.

mu

Definition at line 1708 of file ManagedMonitorToolBase.cxx.

1710{
1711 if (!m_lumiDataKey.empty()) {
1712 SG::ReadCondHandle<LuminosityCondData> lumi (m_lumiDataKey, ctx);
1713 float muToLumi = lumi->muToLumi();
1714 if (muToLumi > 0) {
1715 return lumi->lbLuminosityPerBCIDVector().at (ctx.eventID().bunch_crossing_id()) / muToLumi;
1716 }
1717 return 0;
1718 } else {
1719 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! lbInteractionsPerCrossing() can't work properly! ");
1720 ATH_MSG_DEBUG("Warning: lbInteractionsPerCrossing() - luminosity tools are not retrieved or turned on (i.e. EnableLumi = False)");
1721 return -1.0;
1722 }
1723 // not reached
1724}

◆ lbLuminosityPerBCID()

float ManagedMonitorToolBase::lbLuminosityPerBCID ( const EventContext & ctx) const
virtualinherited

Instantaneous luminosity.

Definition at line 1744 of file ManagedMonitorToolBase.cxx.

1746{
1747 if (!m_lumiDataKey.empty()) {
1748 SG::ReadCondHandle<LuminosityCondData> lumi (m_lumiDataKey, ctx);
1749 return lumi->lbLuminosityPerBCIDVector().at (ctx.eventID().bunch_crossing_id());
1750 } else {
1751 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! lbLuminosityPerBCID() can't work properly! ");
1752 ATH_MSG_DEBUG("Warning: lbLuminosityPerBCID() - luminosity tools are not retrieved or turned on (i.e. EnableLumi = False)");
1753 return -1.0;
1754 }
1755 // not reached
1756}

◆ lbLumiWeight()

double ManagedMonitorToolBase::lbLumiWeight ( const EventContext & ctx) const
virtualinherited

Average Integrated Luminosity Live Fraction.

Definition at line 1799 of file ManagedMonitorToolBase.cxx.

1801{
1802 if (!m_lumiDataKey.empty()) {
1804 } else{
1805 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! lbLumiWeight() can't work properly! ");
1806 ATH_MSG_DEBUG("Warning: lbLumiWeight() - luminosity tools are not retrieved or turned on (i.e. EnableLumi = False)");
1807 return -1.0;
1808 }
1809 // not reached
1810}
virtual double lbDuration(const EventContext &ctx) const
Luminosity block time (in seconds).
virtual float lbAverageLivefraction(const EventContext &ctx) const
Average luminosity livefraction.
virtual float lbAverageLuminosity(const EventContext &ctx) const
Average luminosity (in ub-1 s-1 => 10^30 cm-2 s-1).

◆ livefractionPerBCID()

float ManagedMonitorToolBase::livefractionPerBCID ( const EventContext & ctx) const
virtualinherited

Livefraction per bunch crossing ID.

Definition at line 1780 of file ManagedMonitorToolBase.cxx.

1782{
1784 return 1.0;
1785
1786 if (!m_trigLiveFractionDataKey.empty()) {
1787 SG::ReadCondHandle<TrigLiveFractionCondData> live (m_trigLiveFractionDataKey, ctx);
1788 return live->l1LiveFractionVector().at (ctx.eventID().bunch_crossing_id());
1789 } else {
1790 //ATH_MSG_FATAL("! Luminosity tool has been disabled ! livefractionPerBCID() can't work properly! ");
1791 ATH_MSG_DEBUG("Warning: livefractionPerBCID() - luminosity retrieved available (i.e. EnableLumi = False)");
1792 return -1.0;
1793 }
1794 // not reached
1795}

◆ makeErrorReport()

void CscCalibMonToolPed::makeErrorReport ( )
private

Definition at line 784 of file CscCalibMonToolPed.cxx.

784 {
785 std::stringstream report;
786
787 double numBadPed = m_h_numBad->GetBinContent(m_pedBadBin);
788 report << "Num channels with Delta Ped > " << m_pedMaxDiff << " : " << numBadPed << std::endl ;
789
790 double numBadRms = m_h_numBad->GetBinContent(m_rmsBadBin);
791 report << "Num channels with Delta RMS > " << m_rmsMaxDiff << " : " << numBadRms << std::endl ;
792
793 double numBadF001 = m_h_numBad->GetBinContent(m_f001BadBin);
794 report << "Num channels with Delta f001 > " << m_f001MaxDiff << " : " << numBadF001 << std::endl ;
795
796 double numBadNoise = m_h_numBad->GetBinContent(m_noiseBadBin);
797 report << "Num channels with Delta sigma > " << m_noiseMaxDiff << " : " << numBadNoise << std::endl ;
798
799 double numBadNEntries = m_h_numBad->GetBinContent(m_nEntriesBadBin);
800 report << "Num channels with num pedestal amplitude entries < " << m_minAmpHistEntries
801 << ": " << numBadNEntries <<std::endl ;
802
803 double numBreachEntries = m_h_numBad->GetBinContent(m_onlTHoldBreachBadBin);
804 report << "Num channels with too high an occupancy (> " << m_onlTHoldBreachMax << ")."
805 << ": " << numBreachEntries <<std::endl ;
806
807 if(!(numBadPed >100 || numBadRms > 100 || numBadNEntries>0|| numBreachEntries > 0)){
808 std::ofstream allGoodFile(m_allGoodFileName.c_str());
809 allGoodFile << "All tests past.";
810 allGoodFile.close();
811 }
812
813 std::ofstream reportFile(m_statusReportName.c_str());
814 reportFile << m_statusReportPrefix;
815 reportFile << "\n\n";
816 reportFile << report.str();
817 return;
818
819}
list report
Definition checkTP.py:125

◆ MMTB_DEPRECATED() [1/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( endOfEventsBlock )
inherited

◆ MMTB_DEPRECATED() [2/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( endOfLowStat )
inherited

◆ MMTB_DEPRECATED() [3/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( endOfLumiBlock )
inherited

◆ MMTB_DEPRECATED() [4/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( endOfRun )
inherited

◆ MMTB_DEPRECATED() [5/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( newEventsBlock )
inherited

◆ MMTB_DEPRECATED() [6/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( newHigStatInterval )
inherited

◆ MMTB_DEPRECATED() [7/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( newLowStat )
inherited

◆ MMTB_DEPRECATED() [8/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( newLowStatInterval )
inherited

◆ MMTB_DEPRECATED() [9/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( newLumiBlock )
inherited

◆ MMTB_DEPRECATED() [10/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( newMedStatInterval )
inherited

◆ MMTB_DEPRECATED() [11/11]

ManagedMonitorToolBase::MMTB_DEPRECATED ( newRun )
inherited

◆ msg()

MsgStream & AthCommonMsg< AlgTool >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24 {
25 return this->msgStream();
26 }

◆ msgLvl()

bool AthCommonMsg< AlgTool >::msgLvl ( const MSG::Level lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30 {
31 return this->msgLevel(lvl);
32 }

◆ newEventsBlockFlag()

bool ManagedMonitorToolBase::newEventsBlockFlag ( ) const
inlineprotectedinherited

Definition at line 794 of file ManagedMonitorToolBase.h.

794{ return m_newEventsBlock; }

◆ newHigStatIntervalFlag()

bool ManagedMonitorToolBase::newHigStatIntervalFlag ( ) const
inlineprotectedinherited

Definition at line 790 of file ManagedMonitorToolBase.h.

790{ return m_newHigStatInterval; }

◆ newLowStatFlag()

bool ManagedMonitorToolBase::newLowStatFlag ( ) const
inlineprotectedinherited

Definition at line 791 of file ManagedMonitorToolBase.h.

791{ return m_newLowStat; }

◆ newLowStatIntervalFlag()

bool ManagedMonitorToolBase::newLowStatIntervalFlag ( ) const
inlineprotectedinherited

Flag functions allowing clients to determine when to book new and process old histograms; values are updated by fillHists() based on counting lumiBlocks, and are correctly set when fillHistograms(), bookHistograms() and procHistograms() are called.

Definition at line 788 of file ManagedMonitorToolBase.h.

788{ return m_newLowStatInterval; }

◆ newLumiBlockFlag()

bool ManagedMonitorToolBase::newLumiBlockFlag ( ) const
inlineprotectedinherited

Definition at line 792 of file ManagedMonitorToolBase.h.

792{ return m_newLumiBlock; }

◆ newMedStatIntervalFlag()

bool ManagedMonitorToolBase::newMedStatIntervalFlag ( ) const
inlineprotectedinherited

Definition at line 789 of file ManagedMonitorToolBase.h.

789{ return m_newMedStatInterval; }

◆ newRunFlag()

bool ManagedMonitorToolBase::newRunFlag ( ) const
inlineprotectedinherited

Definition at line 793 of file ManagedMonitorToolBase.h.

793{ return m_newRun; }

◆ outputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< AlgTool > >::outputHandles ( ) const
overridevirtualinherited

Return this algorithm's output handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ parseList()

StatusCode ManagedMonitorToolBase::parseList ( const std::string & line,
std::vector< std::string > & result )
protectedinherited

Definition at line 2112 of file ManagedMonitorToolBase.cxx.

2113 {
2114 std::string item;
2115 std::stringstream ss(line);
2116
2117 if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << "ManagedMonitorToolBase::parseList:";
2118
2119 while ( std::getline(ss, item, ',') ) {
2120 std::stringstream iss(item); // remove
2121 iss >> item; // whitespace
2122 if (msgLvl(MSG::DEBUG)) msg(MSG::DEBUG) << " " << item;
2123 result.push_back(item);
2124 }
2125
2126 msg(MSG::DEBUG) << endmsg;
2127 return StatusCode::SUCCESS;
2128}
bool msgLvl(const MSG::Level lvl) const

◆ postProc()

StatusCode CscCalibMonToolPed::postProc ( )
privatevirtual

postProc does some post processing work after the main parameter histograms are filled

Reimplemented from CscCalibMonToolBase.

Definition at line 518 of file CscCalibMonToolPed.cxx.

519{
520 ATH_MSG_DEBUG( "CscCalibMonToolPed : in postProc()" );
521
522 IdContext chanContext = m_idHelperSvc->cscIdHelper().channel_context();
523
525
527
528 if(m_doRmsVNoise) {
529 std::string geoPath = getGeoPath();
530 std::string path = getFullPath(geoPath, "Misc", "");
531
532 m_h2_rmsVnoiseEta = new TH2I("rmsVsigma_eta", "RMS versus sigma for #eta strips", 100, 0, 30, 100, 0,30) ;
533 m_h2_rmsVnoiseEta->GetXaxis()->SetTitle("Sigma");
534 m_h2_rmsVnoiseEta->GetYaxis()->SetTitle("RMS");
536
537 m_h2_rmsVnoisePhi = new TH2I("rmsVsigma_phi", "RMS versus sigma for #phi strips", 100, 0, 30, 100, 0,30) ;
538 m_h2_rmsVnoisePhi->GetXaxis()->SetTitle("Sigma");
539 m_h2_rmsVnoisePhi->GetYaxis()->SetTitle("RMS");
541
542 std::vector<float> & rmsVec = m_rmsNewColl->data;
543 std::vector<float> & noiseVec = m_noiseNewColl->data;
544 size_t nEntries = rmsVec.size();
545 if(nEntries != noiseVec.size()){
546 ATH_MSG_ERROR( "Number of noises != number of rmses" );
547 return StatusCode::FAILURE;
548 }
549 ATH_MSG_DEBUG( "Filling rmsVnoise " );
550
551 for(unsigned int hashId = 0; hashId < nEntries; hashId++){
552 ATH_MSG_DEBUG( "Filling rmsVnoise for hash id " << hashId );
553 Identifier chanId;
554 m_idHelperSvc->cscIdHelper().get_id(IdentifierHash(hashId), chanId, &chanContext);
555 int measuresPhi = m_idHelperSvc->cscIdHelper().measuresPhi(chanId);
556
557 if(m_expectedHashIdsAll.count(hashId)) {
558 if(measuresPhi)
559 m_h2_rmsVnoisePhi->Fill(noiseVec[hashId], rmsVec[hashId]);
560 else
561 m_h2_rmsVnoiseEta->Fill(noiseVec[hashId], rmsVec[hashId]);
562 }
563 }
564 ATH_MSG_DEBUG( "filled rmsVnoise " );
565
566 }
567
569 {
570 //Retrieve calibration report container from transient data store
571 const CscCalibReportContainer* repCont = nullptr;
572 if (!evtStore()->retrieve(repCont, m_histKey).isSuccess())
573 {
574 ATH_MSG_WARNING( " Cannot retrieve object from storegate with key "
575 << m_histKey << " aborting retrieving hists " );
576 return StatusCode::RECOVERABLE;
577 }
578
579 if(repCont->size() != 1)
580 {
581 ATH_MSG_WARNING( "Container with key " << m_histKey
582 << " does not have a size of one. Do not know how to proceed, so aborting"
583 << " retrieving calibration histograms." );
584 return StatusCode::RECOVERABLE;
585 }
586
587 //Retrieve DataVector of amplitude histograms
588 const CscCalibReportPed * pedReport = dynamic_cast<const CscCalibReportPed *>(repCont->front());
589 if((not pedReport) or (pedReport->getLabel() != "pedAmps"))
590 {
591 ATH_MSG_WARNING( "Incorrect object retrieved from container."
592 << " Aborting hist retrieval." );
593 return StatusCode::RECOVERABLE;
594 }
595
596 const std::vector<TH1I*>& pedAmpHists = pedReport->getPedAmpHists();
597 if(pedAmpHists.empty())
598 ATH_MSG_WARNING( "No pedAmpHists vector found from calibration. "
599 << " Won't be in monitoring output file" );
600
601 const std::vector<TH1I*>& bitHists = pedReport->getBitHists();
602 if(bitHists.empty())
603 ATH_MSG_INFO( "No bit histogram vector found from calibration. "
604 << " Won't be in monitoring output file. " );
605
606 const std::vector<TH2F*>* bitCorrelations = nullptr;
607
609 bitCorrelations = &pedReport->getBitCorrelation();
610
611 const std::vector< std::vector<TH1I*> >& sampHists = pedReport->getSampHists();
612
613 //These are the channels we will get detailed amplitude histograms for.
614 for(unsigned int idItr = 0; idItr <= m_maxHashId; idItr++)
615 {
616 if(m_expectedHashIdsAll.count(idItr))
617 {
618 ATH_MSG_VERBOSE( "Debug info for hash " << idItr
619 << " is being retrieved." );
620 TH1I * sourceHist;
621
622 Identifier chanId;
623 m_idHelperSvc->cscIdHelper().get_id(IdentifierHash(idItr), chanId, &chanContext);
624 int stationSize = m_idHelperSvc->cscIdHelper().stationName(chanId);
625 int stationEta = m_idHelperSvc->cscIdHelper().stationEta(chanId);
626 int stationPhi = m_idHelperSvc->cscIdHelper().stationPhi(chanId);
627 int wireLayer = m_idHelperSvc->cscIdHelper().wireLayer(chanId);
628 int measuresPhi = m_idHelperSvc->cscIdHelper().measuresPhi(chanId);
629 int strip = m_idHelperSvc->cscIdHelper().strip(chanId);
630 int sector = getSector(stationPhi, stationSize);
631
632 std::string geoPath = getGeoPath(stationEta, sector, wireLayer, measuresPhi);
633
634 std::string pedAmpPath = getFullPath(geoPath, "PedAmpHists", "");
635 std::string sampPath = getFullPath(geoPath, "SampHists","");
636 std::string bitHistPath = getFullPath(geoPath, "BitHists", "");
637 std::string bitCorrelationPath("");
638 if(bitCorrelations)
639 bitCorrelationPath = getFullPath(geoPath, "BitCorrelations", "");
640
641 ATH_MSG_DEBUG( "Hash Id: " << idItr << ". Booking channel histograms in paths : " << pedAmpPath << " and " << bitHistPath );
642 //MonGroup chanMonGroup( this, path , run, ATTRIB_MANAGED);
643
644 //Pedestal amplitude histograms
645 //copy source histogram into new histogram, and store
646 if(!pedAmpHists.empty())
647 {
648 sourceHist = const_cast<TH1I*>(pedAmpHists[idItr]);
649 if(!sourceHist)
650 {
651 ATH_MSG_ERROR( "There is no pedestal amplitude histogram with hashId "
652 << idItr );
653 return StatusCode::RECOVERABLE;
654 }
655
656 double nEntries = sourceHist->GetEntries();
657
658 if(idItr >= m_nEntriesColl->data.size() ){
659
660 ATH_MSG_ERROR( "idItr == " << idItr
661 << " but maximum m_nEntriesColl.data.size() == "
662 << m_nEntriesColl->data.size() );
663 return StatusCode::RECOVERABLE;
664 }
665 m_nEntriesColl->data[idItr] = nEntries;
666
667 if(nEntries < m_minAmpHistEntries){
668 m_detailedHashIds[idItr] = true;
670 }
671
673
674
675 std::stringstream name;
676 name << "h_pedAmp"
677 << "_EC" << getEndCap(stationEta)
678 << "_sector_" << sector
679 << "_layer_" << wireLayer
680 << "_" << (measuresPhi ? "trans" : "prec")
681 << "_strip_"
682 << std::setfill ('0') << std::setw (measuresPhi ? 2 : 3)
683 << strip;
684
685 //Calibration is finished with histogram, so we can modify it a bit:
686
687 sourceHist->SetName(name.str().c_str());
688 sourceHist->SetFillColor((m_detailedHashIds[idItr] ? m_histColAlert : m_histCol));
689 ATH_CHECK( regHist(sourceHist, pedAmpPath, run, ATTRIB_MANAGED) );
690 }
691 }
692
693 if(!sampHists.empty()) {
694 const std::vector<TH1I*>& histVect = sampHists[idItr];
695
696 size_t hNum = histVect.size();
697 for(size_t hCnt = 0; hCnt < hNum; hCnt++) {
698 sourceHist = const_cast<TH1I*>(histVect[hCnt]);
699 std::stringstream name;
700 name << "h_samp"
701 << "_EC" << getEndCap(stationEta)
702 << "_sector_" << sector
703 << "_layer_" << wireLayer
704 << "_" << (measuresPhi ? "trans" : "prec")
705 << "_strip_"
706 << std::setfill ('0') << std::setw (measuresPhi ? 2 : 3)
707 << strip
708 <<"_samp_"
709 << hCnt;
710 sourceHist->SetName(name.str().c_str());
711 sourceHist->SetFillColor(m_histCol);
712 ATH_CHECK( regHist(sourceHist,sampPath,run, ATTRIB_MANAGED) );
713 }
714 }
715
716 //Bit map histograms
717 //copy source histogram into new histogram, and store
718 if(!bitHists.empty())
719 {
720 sourceHist = const_cast<TH1I*>(bitHists[idItr]);
721 if(!sourceHist)
722 {
723 ATH_MSG_ERROR( "There is no bit histogram with hashId "
724 << idItr << " Quiting out of detailed histogram loop." );
725 return StatusCode::RECOVERABLE;
726 }
727
728 std::stringstream name2;
729 name2 << "h_bitMap"
730 << "_EC" << getEndCap(stationEta)
731 << "_sector_" << sector
732 << "_layer_" << wireLayer
733 << "_" << (measuresPhi ? "trans" : "prec")
734 << "_strip_"
735 << std::setfill ('0') << std::setw (measuresPhi ? 2 : 3)
736 << strip;
737 sourceHist->SetName(name2.str().c_str());
738 sourceHist->SetFillColor((m_detailedHashIds[idItr] ? m_histColAlert : m_histCol));
739
740 ATH_CHECK( regHist(sourceHist, bitHistPath, run, ATTRIB_MANAGED) );
741 }//end if bithists*/
742
743 if(bitCorrelations)
744 {
745 TH2F* hist = const_cast<TH2F*>((*bitCorrelations)[idItr]);
746 ATH_CHECK( regHist(hist,bitCorrelationPath,run, ATTRIB_MANAGED) );
747
748 float maxVal = -2;
749 //Now find the maximum correlation
750 size_t nx = hist->GetXaxis()->GetNbins();
751 size_t ny = hist->GetYaxis()->GetNbins();
752 size_t x_cut = nx -1; //skip last two bits, which can introduce fake
753 size_t y_cut = ny -1; //correlation
754 for(size_t xi = 1; xi < x_cut; xi++){
755 for(size_t yi = 1; yi < y_cut; yi++){
756 if(yi == xi) //Don't do diagonal
757 continue;
758 float val = hist->GetBinContent(xi,yi);
759 if(val > maxVal)
760 maxVal = val;
761 }
762 }//end x/y loops
763 m_maxBitCorrColl->data[idItr] = maxVal;
764
765 }
766 }//if detailedHashInfo[stripHash] || do all hists.
767 }//end hash loop
768 }
769 else
770 ATH_MSG_DEBUG( "No channels flagged for debug info retrieval" );
771
772 //Copy data from the num entries vector to all relevant histograms
774 //Copy data from the bit correlation vector to all relevant histograms
777 }
779
780 return StatusCode::SUCCESS;
781}
ServiceHandle< StoreGateSvc > & evtStore()
void genThreshold(HistCollection *pedColl, HistCollection *noiseColl, HistCollection *tholdColl, float multiplier)
const T * front() const
Access the first element in the collection as an rvalue.
size_type size() const noexcept
Returns the number of elements in the collection.
virtual StatusCode regHist(TH1 *h, const std::string &system, Interval_t interval, MgmtAttr_t histo_mgmt=ATTRIB_MANAGED, const std::string &chain="", const std::string &merge="")
Registers a TH1 (including TH2, TH3, and TProfile) to be included in the output stream using logical ...

◆ preSelector()

bool ManagedMonitorToolBase::preSelector ( )
virtualinherited

Implements IMonitorToolBase.

Definition at line 1680 of file ManagedMonitorToolBase.cxx.

1682{
1683 if( m_preScaleProp > 1 ) {
1684 return ( (m_nEvents % m_preScaleProp) == 1 );
1685 }
1686 return true;
1687}

◆ procHistograms()

StatusCode CscCalibMonToolBase::procHistograms ( )
virtualinherited

At end of run this processes the calibration results and fills the histograms.

fillHistograms() retrieves a CscCalibResultContainer from the TDS, and loops through CscCalibResultCollection objects, each holding info for a calibration parameter.

It calls handleParameter() for each CscCalibResultCollection, which is used in a derived class to determine what is to be done with each parameter.

Reimplemented from ManagedMonitorToolBase.

Definition at line 709 of file CscCalibMonToolBase.cxx.

710{
711
712 ATH_MSG_DEBUG( "CscCalibMonToolBase : in procHistograms()" );
713
714 if(endOfRunFlag())
715 {
716 const CscCalibResultContainer* calibContainer = nullptr;
717 if (!evtStore()->retrieve(calibContainer, m_calibResultKey).isSuccess())
718 {
719 ATH_MSG_ERROR( " Cannot retrieve container with name " << m_calibResultKey );
720 return StatusCode::RECOVERABLE;
721 }
722
723 ATH_MSG_DEBUG( "There are " << calibContainer->size() << " parameters to monitor" );
724
725 for(const CscCalibResultCollection* thisParameter: *calibContainer) {
726 ATH_CHECK( handleParameter(thisParameter) );
727 }
728 ATH_CHECK( postProc() );
729 }
730 return StatusCode::SUCCESS;
731}//end procHistograms
virtual StatusCode postProc()
Run after handleParameter.
virtual StatusCode handleParameter(const CscCalibResultCollection *parVals)
Should be written by user in derived class.

◆ procParameter()

StatusCode CscCalibMonToolBase::procParameter ( const CscCalibResultCollection * parVals,
ProcSetupInfo * simpleSet )
protectedvirtualinherited

Processors a parameter type.

Typically called by derived classes' handleParameter. It does several things

-Fills the histograms in simpleSet -Determines if a given channel deviates too much from an expected value (expected value is from COOL or specified in simpleSet). -Optionally tests the chi^2 value in parVals -Fills the std::vectors in simpleSet. These vectors contain info such as the per-channel values, difference from old COOL values, and the COOL values themselves. -Looks for any expected channels missing in parVals. If so, it mentions it.

Parameters
parValsCollection of values for a given parameter
simpleSetcontains a set of histograms and vectors to be filled.

Definition at line 771 of file CscCalibMonToolBase.cxx.

773{
774 ATH_MSG_DEBUG( "Entering proc parameter for " << parVals->parName() << ". Max diff " << procParameterInput->maxDiff << "." );
775 if (procParameterInput->doChi2)
776 ATH_MSG_DEBUG( " Will retrieve chi2 with expected max of " << procParameterInput->chi2Max );
777
778 //Start with expected channels, remove whenever one is found, leftover are
779 //missing channels
780 std::set<int> missingChannels = procParameterInput->expectedChannels;
781
782 SG::ReadCondHandle<CscCondDbData> readHandle{m_readKey};
783 const CscCondDbData* readCdo{*readHandle};
784
785 //--Cycle through values and fill histograms
786 int numFailures = 0, maxFailures = 10;
787 for(const CscCalibResult* chan: *parVals)
788 {
789 const int hashId = chan->hashId();
790 const float val = chan->value();
791 const float error = chan->error();
792 float oldVal = 0;
793
794 //This channel isn't missing
795 missingChannels.erase(hashId);
796
797 //--Compare measured value with an expected value---------------------
798 if(procParameterInput->dbName != "")
799 {
800 //Get expected value from database
801 if(!(readCdo->readChannelParam(hashId, oldVal, procParameterInput->dbName)).isSuccess())
802 {
803 numFailures++;
804 ATH_MSG_WARNING( "CscCalibMonToolBase : Failed to retrieve parameter"
805 << " for channel " << hashId
806 << " from COOL database. Continuing with COOL value = 0"
807 );
808 if(numFailures==maxFailures)
809 {
810 ATH_MSG_FATAL( "CscCalibMonToolBase : "
811 << maxFailures << " failed retrievals. Quiting. " );
812 return StatusCode::FAILURE;
813 }
814 }
815 }
816 else
817 {
818 //No value in database, compare to provided expected value
819 oldVal = procParameterInput->expectedVal;
820 }
821
822 float diff = val - oldVal;
823
824 bool isBad = false;
825 if( std::abs(diff) > procParameterInput->maxDiff)
826 {
827 ATH_MSG_INFO( "CscCalibMonToolBase : Possible problem! " << parVals->parName()
828 << " measurement of " << val << " varies by " << diff
829 << " from expected value of " << oldVal << " on channel with hash Id "
830 << hashId << ". Specified maximum variance is " << procParameterInput->maxDiff );
831 isBad = true;
832 procParameterInput->badHist->Fill(procParameterInput->badBin); //Too high a difference
833 }
834
835 float chi2_ndf = 0;
836 if(procParameterInput->doChi2)
837 {
838 chi2_ndf = chan->chi2()/chan->ndf();
839 if(chi2_ndf > procParameterInput->chi2Max)
840 {
841 procParameterInput->badHist->Fill(procParameterInput->chi2BadBin);
842 isBad = true;
843 }
844 }
845
846 //If there is a bad channel, specify that we want details about it.
847 if( isBad && ( (int)m_numBad <= m_maxDetailedChannels || m_maxDetailedChannels < 0 ) )
848 {
849 if(!m_detailedHashIds[hashId])
850 {
851 m_numBad++;
852 m_detailedHashIds[hashId] = true; //Look closer at this hash id (used in derived class)
853 }
854 }
855
856 (*procParameterInput->vals)[hashId] = val;
857 if((procParameterInput->errors->size()))
858 (*procParameterInput->errors)[hashId] = error;
859 if(procParameterInput->oldVals)
860 (*procParameterInput->oldVals)[hashId] = oldVal;
861 if(procParameterInput->diffs)
862 (*procParameterInput->diffs)[hashId] = diff;
863 if(procParameterInput->doChi2)
864 (*procParameterInput->chi2s)[hashId] = chi2_ndf;
865 //--Print out values channel-by channel sorted by Hash Id-------------------
866 }//End chanItr loop
867
868 if(missingChannels.size() !=0)
869 {
870 for(const auto & thisChan: missingChannels)
871 {
872 if(procParameterInput->missingChans != nullptr)
873 {
874 //If we haven't already noticed that this channel is missing,
875 //increment missing bad bin in badHist.
876 if(!procParameterInput->missingChans->GetBinContent(thisChan+1))
877 procParameterInput->badHist->Fill(procParameterInput->missingBadBin);
878 //Always fill missingChans histogram
879 procParameterInput->missingChans->Fill(thisChan);
880
881 }
882 }
883 }
884 return StatusCode::SUCCESS;
885}
static dqm_algorithms::Chi2Test chi2_ndf("Chi2_per_NDF")
void diff(const Jet &rJet1, const Jet &rJet2, std::map< std::string, double > varDiff)
Difference between jets - Non-Class function required by trigger.
Definition Jet.cxx:631
SG::ReadCondHandleKey< CscCondDbData > m_readKey
Access to COOL database.
int m_maxDetailedChannels
To keep track of channels that should have more data printed to root file.
StatusCode readChannelParam(IdentifierHash hash, T &val, const std::string &parName) const

◆ regEfficiency()

StatusCode ManagedMonitorToolBase::regEfficiency ( TEfficiency * e,
const MonGroup & group )
virtualinherited

Registers a TEfficiency to be included in the output stream using logical parameters that describe the plot.

Definition at line 1445 of file ManagedMonitorToolBase.cxx.

1445 {
1446 if (!e)
1447 return StatusCode::FAILURE;
1448
1449 TGraph* g = reinterpret_cast<TGraph*>(e);
1450 std::string name = e->GetName();
1451
1452 // MANAGED
1453 if ( group.histo_mgmt() != ATTRIB_UNMANAGED ) {
1454 // warn about not using merge algorithms
1455 if (group.histo_mgmt() == ATTRIB_X_VS_LB && group.merge().empty()) {
1456 ATH_MSG_WARNING("HEY! Attempting to register "<<name<<" as a per-LB histogram, but not setting the merge algorithm! Use \"merge\", at least.");
1457 }
1458 // add the efficiency to rebooking vector
1459 if (m_supportedIntervalsForRebooking.count(group.interval())) {
1460 m_templateEfficiencies[group.interval()].push_back( MgmtParams<TEfficiency>(e, group) );
1461 } else {
1462 ATH_MSG_ERROR("Attempt to book managed graph " << name << " with invalid interval type " << intervalEnumToString(group.interval()));
1463 return StatusCode::FAILURE;
1464 }
1465
1466 MonGroup group_unmanaged( this, group.system(), group.interval(), ATTRIB_UNMANAGED, group.chain(), group.merge());
1467 std::string streamName = streamNameFunction()->getStreamName( this, group_unmanaged, name, false );
1468 registerMetadata(streamName, name, group).ignore();
1469 return m_THistSvc->regGraph( streamName, g );
1470 } else {
1471 // UNMANAGED
1472 if( m_manager != 0 ) {
1473 std::string genericName = NoOutputStream().getStreamName( this, group, name );
1474 m_manager->writeAndDelete( genericName );
1475 m_manager->passOwnership( e, genericName );
1476 }
1477
1478 std::string streamName = streamNameFunction()->getStreamName( this, group, name, false );
1479 StatusCode smd = registerMetadata(streamName, name, group);
1480 if (smd != StatusCode::SUCCESS)
1481 return StatusCode::FAILURE;
1482
1483 return m_THistSvc->regGraph( streamName, g );
1484 }
1485}
virtual std::string getStreamName(const ManagedMonitorToolBase *tool, const MonGroup &group, const std::string &objName, bool usePreviousInterval=false)
A function that converts a MonGroup of logical parameters into a physical output stream name.
std::set< Interval_t > m_supportedIntervalsForRebooking
StatusCode registerMetadata(const std::string &streamName, const std::string &hName, const MonGroup &group)
static std::string intervalEnumToString(Interval_t interval)
Converts a LevelOfDetail_t to a string of the same name.

◆ regGraph() [1/2]

StatusCode ManagedMonitorToolBase::regGraph ( TGraph * g,
const MonGroup & group )
virtualinherited

Registers a TGraph to be included in the output stream using logical parameters that describe the graph.

Definition at line 1499 of file ManagedMonitorToolBase.cxx.

1501{
1502 if (!g)
1503 return StatusCode::FAILURE;
1504
1505 // This part of the code deals with MANAGED type
1506 if ( group.histo_mgmt() != ATTRIB_UNMANAGED ) {
1507 // Create an unmanaged group based on the original MonGroup instance passed
1508 // This is needed because managed graph is presented as a number of unmanaged
1509 // graphs (one per each interval)
1510 MonGroup group_unmanaged( this, group.system(), group.interval(), ATTRIB_UNMANAGED, group.chain(), group.merge());
1511
1512 if (m_supportedIntervalsForRebooking.count(group.interval())) {
1513 m_templateGraphs[group.interval()].push_back( MgmtParams<TGraph>(g, group_unmanaged) );
1514 } else {
1515 ATH_MSG_ERROR("Attempt to book managed graph " << g->GetName() << " with invalid interval type " << intervalEnumToString(group.interval()));
1516 return StatusCode::FAILURE;
1517 }
1518
1519 std::string name = g->GetName();
1520 std::string streamName = streamNameFunction()->getStreamName( this, group_unmanaged, name, false );
1521 registerMetadata(streamName, name, group).ignore();
1522 return m_THistSvc->regGraph( streamName, g );
1523 //return m_THistSvc->regGraph( streamName );
1524 }
1525
1526 // This part of the code deals with UNMANAGED type
1527 std::string gName = g->GetName();
1528
1529 if( m_manager != 0 ) {
1530 std::string genericName = NoOutputStream().getStreamName( this, group, gName );
1531 m_manager->writeAndDelete( genericName );
1532 m_manager->passOwnership( g, genericName );
1533 }
1534
1535 std::string streamName = streamNameFunction()->getStreamName( this, group, gName, false );
1536
1537 StatusCode smd = registerMetadata(streamName, gName, group);
1538 if (smd != StatusCode::SUCCESS) return StatusCode::FAILURE;
1539
1540 return m_THistSvc->regGraph( streamName, g );
1541}

◆ regGraph() [2/2]

StatusCode ManagedMonitorToolBase::regGraph ( TGraph * g,
const std::string & system,
Interval_t interval,
MgmtAttr_t histo_mgmt = ATTRIB_MANAGED,
const std::string & chain = "",
const std::string & merge = "" )
virtualinherited

Registers a TGraph to be included in the output stream using logical parameters that describe the graph.

Definition at line 1489 of file ManagedMonitorToolBase.cxx.

1492{
1493 MonGroup group( this, system, interval, histo_mgmt, chain, merge );
1494 return regGraph( g, group );
1495}
virtual StatusCode regGraph(TGraph *g, const std::string &system, Interval_t interval, MgmtAttr_t histo_mgmt=ATTRIB_MANAGED, const std::string &chain="", const std::string &merge="")
Registers a TGraph to be included in the output stream using logical parameters that describe the gra...

◆ regHist() [1/2]

StatusCode ManagedMonitorToolBase::regHist ( TH1 * h,
const MonGroup & group )
virtualinherited

Registers a TH1 (including TH2, TH3, and TProfile) to be included in the output stream using logical parameters that describe the histogram.

A histogram is passed via reference to a pointer.

Definition at line 1353 of file ManagedMonitorToolBase.cxx.

1355{
1356// ManagedMonitorToolBase_addHistStatistics(this,h);
1357
1358 if (!h)
1359 return StatusCode::FAILURE;
1360
1361 // This part of the code deals with MANAGED type
1362 if ( group.histo_mgmt() != ATTRIB_UNMANAGED ) {
1363 /*
1364 Create an unmanaged group based on the original MonGroup instance passed
1365 It is needed because managed histogram is presented as a number of unmanaged
1366 histograms (one per each interval)
1367 Update (PUEO) - I don't think it actually matters, and need to keep
1368 track of "proper" attribute for X_VS_LB
1369 */
1370
1371 if (group.histo_mgmt() == ATTRIB_X_VS_LB && group.merge().empty()) {
1372 ATH_MSG_WARNING("HEY! You're attempting to register " << h->GetName() << " as a per-LB histogram, but you're not setting the merge algorithm! This is a SUPER-BAD idea! Use \"merge\", at least.");
1373 }
1374
1375 if (m_supportedIntervalsForRebooking.count(group.interval())) {
1376 m_templateHistograms[group.interval()].push_back( MgmtParams<TH1>(h, group) );
1377 } else {
1378 ATH_MSG_ERROR("Attempt to book managed histogram " << h->GetName() << " with invalid interval type " << intervalEnumToString(group.interval()));
1379 return StatusCode::FAILURE;
1380 }
1381
1382 std::string hName = h->GetName();
1383 MonGroup group_unmanaged( this, group.system(), group.interval(), ATTRIB_UNMANAGED, group.chain(), group.merge());
1384 std::string streamName = streamNameFunction()->getStreamName( this, group_unmanaged, hName, false );
1385 registerMetadata(streamName, hName, group).ignore();
1386 return m_THistSvc->regHist( streamName, h );
1387 }
1388
1389 // This part of the code deals with UNMANAGED type
1390 std::string hName = h->GetName();
1391
1392 if( m_manager != 0 ) {
1393 std::string genericName = NoOutputStream().getStreamName( this, group, hName );
1394 m_manager->writeAndDelete( genericName );
1395 m_manager->passOwnership( h, genericName );
1396 }
1397
1398 std::string streamName = streamNameFunction()->getStreamName( this, group, hName, false );
1399
1400 StatusCode smd = registerMetadata(streamName, hName, group);
1401 if (smd != StatusCode::SUCCESS) return StatusCode::FAILURE;
1402
1403 return m_THistSvc->regHist( streamName, h );
1404}

◆ regHist() [2/2]

StatusCode ManagedMonitorToolBase::regHist ( TH1 * h,
const std::string & system,
Interval_t interval,
MgmtAttr_t histo_mgmt = ATTRIB_MANAGED,
const std::string & chain = "",
const std::string & merge = "" )
virtualinherited

Registers a TH1 (including TH2, TH3, and TProfile) to be included in the output stream using logical parameters that describe the histogram.

Definition at line 1344 of file ManagedMonitorToolBase.cxx.

1347{
1348 MonGroup group( this, system, interval, histo_mgmt, chain, merge );
1349 return regHist( h, group );
1350}

◆ registerMetadata()

StatusCode ManagedMonitorToolBase::registerMetadata ( const std::string & streamName,
const std::string & hName,
const MonGroup & group )
protectedinherited

Definition at line 946 of file ManagedMonitorToolBase.cxx.

948 {
950 TTree* metadata(0);
951 std::string mdStreamName( streamName );
952 size_t found=mdStreamName.rfind('/');
953
954 if ( found != std::string::npos )
955 mdStreamName.replace( found, mdStreamName.length(), "/metadata" );
956
957 MDMap_t::iterator i = m_metadataMap.find( mdStreamName );
958 if( i == m_metadataMap.end() ) {
959 metadata = new TTree( "metadata", "Monitoring Metadata" );
960 if (! metadata) return StatusCode::FAILURE;
961 StatusCode scmd = m_THistSvc->regTree( mdStreamName, metadata );
962 if (scmd == StatusCode::FAILURE) return StatusCode::FAILURE;
963 i = m_metadataMap.emplace( mdStreamName, new OutputMetadata(metadata) ).first;
964 }
965
966 i->second->fill( hName, group.interval(), group.chain(), group.merge() );
967 }
968 return StatusCode::SUCCESS;
969}

◆ regManagedEfficiencies()

StatusCode ManagedMonitorToolBase::regManagedEfficiencies ( std::vector< MgmtParams< TEfficiency > > & templateEfficiencies)
protectedinherited

Definition at line 1140 of file ManagedMonitorToolBase.cxx.

1140 {
1141 bool allIsOk = true;
1142 for( auto& it : templateEfficiencies ) {
1143 // get components of MgmtParams and copy efficiency
1144 MonGroup group = it.m_group;
1145 TEfficiency* theEfficiency = it.m_templateHist;
1146 TEfficiency* e = static_cast<TEfficiency*>(theEfficiency->Clone());
1147 int nbins = theEfficiency->GetTotalHistogram()->GetNbinsX();
1148 int xlow = theEfficiency->GetTotalHistogram()->GetXaxis()->GetXmin();
1149 int xhigh = theEfficiency->GetTotalHistogram()->GetXaxis()->GetXmax();
1150 e->SetBins(nbins,xlow,xhigh); // reset histogram
1151 std::string name = e->GetName();
1152
1153 // make TGraph casts of TEfficiencies
1154 TGraph* theGraph = reinterpret_cast<TGraph*>(theEfficiency);
1155 TGraph* g = reinterpret_cast<TGraph*>(e);
1156
1157 // Get the streamName for the previous interval
1158 std::string streamName = streamNameFunction()->getStreamName( this, group, name, true );
1159
1160 // RE-REGISTER
1161 // 1) De-register the original graph with the THistSvc
1162 StatusCode sc1 = m_THistSvc->deReg( theGraph );
1163 if (sc1 == StatusCode::FAILURE) allIsOk = false;
1164 // 2) Fix THistSvc->deReg for TGraphs
1165 bool doneCleaning = false;
1166 std::string directoryName = streamNameFunction()->getDirectoryName( this, group, name, true );
1167 TSeqCollection *filelist=gROOT->GetListOfFiles();
1168 for (int i=0; i<filelist->GetEntries(); i++) {
1169 ATH_MSG_DEBUG( "List of files: " << filelist->At(i)->GetName());
1170 TFile* file = static_cast<TFile*>(filelist->At(i));
1171 StatusCode sc2 = THistSvc_deReg_fixTGraph(file, theGraph, directoryName);
1172 if (sc2 == StatusCode::SUCCESS) doneCleaning = true;
1173 }
1174 // 3) Check if TGraph fix has been applied successfully
1175 if (!doneCleaning) {
1176 ATH_MSG_ERROR("THistSvc_deReg_fixTGraph: failed to apply TGraph fix for the THist Svc!");
1177 allIsOk = false;
1178 }
1179 // 4) Register cloned histogram under previous interval streamName
1180 StatusCode sc3 = m_THistSvc->regGraph( streamName, g );
1181 if (sc3 == StatusCode::FAILURE)
1182 allIsOk = false;
1183
1184 // get streamname for interval
1185 streamName = streamNameFunction()->getStreamName( this, group, name, false );
1186 // store metadata
1187 StatusCode smd = registerMetadata(streamName, name, group);
1188 if (smd != StatusCode::SUCCESS) allIsOk = false;
1189 // Re-register the original graph
1190 StatusCode sc4 = m_THistSvc->regGraph( streamName, theGraph );
1191 if (sc4 == StatusCode::FAILURE) allIsOk = false;
1192 }
1193
1194 if (!allIsOk) return StatusCode::FAILURE;
1195 return StatusCode::SUCCESS;
1196}
virtual std::string getDirectoryName(const ManagedMonitorToolBase *tool, const MonGroup &group, const std::string &objName, const bool usePreviousInterval)=0
A function that returns TDirectory path in a file that corresponds to a given MonGroup and object nam...
StatusCode THistSvc_deReg_fixTGraph(TFile *file, TGraph *theGraph, std::string &directoryName)
Fixes THistSvc->deReg(obj) when obj is TGraph instance.
filelist
print ("Checking files %s..." % fullfile)
Definition envutil.py:133

◆ regManagedGraphs()

StatusCode ManagedMonitorToolBase::regManagedGraphs ( std::vector< MgmtParams< TGraph > > & templateGraphs)
protectedinherited

Definition at line 1069 of file ManagedMonitorToolBase.cxx.

1071{
1072 // See the description for the regManagedHistograms method
1073 bool allIsOk = true;
1074
1075 for( std::vector< MgmtParams<TGraph> >::iterator it = templateGraphs.begin(); it != templateGraphs.end(); ++it ) {
1076 MonGroup group = (*it).m_group;
1077
1078 // Get a handle to the graph
1079 TGraph* theGraph = (*it).m_templateHist;
1080
1081 // Clone the graph
1082 TGraph* g = static_cast<TGraph*>(theGraph->Clone());
1083 theGraph->Set(0); // equivalent to Reset() for TH1
1084
1085 // Get name
1086 std::string gName = g->GetName();
1087
1088 // Get the streamName for the previous interval
1089 std::string streamName = streamNameFunction()->getStreamName( this, group, gName, true );
1090
1091 // De-register the original graph with the THistSvc
1092 StatusCode sc1 = m_THistSvc->deReg( theGraph );
1093 if (sc1 == StatusCode::FAILURE)
1094 allIsOk = false;
1095
1096 // *** begin ***
1097 // Fix THistSvc->deReg for TGraphs
1098 bool doneCleaning = false;
1099 std::string directoryName = streamNameFunction()->getDirectoryName( this, group, gName, true );
1100 TSeqCollection *filelist=gROOT->GetListOfFiles();
1101 for (int i=0; i<filelist->GetEntries(); i++) {
1102 ATH_MSG_DEBUG( "List of files: " << filelist->At(i)->GetName());
1103 TFile* file = static_cast<TFile*>(filelist->At(i));
1104 StatusCode sc2 = THistSvc_deReg_fixTGraph(file, theGraph, directoryName);
1105 if (sc2 == StatusCode::SUCCESS)
1106 doneCleaning = true;
1107 }
1108
1109 // Check if TGraph fix has been applied successfully
1110 if (!doneCleaning) {
1111 ATH_MSG_ERROR("THistSvc_deReg_fixTGraph: failed to apply TGraph fix for the THist Svc!");
1112 allIsOk = false;
1113 }
1114 // *** end ***
1115
1116 // Register clonned histogram under previous interval streamName
1117 StatusCode sc3 = m_THistSvc->regGraph( streamName, g );
1118 if (sc3 == StatusCode::FAILURE)
1119 allIsOk = false;
1120
1121 // Get streamName for the current interval
1122 streamName = streamNameFunction()->getStreamName( this, group, gName, false );
1123 // Register metadata information with the current interval streamname
1124 StatusCode smd = registerMetadata(streamName, gName, group);
1125 if (smd != StatusCode::SUCCESS)
1126 allIsOk = false;
1127
1128 // Re-register the original graph with the current interval streamName
1129 StatusCode sc4 = m_THistSvc->regGraph( streamName, theGraph );
1130 if (sc4 == StatusCode::FAILURE)
1131 allIsOk = false;
1132
1133 }
1134
1135 if (!allIsOk) return StatusCode::FAILURE;
1136
1137 return StatusCode::SUCCESS;
1138}

◆ regManagedHistograms()

StatusCode ManagedMonitorToolBase::regManagedHistograms ( std::vector< MgmtParams< TH1 > > & templateHistograms)
protectedinherited

Definition at line 972 of file ManagedMonitorToolBase.cxx.

974{
975 // The method registers histograms with the THistSvc and saves them to file.
976
977 // The funky business with registering and deregistering the histogram is needed
978 // to get the correct directory when saving histograms. THistSvc deals with ROOT
979 // to set up proper TDirectory, so we rely on it.
980 // E.g.
981 // m_THistSvc->regHist( streamName, h ): sets the correct TDirectory with streamName
982 // m_THistSvc->deReg( h ) - deregister from THistSvc otherwise THistSvc will try to save it
983 // at the end of execution
984 // use passownership of the histogram and save it to file
985 // m_manager->passOwnership( h, genericName );
986 // m_manager->writeAndDelete( genericName );
987 bool allIsOk = true;
988
989 for( std::vector< MgmtParams<TH1> >::iterator it = templateHistograms.begin(); it != templateHistograms.end(); ++it ) {
990 MonGroup& group = (*it).m_group;
991
992 // Get a handle to the histogram
993 TH1* theHist = (*it).m_templateHist;
994
995 // Clone the histogram
996 TH1* h = static_cast<TH1*>(theHist->Clone());
997 theHist->Reset();
998
999 // Get name
1000 std::string hName = h->GetName();
1001
1002 // Get the streamName for the previous interval
1003 std::string streamName = streamNameFunction()->getStreamName( this, group, hName, true );
1004
1005 // Register the histogram with the THistSvc
1006 StatusCode sc1 = m_THistSvc->deReg( theHist );
1007 if (sc1 == StatusCode::FAILURE) allIsOk = false;
1008
1009 // Register clonned histogram under previous interval streamName
1010 StatusCode sc2 = m_THistSvc->regHist( streamName, h );
1011 if (sc2 == StatusCode::FAILURE) allIsOk = false;
1012
1013 if( m_manager != 0 ) {
1014 std::string genericName = NoOutputStream().getStreamName( this, group, hName );
1015 m_manager->passOwnership( h, genericName );
1016 m_manager->writeAndDelete( genericName );
1017 }
1018
1019 // Get streamName for the current interval
1020 streamName = streamNameFunction()->getStreamName( this, group, hName, false );
1021 // Register metadata information with the current interval streamname
1022 StatusCode smd = registerMetadata(streamName, hName, group);
1023 if (smd != StatusCode::SUCCESS) allIsOk = false;
1024
1025 // Re-register the original histogram with the current interval streamName
1026 StatusCode sc3 = m_THistSvc->regHist( streamName, theHist );
1027 if (sc3 == StatusCode::FAILURE) allIsOk = false;
1028
1029 }
1030
1031 if (!allIsOk) return StatusCode::FAILURE;
1032
1033 return StatusCode::SUCCESS;
1034}

◆ regManagedTrees()

StatusCode ManagedMonitorToolBase::regManagedTrees ( std::vector< MgmtParams< TTree > > & templateTrees)
protectedinherited

Definition at line 1200 of file ManagedMonitorToolBase.cxx.

1202{
1203 // See the description for the regManagedHistograms method
1204 bool allIsOk = true;
1205
1206 for( std::vector< MgmtParams<TTree> >::iterator it = templateTrees.begin(); it != templateTrees.end(); ++it ) {
1207 MonGroup group = (*it).m_group;
1208
1209 // Get a handle to the original tree
1210 TTree* theTree = (*it).m_templateHist;
1211
1212 // Clone the tree
1213 TTree* t = static_cast<TTree*>(theTree->Clone());
1214 theTree->Reset();
1215
1216 // Dumping the tree
1217 std::string name = t->GetName();
1218
1219 // Get the streamName for the previous interval
1220 std::string streamName = streamNameFunction()->getStreamName( this, group, name, true );
1221
1222 // De-register original tree with the THistSvc
1223 StatusCode sc1 = m_THistSvc->deReg( theTree );
1224 if (sc1 == StatusCode::FAILURE) allIsOk = false;
1225
1226 // Register clonned tree under previous interval streamName
1227 StatusCode sc2 = m_THistSvc->regTree( streamName, t );
1228 if (sc2 == StatusCode::FAILURE) allIsOk = false;
1229
1230 if( m_manager != 0 ) {
1231 std::string genericName = NoOutputStream().getStreamName( this, group, name );
1232 m_manager->passOwnership( t, genericName );
1233 m_manager->writeAndDelete( genericName );
1234 }
1235
1236 // Get streamName for the current interval
1237 streamName = streamNameFunction()->getStreamName( this, group, name, false );
1238 // Register metadata information with the current interval streamname
1239 StatusCode smd = registerMetadata(streamName, name, group);
1240 if (smd != StatusCode::SUCCESS) allIsOk = false;
1241
1242 // Re-register the original graph with the current interval streamName
1243 StatusCode sc3 = m_THistSvc->regTree( streamName, theTree );
1244 if (sc3 == StatusCode::FAILURE) allIsOk = false;
1245
1246 }
1247
1248 if (!allIsOk) return StatusCode::FAILURE;
1249
1250 return StatusCode::SUCCESS;
1251}

◆ regTree() [1/2]

StatusCode ManagedMonitorToolBase::regTree ( TTree * t,
const MonGroup & group )
virtualinherited

Registers a TTree to be included in the output stream using logical parameters that describe it.

Definition at line 1555 of file ManagedMonitorToolBase.cxx.

1557{
1558
1559 // This part of the code deals with MANAGED type
1560 if ( group.histo_mgmt() != ATTRIB_UNMANAGED ) {
1561 // Create an unmanaged group based on the original MonGroup instance passed
1562 // This is needed because managed tree is presented as a number of unmanaged
1563 // trees (one per each interval)
1564 MonGroup group_unmanaged( this, group.system(), group.interval(), ATTRIB_UNMANAGED, group.chain(), group.merge());
1565
1566 if (m_supportedIntervalsForRebooking.count(group.interval())) {
1567 m_templateTrees[group.interval()].push_back( MgmtParams<TTree>(t, group_unmanaged) );
1568 } else {
1569 ATH_MSG_ERROR("Attempt to book managed tree " << t->GetName() << " with invalid interval type " << intervalEnumToString(group.interval()));
1570 return StatusCode::FAILURE;
1571 }
1572
1573 std::string name = t->GetName();
1574 std::string genericName = NoOutputStream().getStreamName( this, group_unmanaged, name );
1575 std::string streamName = streamNameFunction()->getStreamName( this, group_unmanaged, name, false );
1576 registerMetadata(streamName, name, group).ignore();
1577 return m_THistSvc->regTree( streamName, t );
1578 }
1579
1580
1581 // This part of the code deals with UNMANAGED type
1582 std::string tName = t->GetName();
1583
1584 if( m_manager != 0 ) {
1585 std::string genericName = NoOutputStream().getStreamName( this, group, tName );
1586 m_manager->writeAndDelete( genericName );
1587 m_manager->passOwnership( t, genericName );
1588 }
1589
1590 std::string streamName = streamNameFunction()->getStreamName( this, group, tName, false );
1591
1592 StatusCode smd = registerMetadata(streamName, tName, group);
1593 if (smd != StatusCode::SUCCESS) return StatusCode::FAILURE;
1594
1595 return m_THistSvc->regTree( streamName, t );
1596}

◆ regTree() [2/2]

StatusCode ManagedMonitorToolBase::regTree ( TTree * t,
const std::string & system,
Interval_t interval,
MgmtAttr_t histo_mgmt = ATTRIB_MANAGED,
const std::string & chain = "",
const std::string & merge = "" )
virtualinherited

Registers a TTree to be included in the output stream using logical parameters that describe it.

Definition at line 1545 of file ManagedMonitorToolBase.cxx.

1548{
1549 MonGroup group( this, system, interval, histo_mgmt, chain, merge );
1550 return regTree( t, group );
1551}
virtual StatusCode regTree(TTree *t, const std::string &system, Interval_t interval, MgmtAttr_t histo_mgmt=ATTRIB_MANAGED, const std::string &chain="", const std::string &merge="")
Registers a TTree to be included in the output stream using logical parameters that describe it.

◆ renounce()

std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > AthCommonDataStore< AthCommonMsg< AlgTool > >::renounce ( T & h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381 {
382 h.renounce();
384 }
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce(T &h)

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ runStat()

StatusCode ManagedMonitorToolBase::runStat ( )
virtualinherited

This implementation does nothing; equivalent functionality may be provided by procHists( true, true, true ).

Implements IMonitorToolBase.

Definition at line 1662 of file ManagedMonitorToolBase.cxx.

1664{
1665 return StatusCode::SUCCESS;
1666}

◆ setMonManager()

void ManagedMonitorToolBase::setMonManager ( AthenaMonManager * manager)
virtualinherited

Takes a pointer to a managing object to get information from it when needed.

Definition at line 1326 of file ManagedMonitorToolBase.cxx.

1328{
1329 ATH_MSG_DEBUG( "ManagedMonitorToolBase::setMonManager():");
1331 if( m_manager != 0 ) {
1332 ATH_MSG_DEBUG( " --> Setting manager");
1333 m_managerNameProp = m_manager->name();
1334 m_fileKey = m_manager->fileKey();
1335 m_dataType = m_manager->dataType();
1336 m_environment = m_manager->environment();
1337 delete m_streamNameFcn;
1339 }
1340 ATH_MSG_DEBUG( " --> Exiting successfully");
1341}
virtual StreamNameFcn * getNewStreamNameFcn() const

◆ setupOutputStreams()

StatusCode ManagedMonitorToolBase::setupOutputStreams ( std::vector< std::string > Mapping = std::vector<std::string>())
virtualinherited

This implementation does nothing—streams in this class should be managed by the AthenaMonManager.

Consider using MonitorToolBase for user-managed streams.

Implements IMonitorToolBase.

Definition at line 1651 of file ManagedMonitorToolBase.cxx.

1653{
1654 // All instances should write to the stream(s) defined by the
1655 // AthenaMonManager.
1656
1657 return StatusCode::SUCCESS;
1658}

◆ streamNameFunction()

ManagedMonitorToolBase::StreamNameFcn * ManagedMonitorToolBase::streamNameFunction ( )
virtualinherited

Returns the function object that converts logical paramters into a physical stream name.

Definition at line 451 of file ManagedMonitorToolBase.cxx.

453{
454 if( m_streamNameFcn == 0 ) {
455 msg(MSG::ERROR) << "!! streamNameFunction() has not been initialized !!" << endmsg;
456 msg(MSG::ERROR) << " --> neither ManagedMonitorToolBase::initialize() nor" << endmsg;
457 msg(MSG::ERROR) << " --> ManagedMonitorToolBase::setMonManager() has been called." << endmsg;
458 msg(MSG::ERROR) << " --> Correct configuration cannot be guaranteed from this point." << endmsg;
460 }
461 return m_streamNameFcn;
462}

◆ sysInitialize()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysInitialize ( )
overridevirtualinherited

Perform system initialization for an algorithm.

We override this to declare all the elements of handle key arrays at the end of initialization. See comments on updateVHKA.

Reimplemented in asg::AsgMetadataTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and DerivationFramework::CfAthAlgTool.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ THistSvc_deReg_fixTGraph()

StatusCode ManagedMonitorToolBase::THistSvc_deReg_fixTGraph ( TFile * file,
TGraph * theGraph,
std::string & directoryName )
protectedinherited

Fixes THistSvc->deReg(obj) when obj is TGraph instance.

Read more in source file about this bug.

Definition at line 1037 of file ManagedMonitorToolBase.cxx.

1039{
1040 // THistSvc employs TDirectory Append method when registering TGraph.
1041 // When deReg is used to de-register TGraph object, THistSvc only removes the object
1042 // from its internal management but forgets to delete from TDirectory.
1043 // The current method fixes this problem by removing the TGraph object manually
1044 // after THistSvc->deReg(TGraph* obj) is called.
1045
1046 // Saves and restores gFile and gDirectory
1047 GlobalDirectoryRestore restore;
1048
1049 // This check is true when TGraph object is removed successfully
1050 bool graphRemoved = false;
1051
1052 file->cd("/");
1053 TDirectory* dir = file->GetDirectory(directoryName.c_str());
1054 if (dir != 0) {
1055 dir->cd();
1056 TObject* obj = dir->Remove(theGraph);
1057 if (obj != 0)
1058 graphRemoved = true;
1059 }
1060
1061 if (!graphRemoved) {
1062 return StatusCode::FAILURE;
1063 }
1064
1065 return StatusCode::SUCCESS;
1066}

◆ trigChainsArePassed()

bool ManagedMonitorToolBase::trigChainsArePassed ( std::vector< std::string > & vTrigNames)
protectedvirtualinherited

Definition at line 2093 of file ManagedMonitorToolBase.cxx.

2095{
2096 ATH_MSG_DEBUG( "ManagedMonitorToolBase::trigChainsArePassed:");
2097
2098 for(unsigned int i=0; i<vTrigNames.size(); i++) {
2099 if( m_trigDecTool->isPassed(vTrigNames[i]) ) {
2100 ATH_MSG_DEBUG( " + \"" << vTrigNames[i] << "\" passed, returning \'true\'");
2101 return true;
2102 }
2103 else {
2104 ATH_MSG_DEBUG( " - \"" << vTrigNames[i] << "\" did not pass");
2105 }
2106 }
2107
2108 return false;
2109}

◆ updateTriggersForGroups()

void ManagedMonitorToolBase::updateTriggersForGroups ( std::vector< std::string > & vTrigChainNames)
protectedinherited

Definition at line 2131 of file ManagedMonitorToolBase.cxx.

2132 {
2133 for (size_t i = 0; i < vTrigChainNames.size(); ++i) {
2134 std::string& thisName = vTrigChainNames[i];
2135 if (thisName.compare(0, 9, "CATEGORY_") ==0) {
2136 ATH_MSG_DEBUG("Found a trigger category: " << thisName << ". We will unpack it.");
2137 std::vector<std::string> triggers = m_trigTranslator->translate(thisName.substr(9,std::string::npos));
2138 std::ostringstream oss;
2139 oss << "(";
2140 for (size_t itrig = 0; itrig < triggers.size(); ++itrig) {
2141 if (itrig != 0) {
2142 oss << "|";
2143 }
2144 oss << triggers[itrig];
2145 }
2146 oss << ")";
2147 // replace with new value
2148 std::string newval = oss.str();
2149 ATH_MSG_DEBUG("Replaced with " << newval);
2150 vTrigChainNames[i] = std::move(newval);
2151 }
2152 }
2153}
PublicToolHandle< ITriggerTranslatorTool > m_trigTranslator

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::updateVHKA ( Gaudi::Details::PropertyBase & )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308 {
309 // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310 // << " size: " << m_vhka.size() << endmsg;
311 for (auto &a : m_vhka) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka

◆ writeAndDelete()

StatusCode ManagedMonitorToolBase::writeAndDelete ( TH1 * h,
const MonGroup & group )
virtualinherited

Write out histogram and delete it.

Definition at line 1600 of file ManagedMonitorToolBase.cxx.

1601 {
1602 if (!h)
1603 return StatusCode::FAILURE;
1604
1605 std::string hName = h->GetName();
1606
1607 if( m_manager != 0 ) {
1608 std::string genericName = NoOutputStream().getStreamName( this, group, hName );
1609 m_manager->writeAndDelete( genericName );
1610 }
1611 return StatusCode::SUCCESS;
1612}

Member Data Documentation

◆ m_allChan1dName

std::string CscCalibMonToolBase::m_allChan1dName
protectedinherited

Definition at line 138 of file CscCalibMonToolBase.h.

◆ m_allChan1dTitle

std::string CscCalibMonToolBase::m_allChan1dTitle
protectedinherited

Definition at line 139 of file CscCalibMonToolBase.h.

◆ m_allChan2dName

std::string CscCalibMonToolBase::m_allChan2dName
protectedinherited

Definition at line 140 of file CscCalibMonToolBase.h.

◆ m_allChan2dPath

std::string CscCalibMonToolBase::m_allChan2dPath
protectedinherited

Definition at line 158 of file CscCalibMonToolBase.h.

◆ m_allChan2dTitle

std::string CscCalibMonToolBase::m_allChan2dTitle
protectedinherited

Definition at line 141 of file CscCalibMonToolBase.h.

◆ m_allGoodFileName

std::string CscCalibMonToolPed::m_allGoodFileName
private

name of file indicating all is well

Definition at line 89 of file CscCalibMonToolPed.h.

◆ m_bookHistogramsInitial

bool ManagedMonitorToolBase::m_bookHistogramsInitial
privateinherited

Definition at line 894 of file ManagedMonitorToolBase.h.

◆ m_calibResultKey

std::string CscCalibMonToolBase::m_calibResultKey
protectedinherited

Calibration result storegate key.

Definition at line 166 of file CscCalibMonToolBase.h.

◆ m_chamHistName

std::string CscCalibMonToolBase::m_chamHistName
protectedinherited

Definition at line 148 of file CscCalibMonToolBase.h.

◆ m_chamHistTitle

std::string CscCalibMonToolBase::m_chamHistTitle
protectedinherited

Definition at line 149 of file CscCalibMonToolBase.h.

◆ m_chamProfName

std::string CscCalibMonToolBase::m_chamProfName
protectedinherited

Definition at line 142 of file CscCalibMonToolBase.h.

◆ m_chamProfPath

std::string CscCalibMonToolBase::m_chamProfPath
protectedinherited

Definition at line 158 of file CscCalibMonToolBase.h.

◆ m_chamProfTitle

std::string CscCalibMonToolBase::m_chamProfTitle
protectedinherited

Definition at line 143 of file CscCalibMonToolBase.h.

◆ m_chamSummHistName

std::string CscCalibMonToolBase::m_chamSummHistName
protectedinherited

Definition at line 146 of file CscCalibMonToolBase.h.

◆ m_chamSummHistPath

std::string CscCalibMonToolBase::m_chamSummHistPath
protectedinherited

Definition at line 159 of file CscCalibMonToolBase.h.

◆ m_chamSummHistTitle

std::string CscCalibMonToolBase::m_chamSummHistTitle
protectedinherited

Definition at line 147 of file CscCalibMonToolBase.h.

◆ m_chi2BadBin

int CscCalibMonToolPed::m_chi2BadBin
private

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_chi2Coll

HistCollection* CscCalibMonToolPed::m_chi2Coll
private

Definition at line 112 of file CscCalibMonToolPed.h.

◆ m_chi2Max

float CscCalibMonToolPed::m_chi2Max
private

Allowed maximum values.

Definition at line 83 of file CscCalibMonToolPed.h.

◆ m_d

Imp* ManagedMonitorToolBase::m_d
privateinherited

Definition at line 901 of file ManagedMonitorToolBase.h.

◆ m_dataType

AthenaMonManager::DataType_t ManagedMonitorToolBase::m_dataType
protectedinherited

Definition at line 839 of file ManagedMonitorToolBase.h.

◆ m_dataTypeStr

std::string ManagedMonitorToolBase::m_dataTypeStr
protectedinherited

Definition at line 835 of file ManagedMonitorToolBase.h.

◆ m_defaultLBDuration

float ManagedMonitorToolBase::m_defaultLBDuration
privateinherited

Definition at line 896 of file ManagedMonitorToolBase.h.

◆ m_detailedHashIds

bool* CscCalibMonToolBase::m_detailedHashIds {}
protectedinherited

Definition at line 129 of file CscCalibMonToolBase.h.

129{};

◆ m_detailLevel

unsigned int ManagedMonitorToolBase::m_detailLevel
protectedinherited

Definition at line 837 of file ManagedMonitorToolBase.h.

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default).

Definition at line 393 of file AthCommonDataStore.h.

◆ m_doAllDetailed

bool CscCalibMonToolBase::m_doAllDetailed {}
protectedinherited

Definition at line 123 of file CscCalibMonToolBase.h.

123{}, m_doBadDetailed{};

◆ m_doBadDetailed

bool CscCalibMonToolBase::m_doBadDetailed {}
protectedinherited

Definition at line 123 of file CscCalibMonToolBase.h.

123{}, m_doBadDetailed{};

◆ m_doBitCorrelations

bool CscCalibMonToolPed::m_doBitCorrelations
private

DO bit correlation plots?

"

Definition at line 95 of file CscCalibMonToolPed.h.

◆ m_doRmsVNoise

bool CscCalibMonToolPed::m_doRmsVNoise
private

Definition at line 128 of file CscCalibMonToolPed.h.

◆ m_doStatDb

bool CscCalibMonToolBase::m_doStatDb {}
protectedinherited

Definition at line 241 of file CscCalibMonToolBase.h.

241{};

◆ m_DQFilterTools

ToolHandleArray<IDQFilterTool> ManagedMonitorToolBase::m_DQFilterTools {this,"FilterTools",{}}
protectedinherited

Definition at line 850 of file ManagedMonitorToolBase.h.

850{this,"FilterTools",{}};

◆ m_endOfEventsBlock

bool ManagedMonitorToolBase::m_endOfEventsBlock
privateinherited

Definition at line 824 of file ManagedMonitorToolBase.h.

◆ m_endOfLowStat

bool ManagedMonitorToolBase::m_endOfLowStat
privateinherited

Definition at line 824 of file ManagedMonitorToolBase.h.

◆ m_endOfLumiBlock

bool ManagedMonitorToolBase::m_endOfLumiBlock
privateinherited

Definition at line 824 of file ManagedMonitorToolBase.h.

◆ m_endOfRun

bool ManagedMonitorToolBase::m_endOfRun
privateinherited

Definition at line 824 of file ManagedMonitorToolBase.h.

◆ m_environment

AthenaMonManager::Environment_t ManagedMonitorToolBase::m_environment
protectedinherited

Definition at line 840 of file ManagedMonitorToolBase.h.

◆ m_environmentStr

std::string ManagedMonitorToolBase::m_environmentStr
protectedinherited

Definition at line 836 of file ManagedMonitorToolBase.h.

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default).

Definition at line 390 of file AthCommonDataStore.h.

◆ m_expectedChamberLayer

unsigned int CscCalibMonToolBase::m_expectedChamberLayer {}
protectedinherited

Definition at line 116 of file CscCalibMonToolBase.h.

116{};

◆ m_expectedHashIdsAll

std::set<int> CscCalibMonToolBase::m_expectedHashIdsAll
protectedinherited

Definition at line 133 of file CscCalibMonToolBase.h.

◆ m_expectedHashIdsPrec

std::set<int> CscCalibMonToolBase::m_expectedHashIdsPrec
protectedinherited

Definition at line 133 of file CscCalibMonToolBase.h.

◆ m_f001BadBin

int CscCalibMonToolPed::m_f001BadBin
private

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_f001DiffColl

HistCollection * CscCalibMonToolPed::m_f001DiffColl
private

Definition at line 114 of file CscCalibMonToolPed.h.

◆ m_f001MaxDiff

float CscCalibMonToolPed::m_f001MaxDiff
private

Definition at line 80 of file CscCalibMonToolPed.h.

◆ m_f001NewColl

HistCollection* CscCalibMonToolPed::m_f001NewColl
private

Definition at line 114 of file CscCalibMonToolPed.h.

◆ m_f001OldColl

HistCollection * CscCalibMonToolPed::m_f001OldColl
private

Definition at line 114 of file CscCalibMonToolPed.h.

◆ m_fileKey

std::string ManagedMonitorToolBase::m_fileKey
protectedinherited

Definition at line 834 of file ManagedMonitorToolBase.h.

◆ m_generic_path_csccalibmonitoring

std::string CscCalibMonToolBase::m_generic_path_csccalibmonitoring
protectedinherited

Path of histograms.

Definition at line 157 of file CscCalibMonToolBase.h.

◆ m_h2_rmsVnoiseEta

TH2I* CscCalibMonToolPed::m_h2_rmsVnoiseEta
private

Definition at line 126 of file CscCalibMonToolPed.h.

◆ m_h2_rmsVnoisePhi

TH2I * CscCalibMonToolPed::m_h2_rmsVnoisePhi
private

Definition at line 126 of file CscCalibMonToolPed.h.

◆ m_h_numBad

TH1I* CscCalibMonToolPed::m_h_numBad
private

Stores number of channels that are bad in several categories.

Definition at line 107 of file CscCalibMonToolPed.h.

◆ m_h_pedMissingChannels

TH1F* CscCalibMonToolPed::m_h_pedMissingChannels
private

Histograms that simply histogram all entries for a value.

Definition at line 77 of file CscCalibMonToolPed.h.

◆ m_hashName

std::string CscCalibMonToolBase::m_hashName
protectedinherited

Naming info.

Definition at line 136 of file CscCalibMonToolBase.h.

◆ m_hashPath

std::string CscCalibMonToolBase::m_hashPath
protectedinherited

Definition at line 158 of file CscCalibMonToolBase.h.

◆ m_hashTitle

std::string CscCalibMonToolBase::m_hashTitle
protectedinherited

Definition at line 137 of file CscCalibMonToolBase.h.

◆ m_haveClearedLastEventBlock

bool ManagedMonitorToolBase::m_haveClearedLastEventBlock
protectedinherited

Definition at line 867 of file ManagedMonitorToolBase.h.

◆ m_histCol

int CscCalibMonToolBase::m_histCol {}
protectedinherited

Hist colors.

Definition at line 154 of file CscCalibMonToolBase.h.

154{}, m_histColAlert{};

◆ m_histColAlert

int CscCalibMonToolBase::m_histColAlert {}
protectedinherited

Definition at line 154 of file CscCalibMonToolBase.h.

154{}, m_histColAlert{};

◆ m_histKey

std::string CscCalibMonToolPed::m_histKey
private

Samples.

Storegate key for pedestal amplitude histograms

Definition at line 104 of file CscCalibMonToolPed.h.

◆ m_idHelperSvc

ServiceHandle<Muon::IMuonIdHelperSvc> CscCalibMonToolBase::m_idHelperSvc {this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"}
protectedinherited

Definition at line 168 of file CscCalibMonToolBase.h.

168{this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"};

◆ m_lastHigStatInterval

int ManagedMonitorToolBase::m_lastHigStatInterval
protectedinherited

Definition at line 862 of file ManagedMonitorToolBase.h.

◆ m_lastLowStatInterval

int ManagedMonitorToolBase::m_lastLowStatInterval
protectedinherited

Definition at line 862 of file ManagedMonitorToolBase.h.

◆ m_lastLumiBlock

unsigned int ManagedMonitorToolBase::m_lastLumiBlock
protectedinherited

Definition at line 860 of file ManagedMonitorToolBase.h.

◆ m_lastMedStatInterval

int ManagedMonitorToolBase::m_lastMedStatInterval
protectedinherited

Definition at line 862 of file ManagedMonitorToolBase.h.

◆ m_lastRun

unsigned int ManagedMonitorToolBase::m_lastRun
protectedinherited

Definition at line 861 of file ManagedMonitorToolBase.h.

◆ m_layHistName

std::string CscCalibMonToolBase::m_layHistName
protectedinherited

Definition at line 144 of file CscCalibMonToolBase.h.

◆ m_layHistPath

std::string CscCalibMonToolBase::m_layHistPath
protectedinherited

Definition at line 158 of file CscCalibMonToolBase.h.

◆ m_layHistTitle

std::string CscCalibMonToolBase::m_layHistTitle
protectedinherited

Definition at line 145 of file CscCalibMonToolBase.h.

◆ m_laySummHistName

std::string CscCalibMonToolBase::m_laySummHistName
protectedinherited

Definition at line 150 of file CscCalibMonToolBase.h.

◆ m_laySummHistPath

std::string CscCalibMonToolBase::m_laySummHistPath
protectedinherited

Definition at line 159 of file CscCalibMonToolBase.h.

◆ m_laySummHistTitle

std::string CscCalibMonToolBase::m_laySummHistTitle
protectedinherited

Definition at line 151 of file CscCalibMonToolBase.h.

◆ m_lbDurationDataKey

SG::ReadCondHandleKey<LBDurationCondData> ManagedMonitorToolBase::m_lbDurationDataKey {this,"LBDurationCondDataKey","LBDurationCondData","SG Key of LBDurationCondData object"}
privateinherited

Definition at line 889 of file ManagedMonitorToolBase.h.

890{this,"LBDurationCondDataKey","LBDurationCondData","SG Key of LBDurationCondData object"};

◆ m_lumiDataKey

SG::ReadCondHandleKey<LuminosityCondData> ManagedMonitorToolBase::m_lumiDataKey {this,"LuminosityCondDataKey","LuminosityCondData","SG Key of LuminosityCondData object"}
privateinherited

Definition at line 887 of file ManagedMonitorToolBase.h.

888{this,"LuminosityCondDataKey","LuminosityCondData","SG Key of LuminosityCondData object"};

◆ m_makeAllChan1dHists

bool CscCalibMonToolBase::m_makeAllChan1dHists {}
protectedinherited

◆ m_makeAllChan2dHists

bool CscCalibMonToolBase::m_makeAllChan2dHists {}
protectedinherited

◆ m_makeChamHists

bool CscCalibMonToolBase::m_makeChamHists {}
protectedinherited

Definition at line 122 of file CscCalibMonToolBase.h.

122{}, m_makeChamHists{},

◆ m_makeChamProfs

bool CscCalibMonToolBase::m_makeChamProfs {}
protectedinherited

Definition at line 121 of file CscCalibMonToolBase.h.

121{}, m_makeChamProfs{},

◆ m_makeChamSummHists

bool CscCalibMonToolBase::m_makeChamSummHists {}
protectedinherited

Definition at line 122 of file CscCalibMonToolBase.h.

122{}, m_makeChamHists{},

◆ m_makeHashHists

bool CscCalibMonToolBase::m_makeHashHists {}
protectedinherited

Data output options.

Definition at line 120 of file CscCalibMonToolBase.h.

◆ m_makeLayHists

bool CscCalibMonToolBase::m_makeLayHists {}
protectedinherited

◆ m_makeLaySummHists

bool CscCalibMonToolBase::m_makeLaySummHists {}
protectedinherited

Definition at line 121 of file CscCalibMonToolBase.h.

121{}, m_makeChamProfs{},

◆ m_manager

AthenaMonManager* ManagedMonitorToolBase::m_manager
protectedinherited

Definition at line 830 of file ManagedMonitorToolBase.h.

◆ m_managerNameProp

std::string ManagedMonitorToolBase::m_managerNameProp
protectedinherited

Definition at line 832 of file ManagedMonitorToolBase.h.

◆ m_maxBitCorrColl

HistCollection* CscCalibMonToolPed::m_maxBitCorrColl
private

Definition at line 122 of file CscCalibMonToolPed.h.

◆ m_maxChamId

unsigned int CscCalibMonToolBase::m_maxChamId {}
protectedinherited

Definition at line 114 of file CscCalibMonToolBase.h.

114{};

◆ m_maxDetailedChannels

int CscCalibMonToolBase::m_maxDetailedChannels {}
protectedinherited

To keep track of channels that should have more data printed to root file.

Definition at line 128 of file CscCalibMonToolBase.h.

128{};

◆ m_maxHashId

unsigned int CscCalibMonToolBase::m_maxHashId {}
protectedinherited

Definition at line 113 of file CscCalibMonToolBase.h.

113{};

◆ m_metadataMap

MDMap_t ManagedMonitorToolBase::m_metadataMap
protectedinherited

Definition at line 828 of file ManagedMonitorToolBase.h.

◆ m_minAmpHistEntries

int CscCalibMonToolPed::m_minAmpHistEntries
private

Allowed number of entries.

Definition at line 86 of file CscCalibMonToolPed.h.

◆ m_missingBadBin

int CscCalibMonToolPed::m_missingBadBin
private

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_monGroupMap

std::map<std::string, MonGroup*> CscCalibMonToolBase::m_monGroupMap
protectedinherited

Definition at line 163 of file CscCalibMonToolBase.h.

◆ m_monGroupVec

DataVector<MonGroup>* CscCalibMonToolBase::m_monGroupVec {}
protectedinherited

Keeps track of MonGroups.

Definition at line 162 of file CscCalibMonToolBase.h.

162{};

◆ m_nEntriesBadBin

int CscCalibMonToolPed::m_nEntriesBadBin
private

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_nEntriesColl

HistCollection* CscCalibMonToolPed::m_nEntriesColl
private

Definition at line 118 of file CscCalibMonToolPed.h.

◆ m_nEvents

unsigned int ManagedMonitorToolBase::m_nEvents
protectedinherited

Definition at line 864 of file ManagedMonitorToolBase.h.

◆ m_nEventsIgnoreTrigger

unsigned int ManagedMonitorToolBase::m_nEventsIgnoreTrigger
protectedinherited

Definition at line 865 of file ManagedMonitorToolBase.h.

◆ m_newEventsBlock

bool ManagedMonitorToolBase::m_newEventsBlock
privateinherited

Definition at line 823 of file ManagedMonitorToolBase.h.

◆ m_newHigStatInterval

bool ManagedMonitorToolBase::m_newHigStatInterval
privateinherited

Definition at line 821 of file ManagedMonitorToolBase.h.

◆ m_newLowStat

bool ManagedMonitorToolBase::m_newLowStat
privateinherited

Definition at line 822 of file ManagedMonitorToolBase.h.

◆ m_newLowStatInterval

bool ManagedMonitorToolBase::m_newLowStatInterval
privateinherited

Definition at line 821 of file ManagedMonitorToolBase.h.

◆ m_newLumiBlock

bool ManagedMonitorToolBase::m_newLumiBlock
privateinherited

Definition at line 822 of file ManagedMonitorToolBase.h.

◆ m_newMedStatInterval

bool ManagedMonitorToolBase::m_newMedStatInterval
privateinherited

Definition at line 821 of file ManagedMonitorToolBase.h.

◆ m_newRun

bool ManagedMonitorToolBase::m_newRun
privateinherited

Definition at line 822 of file ManagedMonitorToolBase.h.

◆ m_nLumiBlocks

unsigned int ManagedMonitorToolBase::m_nLumiBlocks
protectedinherited

Definition at line 866 of file ManagedMonitorToolBase.h.

◆ m_noiseBadBin

int CscCalibMonToolPed::m_noiseBadBin
private

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_noiseDiffColl

HistCollection * CscCalibMonToolPed::m_noiseDiffColl
private

Definition at line 111 of file CscCalibMonToolPed.h.

◆ m_noiseMaxDiff

float CscCalibMonToolPed::m_noiseMaxDiff
private

Definition at line 80 of file CscCalibMonToolPed.h.

◆ m_noiseNewColl

HistCollection* CscCalibMonToolPed::m_noiseNewColl
private

Definition at line 111 of file CscCalibMonToolPed.h.

◆ m_noiseOldColl

HistCollection * CscCalibMonToolPed::m_noiseOldColl
private

Definition at line 111 of file CscCalibMonToolPed.h.

◆ m_numBad

unsigned int CscCalibMonToolBase::m_numBad {}
protectedinherited

Definition at line 115 of file CscCalibMonToolBase.h.

115{};

◆ m_onlTHoldBreachBadBin

int CscCalibMonToolPed::m_onlTHoldBreachBadBin
private

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_onlTHoldBreachColl

HistCollection* CscCalibMonToolPed::m_onlTHoldBreachColl
private

Definition at line 115 of file CscCalibMonToolPed.h.

◆ m_onlTHoldBreachMax

float CscCalibMonToolPed::m_onlTHoldBreachMax
private

Definition at line 80 of file CscCalibMonToolPed.h.

◆ m_onlyExpectPrecisionHashIds

bool CscCalibMonToolBase::m_onlyExpectPrecisionHashIds {}
protectedinherited

Hash Ids one would expect to be in calibration data.

Definition at line 132 of file CscCalibMonToolBase.h.

132{};

◆ m_path

std::string ManagedMonitorToolBase::m_path
protectedinherited

Definition at line 853 of file ManagedMonitorToolBase.h.

◆ m_pedBadBin

int CscCalibMonToolPed::m_pedBadBin
private

Bin in m_h_numBen corresponding to each type of data.

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_pedDiffColl

HistCollection * CscCalibMonToolPed::m_pedDiffColl
private

Definition at line 110 of file CscCalibMonToolPed.h.

◆ m_pedMaxDiff

float CscCalibMonToolPed::m_pedMaxDiff
private

Allowed deviations from COOL data.

Definition at line 80 of file CscCalibMonToolPed.h.

◆ m_pedNewColl

HistCollection* CscCalibMonToolPed::m_pedNewColl
private

HistCollections.

See CscCalibMonToolBase for definition

Definition at line 110 of file CscCalibMonToolPed.h.

◆ m_pedOldColl

HistCollection * CscCalibMonToolPed::m_pedOldColl
private

Definition at line 110 of file CscCalibMonToolPed.h.

◆ m_preScaleProp

long ManagedMonitorToolBase::m_preScaleProp
protectedinherited

Definition at line 854 of file ManagedMonitorToolBase.h.

◆ m_procNEventsProp

long ManagedMonitorToolBase::m_procNEventsProp
protectedinherited

Definition at line 852 of file ManagedMonitorToolBase.h.

◆ m_readKey

SG::ReadCondHandleKey<CscCondDbData> CscCalibMonToolBase::m_readKey {this, "ReadKey", "CscCondDbData", "Key of CscCondDbData"}
protectedinherited

Access to COOL database.

Definition at line 171 of file CscCalibMonToolBase.h.

171{this, "ReadKey", "CscCondDbData", "Key of CscCondDbData"};

◆ m_rmsBadBin

int CscCalibMonToolPed::m_rmsBadBin
private

Definition at line 98 of file CscCalibMonToolPed.h.

◆ m_rmsDiffColl

HistCollection * CscCalibMonToolPed::m_rmsDiffColl
private

Definition at line 113 of file CscCalibMonToolPed.h.

◆ m_rmsMaxDiff

float CscCalibMonToolPed::m_rmsMaxDiff
private

Definition at line 80 of file CscCalibMonToolPed.h.

◆ m_rmsNewColl

HistCollection* CscCalibMonToolPed::m_rmsNewColl
private

Definition at line 113 of file CscCalibMonToolPed.h.

◆ m_rmsOldColl

HistCollection * CscCalibMonToolPed::m_rmsOldColl
private

Definition at line 113 of file CscCalibMonToolPed.h.

◆ m_statDbColl

HistCollection* CscCalibMonToolBase::m_statDbColl {}
protectedinherited

Definition at line 242 of file CscCalibMonToolBase.h.

242{};

◆ m_statusReportName

std::string CscCalibMonToolPed::m_statusReportName
private

Status report name.

Definition at line 91 of file CscCalibMonToolPed.h.

◆ m_statusReportPrefix

std::string CscCalibMonToolPed::m_statusReportPrefix
private

Status report prefix.

Definition at line 93 of file CscCalibMonToolPed.h.

◆ m_streamNameFcn

StreamNameFcn* ManagedMonitorToolBase::m_streamNameFcn
protectedinherited

Definition at line 842 of file ManagedMonitorToolBase.h.

◆ m_supportedIntervalsForRebooking

std::set<Interval_t> ManagedMonitorToolBase::m_supportedIntervalsForRebooking
privateinherited

Definition at line 897 of file ManagedMonitorToolBase.h.

◆ m_templateEfficiencies

std::map< Interval_t, std::vector< MgmtParams<TEfficiency> > > ManagedMonitorToolBase::m_templateEfficiencies
protectedinherited

Definition at line 677 of file ManagedMonitorToolBase.h.

◆ m_templateGraphs

std::map< Interval_t, std::vector< MgmtParams<TGraph> > > ManagedMonitorToolBase::m_templateGraphs
protectedinherited

Definition at line 669 of file ManagedMonitorToolBase.h.

◆ m_templateHistograms

std::map< Interval_t, std::vector< MgmtParams<TH1> > > ManagedMonitorToolBase::m_templateHistograms
protectedinherited

Definition at line 665 of file ManagedMonitorToolBase.h.

◆ m_templateTrees

std::map< Interval_t, std::vector< MgmtParams<TTree> > > ManagedMonitorToolBase::m_templateTrees
protectedinherited

Definition at line 673 of file ManagedMonitorToolBase.h.

◆ m_THistSvc

ServiceHandle<ITHistSvc> ManagedMonitorToolBase::m_THistSvc
protectedinherited

Definition at line 844 of file ManagedMonitorToolBase.h.

◆ m_tholdDiffColl

HistCollection* CscCalibMonToolPed::m_tholdDiffColl
private

Definition at line 120 of file CscCalibMonToolPed.h.

◆ m_trigDecTool

PublicToolHandle<Trig::ITrigDecisionTool> ManagedMonitorToolBase::m_trigDecTool {this, "TrigDecisionTool",""}
protectedinherited

Definition at line 846 of file ManagedMonitorToolBase.h.

846{this, "TrigDecisionTool",""};

◆ m_triggerChainProp

std::string ManagedMonitorToolBase::m_triggerChainProp
protectedinherited

Definition at line 855 of file ManagedMonitorToolBase.h.

◆ m_triggerGroupProp

std::string ManagedMonitorToolBase::m_triggerGroupProp
protectedinherited

Definition at line 856 of file ManagedMonitorToolBase.h.

◆ m_trigLiveFractionDataKey

SG::ReadCondHandleKey<TrigLiveFractionCondData> ManagedMonitorToolBase::m_trigLiveFractionDataKey {this,"TrigLiveFractionCondDataKey","TrigLiveFractionCondData","SG Key of TrigLiveFractionCondData object"}
privateinherited

Definition at line 891 of file ManagedMonitorToolBase.h.

892{this,"TrigLiveFractionCondDataKey","TrigLiveFractionCondData","SG Key of TrigLiveFractionCondData object"};

◆ m_trigTranslator

PublicToolHandle<ITriggerTranslatorTool> ManagedMonitorToolBase::m_trigTranslator {this,"TriggerTranslatorTool",""}
protectedinherited

Definition at line 848 of file ManagedMonitorToolBase.h.

848{this,"TriggerTranslatorTool",""};

◆ m_useLumi

bool ManagedMonitorToolBase::m_useLumi
privateinherited

Definition at line 895 of file ManagedMonitorToolBase.h.

◆ m_useTrigger

bool ManagedMonitorToolBase::m_useTrigger
protectedinherited

Definition at line 858 of file ManagedMonitorToolBase.h.

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< AlgTool > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.

◆ m_vTrigChainNames

std::vector<std::string> ManagedMonitorToolBase::m_vTrigChainNames
protectedinherited

Definition at line 681 of file ManagedMonitorToolBase.h.

◆ m_vTrigGroupNames

std::vector<std::string> ManagedMonitorToolBase::m_vTrigGroupNames
protectedinherited

Definition at line 681 of file ManagedMonitorToolBase.h.


The documentation for this class was generated from the following files: