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

Class for monitoring CSC relative gain calibration results. More...

#include <CscCalibMonToolSlope.h>

Inheritance diagram for CscCalibMonToolSlope:
Collaboration diagram for CscCalibMonToolSlope:

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

 CscCalibMonToolSlope (const std::string &type, const std::string &name, const IInterface *parent)
 Constructor.
 ~CscCalibMonToolSlope ()
 Destructor.
StatusCode initialize ()
 Initialize slope sepcific values.
StatusCode finalize ()
 Delete slope sepcific values.
StatusCode bookHistograms ()
 Books all histograms not retrieved driectly from CscCalcSlope.
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 retrieves the plots fit to produce the gain
StatusCode makeFracGraphs (const CscCalibReportSlope &slopeReport)
 Make fractional deviation plots between the gain plot points and the fit.
StatusCode findDeadChannels (const CscCalibReportSlope &slopeReport)
 Look for dead channels.
std::vector< float > & setArray (std::vector< float > &array, const float &value, const int &numEntries)
void genNeighborRatios (const std::vector< float > &source, std::vector< float > &ratios) const
 Generated next neighbor channel ratios of the slopes.
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

bool m_doNeighborRatios {}
 Do neighbor ratios.
bool m_histAttenLevels {}
 Histogram all values for all histograms.
float m_slopeMaxDiff {}
 Maximum deviation from expected values allowed before m_h_numBad is incremented.
float m_interceptMax {}
float m_chi2Max {}
float m_fracDevMax {}
float m_peaktMaxDiff {}
int m_slopeBadBin {1}
 Bin corresponding to each category in m_h_numbad.
int m_interceptBadBin {2}
int m_chi2BadBin {3}
int m_peaktBadBin {4}
int m_fracBadBin {5}
int m_deadBadBin {6}
int m_missingBadBin {7}
int m_totalLiveBin {1}
int m_totalDeadBin {2}
int m_newLiveBin {3}
int m_newDeadBin {4}
TH1I * m_h_numBad {}
 Stores number of channels that are bad in several categories.
TH1F * m_h_slopeCompareOverview {}
 Histograms that simply histogram all entries for a value.
TH1F * m_h_interceptOverview {}
TH1F * m_h_chi2Overview {}
TH1F * m_h_slopeMissingChans {}
TH1F * m_h_deadOverview {}
 Overview of dead channels and changes.
std::vector< TProfile * > m_fracProfs
 Holds fractional deviation TProfiles.
HistCollectionm_slopeNewColl {}
 HistCollections.
HistCollectionm_slopeOldColl {}
HistCollectionm_slopeDiffColl {}
HistCollectionm_peaktNewColl {}
HistCollectionm_peaktOldColl {}
HistCollectionm_peaktDiffColl {}
HistCollectionm_interceptColl {}
HistCollectionm_chi2Coll {}
HistCollectionm_deadNewColl {}
HistCollectionm_deadDiffColl {}
HistCollectionm_slopeRatioColl {}
HistCollectionm_fitResColl {}
DataVector< HistCollectionm_ampColls
std::string m_histKey
 Storegate key for pedestal amplitude histograms.
std::string m_subDir
 Name of subdirectory under EXPERT or SHIFT that the histograms will be stored.
int m_deadPulserLevelCutoff
 Dead channel finding user defined parameters.
int m_deadADCCutoff
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 CSC relative gain calibration results.

This class monitors the slope determined to be the relative gain between CSC chanels, as produced by CscCalcSlope.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 slope and intercept and chi^2 of the fit -COOL slope. -Difference between slope and COOL slope

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

Definition at line 37 of file CscCalibMonToolSlope.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

◆ CscCalibMonToolSlope()

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

Constructor.

Definition at line 24 of file CscCalibMonToolSlope.cxx.

25 :
26 CscCalibMonToolBase(type, name, parent){
27 declareProperty("MaxSlopeDiff",m_slopeMaxDiff=0.5);
28 declareProperty("MaxIntercept",m_interceptMax = 5.0);
29 declareProperty("MaxChi2_NDF",m_chi2Max = 100);
30 declareProperty("MaxFracDev",m_fracDevMax = .5);
31 declareProperty("MaxPeaktDiff",m_peaktMaxDiff= 10);
32 m_calibResultKey = "CscCalibResultSlope";
33 declareProperty("calGraphKey", m_histKey = "cscSlopeCalibReport");
34 declareProperty("subDir", m_subDir ="");
35 declareProperty("DeadPulserLevelCutoff", m_deadPulserLevelCutoff = 50);
36 declareProperty("DeadADCCutoff", m_deadADCCutoff =100); //Cutoff after ped subtraction
37 declareProperty("DoNeighborRatio", m_doNeighborRatios = true);
38 declareProperty("HistAttenLevels", m_histAttenLevels = false , "Make histograms for all attenuation levels. Potentially requires a LOT of RAM.");
39
40
41 /*##From CscCalibMonToolBase.cxx, for reference. Do not uncomment!
42 declareProperty("MakeHashValueHist",m_makeHashHist=true);
43 declareProperty("MakeLayerValueHists",m_makeLayerHists=false);
44 declareProperty("DetailedResultHashIds",m_detailedHashIds);
45 */
46
47}
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
float m_slopeMaxDiff
Maximum deviation from expected values allowed before m_h_numBad is incremented.
std::string m_histKey
Storegate key for pedestal amplitude histograms.
int m_deadPulserLevelCutoff
Dead channel finding user defined parameters.
std::string m_subDir
Name of subdirectory under EXPERT or SHIFT that the histograms will be stored.
bool m_histAttenLevels
Histogram all values for all histograms.
bool m_doNeighborRatios
Do neighbor ratios.

◆ ~CscCalibMonToolSlope()

CscCalibMonToolSlope::~CscCalibMonToolSlope ( )
inline

Destructor.

Definition at line 47 of file CscCalibMonToolSlope.h.

47{};

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 CscCalibMonToolSlope::bookHistograms ( )
virtual

Books all histograms not retrieved driectly from CscCalcSlope.

Reimplemented from CscCalibMonToolBase.

Definition at line 83 of file CscCalibMonToolSlope.cxx.

84{
86 ATH_MSG_DEBUG( "CscCalibMonToolSlope : in bookHistograms()" );
87
88 if (newRunFlag())
89 {
90 std::string name,title,xaxis,yaxis;
91 int highbound,lowbound,nbins;
92
93 std::string geoPath = getGeoPath();
94 std::string path = getFullPath(geoPath, "Misc", "");
95 MonGroup monGroup(this, path, run, ATTRIB_MANAGED );
96
97 //num bad histograms
98 name = "h_csc_calib_numSignificant";
99 title = "Number of significant results.";
100 xaxis = "Catagory";
101 yaxis = "Num channels with bad value.";
102 lowbound = 1;
103 highbound = 8;
104 m_h_numBad = new TH1I(name.c_str(),title.c_str(),highbound-lowbound,lowbound,highbound);
105 m_h_numBad->GetYaxis()->SetTitle(yaxis.c_str());
106 m_h_numBad->GetXaxis()->SetTitle(xaxis.c_str());
107 m_h_numBad->GetXaxis()->SetBinLabel(m_slopeBadBin,"slope diff");
108 m_h_numBad->GetXaxis()->SetBinLabel(m_interceptBadBin,"intercept diff");
109 m_h_numBad->GetXaxis()->SetBinLabel(m_chi2BadBin,"chi^2/ndf ");
110 m_h_numBad->GetXaxis()->SetBinLabel(m_peaktBadBin,"Peaking Time Diff");
111 m_h_numBad->GetXaxis()->SetBinLabel(m_fracBadBin,"Fractional Deviation");
112 m_h_numBad->GetXaxis()->SetBinLabel(m_deadBadBin,"New (or fixed) Dead Channel");
113 m_h_numBad->GetXaxis()->SetBinLabel(m_missingBadBin,"Num chans w/ no data");
114 m_h_numBad->SetFillColor(m_histCol);
115 monGroup.regHist(m_h_numBad).ignore();
116
117 //--overview histograms-----------------------------------------------------------------
118 /*
119 name = "h_csc_calib_peaktCompareOverview";
120
121
122 title = "Differences between measured peaking time and values stored in condtions database";
123 xaxis = "Difference (ns)";
124 yaxis = "";
125 lowbound = -10;
126 highbound = 10;
127 nbins = 100;
128 m_h_peaktCompareOverview = new TH1F(name.c_str(),title.c_str(),nbins,lowbound,highbound);
129 m_h_peaktCompareOverview->GetXaxis()->SetTitle(xaxis.c_str());
130 m_h_peaktCompareOverview->GetYaxis()->SetTitle(yaxis.c_str());
131 m_h_peaktCompareOverview->SetFillColor(m_histCol);
132 sc = monGroup.regHist(m_h_peaktCompareOverview);
133
134 name = "h_csc_calib_slopeCompareOverview";
135 title = "Differences between measured slope and values stored in condtions database";
136 xaxis = "Difference (fC/ADC)";
137 yaxis = "";
138 lowbound = -10;
139 highbound = 10;
140 nbins = 100;
141 m_h_slopeCompareOverview = new TH1F(name.c_str(),title.c_str(),nbins,lowbound,highbound);
142 m_h_slopeCompareOverview->GetXaxis()->SetTitle(xaxis.c_str());
143 m_h_slopeCompareOverview->GetYaxis()->SetTitle(yaxis.c_str());
144 m_h_slopeCompareOverview->SetFillColor(m_histCol);
145 sc = monGroup.regHist(m_h_slopeCompareOverview);
146
147 name = "h_csc_calib_interceptOverview";
148 title = "Intercepts";
149 xaxis = "Intercept (ADC count)";
150 yaxis = "";
151 lowbound = 0;
152 highbound = 10;
153 nbins = 100;
154 m_h_interceptOverview = new TH1F(name.c_str(),title.c_str(),nbins,lowbound,highbound);
155 m_h_interceptOverview->GetXaxis()->SetTitle(xaxis.c_str());
156 m_h_interceptOverview->GetYaxis()->SetTitle(yaxis.c_str());
157 m_h_interceptOverview->SetFillColor(m_histCol);
158 sc = monGroup.regHist(m_h_interceptOverview);
159
160 name = "h_csc_calib_chi2Overview";
161 title = "chi^2/ndf for slope fits";
162 xaxis = "chi^2/ndf";
163 yaxis = "";
164 lowbound = 0;
165 highbound = 10;
166 nbins = 100;
167 m_h_chi2Overview = new TH1F(name.c_str(),title.c_str(),nbins,lowbound,highbound);
168 m_h_chi2Overview->GetXaxis()->SetTitle(xaxis.c_str());
169 m_h_chi2Overview->GetYaxis()->SetTitle(yaxis.c_str());
170 m_h_chi2Overview->SetFillColor(m_histCol);
171 sc = monGroup.regHist(m_h_chi2Overview);
172 */
173 name = "h_csc_calib_deadOverview";
174 title = "Number of dead channels";
175 lowbound = 1;
176 highbound = 5;
177 nbins = 4;
178 m_h_deadOverview = new TH1F(name.c_str(),title.c_str(),nbins,lowbound,highbound);
179 m_h_deadOverview->GetXaxis()->SetBinLabel(m_totalLiveBin,"Total Live channels");
180 m_h_deadOverview->GetXaxis()->SetBinLabel(m_totalDeadBin,"Total Dead channels");
181 m_h_deadOverview->GetXaxis()->SetBinLabel(m_newLiveBin,"New Live Channels");
182 m_h_deadOverview->GetXaxis()->SetBinLabel(m_newDeadBin,"New Dead Channels");
183 m_h_deadOverview->SetFillColor(m_histColAlert);
184 monGroup.regHist(m_h_deadOverview).ignore();
185
186 name = "h_csc_calib_slopeMissingChans";
187 title = "Number of dead channels";
188 xaxis = "Channel (Hash ID)";
189 yaxis = "";
190 lowbound = 0;
191 highbound = m_maxHashId+1;
192 nbins = m_maxHashId+1;
193 m_h_slopeMissingChans = new TH1F(name.c_str(),title.c_str(),nbins,lowbound,highbound);
194 m_h_slopeMissingChans->GetXaxis()->SetTitle(xaxis.c_str());
195 m_h_slopeMissingChans->GetYaxis()->SetTitle(yaxis.c_str());
197 monGroup.regHist(m_h_slopeMissingChans).ignore();
198
199
200 std::string peaktDataName = "peakt";
201 std::string peaktDataTitle = "Peaking Time";
202 std::string peaktSubDir = "Peakt";
203
204 std::string slopeDataName = "slope";
205 std::string slopeDataTitle = "Pulser Gain Slope";
206 std::string slopeSubDir = "Slope";
207
208 std::string slopeRatioDataName = "slopeRatio";
209 std::string slopeRatioDataTitle = "Ratio of N : N+1 Channel Slopes";
210 std::string slopeRatioSubDir = "SlopeRatio";
211
212 std::string interceptDataName = "intercept";
213 std::string interceptDataTitle = "Intercept";
214 std::string interceptSubDir = "Intercept";
215
216 std::string chi2DataName = "chi2";
217 std::string chi2DataTitle = "Chi^2/ndf for gain slope fit";
218 std::string chi2SubDir = "Chi2";
219
220 std::string deadDataName = "dead";
221 std::string deadDataTitle = "Dead";
222 std::string deadSubDir = "Dead";
223
224 std::string fitResDataName = "fitRes";
225 std::string fitResDataTitle = "Fit Return Value";
226 std::string fitResSubDir = "FitResult";
227
228 //Set naming parameters for histogram category names
229 std::string newCatName = "new";
230 std::string newCatTitle = "New";
231
232 std::string oldCatName = "old";
233 std::string oldCatTitle = "COOL";
234
235 std::string diffCatName = "diff";
236 std::string diffCatTitle = "Difference Between New and COOL";
237
238 //axis info
239 std::string peaktAxisLabel = "Peaking Time (ns)";
240 std::string peaktDiffAxisLabel = "Peaking Time Difference (ns)";
241 int peaktNumBins = 100;
242 float peaktLowBound = 0;
243 float peaktHighBound = 100;
244
245 std::string slopeAxisLabel = "Gain (fC/ADC)";
246 std::string slopeDiffAxisLabel = "Gain Difference (fC/ADC)";
247 int slopeNumBins =300;
248 float slopeLowBound = 0;
249 float slopeHighBound = 5;
250
251 std::string slopeRatioAxisLabel = "Ratio of N/(N+1) channel";
252 int slopeRatioNumBins = 500;
253 float slopeRatioLowBound = 0;
254 float slopeRatioHighBound = 5;
255
256 std::string interceptAxisLabel = "Intercept (ADC counts)";
257 int interceptNumBins = 200;
258 float interceptLowBound = -100;
259 float interceptHighBound = 100;
260
261 std::string chi2AxisLabel = "Chi^2/ndf";
262 int chi2NumBins = 1000;
263 float chi2LowBound = 0;
264 float chi2HighBound = 3000;
265
266 std::string deadAxisLabel = "Is Dead";
267 int deadNumBins = 3;
268 float deadLowBound = -1.5;
269 float deadHighBound = 1.5;
270
271 std::string fitResAxisLabel = "Fit Return Value";
272 int fitResNumBins =10000;
273 float fitResLowBound = 0;
274 float fitResHighBound = 10000;
275
276 //Initialize histogram collections
278 m_peaktNewColl->ignoreY = false;
280 m_peaktOldColl->ignoreY = false;
282 m_peaktDiffColl->ignoreY = false;
283
284
287 m_slopeRatioColl->ignoreY = true;
288 }
289
291 m_slopeNewColl->ignoreY = true;
293 m_slopeOldColl->ignoreY = true;
295 m_slopeDiffColl->ignoreY = true;
296
298 m_interceptColl->ignoreY = true;
299
301 m_chi2Coll->ignoreY = true;
302
303
305 m_deadNewColl->ignoreY = false;
307 m_deadDiffColl->ignoreY = false;
308
310 m_fitResColl->ignoreY = true;
311
312 //Set subdirectory in monitoring root file
313
314 //initialize, name, and book histograms in histogram collections using the bookHistCollection()
315 //function
316
317 ATH_CHECK( bookHistCollection(m_peaktNewColl, peaktDataName, peaktDataTitle, newCatName,
318 newCatTitle, peaktAxisLabel, peaktNumBins, peaktLowBound, peaktHighBound, peaktSubDir) );
319
320 ATH_MSG_DEBUG( "Registering peaktOldColl" );
321 ATH_CHECK( bookHistCollection(m_peaktOldColl, peaktDataName, peaktDataTitle, oldCatName, oldCatTitle,
322 peaktAxisLabel, peaktNumBins, peaktLowBound, peaktHighBound, peaktSubDir) );
323
324 ATH_MSG_DEBUG( "Registering peaktDiffColl" );
325 ATH_CHECK( bookHistCollection(m_peaktDiffColl, peaktDataName, peaktDataTitle, diffCatName, diffCatTitle,
326 peaktDiffAxisLabel, peaktNumBins, peaktLowBound, peaktHighBound, peaktSubDir) );
327
328 ATH_MSG_DEBUG( "Registering slopeRatioColl" );
329 ATH_CHECK( bookHistCollection(m_slopeNewColl, slopeDataName, slopeDataTitle, newCatName,
330 newCatTitle, slopeAxisLabel, slopeNumBins, slopeLowBound, slopeHighBound, slopeSubDir) );
331
332 ATH_MSG_DEBUG( "Registering slopeNewColl" );
333 ATH_CHECK( bookHistCollection(m_slopeRatioColl, slopeRatioDataName, slopeRatioDataTitle, "",
334 "", slopeRatioAxisLabel, slopeRatioNumBins, slopeRatioLowBound, slopeRatioHighBound, slopeRatioSubDir) );
335
336 ATH_MSG_DEBUG( "Registering slopeOldColl" );
337 ATH_CHECK( bookHistCollection(m_slopeOldColl, slopeDataName, slopeDataTitle, oldCatName, oldCatTitle,
338 slopeAxisLabel, slopeNumBins, slopeLowBound, slopeHighBound, slopeSubDir) );
339
340 ATH_MSG_DEBUG( "Registering slopeDiffColl" );
341 ATH_CHECK( bookHistCollection(m_slopeDiffColl, slopeDataName, slopeDataTitle, diffCatName, diffCatTitle,
342 slopeDiffAxisLabel, slopeNumBins, slopeLowBound, slopeHighBound, slopeSubDir) );
343
344 ATH_MSG_DEBUG( "Registering " << interceptDataTitle );
345 ATH_CHECK( bookHistCollection(m_interceptColl, interceptDataName, interceptDataTitle, "",
346 "", interceptAxisLabel, interceptNumBins, interceptLowBound, interceptHighBound,
347 interceptSubDir) );
348
349 ATH_CHECK( bookHistCollection(m_chi2Coll, chi2DataName, chi2DataTitle, "", "",
350 chi2AxisLabel, chi2NumBins, chi2LowBound, chi2HighBound, chi2SubDir) );
351
352 ATH_CHECK( bookHistCollection(m_deadNewColl, deadDataName, deadDataTitle, newCatName, newCatTitle,
353 deadAxisLabel, deadNumBins, deadLowBound, deadHighBound, deadSubDir) );
354
355 ATH_CHECK( bookHistCollection(m_fitResColl, fitResDataName, fitResDataTitle, "", "",
356 fitResAxisLabel, fitResNumBins, fitResLowBound, fitResHighBound, fitResSubDir) );
357
358 }
359 return StatusCode::SUCCESS;
360
361}
#define ATH_CHECK
Evaluate an expression and check for errors.
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.
HistCollection * m_deadDiffColl
HistCollection * m_peaktNewColl
HistCollection * m_slopeNewColl
HistCollections.
HistCollection * m_fitResColl
TH1I * m_h_numBad
Stores number of channels that are bad in several categories.
HistCollection * m_deadNewColl
HistCollection * m_peaktOldColl
int m_slopeBadBin
Bin corresponding to each category in m_h_numbad.
HistCollection * m_slopeRatioColl
HistCollection * m_peaktDiffColl
TH1F * m_h_deadOverview
Overview of dead channels and changes.
HistCollection * m_slopeDiffColl
HistCollection * m_slopeOldColl
HistCollection * m_interceptColl
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 CscCalibMonToolSlope::finalize ( )
virtual

Delete slope sepcific values.

Also calls CscCalibMonToolBase::finalize

Reimplemented from CscCalibMonToolBase.

Definition at line 49 of file CscCalibMonToolSlope.cxx.

50{
51 ATH_MSG_DEBUG( "Slope Finalizing " );
52 delete m_slopeNewColl;
53 delete m_slopeOldColl;
54 delete m_slopeDiffColl;
55 delete m_interceptColl;
56 delete m_chi2Coll;
57 delete m_deadNewColl;
58 delete m_deadDiffColl;
59 delete m_peaktNewColl;
60 delete m_peaktOldColl;
61 delete m_peaktDiffColl;
62
64}
virtual StatusCode finalize()
deletes private members

◆ findDeadChannels()

StatusCode CscCalibMonToolSlope::findDeadChannels ( const CscCalibReportSlope & slopeReport)
private

Look for dead channels.

Definition at line 867 of file CscCalibMonToolSlope.cxx.

868{//This function has grown a bit unwieldly, and duplicates info in sets and arrays. Can this be merged?
869
870 SG::ReadCondHandle<CscCondDbData> readHandle{m_readKey};
871 const CscCondDbData* readCdo{*readHandle};
872
873 //****Find Dead channels
874 IdContext channelContext = m_idHelperSvc->cscIdHelper().channel_context();
875
876 std::set <int> newDead, newUndead;
877
878 const std::set <int>& pulsedChambers = slopeReport.getPulsedChambers();
879 if(pulsedChambers.empty())
880 {
881 ATH_MSG_ERROR( "No pulsed chambers stored in slopeReport! Skipping dead channel collecting!" );
882 return StatusCode::RECOVERABLE;
883 }
884
885 const std::map <int,TProfile*>& ampProfs = slopeReport.getAmpProfs();
886 if(ampProfs.empty())
887 {
888 ATH_MSG_ERROR( "There are no amplitude profiles in the slope report! Can't find dead chans." );
889 return StatusCode::RECOVERABLE;
890 }
891
892 std::map <int,TProfile*>::const_iterator profItr = ampProfs.begin();
893
894 int pulserLevel = profItr->first;
895 ATH_MSG_INFO( "Looking for dead channels. Lowest attenuation level is "
896 << pulserLevel );
897 ATH_MSG_INFO( "Dead channel cutoff is: "<< m_deadADCCutoff );
898
899 if(pulserLevel < m_deadPulserLevelCutoff)
900 {//Pulser level is low enough (pulse voltage is high enough) to test for dead channels
901
902 const TProfile * ampProf = profItr->second;
903 if(!ampProf)
904 {
905 ATH_MSG_ERROR( "There is no profile for this attenuation level! Skipping dead channel finding!" );
906 return StatusCode::RECOVERABLE;
907 }
908
909 ATH_MSG_DEBUG( "There were " << pulsedChambers.size()
910 << " chambers pulsed." );
911
912 //Prepare dead channel content
913 std::vector<float> & currentDeadVals = m_deadNewColl->data;
914 std::vector<float> & diffDeadVals = m_deadDiffColl->data;
915
916 setArray(currentDeadVals,0,m_maxHashId+1);
917 setArray(diffDeadVals,0,m_maxHashId+1);
918
919 //Loop through each channel in TProfile (bin = hash + 1), and check value to see
920 //if its dead
921 float adc, ped;
922 bool wasDead, isDead;
923 int statusWord;
924 for(unsigned int hashItr = 0; hashItr <= m_maxHashId ; hashItr++)
925 {
926 Identifier id;
927 m_idHelperSvc->cscIdHelper().get_id(hashItr,id, &channelContext);
928 int chamberLayer = m_idHelperSvc->cscIdHelper().chamberLayer(id);
929 IdentifierHash chamberHash;
930 m_idHelperSvc->cscIdHelper().get_module_hash(id, chamberHash);
931
932 if(chamberLayer == 2 && pulsedChambers.count((int)chamberHash))
933 {//This is a good chamber layer and it is a pulsed chamber
934
935 ATH_CHECK(readCdo->readChannelStatus(hashItr, statusWord));
936 ATH_CHECK(readCdo->readChannelPed (hashItr, ped ));
937 wasDead = statusWord & 0x1;
938
939 adc = ampProf->GetBinContent( hashItr + 1 );
940 isDead = ( (adc-ped) < m_deadADCCutoff);
941
942 if(isDead && !wasDead)
943 {
944 ATH_MSG_INFO( "NEW DEAD CHANNEL! Hash: " << hashItr << " ped: " << ped << " adc " << adc << " diff: " << adc-ped );
945 newDead.insert(hashItr);
947 diffDeadVals[hashItr] = 1;
948 m_detailedHashIds[hashItr] = true;
949 }
950 if(!isDead && wasDead)
951 {
952 ATH_MSG_INFO( "PREVIOUSLY DEAD CHANNEL NOW LIVE! Hash: " << hashItr );
953 newUndead.insert(hashItr);
955 diffDeadVals[hashItr] = -1;
956 m_detailedHashIds[hashItr] = true;
957 }
958
959 if(isDead)
960 {
961 currentDeadVals[hashItr] = 1;
963 }
964 else
966
967 }//end if chamberLayer
968
969 }//End for(hashItr)
970
971 //***Generate histograms
972 ATH_MSG_INFO( "Generating dead histograms" );
974
975 //ATH_CHECK( copyDataToHists(m_deadDiffColl) );
976 ATH_MSG_INFO( "Finished generating dead histograms" );
977
978 //***Fill COOL input file if there are new dead channels******
979 if(newDead.size() || newUndead.size())
980 {
981 ATH_MSG_INFO( "There are " << newDead.size()
982 << " newly dead channels and " << newUndead.size()
983 << " newly live channels" );
984 std::ofstream out("deadInfo.cal");
985 out <<"00-00 " << newDead.size() + newUndead.size() << " dead_stat END_HEADER\n";
986
987 for(const auto & thisDeadChannel:newDead)
988 {
989 Identifier id;
990 m_idHelperSvc->cscIdHelper().get_id(thisDeadChannel,id, &channelContext);
991 IdentifierHash chamHash;
992 m_idHelperSvc->cscIdHelper().get_module_hash(id, chamHash);
993 out << thisDeadChannel << " " << (int)chamHash << " "
994 << m_idHelperSvc->cscIdHelper().show_to_string(id, &channelContext) << " 1\n";
995 }
996
997 for(const auto undeadChannel : newUndead)
998 {
999 Identifier id;
1000 m_idHelperSvc->cscIdHelper().get_id(undeadChannel,id, &channelContext);
1001 IdentifierHash chamHash;
1002 m_idHelperSvc->cscIdHelper().get_module_hash(id, chamHash);
1003 out << undeadChannel << " " << (int)chamHash << " "
1004 << m_idHelperSvc->cscIdHelper().show_to_string(id, &channelContext)
1005 << "0\n";
1006 }
1007 out.close();
1008 }//end if newDead.size()
1009
1010 }//end if(pulserLevel < cutoff)
1011 else
1012 {
1013 ATH_MSG_ERROR( "Lowest pulser level isn't low enough to count as a dead channel test. Skipping." );
1014 return StatusCode::RECOVERABLE;
1015 }
1016
1017
1018 return StatusCode::SUCCESS;
1019}
#define ATH_MSG_INFO(x)
SG::ReadCondHandleKey< CscCondDbData > m_readKey
Access to COOL database.
virtual StatusCode copyDataToHists(HistCollection *histCollection)
Fills the histograms in the histCollection based on the data in the std::vector in the HistCollection...
std::vector< float > & setArray(std::vector< float > &array, const float &value, const int &numEntries)
const std::set< int > & getPulsedChambers() const
getPulsedChambers - Contains the chambers that were pulsed.
const std::map< int, TProfile * > & getAmpProfs() const
getAmpProfs - get the map of ampProfs stored.
StatusCode readChannelPed(IdentifierHash, float &) const
StatusCode readChannelStatus(IdentifierHash, int &) const

◆ genNeighborRatios()

void CscCalibMonToolSlope::genNeighborRatios ( const std::vector< float > & source,
std::vector< float > & ratios ) const
private

Generated next neighbor channel ratios of the slopes.

Definition at line 1029 of file CscCalibMonToolSlope.cxx.

1029 {
1030 size_t nEntries = source.size();
1031 if(nEntries != ratios.size()){
1032 ATH_MSG_ERROR( " in genNeighborRatios, source (" << nEntries << ") and ratio (" << ratios.size()
1033 << ") vectors have different numbers of entries!" );
1034 return;
1035 }
1036
1037 //loop through every channel, taking the ratio between it and the next
1038 size_t nloops = nEntries -1; //Can't do this to the last channel
1039 for(size_t cnt=0; cnt < nloops; cnt++){
1040 ratios[cnt] = source[cnt]/source[cnt+1];
1041 }
1042}

◆ 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 CscCalibMonToolSlope::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

Parameters
parValsValues for a particular parameter

Reimplemented from CscCalibMonToolBase.

Definition at line 374 of file CscCalibMonToolSlope.cxx.

375{
376 ATH_MSG_DEBUG( "CscCalibMonToolSlope : in handleParameter()" );
377
378 //The whole point of this funciton is to pass the correct histograms and setup info
379 //to CsccalibMonToolBase::procParameter. To organize this, we store the setup info into
380 //these structs:
381 ProcSetupInfo simpleSet;
382
383 //--setup for this parameter
384 std::string parName = parVals->parName();
385 /*if(parName == "peakt")
386 {
387 m_log << MSG::INFO << "Evaluating peaking times" << endmsg;
388 simpleSet.dbName = parVals->parName();
389 simpleSet.badHist = m_h_numBad;
390 simpleSet.badBin = m_peaktBadBin;
391 simpleSet.maxDiff = m_peaktMaxDiff;
392 simpleSet.overDiff = m_h_peaktCompareOverview;
393 simpleSet.overChi2 = m_h_chi2Overview;
394 simpleSet.chi2BadBin = m_chi2BadBin;
395 simpleSet.doChi2 = false;
396 simpleSet.vals = &m_peaktNewColl->data;
397 simpleSet.errors = &m_peaktNewColl->errors;
398 simpleSet.oldVals = &m_peaktOldColl->data;
399 simpleSet.diffs = &m_peaktDiffColl->data;
400 simpleSet.missingBadBin = m_missingBadBin;
401 simpleSet.missingChans = m_h_slopeMissingChans;
402 simpleSet.expectedChannels = m_expectedHashIdsPrec;
403 }
404 */
405 if(parName == "pslope")
406 {
407 ATH_MSG_INFO( "Evaluating slopes" );
408 simpleSet.dbName = parVals->parName();
409 simpleSet.badHist = m_h_numBad;
410 simpleSet.badBin = m_slopeBadBin;
411 simpleSet.maxDiff = m_slopeMaxDiff;
412 simpleSet.overDiff = m_h_slopeCompareOverview;
413 simpleSet.overChi2 = m_h_chi2Overview;
414 simpleSet.chi2BadBin = m_chi2BadBin;
415 simpleSet.chi2Max = m_chi2Max;
416 simpleSet.doChi2 = true;
417 simpleSet.vals = &m_slopeNewColl->data;
418 simpleSet.errors = &m_slopeNewColl->errors;
419 simpleSet.oldVals = &m_slopeOldColl->data;
420 simpleSet.diffs = &m_slopeDiffColl->data;
421 simpleSet.chi2s = &m_chi2Coll->data;
422 simpleSet.missingBadBin = m_missingBadBin;
423 simpleSet.missingChans = m_h_slopeMissingChans;
424 simpleSet.expectedChannels = m_expectedHashIdsPrec;
425 }
426 else if (parName == "pinter")
427 {
428 ATH_MSG_INFO( "Evaluating intercepts" );
429 simpleSet.expectedVal = 0;
430 simpleSet.badHist = m_h_numBad;
431 simpleSet.badBin = m_interceptBadBin;
432 simpleSet.maxDiff = m_interceptMax;
433 simpleSet.overDiff = m_h_interceptOverview;
434 simpleSet.overChi2 = m_h_chi2Overview;
435 simpleSet.doChi2 = false;
436 simpleSet.vals = &m_interceptColl->data;
437 simpleSet.errors = &m_interceptColl->errors;
438 simpleSet.oldVals = nullptr ;
439 simpleSet.diffs = nullptr ;
440 simpleSet.missingBadBin = m_missingBadBin;
441 simpleSet.missingChans = m_h_slopeMissingChans;
442 simpleSet.expectedChannels = m_expectedHashIdsPrec;
443 }
444 else
445 {
446 ATH_MSG_INFO( "CscCalibMonToolSlope : Did not recognize parameter name "
447 << parName << ". This is usually ok." );
448 return StatusCode::FAILURE;
449 }
450
451 //Process parameter by filling histograms in simpleSet and allIdsSet structures
452 ATH_CHECK( procParameter(parVals,&simpleSet) );
453
454
455 if(parName == "peakt")
456 {
457 ATH_MSG_INFO( "Generating peaking time histograms" );
458
462 }
463 if(parName == "pslope")
464 {
465
466 ATH_MSG_INFO( "Generating slope histograms" );
467
471 }
472
477 }
478 if(parName == "pinter")
479 {
480 ATH_MSG_INFO( "Generating intercept histograms" );
482 }
483 return StatusCode::SUCCESS;
484}
std::set< int > m_expectedHashIdsPrec
virtual StatusCode procParameter(const CscCalibResultCollection *parVals, ProcSetupInfo *simpleSet)
Processors a parameter type.
void genNeighborRatios(const std::vector< float > &source, std::vector< float > &ratios) const
Generated next neighbor channel ratios of the slopes.
TH1F * m_h_slopeCompareOverview
Histograms that simply histogram all entries for a value.
const std::string & parName() const
the identify of this collection
Contains info to be passed to procParameter.

◆ initialize()

StatusCode CscCalibMonToolSlope::initialize ( )
virtual

Initialize slope sepcific values.

Also calls CscCalibMonToolBase::intialize

Reimplemented from CscCalibMonToolBase.

Definition at line 66 of file CscCalibMonToolSlope.cxx.

67{
70
71 ATH_MSG_DEBUG( "Expected chamber layer is " << m_expectedChamberLayer );
72
73 for(unsigned int hash = 0 ; hash <= m_maxHashId; hash++)
74 {
75 m_fracProfs.push_back(nullptr);
76 }
77 m_generic_path_csccalibmonitoring = "MUON_CSC_PULSER";
78
79 return StatusCode::SUCCESS;
80}
unsigned int m_expectedChamberLayer
bool m_onlyExpectPrecisionHashIds
Hash Ids one would expect to be in calibration data.
virtual StatusCode initialize()
initializes services, tools, etc.
std::vector< TProfile * > m_fracProfs
Holds fractional deviation TProfiles.

◆ 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}

◆ makeFracGraphs()

StatusCode CscCalibMonToolSlope::makeFracGraphs ( const CscCalibReportSlope & slopeReport)
private

Make fractional deviation plots between the gain plot points and the fit.

Definition at line 718 of file CscCalibMonToolSlope.cxx.

719{
720 ATH_MSG_DEBUG( "CscCalibMonToolSlope : in makeFracGraphs()" );
721 const std::vector<TGraphErrors*>& calGraphs = slopeReport.getCalGraphs();
722 if(calGraphs.empty())
723 {
724 ATH_MSG_ERROR( "No calGraphs in slopeReport. Not going to make fractional deviation"
725 << " plots." );
726 return StatusCode::RECOVERABLE;
727 }
728
729 //Loop through all channels in geometry:
730 const std::vector <Identifier> & ids = m_idHelperSvc->cscIdHelper().idVector();
731 for(const auto & thisChamberId:ids)
732 {
733 ATH_MSG_VERBOSE( "in Chamber loop " );
734 unsigned int stationSize = m_idHelperSvc->cscIdHelper().stationName(thisChamberId); //51 = large, 50 = small
735 unsigned int stationPhi = m_idHelperSvc->cscIdHelper().stationPhi(thisChamberId);
736 int stationEta = m_idHelperSvc->cscIdHelper().stationEta(thisChamberId);
737 unsigned int sector = getSector(stationPhi,stationSize);
738
739 std::vector <Identifier> stripVect;
740 m_idHelperSvc->cscIdHelper().idChannels(thisChamberId,stripVect);
741 for(const auto & thisStrip : stripVect)
742 {
743 ATH_MSG_VERBOSE( "in strip loop " );
744 IdentifierHash stripHash;
745 m_idHelperSvc->cscIdHelper().get_channel_hash(thisStrip,stripHash);
746 if(!m_expectedHashIdsPrec.count((int)stripHash)){
747 ATH_MSG_VERBOSE( "Skipping hash" << (int)stripHash );
748 continue;
749 }
750 ATH_MSG_VERBOSE( "strip hash " << stripHash );
751
752 const TGraphErrors * graph = calGraphs[stripHash];
753 if(!graph)
754 {
755 ATH_MSG_VERBOSE( "SKipping graph" );
756 continue;
757 }
758
759 TF1 * func = graph->GetFunction("simpleFunc");
760 if(!func){
761 ATH_MSG_DEBUG( "Could not retrieve function, skipping this graph" );
762 continue;
763 }
764
765 ATH_MSG_VERBOSE( "Address is " << graph );
766 ATH_MSG_VERBOSE( "name is "<< graph->GetName() );
767 ATH_MSG_VERBOSE( "Getting n " );
768
769 int nPoints = graph->GetN();
770 ATH_MSG_VERBOSE( "Got n " );
771 //Get identification information
772 //Note, we don't ask for measuresPhi because there should be no
773 //TGraphs with Y anyways.
774 ATH_MSG_VERBOSE( "getting id info " );
775 unsigned int layer = m_idHelperSvc->cscIdHelper().wireLayer(thisStrip);
776 unsigned int strip = m_idHelperSvc->cscIdHelper().strip(thisStrip);
777 ATH_MSG_VERBOSE( "Got strip and layer" );
778 //initialize fractional deviation profile
779 ATH_MSG_VERBOSE( "initializing profile " );
780
781 std::stringstream nameStream;
782 nameStream.setf(std::ios::right,std::ios::adjustfield);
783 nameStream << "dev_"
784 << "X" //orientation
785 << "_eta_" << stationEta
786 << "_sector_" << std::setw (2) << std::setfill ('0') << sector
787 << "_layer_" << layer
788 << "_strip_" << strip;
789 std::stringstream titleStream;
790 titleStream << "Fractional Deviation of Measured ADC From Fit ADC for Precision Direction"
791 << ", Sector " << sector
792 << ", Eta " << stationEta
793 << ", Layer " << layer
794 << ", Strip " << strip;
795 TProfile * fracProf
796 = new TProfile(nameStream.str().c_str(), titleStream.str().c_str(), nPoints,
797 1, nPoints +1);
798 fracProf->GetXaxis()->SetTitle("Pulser Attenuator Settings in dB (not auscaled axis) ");
799 fracProf->GetYaxis()->SetTitle("ADC response");
800
801 ATH_MSG_VERBOSE( "getting parameters " );
802 float intercept = func->GetParameter(0);
803 float slope = func->GetParameter(1);
804 ATH_MSG_VERBOSE( "got them " );
805
806 //Loop through points in graph, and compare the adc value and charge
807 //to that expected from the fit parameters from the TF1 object
808 double adc, db, calcAdc;
809 bool isBad = false;
810 for(int itr = 0; itr < nPoints; itr++)
811 {
812 ATH_MSG_VERBOSE( "in point loop on point " << itr );
813
814 //Find Fractional Deviation
815 graph->GetPoint(itr,db,adc);
816 calcAdc = intercept + slope*std::pow(10,db/-20);
817 double frac = (adc - calcAdc)/( calcAdc - intercept);
818
819 //Test to see if this is a bad result
820 ATH_MSG_VERBOSE( "bad result test " );
821 if(frac > m_fracDevMax)
822 {
824 isBad = true;
825 }
826
827 //test for nan, and put into fracProf
828 if (frac==frac)
829 {
830 ATH_MSG_VERBOSE( "filling fracProf " );
831 fracProf->Fill(itr +1, frac);
832 }
833
834 //Label bin with db amount
835 ATH_MSG_VERBOSE( "labeling bin " );
836 std::stringstream binLabel;
837 binLabel << db;
838 fracProf->GetXaxis()->SetBinLabel(itr+1, binLabel.str().c_str());
839 }
840 ATH_MSG_VERBOSE( "storing fracProf " );
841 //Store fraction graph for later
842 if(stripHash > m_maxHashId)
843 {
844 ATH_MSG_ERROR( "Tried to assign fracProf with stripHash " << stripHash
845 << " when max stripHash is " << m_maxHashId );
846 return StatusCode::RECOVERABLE;
847 }
848
849 m_fracProfs[stripHash] = fracProf;
850 //Record if this was a bad channel
851 if(isBad && ((int)m_numBad <= m_maxDetailedChannels) )
852 {
853 if(!m_detailedHashIds[stripHash])
854 {
855 m_numBad++;
856 m_detailedHashIds[stripHash] = true;
857 }
858 }
859
860 }//end loop over strips
861 }//end loop over chambers
862 ATH_MSG_DEBUG( "Finished generating frac graphs" );
863
864 return StatusCode::SUCCESS;
865}//end makeFracGraphs
int m_maxDetailedChannels
To keep track of channels that should have more data printed to root file.
const std::vector< TGraphErrors * > & getCalGraphs() const
Retrieve pedestal amplitude histogram vector.

◆ 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 CscCalibMonToolSlope::postProc ( )
privatevirtual

postProc retrieves the plots fit to produce the gain

Reimplemented from CscCalibMonToolBase.

Definition at line 488 of file CscCalibMonToolSlope.cxx.

489{
490 ATH_MSG_DEBUG( "CscCalibMonToolSlope : in retrieveHistos()" );
491
492 ATH_MSG_DEBUG( "Do all detailed is: " << m_doAllDetailed );
493
494
495
496 IdContext chanContext = m_idHelperSvc->cscIdHelper().channel_context();
497
498 //Get the slopeReport, checking for pointer errors along the way
499 const CscCalibReportContainer* repCont;
500 if (!evtStore()->retrieve(repCont, m_histKey).isSuccess())
501 {
502 ATH_MSG_ERROR( " Cannot retrieve object from storegate with key "
503 << m_histKey << " aborting retrieving hists " );
504 return StatusCode::RECOVERABLE;
505 }
506 if(repCont->size() != 1)
507 {
508 ATH_MSG_ERROR( "Container with key " << m_histKey
509 << " does not have a size of one. Do not know how to proceed, so aborting"
510 << " retrieving calibration histograms." );
511 return StatusCode::RECOVERABLE;
512 }
513
514 const CscCalibReportSlope * slopeReport =
515 dynamic_cast<const CscCalibReportSlope *>(repCont->front());
516 if(!slopeReport)
517 {
518 ATH_MSG_ERROR( "No report stored in the container with key " << m_histKey
519 << ". Aborting retrieving histograms." );
520 return StatusCode::RECOVERABLE;
521 }
522 if(slopeReport->getLabel() != "calGraphs")
523 {
524 ATH_MSG_ERROR( "Incorect object retrieved from container with key " << m_histKey
525 << ". Aborting hist retrieval" );
526 return StatusCode::RECOVERABLE;
527 }
528
529 //ampProfs
530 const std::map <int,TProfile*>& ampProfs = slopeReport->getAmpProfs();
531 if(ampProfs.empty())
532 {
533 ATH_MSG_ERROR( "There are no amplitude profiles in the slope report! Can't find dead chans." );
534 return StatusCode::RECOVERABLE;
535 }
536
538 for(const auto & [attenuationVal, pProfile] : ampProfs){
539
540 const float atten = attenuationVal * 0.5f;
541 const std::string attenStr = std::to_string(atten);
542
544 ampColl->ignoreY = true;
545
546 //put into ampColls to make for easy deleting later
547 m_ampColls.push_back(ampColl);
548
549
550 std::string dataName = "amp_atten" + attenStr;
551 std::string dataTitle = "ADC response at attenuation " + attenStr + " db" ;
552 std::string axisLabel = "ADC";
553 unsigned int numBins = 300;
554 float lowBound = 0;
555 float highBound = 3000;
556 std::string subDir = "AmpAtten" + attenStr;
557
558 bookHistCollection(ampColl, dataName, dataTitle, "", "", axisLabel, numBins, lowBound, highBound, subDir).ignore();
559 for(unsigned int stripHash = 0; stripHash < m_maxHashId; stripHash++){
560 ampColl->data[stripHash] = pProfile->GetBinContent(stripHash +1);
561 }
562
563 ATH_CHECK( copyDataToHists(ampColl) );
564 }
565 }
566
567
568 const std::vector<float>& fitResVec = slopeReport->getFitResults();
569 m_fitResColl->data = fitResVec;
571
572 //Generate fractional deviation histograms
573 ATH_MSG_DEBUG( "About to generate fractional deviation graphs" );
574 if(!makeFracGraphs(*slopeReport).isSuccess())
575 ATH_MSG_WARNING( "Failed to generate fractional deviation graphs. Continuing anyway.." );
576
577
578 ATH_MSG_DEBUG( "About to find dead channels" );
579 //Determine dead channels
580 //sc = findDeadChannels(*slopeReport);
581 //if(!sc.isSuccess())
582 // m_log << MSG::WARNING << "Failure while finding dead channels" << endmsg;
583
584
585 //Put extra info for those channels indicated in m_detailedHashIds
586 ATH_MSG_DEBUG( "Picking detailed graphs to output to root file" );
588 {
589 const std::vector<TGraphErrors*>& calGraphs
590 = slopeReport->getCalGraphs();
591 if(calGraphs.empty())
592 {
593 ATH_MSG_ERROR( "No calGraph stored inside object with key " << m_histKey
594 << ". Aborting hist retrieval." );
595 return StatusCode::RECOVERABLE;
596 }
597 else
598 ATH_MSG_INFO( "Got calGraphs" );
599
600 const std::vector<TH1I*>& bitHists = slopeReport->getBitHists();
601 if(bitHists.empty())
602 ATH_MSG_INFO( "No bit histogram vector found from calibration. "
603 << " Won't be in monitoring output file. " );
604 else
605 ATH_MSG_INFO( "Got bitHists" );
606
607
608 //These are the channels we will get detailed forr.
609 for(unsigned int idItr = 0; idItr < m_maxHashId; idItr++)
610 {
611 ATH_MSG_ERROR("Calgraph Address: " << calGraphs[idItr]);
612 if(m_expectedHashIdsPrec.count(idItr) && (m_detailedHashIds[idItr] || (m_doAllDetailed) ) )
613 {
614 ATH_MSG_ERROR("Doing detailed plots of hash " << idItr);
615
616 Identifier chanId;
617 m_idHelperSvc->cscIdHelper().get_id(IdentifierHash(idItr), chanId, &chanContext);
618 int stationSize = m_idHelperSvc->cscIdHelper().stationName(chanId);
619 int stationEta = m_idHelperSvc->cscIdHelper().stationEta(chanId);
620 int stationPhi = m_idHelperSvc->cscIdHelper().stationPhi(chanId);
621 int wireLayer = m_idHelperSvc->cscIdHelper().wireLayer(chanId);
622 int measuresPhi = m_idHelperSvc->cscIdHelper().measuresPhi(chanId);
623 int strip = m_idHelperSvc->cscIdHelper().strip(chanId);
624 int sector = getSector(stationPhi, stationSize);
625
626 std::string geoPath = getGeoPath(stationEta, sector, wireLayer, measuresPhi);
627 std::string calGraphPath = getFullPath(geoPath, "CalGraphs","");
628 std::string fracPath = getFullPath(geoPath,"FracProf","");
629 std::string bitHistPath = getFullPath(geoPath, "BitHists", "");
630
631 //Record calgraph
632 TGraphErrors * sourceGraph =
633 const_cast<TGraphErrors*>(calGraphs[idItr]);
634 if(!sourceGraph)
635 {
636 ATH_MSG_ERROR( "The requested calgraph for hash "
637 << idItr << " doesn't exist in CscCalibReport object!" );
638 }
639 else {
640 std::stringstream name;
641 name << "calfit"
642 << "_EC" << getEndCap(stationEta)
643 << "_sector_" << sector
644 << "_layer_" << wireLayer
645 << "_" << (measuresPhi ? "trans" : "prec")
646 << "_strip_"
647 << std::setfill ('0') << std::setw (measuresPhi ? 2 : 3)
648 << strip;
649
650 sourceGraph->SetName(name.str().c_str());
651 ATH_MSG_DEBUG( "CalGraph axis title: " << sourceGraph->GetXaxis()->GetTitle() );
652
653 ATH_CHECK( regGraph(sourceGraph, calGraphPath, run, ATTRIB_MANAGED) );
654 }
655
656 //record fracDev graph
657 TProfile * sourceProf = m_fracProfs[idItr];
658 if(!sourceProf)
659 {
660 ATH_MSG_ERROR( "There is no fractional profile available for hash "
661 << idItr << ". Quitting retrieveHistos()." );
662 }
663 else{
664 std::stringstream fracName;
665 fracName << "frac_"
666 << "_EC" << getEndCap(stationEta)
667 << "_sector_" << sector
668 << "_layer_" << wireLayer
669 << "_" << (measuresPhi ? "trans" : "prec")
670 << "_strip_"
671 << std::setfill ('0') << std::setw (measuresPhi ? 2 : 3)
672 << strip;
673
674 sourceProf->SetName(fracName.str().c_str());
675
676 ATH_CHECK( regHist(sourceProf, fracPath, run, ATTRIB_MANAGED) );
677 }
678
679 //Bit map histograms
680 //copy source histogram into new histogram, and store
681 if(!bitHists.empty())
682 {
683 TH1I * bitHist = const_cast<TH1I*>(bitHists[idItr]);
684 if(!bitHist)
685 {
686 ATH_MSG_ERROR( "There is no bit histogram with hashId "
687 << idItr << " Quiting out of detailed histogram loop." );
688 }
689 else {
690
691 std::stringstream name2;
692 name2 << "h_bitMap"
693 << "_EC" << getEndCap(stationEta)
694 << "_sector_" << sector
695 << "_layer_" << wireLayer
696 << "_" << (measuresPhi ? "trans" : "prec")
697 << "_strip_"
698 << std::setfill ('0') << std::setw (measuresPhi ? 2 : 3)
699 << strip;
700 // TH1I * newHist2 = (TH1I*)bitHist->Clone(name2.str().c_str());
701 bitHist->SetName(name2.str().c_str());
702 bitHist->SetFillColor((m_detailedHashIds[idItr] ? m_histColAlert : m_histCol));
703
704 //ATH_CHECK( regHist(newHist2, chanPath, run, ATTRIB_MANAGED) );
705 ATH_CHECK( regHist(bitHist, bitHistPath, run, ATTRIB_MANAGED) );
706 }
707 }//end if bithists*/
708
709 }//end if (m_detailedHashIds)
710 else
711 ATH_MSG_ERROR("Skipping hash " << idItr << " " << m_expectedHashIdsPrec.count(idItr) << " " << m_doAllDetailed);
712 }//end idItr loop
713 }//if numBad > 0
714 return StatusCode::SUCCESS;
715}// end retrieveHistos
ServiceHandle< StoreGateSvc > & evtStore()
DataVector< HistCollection > m_ampColls
StatusCode makeFracGraphs(const CscCalibReportSlope &slopeReport)
Make fractional deviation plots between the gain plot points and the fit.
const std::string & getLabel() const
const std::vector< float > & getFitResults() const
getFitReturns - Contains slope fit results.
const std::vector< TH1I * > & getBitHists() const
Retrieve bit histogram vector.
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 ...
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...

◆ 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
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}

◆ 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}

◆ setArray()

std::vector< float > & CscCalibMonToolSlope::setArray ( std::vector< float > & array,
const float & value,
const int & numEntries )
private

Definition at line 1022 of file CscCalibMonToolSlope.cxx.

1023{
1024 for(int i = 0 ; i < numEntries; i++)
1025 array[i] = value;
1026 return array;
1027}

◆ 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_ampColls

DataVector<HistCollection> CscCalibMonToolSlope::m_ampColls
private

Definition at line 122 of file CscCalibMonToolSlope.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 CscCalibMonToolSlope::m_chi2BadBin {3}
private

Definition at line 93 of file CscCalibMonToolSlope.h.

◆ m_chi2Coll

HistCollection* CscCalibMonToolSlope::m_chi2Coll {}
private

Definition at line 115 of file CscCalibMonToolSlope.h.

115{};

◆ m_chi2Max

float CscCalibMonToolSlope::m_chi2Max {}
private

Definition at line 90 of file CscCalibMonToolSlope.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_deadADCCutoff

int CscCalibMonToolSlope::m_deadADCCutoff
private

Definition at line 131 of file CscCalibMonToolSlope.h.

◆ m_deadBadBin

int CscCalibMonToolSlope::m_deadBadBin {6}
private

Definition at line 94 of file CscCalibMonToolSlope.h.

94{6},m_missingBadBin{7};

◆ m_deadDiffColl

HistCollection * CscCalibMonToolSlope::m_deadDiffColl {}
private

Definition at line 116 of file CscCalibMonToolSlope.h.

116{}, *m_deadDiffColl{};

◆ m_deadNewColl

HistCollection* CscCalibMonToolSlope::m_deadNewColl {}
private

Definition at line 116 of file CscCalibMonToolSlope.h.

116{}, *m_deadDiffColl{};

◆ m_deadPulserLevelCutoff

int CscCalibMonToolSlope::m_deadPulserLevelCutoff
private

Dead channel finding user defined parameters.

Definition at line 131 of file CscCalibMonToolSlope.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.

◆ m_doBadDetailed

bool CscCalibMonToolBase::m_doBadDetailed {}
protectedinherited

Definition at line 123 of file CscCalibMonToolBase.h.

123{}, m_doBadDetailed{};

◆ m_doNeighborRatios

bool CscCalibMonToolSlope::m_doNeighborRatios {}
private

Do neighbor ratios.

Definition at line 84 of file CscCalibMonToolSlope.h.

84{};

◆ 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_fileKey

std::string ManagedMonitorToolBase::m_fileKey
protectedinherited

Definition at line 834 of file ManagedMonitorToolBase.h.

◆ m_fitResColl

HistCollection* CscCalibMonToolSlope::m_fitResColl {}
private

Definition at line 120 of file CscCalibMonToolSlope.h.

120{};

◆ m_fracBadBin

int CscCalibMonToolSlope::m_fracBadBin {5}
private

Definition at line 93 of file CscCalibMonToolSlope.h.

◆ m_fracDevMax

float CscCalibMonToolSlope::m_fracDevMax {}
private

Definition at line 90 of file CscCalibMonToolSlope.h.

◆ m_fracProfs

std::vector<TProfile*> CscCalibMonToolSlope::m_fracProfs
private

Holds fractional deviation TProfiles.

Definition at line 109 of file CscCalibMonToolSlope.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_h_chi2Overview

TH1F * CscCalibMonToolSlope::m_h_chi2Overview {}
private

Definition at line 101 of file CscCalibMonToolSlope.h.

◆ m_h_deadOverview

TH1F* CscCalibMonToolSlope::m_h_deadOverview {}
private

Overview of dead channels and changes.

Definition at line 106 of file CscCalibMonToolSlope.h.

106{};

◆ m_h_interceptOverview

TH1F * CscCalibMonToolSlope::m_h_interceptOverview {}
private

Definition at line 101 of file CscCalibMonToolSlope.h.

◆ m_h_numBad

TH1I* CscCalibMonToolSlope::m_h_numBad {}
private

Stores number of channels that are bad in several categories.

Definition at line 98 of file CscCalibMonToolSlope.h.

98{};

◆ m_h_slopeCompareOverview

TH1F* CscCalibMonToolSlope::m_h_slopeCompareOverview {}
private

Histograms that simply histogram all entries for a value.

Definition at line 101 of file CscCalibMonToolSlope.h.

◆ m_h_slopeMissingChans

TH1F * CscCalibMonToolSlope::m_h_slopeMissingChans {}
private

Definition at line 102 of file CscCalibMonToolSlope.h.

102{};

◆ 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_histAttenLevels

bool CscCalibMonToolSlope::m_histAttenLevels {}
private

Histogram all values for all histograms.

Definition at line 87 of file CscCalibMonToolSlope.h.

87{};

◆ 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 CscCalibMonToolSlope::m_histKey
private

Storegate key for pedestal amplitude histograms.

Definition at line 125 of file CscCalibMonToolSlope.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_interceptBadBin

int CscCalibMonToolSlope::m_interceptBadBin {2}
private

Definition at line 93 of file CscCalibMonToolSlope.h.

◆ m_interceptColl

HistCollection* CscCalibMonToolSlope::m_interceptColl {}
private

Definition at line 114 of file CscCalibMonToolSlope.h.

114{};

◆ m_interceptMax

float CscCalibMonToolSlope::m_interceptMax {}
private

Definition at line 90 of file CscCalibMonToolSlope.h.

◆ 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_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_missingBadBin

int CscCalibMonToolSlope::m_missingBadBin {7}
private

Definition at line 94 of file CscCalibMonToolSlope.h.

94{6},m_missingBadBin{7};

◆ 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_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_newDeadBin

int CscCalibMonToolSlope::m_newDeadBin {4}
private

Definition at line 96 of file CscCalibMonToolSlope.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_newLiveBin

int CscCalibMonToolSlope::m_newLiveBin {3}
private

Definition at line 96 of file CscCalibMonToolSlope.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_numBad

unsigned int CscCalibMonToolBase::m_numBad {}
protectedinherited

Definition at line 115 of file CscCalibMonToolBase.h.

115{};

◆ 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_peaktBadBin

int CscCalibMonToolSlope::m_peaktBadBin {4}
private

Definition at line 93 of file CscCalibMonToolSlope.h.

◆ m_peaktDiffColl

HistCollection * CscCalibMonToolSlope::m_peaktDiffColl {}
private

Definition at line 113 of file CscCalibMonToolSlope.h.

◆ m_peaktMaxDiff

float CscCalibMonToolSlope::m_peaktMaxDiff {}
private

Definition at line 90 of file CscCalibMonToolSlope.h.

◆ m_peaktNewColl

HistCollection* CscCalibMonToolSlope::m_peaktNewColl {}
private

Definition at line 113 of file CscCalibMonToolSlope.h.

◆ m_peaktOldColl

HistCollection * CscCalibMonToolSlope::m_peaktOldColl {}
private

Definition at line 113 of file CscCalibMonToolSlope.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_slopeBadBin

int CscCalibMonToolSlope::m_slopeBadBin {1}
private

Bin corresponding to each category in m_h_numbad.

Definition at line 93 of file CscCalibMonToolSlope.h.

◆ m_slopeDiffColl

HistCollection * CscCalibMonToolSlope::m_slopeDiffColl {}
private

Definition at line 112 of file CscCalibMonToolSlope.h.

◆ m_slopeMaxDiff

float CscCalibMonToolSlope::m_slopeMaxDiff {}
private

Maximum deviation from expected values allowed before m_h_numBad is incremented.

Definition at line 90 of file CscCalibMonToolSlope.h.

◆ m_slopeNewColl

HistCollection* CscCalibMonToolSlope::m_slopeNewColl {}
private

HistCollections.

See CscCalibMonToolBase for definition

Definition at line 112 of file CscCalibMonToolSlope.h.

◆ m_slopeOldColl

HistCollection * CscCalibMonToolSlope::m_slopeOldColl {}
private

Definition at line 112 of file CscCalibMonToolSlope.h.

◆ m_slopeRatioColl

HistCollection* CscCalibMonToolSlope::m_slopeRatioColl {}
private

Definition at line 117 of file CscCalibMonToolSlope.h.

117{};

◆ m_statDbColl

HistCollection* CscCalibMonToolBase::m_statDbColl {}
protectedinherited

Definition at line 242 of file CscCalibMonToolBase.h.

242{};

◆ m_streamNameFcn

StreamNameFcn* ManagedMonitorToolBase::m_streamNameFcn
protectedinherited

Definition at line 842 of file ManagedMonitorToolBase.h.

◆ m_subDir

std::string CscCalibMonToolSlope::m_subDir
private

Name of subdirectory under EXPERT or SHIFT that the histograms will be stored.

Definition at line 128 of file CscCalibMonToolSlope.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_totalDeadBin

int CscCalibMonToolSlope::m_totalDeadBin {2}
private

Definition at line 96 of file CscCalibMonToolSlope.h.

◆ m_totalLiveBin

int CscCalibMonToolSlope::m_totalLiveBin {1}
private

Definition at line 96 of file CscCalibMonToolSlope.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: