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

#include <TrigEDMChecker.h>

Inheritance diagram for TrigEDMChecker:
Collaboration diagram for TrigEDMChecker:

Public Member Functions

 TrigEDMChecker (const std::string &name, ISvcLocator *pSvcLocator)
virtual ~TrigEDMChecker ()
virtual StatusCode initialize () override
virtual StatusCode execute (const EventContext &ctx) override
 Execute method.
virtual StatusCode sysInitialize () override
 Function initialising the tool in the correct way in Athena.
virtual StatusCode sysExecute (const EventContext &) override
 override to do firstEvent method
template<typename T>
StatusCode retrieveMetadata (const std::string &folder, const std::string &key, T &out)
 Helper function to access IOVMetaDataContainer information helped in the MetaDataStore.
template<typename T>
StatusCode retrieveMetadata (const std::string &folder, const std::string &key, T &out, const IOVTime &time, int channel=-1)
 Helper function to access IOVMetaDataContainer information held in InputMetaDataStore, but will check IOVTime.
const ServiceHandle< ITHistSvc > & histSvc () const
 The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a pointer to the THistSvc.
virtual bool isClonable () const override
 Specify if the algorithm is clonable.
virtual const DataObjIDColl & extraOutputDeps () const override
 Return the list of extra output dependencies.
virtual bool filterPassed (const EventContext &ctx) const
 Get filter decision:
virtual void setFilterPassed (bool state, const EventContext &ctx) const
 Set filter decision:
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 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
Functions providing access to the input/output metadata
const ServiceHandle< StoreGateSvc > & inputMetaStore () const
 Const accessor for the input metadata store.
ServiceHandle< StoreGateSvc > & inputMetaStore ()
 Accessor for the input metadata store.
const ServiceHandle< StoreGateSvc > & outputMetaStore () const
 Const accessor for the output metadata store.
ServiceHandle< StoreGateSvc > & outputMetaStore ()
 Accessor for the output metadata store.

Protected Member Functions

void updateEvtStore (Gaudi::Details::PropertyBase &prop)
virtual void handle (const Incident &inc) override
 Function receiving incidents from IncidentSvc/TEvent Experts can override but they should ensure they add AthAnalysisAlgorithm::handle(); to the end of their own implementation.
virtual StatusCode beginInputFile ()
 Function called when a new input file is opened user can read input metadata from inputMetaStore().
virtual StatusCode endInputFile ()
 Function called as an input file is being closed.
virtual StatusCode metaDataStop ()
 Function called before finalize user can read output metadata from outputMetaStore().
virtual StatusCode firstExecute ()
 Function called when first execute is encountered user can read event information with evtStore().
virtual TFile * currentFile (const char *evtSelName="EventSelector") final
 Function returning the TFile pointer of the currently open file of the given EventSelector (in athena jobs this defaults to "EventSelector").
virtual bool isReEntrant () const override final
 Legacy algorithms are not thread-safe.
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.
StatusCode configAthHistogramming (const ServiceHandle< ITHistSvc > &histSvc, const std::string &prefix, const std::string &rootDir, const std::string &histNamePrefix, const std::string &histNamePostfix, const std::string &histTitlePrefix, const std::string &histTitlePostfix)
 To be called by the derived classes to fill the internal configuration.
TH1 * bookGetPointer (const TH1 &hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
TH1 * bookGetPointer (TH1 *hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
TH1 * bookGetPointer (TH1 &histRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
TTree * bookGetPointer (const TTree &treeRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of TTrees.
TGraph * bookGetPointer (const TGraph &graphRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of TGraphs.
TEfficiency * bookGetPointer (const TEfficiency &eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
TEfficiency * bookGetPointer (TEfficiency *eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
TEfficiency * bookGetPointer (TEfficiency &effRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
StatusCode book (const TH1 &hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
StatusCode book (TH1 *hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
StatusCode book (TH1 &histRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
StatusCode book (const TTree &treeRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TTrees.
StatusCode book (const TGraph &graphRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TGraphs.
StatusCode book (const TEfficiency &eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
StatusCode book (TEfficiency *eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
StatusCode book (TEfficiency &effRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
TH1 * hist (const std::string &histName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered histograms of any type.
TH2 * hist2d (const std::string &histName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered 2-d histograms.
TH3 * hist3d (const std::string &histName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered 3-d histograms.
TTree * tree (const std::string &treeName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered TTrees.
TGraph * graph (const std::string &graphName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered TGraphs.
TEfficiency * efficiency (const std::string &effName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered TEfficiency.

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t
typedef uint32_t hash_t
 typedef for the internal hash
typedef std::map< const hash_t, TH1 * > HistMap_t
 Typedef for convenience.
typedef std::map< const hash_t, TEfficiency * > EffMap_t
 Typedef for convenience.
typedef std::map< const hash_t, TTree * > TreeMap_t
 Typedef for convenience.
typedef std::map< const hash_t, TGraph * > GraphMap_t
 Typedef for convenience.

Private Member Functions

StatusCode do_execute ATLAS_NOT_THREAD_SAFE (const EventContext &ctx)
StatusCode dumpTrigPassBits ()
StatusCode dumpLVL1_ROI ()
StatusCode dumpTrackParticleContainer ()
StatusCode dumpTrigMissingET ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpxAODTrigMissingET ()
StatusCode dumpxAODJetContainer ()
StatusCode dumpTrigL2BphysContainer ()
StatusCode dumpTrigEFBphysContainer ()
StatusCode dumpTrigEFBjetContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigL2BjetContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigTauClusterContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigEMCluster ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigEMClusterContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpxAODTrigEMCluster ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpxAODTrigEMClusterContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpCombinedMuonFeature ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpCombinedMuonFeatureContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpMuonFeature ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTileMuFeatureContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTileTrackMuFeatureContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigPhotonContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigMuonEFContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigMuonEFInfoContainer ATLAS_NOT_THREAD_SAFE ()
void printMuonTrk (const TrigMuonEFTrack *muonTrack)
void printMuonTrk (const TrigMuonEFCbTrack *muonTrack)
StatusCode dumpxAODMuonContainer ()
StatusCode dumpTrigMuonEFIsolationContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigElectronContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpxAODTrigElectronContainer ()
StatusCode dumpxAODTrigPhotonContainer ()
StatusCode dumpxAODElectronContainer ()
StatusCode dumpxAODPhotonContainer ()
StatusCode dumpTrigTauContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTrigTauTracksInfo ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpHLTResult ()
StatusCode dumpTrigInDetTrackCollection ()
StatusCode dumpTrigVertexCollection ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpxAODTauJetContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpTauJetContainer ATLAS_NOT_THREAD_SAFE ()
StatusCode dumpxAODTrackParticle ()
StatusCode dumpxAODVertex ()
StatusCode dumpStoreGate ()
StatusCode dumpTDT ()
StatusCode dumpxAODTrigMinBias ()
void dumpTrigSpacePointCounts ()
void dumpTrigT2MBTSBits ()
void dumpTrigVertexCounts ()
void dumpTrigTrackCounts ()
StatusCode dumpNavigation (const EventContext &ctx)
StatusCode dumpTrigComposite ()
 Dump information on TrigComposite collections.
StatusCode checkTrigCompositeElementLink (const xAOD::TrigComposite *tc, size_t element)
 Dump details on element links within TrigComposites.
StatusCode TrigCompositeNavigationToDot (std::string &returnValue, bool &pass)
 Construct graph of HLT navigation in Run-3.
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>
void buildBookingString (std::string &bookingString, std::string &histName, std::string &tDir, std::string &stream, bool usePrefixPostfix=false)
 Method to build individual booking string.
void myReplace (std::string &str, const std::string &oldStr, const std::string &newStr)
 Helper method to replace sub-string.
hash_t hash (const std::string &histName) const
 Method to calculate a 32-bit hash from a string.

Private Attributes

bool m_doDumpAll
 a handle on Store Gate for access to the Event Store
bool m_doDumpTrigPassBits
bool m_doDumpLVL1_ROI
bool m_doDumpTrackParticleContainer
bool m_doDumpTrigMissingET
bool m_doDumpxAODTrigMissingET
bool m_doDumpxAODJetContainer
bool m_doDumpTrigL2BphysContainer
bool m_doDumpTrigEFBphysContainer
bool m_doDumpTrigEFBjetContainer
bool m_doDumpTrigL2BjetContainer
bool m_doDumpTrigTauClusterContainer
bool m_doDumpTrigEMCluster
bool m_doDumpTrigEMClusterContainer
bool m_doDumpxAODTrigEMCluster
bool m_doDumpxAODTrigEMClusterContainer
bool m_doDumpCombinedMuonFeature
bool m_doDumpMuonFeature
bool m_doDumpTileMuFeature
bool m_doDumpTileTrackMuFeature
bool m_doDumpTrigPhotonContainer
bool m_doDumpTrigMuonEFContainer
bool m_doDumpTrigMuonEFInfoContainer
bool m_doDumpxAODMuonContainer
bool m_doDumpTrigMuonEFIsolationContainer
bool m_doDumpTrigElectronContainer
bool m_doDumpxAODTrigElectronContainer
bool m_doDumpxAODTrigPhotonContainer
bool m_doDumpxAODElectronContainer
bool m_doDumpxAODPhotonContainer
bool m_doDumpTrigTauContainer
bool m_doDumpTrigTauTracksInfo
bool m_doDumpHLTResult
bool m_doDumpTrigInDetTrackCollection
bool m_doDumpTrigVertexCollection
bool m_doDumpxAODTauJetContainer
bool m_doDumpTauJetContainer
bool m_doDumpxAODTrackParticle
bool m_doDumpxAODVertex
bool m_doDumpStoreGate
bool m_doTDTCheck
bool m_doDumpxAODTrigMinBias
bool m_doDumpAllTrigComposite
std::vector< std::string > m_dumpTrigCompositeContainers
bool m_doDumpNavigation
Gaudi::Property< std::string > m_dumpNavForChain {this, "DumpNavigationForChain", "", "Optional chain to restrict navigation dump info."}
Gaudi::Property< bool > m_excludeFailedHypoNodes
bool m_doDumpTrigCompsiteNavigation
ToolHandle< Rec::IMuonPrintingToolm_muonPrinter {this, "MuonPrinter", "Rec::MuonPrintingTool/MuonPrintingTool"}
ServiceHandle< ::IClassIDSvc > m_clidSvc
SG::ReadHandleKey< xAOD::TrackParticleContainerm_muonTracksKey { this, "MuonTracksKey", "HLT_IDTrack_Muon_FTF"}
SG::ReadHandleKey< xAOD::TrigNavigationm_navigationHandleKey { this, "TrigNavigation", "TrigNavigation", "" }
SG::WriteHandleKey< TrigCompositeUtils::DecisionContainerm_decisionsKey { this, "Decisions", "RoIDecisions", "Decisions created from TEs" }
ToolHandle< HLT::Navigationm_navigationTool { this, "NavigationTool", "HLT::Navigation/Navigation", "" }
PublicToolHandle< Trig::TrigDecisionToolm_trigDec { this, "TriggerDecisionTool", "Trig::TrigDecisionTool/TrigDecisionTool", ""}
int m_trackWarningNum {0}
int m_vertexWarningNum {0}
ServiceHandle< StoreGateSvcm_inputMetaStore
 Object accessing the input metadata store.
ServiceHandle< StoreGateSvcm_outputMetaStore
 Object accessing the output metadata store.
TFile * m_currentFile {nullptr}
bool m_doneFirstEvent {false}
ServiceHandle< ITHistSvc > m_histSvc
 Default constructor: AthHistogramAlgorithm();.
std::string m_prefix
 Name of the ROOT output stream (file).
std::string m_rootDir
 Name of the ROOT directory.
std::string m_histNamePrefix
 The prefix for the histogram THx name.
std::string m_histNamePostfix
 The postfix for the histogram THx name.
std::string m_histTitlePrefix
 The prefix for the histogram THx title.
std::string m_histTitlePostfix
 The postfix for the histogram THx title.
DataObjIDColl m_extendedExtraObjects
 Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.
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
HistMap_t m_histMap
 The map of histogram names to their pointers.
EffMap_t m_effMap
 The map of histogram names to their pointers.
TreeMap_t m_treeMap
 The map of TTree names to their pointers.
GraphMap_t m_graphMap
 The map of TGraph names to their pointers.
std::string m_streamName
 Name of the ROOT output stream (file).
std::string m_name
 Instance name.
MsgStream m_msg
 Cached Message Stream.

Detailed Description

Definition at line 34 of file TrigEDMChecker.h.

Member Typedef Documentation

◆ EffMap_t

typedef std::map< const hash_t, TEfficiency* > AthHistogramming::EffMap_t
privateinherited

Typedef for convenience.

Definition at line 207 of file AthHistogramming.h.

◆ GraphMap_t

typedef std::map< const hash_t, TGraph* > AthHistogramming::GraphMap_t
privateinherited

Typedef for convenience.

Definition at line 221 of file AthHistogramming.h.

◆ hash_t

typedef uint32_t AthHistogramming::hash_t
privateinherited

typedef for the internal hash

Definition at line 171 of file AthHistogramming.h.

◆ HistMap_t

typedef std::map< const hash_t, TH1* > AthHistogramming::HistMap_t
privateinherited

Typedef for convenience.

Definition at line 200 of file AthHistogramming.h.

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

◆ TreeMap_t

typedef std::map< const hash_t, TTree* > AthHistogramming::TreeMap_t
privateinherited

Typedef for convenience.

Definition at line 214 of file AthHistogramming.h.

Constructor & Destructor Documentation

◆ TrigEDMChecker()

TrigEDMChecker::TrigEDMChecker ( const std::string & name,
ISvcLocator * pSvcLocator )

switches to control the analysis through job options

Definition at line 112 of file TrigEDMChecker.cxx.

113 : AthAnalysisAlgorithm(name, pSvcLocator),
114 m_clidSvc( "ClassIDSvc", name )
115{
117
118 declareProperty("doDumpAll", m_doDumpAll = true);
119 declareProperty("doDumpTrigPassBits", m_doDumpTrigPassBits = false);
120 declareProperty("doDumpLVL1_ROI", m_doDumpLVL1_ROI = false);
121 declareProperty("doDumpTrigMissingET", m_doDumpTrigMissingET = false);
122 declareProperty("doDumpxAODTrigMissingET", m_doDumpxAODTrigMissingET = false);
123 declareProperty("doDumpMuonFeature", m_doDumpMuonFeature = false);
124 declareProperty("doDumpCombinedMuonFeature", m_doDumpCombinedMuonFeature = false);
125 declareProperty("doDumpTileMuFeature", m_doDumpTileMuFeature = false);
126 declareProperty("doDumpTileTrackMuFeature", m_doDumpTileTrackMuFeature = false);
127 declareProperty("doDumpTrigPhotonContainer", m_doDumpTrigPhotonContainer = false);
128 declareProperty("doDumpTrigL2BphysContainer", m_doDumpTrigL2BphysContainer = false);
129 declareProperty("doDumpTrigEFBphysContainer", m_doDumpTrigEFBphysContainer = false);
130 declareProperty("doDumpTrigEFBjetContainer", m_doDumpTrigEFBjetContainer = false);
131 declareProperty("doDumpTrigL2BjetContainer", m_doDumpTrigL2BjetContainer = false);
132 declareProperty("doDumpxAODJetContainer", m_doDumpxAODJetContainer = false);
133 declareProperty("doDumpTrigMuonEFContainer", m_doDumpTrigMuonEFContainer = false);
134 declareProperty("doDumpTrigMuonEFInfoContainer", m_doDumpTrigMuonEFInfoContainer = false);
135 declareProperty("doDumpTrigMuonEFIsolationContainer", m_doDumpTrigMuonEFIsolationContainer = false);
136 declareProperty("doDumpxAODMuonContainer", m_doDumpxAODMuonContainer = false);
137 declareProperty("doDumpTrigElectronContainer", m_doDumpTrigElectronContainer = false);
138 declareProperty("doDumpxAODTrigElectronContainer", m_doDumpxAODTrigElectronContainer = false);
139 declareProperty("doDumpxAODTrigPhotonContainer", m_doDumpxAODTrigPhotonContainer = false);
140 declareProperty("doDumpxAODElectronContainer", m_doDumpxAODElectronContainer = false);
141 declareProperty("doDumpxAODPhotonContainer", m_doDumpxAODPhotonContainer = false);
142 declareProperty("doDumpHLTResult", m_doDumpHLTResult = false);
143 declareProperty("doDumpTrigTauContainer", m_doDumpTrigTauContainer = false);
144 declareProperty("doDumpTrigTauTracksInfo", m_doDumpTrigTauTracksInfo = false);
145 declareProperty("doDumpTrigInDetTrackCollection", m_doDumpTrigInDetTrackCollection = false);
146 declareProperty("doDumpTrigVertexCollection", m_doDumpTrigVertexCollection = false);
147 declareProperty("doDumpTrigEMCluster", m_doDumpTrigEMCluster = false);
148 declareProperty("doDumpTrigEMClusterContainer", m_doDumpTrigEMClusterContainer = false);
149 declareProperty("doDumpxAODTrigEMCluster", m_doDumpxAODTrigEMCluster = false);
150 declareProperty("doDumpxAODTrigEMClusterContainer", m_doDumpxAODTrigEMClusterContainer = false);
151 declareProperty("doDumpTrigTauClusterContainer", m_doDumpTrigTauClusterContainer = false);
152 declareProperty("doDumpTrackParticleContainer", m_doDumpTrackParticleContainer = false);
153 declareProperty("doDumpTauJetContainer", m_doDumpTauJetContainer = false);
154 declareProperty("doDumpxAODTrackParticle", m_doDumpxAODTrackParticle = false);
155 declareProperty("doDumpxAODVertex", m_doDumpxAODVertex = false);
156 declareProperty("doDumpxAODTauJetContainer", m_doDumpxAODTauJetContainer = false);
157 declareProperty("doDumpxAODTrigMinBias", m_doDumpxAODTrigMinBias = false);
158 declareProperty("doDumpStoreGate", m_doDumpStoreGate = false );
159 declareProperty("doDumpAllTrigComposite", m_doDumpAllTrigComposite = false );
160 declareProperty("dumpTrigCompositeContainers", m_dumpTrigCompositeContainers, "List of TC to dump" );
161 declareProperty("doDumpTrigCompsiteNavigation", m_doDumpTrigCompsiteNavigation = false );
162 declareProperty("doDumpNavigation", m_doDumpNavigation = false );
163 declareProperty("doTDTCheck", m_doTDTCheck = false );
164 declareProperty( "ClassIDSvc", m_clidSvc, "Service providing CLID info" );
165}
AthAnalysisAlgorithm(const std::string &name)
Constructor taking just a name.
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
bool m_doDumpxAODTrigMissingET
bool m_doDumpTrigTauContainer
bool m_doDumpTrigVertexCollection
bool m_doDumpTrigEFBphysContainer
bool m_doDumpTrigPhotonContainer
bool m_doDumpxAODTrigEMClusterContainer
bool m_doDumpTrigMuonEFContainer
bool m_doDumpxAODTrigElectronContainer
ServiceHandle< ::IClassIDSvc > m_clidSvc
bool m_doDumpxAODElectronContainer
bool m_doDumpTrigL2BjetContainer
bool m_doDumpTrigElectronContainer
bool m_doDumpTrigEMClusterContainer
bool m_doDumpxAODTauJetContainer
bool m_doDumpTrigInDetTrackCollection
bool m_doDumpTrigL2BphysContainer
bool m_doDumpAll
a handle on Store Gate for access to the Event Store
std::vector< std::string > m_dumpTrigCompositeContainers
bool m_doDumpTrigEFBjetContainer
bool m_doDumpTrigMuonEFIsolationContainer
bool m_doDumpTrigTauTracksInfo
bool m_doDumpTrackParticleContainer
bool m_doDumpTrigMuonEFInfoContainer
bool m_doDumpCombinedMuonFeature
bool m_doDumpTileTrackMuFeature
bool m_doDumpTrigCompsiteNavigation
bool m_doDumpxAODTrigPhotonContainer
bool m_doDumpxAODPhotonContainer
bool m_doDumpxAODTrackParticle
bool m_doDumpxAODJetContainer
bool m_doDumpTrigTauClusterContainer
bool m_doDumpxAODTrigEMCluster
bool m_doDumpAllTrigComposite
bool m_doDumpxAODMuonContainer

◆ ~TrigEDMChecker()

TrigEDMChecker::~TrigEDMChecker ( )
virtual

Definition at line 169 of file TrigEDMChecker.cxx.

169{}

Member Function Documentation

◆ ATLAS_NOT_THREAD_SAFE() [1/24]

StatusCode dumpTauJetContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [2/24]

StatusCode dumpxAODTauJetContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [3/24]

StatusCode dumpTrigVertexCollection TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [4/24]

StatusCode dumpTrigTauTracksInfo TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [5/24]

StatusCode dumpTrigTauContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [6/24]

StatusCode dumpTrigElectronContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [7/24]

StatusCode dumpTrigMuonEFIsolationContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [8/24]

StatusCode dumpTrigMuonEFInfoContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [9/24]

StatusCode dumpTrigMuonEFContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [10/24]

StatusCode dumpTrigPhotonContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [11/24]

StatusCode dumpTileTrackMuFeatureContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [12/24]

StatusCode dumpTileMuFeatureContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [13/24]

StatusCode dumpMuonFeature TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [14/24]

StatusCode dumpCombinedMuonFeatureContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [15/24]

StatusCode dumpCombinedMuonFeature TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [16/24]

StatusCode dumpxAODTrigEMClusterContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [17/24]

StatusCode dumpxAODTrigEMCluster TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [18/24]

StatusCode dumpTrigEMClusterContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [19/24]

StatusCode dumpTrigEMCluster TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [20/24]

StatusCode dumpTrigTauClusterContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [21/24]

StatusCode dumpTrigL2BjetContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [22/24]

StatusCode dumpTrigEFBjetContainer TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [23/24]

StatusCode dumpTrigMissingET TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( )
private

◆ ATLAS_NOT_THREAD_SAFE() [24/24]

StatusCode do_execute TrigEDMChecker::ATLAS_NOT_THREAD_SAFE ( const EventContext & ctx)
private

◆ beginInputFile()

StatusCode AthAnalysisAlgorithm::beginInputFile ( )
protectedvirtualinherited

Function called when a new input file is opened user can read input metadata from inputMetaStore().

Dummy implementation that can be overridden by the derived tool.

Reimplemented in MuonVal::MetaDataAlg.

Definition at line 114 of file AthAnalysisAlgorithm.cxx.

114 {
115
116 // Return gracefully:
117 return StatusCode::SUCCESS;
118}

◆ book() [1/8]

StatusCode AthHistogramming::book ( const TEfficiency & eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 337 of file AthHistogramming.h.

338{
339 // We need to create a non-const clone
340 TEfficiency* effClone = dynamic_cast< TEfficiency* >( eff.Clone() );
341 if ( !effClone ) {
342 m_msg << MSG::ERROR << "Couldn't create a TEfficiency clone" << endmsg;
343 return StatusCode::FAILURE;
344 }
345 return this->book( *effClone, tDir, stream );
346}
#define endmsg
StatusCode book(const TH1 &hist, const std::string &tDir="", const std::string &stream="")
Simplify the booking and registering (into THistSvc) of histograms.
MsgStream m_msg
Cached Message Stream.

◆ book() [2/8]

StatusCode AthHistogramming::book ( const TGraph & graphRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TGraphs.

◆ book() [3/8]

StatusCode AthHistogramming::book ( const TH1 & hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 305 of file AthHistogramming.h.

306{
307 // We need to create a non-const clone
308 TH1* histClone = dynamic_cast< TH1* >( hist.Clone() );
309 if ( !histClone ) {
310 m_msg << MSG::ERROR << "Couldn't create a TH1 clone" << endmsg;
311 return StatusCode::FAILURE;
312 }
313 return this->book( *histClone, tDir, stream );
314}
TH1 * hist(const std::string &histName, const std::string &tDir="", const std::string &stream="")
Simplify the retrieval of registered histograms of any type.

◆ book() [4/8]

StatusCode AthHistogramming::book ( const TTree & treeRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TTrees.

Definition at line 405 of file AthHistogramming.h.

406{
407 // Call the other Book method and see if it returns a valid pointer
408 TTree* treePointer = this->bookGetPointer( treeRef, tDir, stream );
409 if ( treePointer )
410 {
411 return StatusCode::SUCCESS;
412 }
413 else
414 {
415 return StatusCode::FAILURE;
416 }
417}
TH1 * bookGetPointer(const TH1 &hist, const std::string &tDir="", const std::string &stream="")
Simplify the booking and registering (into THistSvc) of histograms.

◆ book() [5/8]

StatusCode AthHistogramming::book ( TEfficiency & effRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 358 of file AthHistogramming.h.

359{
360 // Call the other Book method and see if it returns a valid pointer
361 TEfficiency* effPointer = this->bookGetPointer( effRef, tDir, stream );
362 if ( !effPointer ) {
363 m_msg << MSG::ERROR << "Couldn't book a TEfficiency" << endmsg;
364 return StatusCode::FAILURE;
365 }
366 return StatusCode::SUCCESS;
367}

◆ book() [6/8]

StatusCode AthHistogramming::book ( TEfficiency * eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 348 of file AthHistogramming.h.

349{
350 if ( !eff ) {
351 m_msg << MSG::ERROR << "Got a zero pointer to a TEfficiency" << endmsg;
352 return StatusCode::FAILURE;
353 }
354 return this->book( *eff, tDir, stream );
355}

◆ book() [7/8]

StatusCode AthHistogramming::book ( TH1 & histRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 326 of file AthHistogramming.h.

327{
328 // Call the other Book method and see if it returns a valid pointer
329 TH1* histPointer = this->bookGetPointer( histRef, tDir, stream );
330 if ( !histPointer ) {
331 m_msg << MSG::ERROR << "Couldn't book a TH1" << endmsg;
332 return StatusCode::FAILURE;
333 }
334 return StatusCode::SUCCESS;
335}

◆ book() [8/8]

StatusCode AthHistogramming::book ( TH1 * hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 316 of file AthHistogramming.h.

317{
318 if ( !hist ) {
319 m_msg << MSG::ERROR << "Got a zero pointer to a TH1" << endmsg;
320 return StatusCode::FAILURE;
321 }
322 return this->book( *hist, tDir, stream );
323}

◆ bookGetPointer() [1/8]

TEfficiency * AthHistogramming::bookGetPointer ( const TEfficiency & eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 283 of file AthHistogramming.h.

284{
285 // We need to create a non-const clone
286 TEfficiency* histClone = dynamic_cast< TEfficiency* >( hist.Clone() );
287 if ( !histClone ) {
288 m_msg << MSG::ERROR << "Couldn't create a TEfficiency clone in bookGetPointer" << endmsg;
289 return 0;
290 }
291 return this->bookGetPointer( *histClone, tDir, stream );
292
293}

◆ bookGetPointer() [2/8]

TGraph * AthHistogramming::bookGetPointer ( const TGraph & graphRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of TGraphs.

Definition at line 388 of file AthHistogramming.cxx.

389{
390 // Get a pointer
391 const TGraph* graphPointer = &graphRef;
392
393 // Check that we got a valid pointer
394 if ( !graphPointer )
395 {
396 m_msg << MSG::WARNING
397 << "We got an invalid TGraph pointer in the BookGetPointer(TGraph*) method of the class" << m_name
398 << "!" << endmsg;
399 return NULL;
400 }
401
402 // Modify the name and title according to the prefixes of this classes instance
403 std::string graphName = graphPointer->GetName();
404 const std::string graphTitle = graphPointer->GetTitle();
405
406 // Check if the hash for this graphName already exists, i.e., if we have a hash collision
407 const hash_t graphHash = this->hash(graphName);
408 GraphMap_t::const_iterator it = m_graphMap.find( graphHash );
409 if ( it != m_graphMap.end() ) // It does exist!
410 {
411 m_msg << MSG::WARNING
412 << "Detected a hash collision. The hash for the TGraph with name=" << graphName
413 << " already exists and points to a TGraph with name=" << it->second->GetName()
414 << " NOT going to book the new histogram and returning a NULL pointer!" << endmsg;
415 return NULL;
416 }
417
418 // Create a clone that has the new name
419 TGraph* graphClone = dynamic_cast< TGraph* >( graphPointer->Clone((m_histNamePrefix+graphName+m_histNamePostfix).c_str()) );
420 if( !graphClone )
421 {
422 m_msg << MSG::WARNING
423 << "We couldn't clone the TGraph in the BookGetPointer(TGraph&) method of the class" << m_name
424 << "!" << endmsg;
425 return NULL;
426 }
427 graphClone->SetTitle ((m_histTitlePrefix+graphTitle+m_histTitlePostfix).c_str());
428
429 // Massage the final string to book things
430 std::string bookingString("");
431 this->buildBookingString( bookingString, graphName, tDir, stream );
432
433 // Register the TGraph into the THistSvc
434 if ( !((histSvc()->regGraph(bookingString, graphClone)).isSuccess()) )
435 {
436 m_msg << MSG::WARNING
437 << "Problem registering TGraph with name " << graphName
438 << ", title " << graphTitle
439 << " in " << m_name << "!" << endmsg;
440 return NULL;
441 }
442
443 // Also register it in the local map of string to pointer
444 m_graphMap.insert( m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphClone ) );
445
446 return graphClone;
447}
const ServiceHandle< ITHistSvc > & histSvc() const
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a...
std::string m_histNamePostfix
The postfix for the histogram THx name.
hash_t hash(const std::string &histName) const
Method to calculate a 32-bit hash from a string.
uint32_t hash_t
typedef for the internal hash
std::string m_histTitlePostfix
The postfix for the histogram THx title.
std::string m_histTitlePrefix
The prefix for the histogram THx title.
std::string m_name
Instance name.
void buildBookingString(std::string &bookingString, std::string &histName, std::string &tDir, std::string &stream, bool usePrefixPostfix=false)
Method to build individual booking string.
std::string m_histNamePrefix
The prefix for the histogram THx name.
GraphMap_t m_graphMap
The map of TGraph names to their pointers.

◆ bookGetPointer() [3/8]

TH1 * AthHistogramming::bookGetPointer ( const TH1 & hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 262 of file AthHistogramming.h.

263{
264 // We need to create a non-const clone
265 TH1* histClone = dynamic_cast< TH1* >( hist.Clone() );
266 if ( !histClone ) {
267 m_msg << MSG::ERROR << "Couldn't create a TH1 clone in bookGetPointer" << endmsg;
268 return 0;
269 }
270 return this->bookGetPointer( *histClone, tDir, stream );
271
272}

◆ bookGetPointer() [4/8]

TTree * AthHistogramming::bookGetPointer ( const TTree & treeRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of TTrees.

Definition at line 273 of file AthHistogramming.cxx.

274{
275 // Get a pointer
276 const TTree* treePointer = &treeRef;
277
278 // Check that we got a valid pointer
279 if ( !treePointer )
280 {
281 m_msg << MSG::WARNING
282 << "We got an invalid TTree pointer in the BookGetPointer(TTree*) method of the class" << m_name
283 << "!" << endmsg;
284 return NULL;
285 }
286
287 // Modify the name and title according to the prefixes of this classes instance
288 std::string treeName = treePointer->GetName();
289 const std::string treeTitle = treePointer->GetTitle();
290
291 // Check if the hash for this treeName already exists, i.e., if we have a hash collision
292 const hash_t treeHash = this->hash(treeName);
293 TreeMap_t::const_iterator it = m_treeMap.find( treeHash );
294 if ( it != m_treeMap.end() ) // It does exist!
295 {
296 m_msg << MSG::WARNING
297 << "Detected a hash collision. The hash for the TTree with name=" << treeName
298 << " already exists and points to a TTree with name=" << it->second->GetName()
299 << " NOT going to book the new histogram and returning a NULL pointer!" << endmsg;
300 return NULL;
301 }
302
303 // Create a clone that has the new name
304 TTree* treeClone = dynamic_cast< TTree* >( treePointer->Clone(treeName.c_str()) );
305 if( !treeClone )
306 {
307 m_msg << MSG::WARNING
308 << "We couldn't clone the TTree in the BookGetPointer(TTree&) method of the class" << m_name
309 << "!" << endmsg;
310 return NULL;
311 }
312 treeClone->SetTitle (treeTitle.c_str());
313
314 // Massage the final string to book things
315 std::string bookingString("");
316 this->buildBookingString( bookingString, treeName, tDir, stream );
317
318 // Register the TTree into the THistSvc
319 if ( !((histSvc()->regTree(bookingString, treeClone)).isSuccess()) )
320 {
321 m_msg << MSG::WARNING
322 << "Problem registering TTree with name " << treeName
323 << ", title " << treeTitle
324 << " in " << m_name << "!" << endmsg;
325 return NULL;
326 }
327
328 // Also register it in the local map of string to pointer
329 m_treeMap.insert( m_treeMap.end(), std::pair< const hash_t, TTree* >( treeHash, treeClone ) );
330
331 return treeClone;
332}
TreeMap_t m_treeMap
The map of TTree names to their pointers.

◆ bookGetPointer() [5/8]

TEfficiency * AthHistogramming::bookGetPointer ( TEfficiency & effRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 123 of file AthHistogramming.cxx.

124{
125 std::string effName(effRef.GetName());
126 const std::string effTitle(effRef.GetTitle());
127 std::string bookingString;
128 this->buildBookingString(bookingString, effName, tDir, stream);
129 const std::string finalEffName = m_histNamePrefix + effName + m_histNamePostfix;
130 effRef.SetTitle((m_histTitlePrefix + effTitle + m_histTitlePostfix).c_str());
131 effRef.SetName(finalEffName.c_str());
132
133 const hash_t effHash = this->hash(effName);
134 EffMap_t::const_iterator it = m_effMap.find(effHash);
135 if (it != m_effMap.end()) {
136 m_msg << MSG::WARNING
137 << "Detected a hash collision. The hash for the TEfficiency with name=" << effName
138 << " already exists and points to a TEfficiency with name=" << it->second->GetName()
139 << " NOT going to book the new TEfficiency and returning a NULL pointer!" << endmsg;
140 return nullptr;
141 }
142
143 if (!histSvc()->regEfficiency(bookingString, &effRef).isSuccess()) {
144 m_msg << MSG::WARNING
145 << "Problem registering TEfficiency with name " << effName
146 << ", name prefix " << m_histNamePrefix
147 << ", title " << effTitle
148 << ", title prefix " << m_histTitlePrefix
149 << ", and title postfix " << m_histTitlePostfix
150 << " in " << m_name << "!" << endmsg;
151 return nullptr;
152 }
153
154 m_effMap.insert(m_effMap.end(), std::pair<const hash_t, TEfficiency*>(effHash, &effRef));
155
156 return &effRef;
157}
EffMap_t m_effMap
The map of histogram names to their pointers.

◆ bookGetPointer() [6/8]

TEfficiency * AthHistogramming::bookGetPointer ( TEfficiency * eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 295 of file AthHistogramming.h.

296{
297 if ( !hist ) {
298 m_msg << MSG::ERROR << "Got a zero pointer to a TEfficiency in bookGetPointer" << endmsg;
299 return 0;
300 }
301 return this->bookGetPointer( *hist, tDir, stream );
302}

◆ bookGetPointer() [7/8]

TH1 * AthHistogramming::bookGetPointer ( TH1 & histRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 83 of file AthHistogramming.cxx.

84{
85 std::string histName(histRef.GetName());
86 const std::string histTitle(histRef.GetTitle());
87 std::string bookingString;
88
89 this->buildBookingString(bookingString, histName, tDir, stream);
90
91 const std::string finalHistName = m_histNamePrefix + histName + m_histNamePostfix;
92
93 histRef.SetTitle((m_histTitlePrefix + histTitle + m_histTitlePostfix).c_str());
94 histRef.SetName(finalHistName.c_str());
95
96 const hash_t histHash = this->hash(histName);
97 HistMap_t::const_iterator it = m_histMap.find(histHash);
98 if (it != m_histMap.end()) {
99 m_msg << MSG::WARNING
100 << "Detected a hash collision. The hash for the histogram with name=" << histName
101 << " already exists and points to a histogram with name=" << it->second->GetName()
102 << " NOT going to book the new histogram and returning a NULL pointer!" << endmsg;
103 return nullptr;
104 }
105
106 if (!histSvc()->regHist(bookingString, &histRef).isSuccess()) {
107 m_msg << MSG::WARNING
108 << "Problem registering histogram with name " << histName
109 << ", name prefix " << m_histNamePrefix
110 << ", title " << histTitle
111 << ", title prefix " << m_histTitlePrefix
112 << ", and title postfix " << m_histTitlePostfix
113 << " in " << m_name << "!" << endmsg;
114 return nullptr;
115 }
116
117 m_histMap.insert(m_histMap.end(), std::pair<const hash_t, TH1*>(histHash, &histRef));
118
119 return &histRef;
120}
HistMap_t m_histMap
The map of histogram names to their pointers.

◆ bookGetPointer() [8/8]

TH1 * AthHistogramming::bookGetPointer ( TH1 * hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 274 of file AthHistogramming.h.

275{
276 if ( !hist ) {
277 m_msg << MSG::ERROR << "Got a zero pointer to a TH1 in bookGetPointer" << endmsg;
278 return 0;
279 }
280 return this->bookGetPointer( *hist, tDir, stream );
281}

◆ buildBookingString()

void AthHistogramming::buildBookingString ( std::string & bookingString,
std::string & histName,
std::string & tDir,
std::string & stream,
bool usePrefixPostfix = false )
privateinherited

Method to build individual booking string.

Definition at line 521 of file AthHistogramming.cxx.

526{
527 // Massage the final string to book things
528 if(tDir.empty()) tDir = m_rootDir;
529 size_t pos = histName.rfind('/');
530 if(pos != std::string::npos){
531 tDir+='/';
532 tDir.append(histName, 0,pos);
533 histName.erase(0,pos+1);
534 };
535 if(stream.empty()) stream = m_streamName;
536
537 if(usePrefixPostfix){
538 bookingString = "/"+stream+"/"+tDir+"/"+m_histNamePrefix+histName+m_histNamePostfix;
539 } else {
540 bookingString = "/"+stream+"/"+tDir+"/"+histName;
541 }
542 while(bookingString.find("//") != std::string::npos){
543 this->myReplace(bookingString,"//","/");
544 }
545
546 return;
547}
std::string m_rootDir
Name of the ROOT directory.
std::string m_streamName
Name of the ROOT output stream (file).
void myReplace(std::string &str, const std::string &oldStr, const std::string &newStr)
Helper method to replace sub-string.

◆ checkTrigCompositeElementLink()

StatusCode TrigEDMChecker::checkTrigCompositeElementLink ( const xAOD::TrigComposite * tc,
size_t element )
private

Dump details on element links within TrigComposites.

With specific checking of the Run-3 relationships

Definition at line 4145 of file TrigEDMChecker.cxx.

4145 {
4146
4147 const std::string name = tc->linkColNames().at(element);
4148 const CLID clid = static_cast<CLID>(tc->linkColClids().at(element));
4149
4151
4152 const ElementLink<TrigRoiDescriptorCollection> elementLink = tc->objectLink<TrigRoiDescriptorCollection>(name);
4153 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to TrigRoiDescriptorCollection, link name:'" << name << "'");
4154 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "'' to TrigRoiDescriptor:" << *elementLink);
4155
4156 } else if (clid == ClassID_traits< DataVector< LVL1::RecEmTauRoI > >::ID()) { // There could be a few ROI types....
4157 // CLASS_DEF( DataVector< LVL1::RecEmTauRoI >, 6256, 1 )
4158
4159 const ElementLink<DataVector< LVL1::RecEmTauRoI >> elementLink = tc->objectLink<DataVector< LVL1::RecEmTauRoI >>(name);
4160 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to LVL1::RecEmTauRoI, link name:'" << name << "'");
4161 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "' to LVL1::RecEmTauRoI:" << *elementLink);
4162
4164
4166 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to TrigComposite, link name:'" << name << "'");
4167 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "' to TrigComposite, TC name:'" << (*elementLink)->name() << "'");
4168
4169 } else if (clid == ClassID_traits< ViewContainer >::ID()) {
4170
4171 const ElementLink<ViewContainer> elementLink = tc->objectLink<ViewContainer>(name);
4172 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to View, link name:'" << name << "'");
4173 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "' to View:'" << *elementLink);
4174
4175 } else if (name == "feature") {
4176
4178
4180 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to xAOD::TrigEMClusterContainer 'feature'");
4181 else ATH_MSG_DEBUG(" Dereferenced xAOD::TrigEMClusterContainer link 'feature', Energy:" << (*elementLink)->energy());
4182
4184
4186 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to xAOD::TrigMissingETContainer 'feature'");
4187 else ATH_MSG_DEBUG(" Dereferenced xAOD::TrigMissingETContainer link 'feature', ex:" << (*elementLink)->ex() << " ey:" << (*elementLink)->ey());
4188
4189 } else {
4190
4191 try {
4192 const ElementLink<xAOD::IParticleContainer> elementLink = tc->objectLink<xAOD::IParticleContainer>(name);
4193 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to 'feature'");
4194 else ATH_MSG_DEBUG(" Dereferenced IParticle link 'feature', pt:" << (*elementLink)->pt() << " eta:" << (*elementLink)->eta() << " phi:" << (*elementLink)->phi());
4195 } catch(std::runtime_error& e) {
4196 ATH_MSG_WARNING(" Cannot dereference 'feature' as IParticle: '" << e.what() << "'");
4197 }
4198
4199 }
4200
4201 } else {
4202 ATH_MSG_DEBUG(" Ignoring link to '" << name << "' with link CLID " << clid);
4203 }
4204
4205 return StatusCode::SUCCESS;
4206
4207}
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
uint32_t CLID
The Class ID type.
static Double_t tc
Athena::TPCnvVers::Current Athena::TPCnvVers::Old TrigRoiDescriptorCollection
DataVector< SG::View > ViewContainer
View container for recording in StoreGate.
Definition View.h:290
mapped_type at(key_type key) const
Look up an element in the map.
TrigMissingETContainer_v1 TrigMissingETContainer
DataVector of TrigMissingET - the current version.
TrigCompositeContainer_v1 TrigCompositeContainer
Declare the latest version of the container.
TrigEMClusterContainer_v1 TrigEMClusterContainer
Define the latest version of the trigger EM cluster container.
DataVector< IParticle > IParticleContainer
Simple convenience declaration of IParticleContainer.

◆ configAthHistogramming()

StatusCode AthHistogramming::configAthHistogramming ( const ServiceHandle< ITHistSvc > & histSvc,
const std::string & prefix,
const std::string & rootDir,
const std::string & histNamePrefix,
const std::string & histNamePostfix,
const std::string & histTitlePrefix,
const std::string & histTitlePostfix )
protectedinherited

To be called by the derived classes to fill the internal configuration.

Definition at line 51 of file AthHistogramming.cxx.

55{
58 m_rootDir = rootDir;
59 m_histNamePrefix = histNamePrefix;
60 m_histNamePostfix = histNamePostfix;
61 m_histTitlePrefix = histTitlePrefix;
62 m_histTitlePostfix = histTitlePostfix;
63
64 return StatusCode::SUCCESS;
65}
ServiceHandle< ITHistSvc > m_histSvc
Pointer to the THistSvc (event store by default).

◆ currentFile()

TFile * AthAnalysisAlgorithm::currentFile ( const char * evtSelName = "EventSelector")
finalprotectedvirtualinherited

Function returning the TFile pointer of the currently open file of the given EventSelector (in athena jobs this defaults to "EventSelector").

Definition at line 147 of file AthAnalysisAlgorithm.cxx.

147 {
148 if(m_currentFile) return m_currentFile;
149
150 //get the EventSelector so we can get it's list of input files
151 //dont get it with a ServiceHandle, because that invokes initialize, can get into init loop
152
153 SmartIF<IProperty> evtSelector{service(evtSelName, false)};
154 if(!evtSelector) {
155 ATH_MSG_ERROR("currentFile(): Couldn't find the service: " << evtSelName);return 0;
156 }
157
158 try {
159 //get the list of input files - use this to determine which open file is the current input file
160 const StringArrayProperty& inputCollectionsName = dynamic_cast<const StringArrayProperty&>(evtSelector->getProperty("InputCollections"));
161
162 ATH_MSG_VERBOSE("nOpenFile=" << gROOT->GetListOfFiles()->GetSize() << ". nFilesInInputCollection=" << inputCollectionsName.value().size());
163 if(msgLvl(MSG::VERBOSE)) {
164 for(int i=0;i<gROOT->GetListOfFiles()->GetSize();i++) {
165 ATH_MSG_VERBOSE("Open file: " << gROOT->GetListOfFiles()->At(i)->GetName());
166 }
167 }
168
169 //look through list of files and find the one from the input collection that is currently open
170
171 for(int i=0;i<gROOT->GetListOfFiles()->GetSize();i++) {
172 TFile *g = (TFile*)gROOT->GetListOfFiles()->At(i);
173 //see if this file is in the input file list
174 //strip everything except stuff either side of last /
175 TString s(g->GetName());
176 TObjArray* tokens = s.Tokenize("/");
177 TObjString* lastToken = static_cast<TObjString*>(tokens->Last());
178 TString sToCompare("");
179 bool shortComparison(false);
180 if(tokens->GetEntries()>1) {
181 TString beforeSlash((static_cast<TObjString*>(tokens->At(tokens->GetEntries()-2)))->GetString());
182 if(beforeSlash.Length()>0) sToCompare += beforeSlash;
183 sToCompare += "/";
184 } else {
185 shortComparison=true;
186 }
187 sToCompare += lastToken->GetString();
188 TString sToCompare_short(lastToken->GetString()); //short versions search
189 delete tokens;
190
191 for(unsigned int j=0;j<inputCollectionsName.value().size();j++) {
192 TString t(inputCollectionsName.value()[j].c_str());
193 //try perfect match first
194 if(s.EqualTo(t)) {
195 ATH_MSG_VERBOSE("Current File is: " << inputCollectionsName.value()[j]);
197 return g;
198 }
199 TObjArray* tokens = t.Tokenize("/");
200 TObjString* lastToken = dynamic_cast<TObjString*>(tokens->Last());
201 if (!lastToken) {
202 ATH_MSG_ERROR("Cannot cast token string to TObjString");
203 return nullptr;
204 }
205 TString tToCompare = "";
206 bool shortComparison2(false);
207 if(tokens->GetEntries()>1) {
208 TObjString* beforeSlashStr = dynamic_cast<TObjString*>(tokens->At(tokens->GetEntries()-2));
209 if (!beforeSlashStr) {
210 ATH_MSG_ERROR("Cannot cast token string to TObjString");
211 return nullptr;
212 }
213 TString beforeSlash(beforeSlashStr->GetString());
214 if(beforeSlash.Length()>0) tToCompare += beforeSlash;
215 tToCompare += "/";
216 } else {
217 shortComparison2=true;
218 }
219 tToCompare += lastToken->GetString();
220 TString tToCompare_short(lastToken->GetString());
221 delete tokens;
222
223 if(shortComparison || shortComparison2) { //doing short version search, no directories to distinguish files!
224 if(sToCompare_short.EqualTo(tToCompare_short)) {
225 ATH_MSG_VERBOSE("Current File is: " << inputCollectionsName.value()[j]);
227 return g;
228 }
229 } else
230 if(sToCompare.EqualTo(tToCompare)) {
231 ATH_MSG_VERBOSE("Current File is: " << inputCollectionsName.value()[j]);
233 return g;
234 }
235 }
236 }
237
238 } catch(...) {
239 ATH_MSG_ERROR("currentFile(): Couldn't load InputCollections property of " << evtSelName); return 0;
240 }
241
242 ATH_MSG_ERROR("currentFile(): Could not find the current file!");
243 return 0; //something went wrong :-(
244
245}
#define ATH_MSG_ERROR(x)
#define ATH_MSG_VERBOSE(x)
size_t size() const
Number of registered mappings.
bool msgLvl(const MSG::Level lvl) const
float j(const xAOD::IParticle &, const xAOD::TrackMeasurementValidation &hit, const Eigen::Matrix3d &jab_inv)

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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< Gaudi::Algorithm > >::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>

◆ detStore()

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

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

Definition at line 95 of file AthCommonDataStore.h.

◆ dumpHLTResult()

StatusCode TrigEDMChecker::dumpHLTResult ( )
private

Definition at line 2099 of file TrigEDMChecker.cxx.

2099 {
2100
2101 ATH_MSG_DEBUG("in dumpHLTResult()");
2102
2103 ATH_MSG_INFO("REGTEST ==========START of HLTResult DUMP===========");
2104
2105 const HLT::HLTResult* hltResult = 0;
2106 StatusCode sc=evtStore()->retrieve( hltResult, "HLTResult_L2");
2107 if( sc.isFailure() || !hltResult ) {
2108 ATH_MSG_INFO("No HLTResult_L2 found in TDS");
2109 return StatusCode::SUCCESS;
2110 }
2111 ATH_MSG_INFO("REGTEST HLTResult_L2 Successfully Retrieved");
2112
2113 ATH_MSG_INFO("REGTEST HLTResult_L2->isEmpty() returns " << hltResult->isEmpty());
2114 ATH_MSG_INFO("REGTEST HLTResult_L2->size() returns " << hltResult->size());
2115 ATH_MSG_INFO("REGTEST HLTResult_L2->isPassThrough() returns " << hltResult->isPassThrough());
2116 ATH_MSG_INFO("REGTEST HLTResult_L2->isAccepted() returns " << hltResult->isAccepted());
2117
2118 ATH_MSG_INFO("REGTEST ==========END of HLTResult DUMP===========");
2119
2120 ATH_MSG_DEBUG("dumpHLTResult() succeeded");
2121
2122 return StatusCode::SUCCESS;
2123}
#define ATH_MSG_INFO(x)
static Double_t sc
ServiceHandle< StoreGateSvc > & evtStore()
bool isAccepted() const
gets HLT decision
Definition HLTResult.h:129
bool isPassThrough() const
forced-accepted (FA) event configuration the FA request(s) are set per chain and hlt level by the tig...
Definition HLTResult.h:144
bool isEmpty() const
true if result is empty
unsigned int size() const
::StatusCode StatusCode
StatusCode definition for legacy code.

◆ dumpLVL1_ROI()

StatusCode TrigEDMChecker::dumpLVL1_ROI ( )
private

Definition at line 1164 of file TrigEDMChecker.cxx.

1164 {
1165
1166 ATH_MSG_DEBUG("in dumpLVL1_ROI()");
1167
1168 ATH_MSG_INFO("REGTEST ==========START of LVL1_ROI DUMP===========");
1169
1170 const LVL1_ROI * lvl1ROI;
1171 StatusCode sc = evtStore()->retrieve(lvl1ROI);
1172 if (sc.isFailure() ) {
1173 ATH_MSG_INFO("REGTEST No LVL1_ROI found");
1174 return StatusCode::SUCCESS;
1175 }
1176
1177 ATH_MSG_INFO("REGTEST LVL1_ROI retrieved");
1178
1179 LVL1_ROI::emtaus_type::const_iterator itEMTau =
1180 (lvl1ROI->getEmTauROIs()).begin();
1181 LVL1_ROI::emtaus_type::const_iterator itEMTau_e =
1182 (lvl1ROI->getEmTauROIs()).end();
1183 int j = 0;
1184 for( ; itEMTau != itEMTau_e; ++itEMTau, ++j) {
1185 ATH_MSG_INFO("REGTEST Looking at LVL1_ROI " << j);
1186 ATH_MSG_INFO("REGTEST LVL1 EmTauROI Eta is " << itEMTau->getEta());
1187 ATH_MSG_INFO("REGTEST LVL1 EmTauROI Phi is " << itEMTau->getPhi());
1188 ATH_MSG_INFO("REGTEST LVL1 EmTauROI EMClus is " << itEMTau->getEMClus());
1189 ATH_MSG_INFO("REGTEST LVL1 EmTauROI TauClus is " << itEMTau->getTauClus());
1190 ATH_MSG_INFO("REGTEST LVL1 EmTauROI EMIsol is " << itEMTau->getEMIsol());
1191 ATH_MSG_INFO("REGTEST LVL1 EmTauROI HadIsol is " << itEMTau->getHadIsol());
1192 ATH_MSG_INFO("REGTEST LVL1 EmTauROI Core is " << itEMTau->getCore());
1193 ATH_MSG_INFO("REGTEST LVL1 EmTauROI HadCore is " << itEMTau->getHadCore());
1194 ATH_MSG_INFO("REGTEST LVL1 EmTauROI roiWord is " << itEMTau->getROIWord());
1195 }
1196
1197 ATH_MSG_INFO("REGTEST ==========END of LVL1_ROI DUMP===========");
1198 ATH_MSG_DEBUG("dumpLVL1_ROI() succeeded");
1199 return StatusCode::SUCCESS;
1200}
const emtaus_type & getEmTauROIs() const
Get all the em/tau RoIs in the event.
Definition LVL1_ROI.h:65

◆ dumpNavigation()

StatusCode TrigEDMChecker::dumpNavigation ( const EventContext & ctx)
private

Definition at line 4436 of file TrigEDMChecker.cxx.

4437{
4438 // Get object from store
4439 const xAOD::TrigNavigation * navigationHandle = nullptr;
4440 ATH_CHECK( evtStore()->retrieve( navigationHandle, m_navigationHandleKey.key() ) );
4441 // Proper version doesn't work - conversion issue?
4442 //SG::ReadHandle< xAOD::TrigNavigation > navigationHandle = SG::ReadHandle< xAOD::TrigNavigation >( m_navigationHandleKey );
4443 //if ( !navigationHandle.isValid() ) ATH_MSG_FATAL( "Could not retrieve navigation" );
4444
4445 // Get serialised navigation info
4446 const std::vector< unsigned int > serialisedNavigation = navigationHandle->serialized();
4447 ATH_MSG_INFO( "Serialised navigation size: " << serialisedNavigation.size() );
4448
4449 // Convert the input
4450 HLT::Navigation* testNav = m_navigationTool.get();
4451 testNav->deserialize( serialisedNavigation );
4452
4453 // Make a map of TE name hashes
4454 const xAOD::TriggerMenuContainer * testMenu = nullptr;
4455 ATH_CHECK( inputMetaStore()->retrieve( testMenu, "TriggerMenu" ) );
4456 std::map< int, std::string > hash2string;
4457 for ( auto const& sequence : testMenu->front()->sequenceInputTEs() ) {
4458 for ( auto const& name : sequence ) {
4460 hash2string[ hash ] = name;
4461 }
4462 }
4463
4464 // Map TE names to chain names
4465 unsigned int chainCounter = 0;
4466 std::map< int, std::string > hash2chain;
4467 for ( auto const& chain : testMenu->front()->chainSignatureOutputTEs() ) {
4468
4469 // Find the chain name
4470 std::string chainName = testMenu->front()->chainNames()[ chainCounter ];
4471 ++chainCounter;
4472
4473 // Find all associated TEs
4474 for ( auto const& signature : chain ) {
4475 for ( auto const& name : signature ) {
4477 hash2string[ hash ] = name; // for decoding
4478 hash2chain[ hash ] = chainName;
4479 }
4480 }
4481 }
4482
4483 // Define a map of TE features, to the TEs that use them. Needs a custom sort lambda
4484 auto cmpLambda = []( const HLT::TriggerElement::FeatureAccessHelper &lhs, const HLT::TriggerElement::FeatureAccessHelper &rhs) {
4485
4486 // Compare indices if CLID matches
4487 if ( lhs.getCLID() == rhs.getCLID() ) return ( lhs.getIndex() < rhs.getIndex() );
4488
4489 // Compare CLIDs
4490 else return ( lhs.getCLID() < rhs.getCLID() );
4491 };
4492 std::map< HLT::TriggerElement::FeatureAccessHelper, std::vector< HLT::TriggerElement* >, decltype(cmpLambda) > feature2element(cmpLambda);
4493
4494 // Retrieve all TE features and add them to the map
4495 std::vector< HLT::TriggerElement* > allTEs;
4496 testNav->getAll( allTEs, false );
4497 for ( auto element : allTEs ) {
4498
4499 // Add TE features to the big map
4500 for ( auto helper : element->getFeatureAccessHelpers() ) {
4501 feature2element[ helper ].push_back( element );
4502 }
4503 }
4504
4505 // Debug - output all TEs and their ancestors
4506 // No duplication - only print terminal nodes
4507 for ( auto element : allTEs ) {
4508 if ( testNav->isTerminalNode( element ) ) {
4509 ATH_MSG_INFO( "+++++++++++ " << hash2string[ element->getId() ] << " is terminal node" );
4510 ATH_MSG_INFO( "ptr: " << element );
4511 std::queue< HLT::TriggerElement* > allAncestors;
4512 allAncestors.push( element );
4513 while ( allAncestors.size() ) {
4514
4515 HLT::TriggerElement * thisElement = allAncestors.front();
4516 allAncestors.pop();
4517 auto theseAncestors = thisElement->getRelated( HLT::TriggerElement::Relation::seededByRelation );
4518
4519 // Dump TE
4520 ATH_MSG_INFO( "te: " << thisElement->getId() << " " << hash2string[ thisElement->getId() ] );
4521 ATH_MSG_INFO( " chain: " << hash2chain[ thisElement->getId() ] );
4522 for ( const auto& helper : thisElement->getFeatureAccessHelpers() ) {
4523 ATH_MSG_INFO( " feat: " << helper );
4524 }
4525 ATH_MSG_INFO( theseAncestors.size() << " ancestors" );
4526
4527 // Examine ancestors
4528 for ( auto ancestor : theseAncestors ) {
4529 allAncestors.push( ancestor );
4530 }
4531 }
4532 }
4533 }
4534
4535 // Make the decision container
4536 SG::WriteHandle< TrigCompositeUtils::DecisionContainer > outputNavigation = TrigCompositeUtils::createAndStore( m_decisionsKey, ctx );
4537 auto decisionOutput = outputNavigation.ptr();
4538
4539 // Find unique chains associated with a feature
4540 std::map< HLT::TriggerElement const*, std::vector< int > > element2decisions;
4541 for ( const auto& pair : feature2element ) {
4542
4543 // Get the feature info
4544 std::string featureName = testNav->label( pair.first.getCLID(), pair.first.getIndex().subTypeIndex() );
4545 auto sgKey = evtStore()->stringToKey( featureName, pair.first.getCLID() );
4546
4547 // Store RoIs with appropriate label ?
4548 std::string storeFeatureName = "feature";
4549/* if ( pair.first.getCLID() == ClassID_traits< TrigRoiDescriptor >::ID() ) {
4550 storeFeatureName = "roi";
4551 }*/
4552
4553 // Make a decision object for the feature
4554 auto decision = TrigCompositeUtils::newDecisionIn( decisionOutput );
4555 decision->typelessSetObjectLink( storeFeatureName, sgKey, pair.first.getCLID(), pair.first.getIndex().objectsBegin(), pair.first.getIndex().objectsEnd() );
4556
4557 // Examine associated TEs, look for chains
4558 std::set< std::string > passedChains;
4559 for ( HLT::TriggerElement const* element : pair.second ) {
4560
4561 // TODO - find out what chains actually passed!
4562 passedChains.insert( hash2chain[ element->getId() ] );
4563
4564 // Index the TE
4565 int decisionNumber = decisionOutput->size() - 1;
4566 element2decisions[ element ].push_back( decisionNumber );
4567 }
4568
4569 // Store unique chains in the decision
4570 for ( auto& chain : passedChains ) {
4572 }
4573 }
4574
4575 // Store decision ancestry (had to go through once before to ensure indices populated)
4576 unsigned int decisionCounter = 0;
4577 for ( const auto& pair : feature2element ) {
4578
4579 // Get current decision
4580 auto decision = decisionOutput->at( decisionCounter );
4581 ++decisionCounter;
4582
4583 // Find ancestor TEs
4584 for ( auto element : pair.second ) {
4585 auto theseAncestors = element->getRelated( HLT::TriggerElement::Relation::seededByRelation );
4586 for ( auto ancestor : theseAncestors ) {
4587 for ( int decisionIndex : element2decisions[ ancestor ] ) {
4588 TrigCompositeUtils::linkToPrevious( decision, m_decisionsKey.key(), decisionIndex );
4589 }
4590 }
4591 }
4592 }
4593
4594 return StatusCode::SUCCESS;
4595}
#define ATH_CHECK
Evaluate an expression and check for errors.
ServiceHandle< StoreGateSvc > & inputMetaStore()
Accessor for the input metadata store.
bool deserialize(const std::vector< uint32_t > &input)
void getAll(std::vector< TriggerElement * > &output, const bool activeOnly=true) const
The query returning a collection of all TriggerElements.
static bool isTerminalNode(const TriggerElement *te)
queries if node is terminal (no more TriggerElement are seeded by it)
std::string label(class_id_type clid, const index_or_label_type &sti_or_label) const
const ObjectIndex & getIndex() const
index in the external ojects array
const std::vector< TriggerElement * > & getRelated(Relation rel) const
returns reference to the likns to other TriggerElements related by relation r
const std::vector< FeatureAccessHelper > & getFeatureAccessHelpers() const
returns all features which ara attached to this TE
pointer_type ptr()
Dereference the pointer.
static HLTHash string2hash(const std::string &, const std::string &category="TE")
hash function translating TE names into identifiers
SG::WriteHandleKey< TrigCompositeUtils::DecisionContainer > m_decisionsKey
SG::ReadHandleKey< xAOD::TrigNavigation > m_navigationHandleKey
ToolHandle< HLT::Navigation > m_navigationTool
const std::vector< unsigned int > & serialized() const
expose the navigation information (in serialized form)
Decision * newDecisionIn(DecisionContainer *dc, const std::string &name)
Helper method to create a Decision object, place it in the container and return a pointer to it.
SG::WriteHandle< DecisionContainer > createAndStore(const SG::WriteHandleKey< DecisionContainer > &key, const EventContext &ctx)
Creates and right away records the DecisionContainer with the key.
void linkToPrevious(Decision *d, const std::string &previousCollectionKey, size_t previousIndex)
Links to the previous object, location of previous 'seed' decision supplied by hand.
void addDecisionID(DecisionID id, Decision *d)
Appends the decision (given as ID) to the decision object.
TriggerMenuContainer_v1 TriggerMenuContainer
Define the latest version of the trigger menu container class.
TrigNavigation_v1 TrigNavigation
Define the latest version of the trigger navigation class.

◆ dumpStoreGate()

StatusCode TrigEDMChecker::dumpStoreGate ( )
private

◆ dumpTDT()

StatusCode TrigEDMChecker::dumpTDT ( )
private

Definition at line 4013 of file TrigEDMChecker.cxx.

4013 {
4014 using namespace TrigCompositeUtils; // LinkInfo
4015 ATH_MSG_INFO( "REGTEST ==========START of TDT DUMP===========" );
4016 // Note: This minimal TDT dumper is for use during run-3 dev
4017 std::string chain = m_dumpNavForChain;
4018 if (chain.empty()) {
4019 chain = "HLT_.*";
4020 }
4021 std::vector<std::string> confChains = m_trigDec->getListOfTriggers(chain);
4022 for (const auto& item : confChains) {
4023 bool passed = m_trigDec->isPassed(item);
4024 ATH_MSG_INFO(" HLT Item " << item << " (numeric ID " << TrigConf::HLTUtils::string2hash(item, "Identifier") << ") passed raw? " << passed);
4025 if (m_trigDec->getNavigationFormat() == "TriggerElement") {
4026 ATH_MSG_DEBUG(" Skipping Run 2 features in this dumper");
4027 continue;
4028 }
4029 std::vector< LinkInfo<xAOD::IParticleContainer> > passFeatures = m_trigDec->features<xAOD::IParticleContainer>(item);
4030 if (passFeatures.size()) {
4031 ATH_MSG_INFO(" " << item << " Passed Final IParticle features size: " << passFeatures.size());
4032 for (const LinkInfo<xAOD::IParticleContainer>& li : passFeatures) {
4033 if (!li.isValid()) {
4034 ATH_MSG_WARNING(" Unable to access feature - link invalid.");
4035 } else {
4036 try {
4037 std::string state = "ACTIVE";
4038 if (li.state == ActiveState::INACTIVE) state = "INACTIVE";
4039 else if (li.state == ActiveState::UNSET) state = "UNSET";
4040 ATH_MSG_INFO(" IParticle Feature from " << li.link.dataID() << " index:" << li.link.index() << " pt:" << (*li.link)->pt() << " eta:" << (*li.link)->eta() << " phi:" << (*li.link)->phi() << " state:" << state);
4041 } catch (const std::exception& e) {
4042 ATH_MSG_WARNING(" Unable to dereference feature {" << e.what() << "}");
4043 }
4044 }
4045 }
4046 }
4047 std::vector< LinkInfo<xAOD::IParticleContainer> > passAndFailFeatures = m_trigDec->features<xAOD::IParticleContainer>(item, TrigDefs::includeFailedDecisions);
4048 if (passAndFailFeatures.size()) {
4049 ATH_MSG_INFO(" " << item << " Passed+Failed Final IParticle features size: " << passAndFailFeatures.size());
4050 for (const LinkInfo<xAOD::IParticleContainer>& li : passAndFailFeatures) {
4051 if (!li.isValid()) {
4052 ATH_MSG_WARNING(" Unable to access feature - link invalid.");
4053 } else {
4054 try {
4055 std::string state = "ACTIVE";
4056 if (li.state == ActiveState::INACTIVE) state = "INACTIVE";
4057 else if (li.state == ActiveState::UNSET) state = "UNSET";
4058 ATH_MSG_INFO(" IParticle Feature from " << li.link.dataID() << " index:" << li.link.index() << " pt:" << (*li.link)->pt() << " eta:" << (*li.link)->eta() << " phi:" << (*li.link)->phi() << " state:" << state);
4059 } catch (const std::exception& e) {
4060 ATH_MSG_WARNING(" Unable to dereference feature {" << e.what() << "}");
4061 }
4062 }
4063 }
4064 }
4065 std::vector< LinkInfo<xAOD::IParticleContainer> > allFeatures = m_trigDec->features<xAOD::IParticleContainer>(item, TrigDefs::includeFailedDecisions, "", TrigDefs::allFeaturesOfType);
4066 if (allFeatures.size()) {
4067 ATH_MSG_INFO(" " << item << " Passed+Failed ALL IParticle features size: " << allFeatures.size());
4068 for (const LinkInfo<xAOD::IParticleContainer>& li : allFeatures) {
4069 if (!li.isValid()) {
4070 ATH_MSG_WARNING(" Unable to access feature - link invalid.");
4071 } else {
4072 try {
4073 std::string state = "ACTIVE";
4074 if (li.state == ActiveState::INACTIVE) state = "INACTIVE";
4075 else if (li.state == ActiveState::UNSET) state = "UNSET";
4076 ATH_MSG_INFO(" IParticle Feature from " << li.link.dataID() << " index:" << li.link.index() << " pt:" << (*li.link)->pt() << " eta:" << (*li.link)->eta() << " phi:" << (*li.link)->phi() << " state:" << state);
4077 } catch (const std::exception& e) {
4078 ATH_MSG_WARNING(" Unable to dereference feature {" << e.what() << "}");
4079 }
4080 }
4081 }
4082 }
4083 }
4084
4085 if (m_trigDec->getNavigationFormat() == "TrigComposite") {
4086 // Check associateToEventView helper function
4087 std::vector< LinkInfo<xAOD::IParticleContainer> > muons = m_trigDec->features<xAOD::IParticleContainer>("HLT_mu24_idperf_L1MU20", TrigDefs::Physics, "HLT_MuonL2CBInfo");
4088 SG::ReadHandle<xAOD::TrackParticleContainer> muonTracksReadHandle(m_muonTracksKey, Gaudi::Hive::currentContext());
4089 for (const LinkInfo<xAOD::IParticleContainer>& mu : muons) {
4090 // Note: auto here refers to type std::pair< xAOD::TrackParticleContainer::const_iterator, xAOD::TrackParticleContainer::const_iterator>
4091 const auto roiTrackItPair = m_trigDec->associateToEventView<xAOD::TrackParticleContainer>(muonTracksReadHandle, mu, "roi");
4092 const xAOD::TrackParticleContainer::const_iterator startIt = roiTrackItPair.first;
4093 const xAOD::TrackParticleContainer::const_iterator stopIt = roiTrackItPair.second;
4094 ATH_MSG_INFO("Muon pT: " << (*mu.link)->pt() << " is from the same ROI as tracks with index "
4095 << std::distance(muonTracksReadHandle->begin(), startIt) << "-" << std::distance(muonTracksReadHandle->begin(), stopIt)
4096 << ", which is " << std::distance(startIt, stopIt) << " tracks, out of " << muonTracksReadHandle->size() << " total tracks.");
4097 for (xAOD::TrackParticleContainer::const_iterator it = startIt; it != stopIt; ++it) {
4098 ATH_MSG_VERBOSE(" -- Track " << std::distance(startIt, it) << " in this ROI, pT: " << (*it)->pt() );
4099 }
4100 }
4101 }
4102
4103 ATH_MSG_INFO( "REGTEST ==========END of TDT DUMP===========" );
4104 return StatusCode::SUCCESS;
4105}
bool passed(DecisionID id, const DecisionIDContainer &)
checks if required decision ID is in the set of IDs in the container
DataModel_detail::const_iterator< DataVector > const_iterator
Definition DataVector.h:838
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
size_type size() const noexcept
Returns the number of elements in the collection.
PublicToolHandle< Trig::TrigDecisionTool > m_trigDec
SG::ReadHandleKey< xAOD::TrackParticleContainer > m_muonTracksKey
Gaudi::Property< std::string > m_dumpNavForChain
static const unsigned int includeFailedDecisions
Run3 synonym of alsoDeactivateTEs.
static const unsigned int allFeaturesOfType
Run 3 "enum". Return all features along legs (still with type and container checks).
TrackParticleContainer_v1 TrackParticleContainer
Definition of the current "TrackParticle container version".

◆ dumpTrackParticleContainer()

StatusCode TrigEDMChecker::dumpTrackParticleContainer ( )
private

track

track vertex position

access to TrackSummary information

Definition at line 1057 of file TrigEDMChecker.cxx.

1057 {
1058
1059 ATH_MSG_DEBUG("in dumpTrackParticleContainer()");
1060
1061 ATH_MSG_INFO("REGTEST ==========START of TrackParticleContainer DUMP===========");
1062
1063 std::string trackPtags[]={"HLT_InDetTrigParticleCreation_Bjet_EFID",
1064 "HLT_InDetTrigParticleCreation_Bphysics_EFID",
1065 "HLT_InDetTrigParticleCreation_Electron_EFID",
1066 "HLT_InDetTrigParticleCreation_FullScan_EFID",
1067 "HLT_InDetTrigParticleCreation_Muon_EFID",
1068 "HLT_InDetTrigParticleCreation_Photon_EFID",
1069 "HLT_InDetTrigParticleCreation_Tau_EFID"};
1070
1071 int ntag=7;
1072
1073 StatusCode returnsc=StatusCode::SUCCESS;
1074
1075 for (int itag=0; itag<ntag; itag++){
1076 const Rec::TrackParticleContainer* pTrackParticleC = nullptr;
1077 StatusCode sc = evtStore()->retrieve(pTrackParticleC, trackPtags[itag]);
1078 if (sc.isFailure()) {
1079 ATH_MSG_INFO("REGTEST No TrackParticleContainer found with tag " << trackPtags[itag]);
1080 continue;
1081 }
1082 ATH_MSG_INFO("TrackParticleContainer found with tag " << trackPtags[itag]
1083 << " and size " << pTrackParticleC->size());
1084
1085 Rec::TrackParticleContainer::const_iterator trackItr = pTrackParticleC->begin();
1086 Rec::TrackParticleContainer::const_iterator trackItrE = pTrackParticleC->end();
1087 for (int ind=1; trackItr != trackItrE; ++trackItr, ind++) {
1088 const Rec::TrackParticle * trackParticle = (*trackItr);
1089 ATH_MSG_INFO(" TrackParticle " << ind << " charge "
1090 << trackParticle->charge() << " p "
1091 << trackParticle->p()<< " eta " << trackParticle->eta()
1092 << " phi " << trackParticle->phi());
1093
1095 const Trk::Track * track = trackParticle->originalTrack();
1096 if ( track ) {
1097 ATH_MSG_INFO(" Got attached track");
1098 const Trk::TrackParameters* perigee = track->perigeeParameters();
1099 if (perigee) {
1100 const auto& parameterVector = perigee->parameters();
1101 ATH_MSG_INFO(" q/P " << parameterVector[Trk::qOverP] <<
1102 " theta " << parameterVector[Trk::theta] <<
1103 " phi " <<parameterVector[Trk::phi]);
1104 } else {
1105 ATH_MSG_INFO(" No perigee attached to track");
1106 }
1107
1108 } else {
1110 ATH_MSG_DEBUG(" No attached track");
1112 ATH_MSG_WARNING(" Max attached track warning reached, no further warnings given");
1113 }
1115 }
1116 }
1117
1119 const Trk::VxCandidate * vertex = trackParticle->reconstructedVertex();
1120 if ( vertex ) {
1121 const Trk::RecVertex& vtx = vertex->recVertex();
1122 const Amg::Vector3D& position = vtx.position();
1123 ATH_MSG_INFO(" vertex position (" << position[0] << ", " <<
1124 position[1] << ", " << position[2] << ") ");
1125 } else {
1127 ATH_MSG_DEBUG(" No attached vertex");
1129 ATH_MSG_WARNING(" Max attached vertex warning reached, no further warnings given");
1130 }
1132 }
1133 }
1134
1135 const Trk::Perigee* perigee = trackParticle->measuredPerigee();
1136 if (perigee) {
1137 const auto& parameters = perigee->parameters();
1138 ATH_MSG_INFO("Trk::Perigee parameters:");
1139 ATH_MSG_INFO(" * d_0 : "<< parameters[Trk::d0] );
1140 ATH_MSG_INFO(" * z_0 : "<< parameters[Trk::z0] );
1141 ATH_MSG_INFO(" * phi : "<< parameters[Trk::phi] );
1142 ATH_MSG_INFO(" * Theta : "<< parameters[Trk::theta] );
1143 ATH_MSG_INFO(" * q/p : "<< parameters[Trk::qOverP] );
1144 } else {
1145 ATH_MSG_WARNING(" No attached perigee");
1146 }
1148 const Trk::TrackSummary* summary = trackParticle->trackSummary();
1149 if (summary) {
1150 ATH_MSG_DEBUG("Track summary information:");
1151 ATH_MSG_DEBUG(" * Number of B layer hits : "<<summary->get(Trk::numberOfBLayerHits));
1152 ATH_MSG_DEBUG(" * Number of pixel hits : "<<summary->get(Trk::numberOfPixelHits));
1153 ATH_MSG_DEBUG(" * Number of SCT hits : "<<summary->get(Trk::numberOfSCTHits));
1154 ATH_MSG_DEBUG(" * Number of TRT hits : "<<summary->get(Trk::numberOfTRTHits));
1155 }
1156 }
1157 }
1158 return returnsc;
1159}
static const int maxRepWarnings
Adapted from code by A.Hamilton to check trigger EDM; R.Goncalo 21/11/07.
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
virtual double phi() const =0
phi in [-pi,pi[
virtual double p() const =0
momentum magnitude
virtual double eta() const =0
pseudo rapidity
const Trk::Perigee * measuredPerigee() const
Accessor method for Perigee.
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
const Track * originalTrack() const
Return pointer to associated track.
double charge() const
Return charge of the particle.
const VxCandidate * reconstructedVertex() const
Get a pointer to the primary vertex.
const Amg::Vector3D & position() const
return position of vertex
Definition Vertex.cxx:63
Eigen::Matrix< double, 3, 1 > Vector3D
ParametersT< TrackParametersDim, Charged, PerigeeSurface > Perigee
@ theta
Definition ParamDefs.h:66
@ qOverP
perigee
Definition ParamDefs.h:67
@ phi
Definition ParamDefs.h:75
@ d0
Definition ParamDefs.h:63
@ z0
Definition ParamDefs.h:64
const Amg::Vector3D & position() const
Method to retrieve the position of the Intersection.
ParametersBase< TrackParametersDim, Charged > TrackParameters
@ numberOfPixelHits
number of pixel layers on track with absence of hits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?

◆ dumpTrigComposite()

StatusCode TrigEDMChecker::dumpTrigComposite ( )
private

Dump information on TrigComposite collections.

Only dumpTrigCompositeContainers are dumped unless doDumpAllTrigComposite is set

Definition at line 4107 of file TrigEDMChecker.cxx.

4107 {
4108 ATH_MSG_INFO( "REGTEST ==========START of xAOD::TrigCompositeContainer DUMP===========" );
4109
4112 const CLID TrigCompositeCLID = static_cast<CLID>( ClassID_traits< xAOD::TrigCompositeContainer >::ID() );
4113 evtStore()->keys(TrigCompositeCLID, m_dumpTrigCompositeContainers);
4114 std::string typeNameTC;
4115 ATH_CHECK(m_clidSvc->getTypeNameOfID(TrigCompositeCLID, typeNameTC));
4116 ATH_MSG_DEBUG("dumpTrigComposite got " << m_dumpTrigCompositeContainers.size() << " keys for " << typeNameTC);
4117 } else {
4118 ATH_MSG_DEBUG("Using supplied " << m_dumpTrigCompositeContainers.size() << " keys");
4119 }
4120
4121 for ( const std::string & key: m_dumpTrigCompositeContainers ) {
4122 // get the collection
4124 ATH_MSG_WARNING("Absent TrigCompositeContainer: " << key );
4125 continue;
4126 }
4127 ATH_MSG_DEBUG( "#################### Dumping container of : " << key );
4128 const xAOD::TrigCompositeContainer* cont= nullptr;
4129 ATH_CHECK( evtStore()->retrieve( cont, key ) );
4130
4131 size_t count = 0;
4132 for ( auto tc: *cont ) {
4133 ATH_MSG_DEBUG("########## ELEMENT " << count++);
4134 ATH_MSG_DEBUG(*tc);
4135 // Get the objects we know of
4136 for (size_t i = 0; i < tc->linkColNames().size(); ++i) ATH_CHECK(checkTrigCompositeElementLink(tc, i));
4137 }
4138 }
4139 ATH_MSG_INFO( "REGTEST ==========END of xAOD::TrigCompositeContainer DUMP===========" );
4140 return StatusCode::SUCCESS;
4141}
StatusCode checkTrigCompositeElementLink(const xAOD::TrigComposite *tc, size_t element)
Dump details on element links within TrigComposites.
bool contains(const std::string &s, const std::string &regx)
does a string contain the substring
Definition hcg.cxx:116
int count(std::string s, const std::string &regx)
count how many occurances of a regx are in a string
Definition hcg.cxx:148

◆ dumpTrigEFBphysContainer()

StatusCode TrigEDMChecker::dumpTrigEFBphysContainer ( )
private

Definition at line 2334 of file TrigEDMChecker.cxx.

2334 {
2335
2336 ATH_MSG_DEBUG("in dumpTrigEFBphysContainer()");
2337
2338 ATH_MSG_INFO("REGTEST ==========START of TrigEFBphysContainer DUMP===========");
2339
2340 std::string EFBphysTags[]={"HLT_xAOD__TrigBphysContainer_EFBMuMuFex",
2341 "HLT_xAOD__TrigBphysContainer_EFBMuMuXFex",
2342 "HLT_xAOD__TrigBphysContainer_EFDsPhiPiFex",
2343 "HLT_xAOD__TrigBphysContainer_EFMuPairs",
2344 "HLT_xAOD__TrigBphysContainer_EFMultiMuFex",
2345 "HLT_xAOD__TrigBphysContainer_EFTrackMass"
2346 };
2347
2348 int ntag= (int) sizeof(EFBphysTags) / sizeof(EFBphysTags[0]);
2349
2350
2351 for (int itag=0; itag<ntag; itag++){
2352 const xAOD::TrigBphysContainer* trigEFBphys;
2353 StatusCode sc = evtStore()->retrieve(trigEFBphys, EFBphysTags[itag]);
2354 if (sc.isFailure()) {
2355 ATH_MSG_INFO("REGTEST No TrigEFBphysContainer found with tag " << EFBphysTags[itag]);
2356 continue;
2357 }
2358
2359 ATH_MSG_INFO("REGTEST TrigEFBphysContainer found with tag " << EFBphysTags[itag]
2360 << " and size " << trigEFBphys->size());
2361
2362 // for (int i=0; trigEFBphys != lastTrigEFBphys; ++trigEFBphys, ++i) {
2363
2364 //mLog << MSG::INFO << "REGTEST Looking at TrigEFBphysContainer " << i << endmsg;
2365
2366 xAOD::TrigBphysContainer::const_iterator EFBphysItr = trigEFBphys->begin();
2367 xAOD::TrigBphysContainer::const_iterator EFBphysItrE = trigEFBphys->end();
2368
2369 for (int j=0; EFBphysItr != EFBphysItrE; ++EFBphysItr, ++j ) {
2370
2371 ATH_MSG_INFO("REGTEST Looking at TrigEFBphys " << j);
2372
2373 ATH_MSG_INFO("REGTEST TrigEFBphys->eta() returns " << (*EFBphysItr)->eta());
2374 ATH_MSG_INFO("REGTEST TrigEFBphys->phi() returns " << (*EFBphysItr)->phi());
2375 ATH_MSG_INFO("REGTEST TrigEFBphys->mass() returns " << (*EFBphysItr)->mass());
2376 ATH_MSG_INFO("REGTEST TrigEFBphys->fitmass() returns " << (*EFBphysItr)->fitmass());
2377 // ATH_MSG_INFO("REGTEST TrigEFBphys->isValid() returns " << (*EFBphysItr)->isValid());
2378 ATH_MSG_INFO("REGTEST TrigEFBphys->roiId() returns " << (*EFBphysItr)->roiId());
2379 ATH_MSG_INFO("REGTEST TrigEFBphys->particleType() returns " << (*EFBphysItr)->particleType());
2380
2381 if( (*EFBphysItr)->secondaryDecay() != NULL){
2382 const xAOD::TrigBphys * psecond =(*EFBphysItr)->secondaryDecay();
2383 ATH_MSG_INFO("REGTEST Secondary decay info: ");
2384 ATH_MSG_INFO("REGTEST pSecondDecay->eta() returns " << psecond->eta());
2385 ATH_MSG_INFO("REGTEST pSecondDecay->phi() returns " << psecond->phi());
2386 ATH_MSG_INFO("REGTEST pSecondDecay->mass() returns " << psecond->mass());
2387 ATH_MSG_INFO("REGTEST pSecondDecay->fitmass() returns " << psecond->fitmass());
2388 // ATH_MSG_INFO("REGTEST pSecondDecay->isValid() returns " << (*EFBphysItr)->secondaryDecayLink()->isValid());
2389 ATH_MSG_INFO("REGTEST pSecondDecay->roiId() returns " << psecond->roiId());
2390 ATH_MSG_INFO("REGTEST pSecondDecay->particleType() returns " << psecond->particleType());
2391
2392 } // end if secondary exists
2393
2394
2395
2396 const std::vector<ElementLink<xAOD::TrackParticleContainer> > trackVector = (*EFBphysItr)->trackParticleLinks();
2397 if (trackVector.size() != 0) {
2398 ATH_MSG_INFO(" REGTEST got track vector size: " << trackVector.size());
2399 } else {
2400 ATH_MSG_INFO(" REGTEST no track vector!!! " );
2401 }
2402 std::vector<ElementLink<xAOD::TrackParticleContainer> >::const_iterator trkIt=trackVector.begin();
2403 for (int itrk=0 ; trkIt!= trackVector.end(); ++itrk, ++trkIt) {
2404 if (!(trkIt->isValid())) {
2405 ATH_MSG_WARNING("TrackParticleContainer::Invalid ElementLink to track ");
2406 continue;
2407 }
2408 //const Trk::Perigee* trackPerigee=(*(*trkIt))->measuredPerigee();
2409 const Trk::Perigee* trackPerigee=&((*(*trkIt))->perigeeParameters());
2410
2411 // msg() << MSG::VERBOSE << "track, iterator, pointer " << itrk << " " << *trkIt << " " << *(*trkIt) << endmsg;
2412 double phi = trackPerigee->parameters()[Trk::phi];
2413 double theta = trackPerigee->parameters()[Trk::theta];
2414 double px = trackPerigee->momentum()[Trk::px];
2415 double py = trackPerigee->momentum()[Trk::py];
2416 double pt = sqrt(px*px + py*py);
2417 double eta = -std::log(tan(theta/2));
2418
2419 ATH_MSG_INFO("track " << itrk << " pt phi eta " << pt << " " <<
2420 phi << " " << eta);
2421 }
2422
2423 }
2424 }
2425 ATH_MSG_INFO("REGTEST ==========END of TrigEFBphysContainer DUMP===========");
2426 ATH_MSG_DEBUG("dumpTrigEFBphysContainer() succeeded");
2427
2428 return StatusCode::SUCCESS;
2429}
Scalar eta() const
pseudorapidity method
Scalar phi() const
phi method
Scalar theta() const
theta method
const Amg::Vector3D & momentum() const
Access method for the momentum.
uint32_t roiId() const
accessor method: ID of L1 RoI
float eta() const
accessor method: eta
pType particleType() const
accessor method: particle Type
const TrigBphys_v1 * secondaryDecay() const
accessor method: secondary decay particle
float phi() const
accessor method: phi
float fitmass() const
accessor method: mass from vertex fit
float mass() const
accessor method: mass
@ px
Definition ParamDefs.h:59
@ py
Definition ParamDefs.h:60
TrigBphys_v1 TrigBphys
Definition TrigBphys.h:18
TrigBphysContainer_v1 TrigBphysContainer

◆ dumpTrigInDetTrackCollection()

StatusCode TrigEDMChecker::dumpTrigInDetTrackCollection ( )
private

Definition at line 2130 of file TrigEDMChecker.cxx.

2130 {
2131
2132 std::string TrigInDetTrackTags[]={ "HLT_TrigIDSCAN_Jet",
2133 "HLT_TrigIDSCAN_Tau",
2134 "HLT_TrigIDSCAN_eGamma",
2135 "HLT_TrigIDSCAN_Muon",
2136 "HLT_TrigIDSCAN_muonIso",
2137 "HLT_TrigIDSCAN_Bphysics",
2138 "HLT_TrigIDSCAN_FullScan",
2139 "HLT_TrigIDSCAN_Cosmics",
2140 "HLT_TrigIDSCAN_eGamma_Brem",
2141 "HLT_TrigIDSCAN_Tile",
2142 "HLT_TrigSiTrack_eGamma",
2143 "HLT_TrigSiTrack_Muon",
2144 "HLT_TrigSiTrack_muonIso",
2145 "HLT_TrigSiTrack_Tau",
2146 "HLT_TrigSiTrack_Jet",
2147 "HLT_TrigSiTrack_Bphysics",
2148 "HLT_TrigSiTrack_FullScan",
2149 "HLT_TrigSiTrack_Cosmics",
2150 "HLT_TRTSegmentFinder",
2151 "HLT_TRTxK"};
2152 int ntag=20;
2153
2154 ATH_MSG_DEBUG("in dumpTrigInDetTrackCollection()");
2155
2156 const TrigInDetTrackTruthMap* pTruthMap(nullptr);
2157 bool gotTruthMap = false;
2158
2159 if (evtStore()->contains<TrigInDetTrackTruthMap>("TrigInDetTrackTruthMap")) {
2160 StatusCode sc=evtStore()->retrieve(pTruthMap,"TrigInDetTrackTruthMap");
2161 if (sc.isFailure())
2162 {
2163 ATH_MSG_WARNING(" could not retrieve TrackTruthMap with key TrigInDetTruthMap");
2164 } else {
2165 gotTruthMap=true;
2166 // pTruthMap->print();
2167 }
2168 }
2169 else ATH_MSG_DEBUG(" didn't find any TrackTruthMap objects with key TrigInDetTruthMap");
2170
2171 ATH_MSG_INFO("REGTEST ==========START of TrigInDetTrackCollection DUMP===========");
2172
2173 for (int iTag=0; iTag < ntag; iTag++) {
2174 const TrigInDetTrackCollection* trigInDetTrackCollection = nullptr;
2175 StatusCode sc = evtStore()->retrieve(trigInDetTrackCollection,TrigInDetTrackTags[iTag] );
2176 if (sc.isFailure()) {
2177 ATH_MSG_DEBUG("REGTEST No TrigInDetTrackCollection found with key " << TrigInDetTrackTags[iTag]);
2178 continue;
2179 }
2180 ATH_MSG_INFO("REGTEST TrigInDetTrackCollections retrieved with key "
2181 << TrigInDetTrackTags[iTag]);
2182
2183 ATH_MSG_INFO("REGTEST TrigInDetTrackCollection->size() returns " << trigInDetTrackCollection->size());
2184
2185 TrigInDetTrackCollection::const_iterator trkItr = trigInDetTrackCollection->begin();
2186 TrigInDetTrackCollection::const_iterator trkItrE = trigInDetTrackCollection->end();
2187
2188 for (int j=0; trkItr != trkItrE; ++trkItr, ++j ) {
2189
2190 ATH_MSG_INFO("REGTEST Looking at TrigInDetTrack " << j);
2191
2192 ATH_MSG_INFO("REGTEST TrigInDetTrack->algorithmId() returns " << (*trkItr)->algorithmId());
2193 ATH_MSG_INFO("REGTEST TrigInDetTrack->chi2() returns " << (*trkItr)->chi2());
2194 ATH_MSG_INFO("REGTEST TrigInDetTrack->NStrawHits() returns " << (*trkItr)->NStrawHits());
2195
2196 ATH_MSG_INFO("REGTEST TrigInDetTrack->NStraw() returns " << (*trkItr)->NStraw());
2197 ATH_MSG_INFO("REGTEST TrigInDetTrack->NStrawTime() returns " << (*trkItr)->NStrawTime());
2198 ATH_MSG_INFO("REGTEST TrigInDetTrack->NTRHits() returns " << (*trkItr)->NTRHits());
2199
2200 ATH_MSG_INFO("REGTEST Looking at TrigInDetFitTrack->param()");
2201 const TrigInDetTrackFitPar* my_param = (*trkItr)->param();
2202
2203 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->a0() returns " << my_param->a0());
2204 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->z0() returns " << my_param->z0());
2205 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->phi0() returns " << my_param->phi0());
2206 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->eta() returns " << my_param->eta());
2207 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->pT() returns " << my_param->pT());
2208 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->ea0() returns " << my_param->ea0());
2209 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->ez0() returns " << my_param->ez0());
2210 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->ephi0() returns " << my_param->ephi0());
2211 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->eeta() returns " << my_param->eeta());
2212 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->epT() returns " << my_param->epT());
2213 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->surfaceType() returns " << my_param->surfaceType());
2214 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->surfaceCoordinate() returns " << my_param->surfaceCoordinate());
2215 ATH_MSG_INFO("REGTEST Looking at covarience matrix: ");
2216
2217 const std::vector<double>* const my_cov = my_param->cov();
2218 if (!my_cov) {
2219 ATH_MSG_INFO("REGTEST covarience matrix NULL (not stored)");
2220 } else {
2221 std::vector<double> tempcov = *my_cov;
2222 std::vector<double>::iterator iter;
2223 int k;
2224 for(iter = tempcov.begin(), k=0; iter != tempcov.end(); ++iter, ++k){
2225 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->cov() element " << k << " is " << (*iter));
2226 }
2227 }
2228 if (gotTruthMap) {
2229 if (!(pTruthMap->hasTruth((*trkItr)))) {
2230 ATH_MSG_DEBUG(" REGTEST Track has no truth info ");
2231 } else {
2232 ATH_MSG_DEBUG(" Track has truth info: ");
2233 const TrigInDetTrackTruth* pTRTtruth = pTruthMap->truth((*trkItr));
2234 int nMatches = pTRTtruth->nrMatches() ;
2235 if (nMatches==0) {
2236 ATH_MSG_INFO(" REGTEST Track has no truth matches");
2237 } else {
2238 ATH_MSG_INFO("REGTEST number of matched truth hits: Si: " << pTruthMap->bestMatchSiHits((*trkItr))
2239 << " TRT: " << pTruthMap->bestMatchTRTHits((*trkItr)));
2240 if (pTruthMap->bestMatchSiHits((*trkItr)) > 0) {
2241
2242 const HepMcParticleLink* pSiTruth = pTruthMap->bestMatchSi((*trkItr));
2243
2244 ATH_MSG_INFO("REGTEST Si match to kine ref " << pSiTruth->barcode());
2245 if (pSiTruth->cptr() != 0) {
2246 ATH_MSG_INFO("REGTEST Si PDG id " << pSiTruth->cptr()->pdg_id());
2247 }
2248 }
2249
2250 if (pTruthMap->bestMatchTRTHits((*trkItr)) > 0) {
2251 const HepMcParticleLink* pTRTtruth = pTruthMap->bestMatchTRT((*trkItr));
2252
2253 ATH_MSG_INFO("REGTEST TRT match to kine ref " << pTRTtruth->barcode());
2254 if (pTRTtruth->cptr() != 0) {
2255 ATH_MSG_INFO("REGTEST TRT PDG id " << pTRTtruth->cptr()->pdg_id());
2256 }
2257 }
2258 }
2259 }
2260 } // if (gotTruthMap)
2261 }
2262 }
2263
2264 ATH_MSG_INFO("REGTEST ==========END of TrigInDetTrackCollection DUMP===========");
2265 ATH_MSG_DEBUG("dumpTrigInDetTrackCollection() succeeded");
2266
2267 return StatusCode::SUCCESS;
2268}
Athena::TPCnvVers::Old Athena::TPCnvVers::Current Athena::TPCnvVers::Current TrigInDetTrackCollection
TrigInDetTrackTruthMap
void surfaceCoordinate(double c)
Setter: surface reference coordinate for non-perigee surfaces.
void eta(const double eta)
Setter: pseudorapidity.
void z0(const double z0)
Setter: longitudinal impact parameter.
double ea0() const
variance of transverse impact parameter
void phi0(const double phi0)
Setter: azimuthal angle of the momentum.
void a0(const double a0)
Setter: transverse impact parameter.
double eeta() const
variance of pseudorapidity
void surfaceType(TrigSurfaceType s)
Setter: surface type PERIGEE=0, BARREL=1, ENDCAP=2.
double ez0() const
variance of longitudinal impact parameter
void cov(const std::vector< double > *cov)
Setter: covariance matrix of track parameters.
double ephi0() const
variance of azimuthal angle of the momentum
double epT() const
variance of transverse momentum
void pT(const double pT)
Setter: transverse momentum.
unsigned int nrMatches() const
returns number of matching particles

◆ dumpTrigL2BphysContainer()

StatusCode TrigEDMChecker::dumpTrigL2BphysContainer ( )
private

Definition at line 2432 of file TrigEDMChecker.cxx.

2432 {
2433
2434 ATH_MSG_DEBUG("in dumpTrigL2BphysContainer()");
2435 ATH_MSG_INFO("REGTEST ==========START of TrigL2BphysContainer DUMP===========");
2436
2437 std::string L2BphysTags[]={"HLT_xAOD__TrigBphysContainer_L2BMuMuFex",
2438 "HLT_xAOD__TrigBphysContainer_L2BMuMuXFex",
2439 "HLT_xAOD__TrigBphysContainer_L2DsPhiPiFexDs",
2440 "HLT_xAOD__TrigBphysContainer_L2DsPhiPiFexPhi",
2441 "HLT_xAOD__TrigBphysContainer_L2JpsieeFex",
2442 "HLT_xAOD__TrigBphysContainer_L2MultiMuFex",
2443 "HLT_xAOD__TrigBphysContainer_L2TrackMass",
2444 };
2445 const int ntag = (int) sizeof(L2BphysTags) / sizeof(L2BphysTags[0]);
2446
2447
2448 for (int itag=0; itag<ntag; itag++){
2449 const xAOD::TrigBphysContainer* trigL2Bphys;
2450 StatusCode sc = evtStore()->retrieve(trigL2Bphys, L2BphysTags[itag]);
2451 if (sc.isFailure()) {
2452 ATH_MSG_INFO("REGTEST No TrigL2BphysContainer found with tag " << L2BphysTags[itag]);
2453 continue;
2454 }
2455
2456 ATH_MSG_INFO("REGTEST TrigL2BphysContainer found with tag " << L2BphysTags[itag]
2457 << " and size " << trigL2Bphys->size());
2458
2459 // for (int i=0; trigL2Bphys != lastTrigL2Bphys; ++trigL2Bphys, ++i) {
2460
2461 // mLog << MSG::INFO << "REGTEST Looking at TrigL2BphysContainer " << i << endmsg;
2462
2463 xAOD::TrigBphysContainer::const_iterator L2BphysItr = trigL2Bphys->begin();
2464 xAOD::TrigBphysContainer::const_iterator L2BphysItrE = trigL2Bphys->end();
2465
2466 for (int j=0; L2BphysItr != L2BphysItrE; ++L2BphysItr, ++j ) {
2467
2468 ATH_MSG_INFO("REGTEST Looking at TrigL2Bphys " << j);
2469
2470 ATH_MSG_INFO("REGTEST TrigL2Bphys->eta() returns " << (*L2BphysItr)->eta());
2471 ATH_MSG_INFO("REGTEST TrigL2Bphys->phi() returns " << (*L2BphysItr)->phi());
2472 ATH_MSG_INFO("REGTEST TrigL2Bphys->mass() returns " << (*L2BphysItr)->mass());
2473 ATH_MSG_INFO("REGTEST TrigL2Bphys->fitmass() returns " << (*L2BphysItr)->fitmass());
2474 // ATH_MSG_INFO("REGTEST TrigL2Bphys->isValid() returns " << (*L2BphysItr)->isValid());
2475 ATH_MSG_INFO("REGTEST TrigL2Bphys->roiId() returns " << (*L2BphysItr)->roiId());
2476 ATH_MSG_INFO("REGTEST TrigL2Bphys->particleType() returns " << (*L2BphysItr)->particleType());
2477
2478 if( (*L2BphysItr)->secondaryDecay() != NULL){
2479 const xAOD::TrigBphys * psecond =(*L2BphysItr)->secondaryDecay();
2480 ATH_MSG_INFO("REGTEST Secondary decay info: ");
2481 ATH_MSG_INFO("REGTEST pSecondDecay->eta() returns " << psecond->eta());
2482 ATH_MSG_INFO("REGTEST pSecondDecay->phi() returns " << psecond->phi());
2483 ATH_MSG_INFO("REGTEST pSecondDecay->mass() returns " << psecond->mass());
2484 ATH_MSG_INFO("REGTEST pSecondDecay->fitmass() returns " << psecond->fitmass());
2485 // ATH_MSG_INFO("REGTEST pSecondDecay->isValid() returns " << (*L2BphysItr)->secondaryDecayLink()->isValid());
2486 ATH_MSG_INFO("REGTEST pSecondDecay->roiId() returns " << psecond->roiId());
2487 ATH_MSG_INFO("REGTEST pSecondDecay->particleType() returns " << psecond->particleType());
2488 } // end if secondary exists
2489
2490 const std::vector<ElementLink<xAOD::TrackParticleContainer> > trackVector = (*L2BphysItr)->trackParticleLinks();
2491 if (trackVector.size() != 0) {
2492 ATH_MSG_INFO(" REGTEST got track vector size: " << trackVector.size());
2493 } else {
2494 ATH_MSG_INFO(" REGTEST no track vector!!! " );
2495 }
2496 std::vector<ElementLink<xAOD::TrackParticleContainer> >::const_iterator trkIt=trackVector.begin();
2497 for (int itrk=0 ; trkIt!= trackVector.end(); ++itrk, ++trkIt) {
2498 if (!(trkIt->isValid())) {
2499 ATH_MSG_WARNING("TrackParticleContainer::Invalid ElementLink to track ");
2500 continue;
2501 }
2502 //const Trk::Perigee* trackPerigee=(*(*trkIt))->measuredPerigee();
2503 const Trk::Perigee* trackPerigee=&((*(*trkIt))->perigeeParameters());
2504
2505 // msg() << MSG::VERBOSE << "track, iterator, pointer " << itrk << " " << *trkIt << " " << *(*trkIt) << endmsg;
2506 double phi = trackPerigee->parameters()[Trk::phi];
2507 double theta = trackPerigee->parameters()[Trk::theta];
2508 double px = trackPerigee->momentum()[Trk::px];
2509 double py = trackPerigee->momentum()[Trk::py];
2510 double pt = sqrt(px*px + py*py);
2511 double eta = -std::log(tan(theta/2));
2512
2513 ATH_MSG_INFO("track " << itrk << " pt phi eta " << pt << " " <<
2514 phi << " " << eta);
2515 }
2516 }
2517 }
2518
2519 ATH_MSG_INFO("REGTEST ==========END of TrigL2BphysContainer DUMP===========");
2520 ATH_MSG_DEBUG("dumpTrigL2BphysContainer() succeeded");
2521
2522 return StatusCode::SUCCESS;
2523}

◆ dumpTrigPassBits()

StatusCode TrigEDMChecker::dumpTrigPassBits ( )
private

Definition at line 581 of file TrigEDMChecker.cxx.

581 {
582 const std::string name="HLT_xAOD__TrigPassBitsContainer_passbits";
583 const xAOD::TrigPassBitsContainer *xbitscont=nullptr;
584 StatusCode sc = evtStore()->retrieve(xbitscont,name);
585 if (sc.isFailure() ){
586 ATH_MSG_INFO("Cannot retrieve TrigPassBits");
587 }
588 else {
589 ATH_MSG_INFO("Size of PassBits container : " << xbitscont->size());
590 for(const auto bits:*xbitscont){
591 if(bits==nullptr){
592 ATH_MSG_INFO("TrigPassBits point nullptr ");
593 continue;
594 }
595 ATH_MSG_DEBUG("Analyzing bits for " << bits->containerClid() << " of size " << bits->size() << " with bit size " << bits->passBits().size());
596 }
597
598 for(const xAOD::TrigPassBits* bits : *xbitscont){
599 if(bits==nullptr){
600 ATH_MSG_INFO("TrigPassBits point nullptr ");
601 continue;
602 }
603 ATH_MSG_DEBUG("Analyzing bits for " << bits->containerClid() << " of size " << bits->size() << " with bit size " << bits->passBits().size());
604 }
605 }
606 return StatusCode::SUCCESS;
607}
TrigPassBitsContainer_v1 TrigPassBitsContainer
Define the latest version of the trig pass bits container class.
TrigPassBits_v1 TrigPassBits
Define the latest version of the trigger pass bits class.

◆ dumpTrigSpacePointCounts()

void TrigEDMChecker::dumpTrigSpacePointCounts ( )
private

Definition at line 609 of file TrigEDMChecker.cxx.

610{
611 ATH_MSG_INFO("MinBias in dumpTrigSpacePointCounts()");
612
613 std::string METTag="HLT_xAOD__TrigSpacePointCountsContainer_spacepoints";
614
615 const xAOD::TrigSpacePointCountsContainer* SpacePointCountsCont=0;
616 StatusCode sc = evtStore()->retrieve(SpacePointCountsCont,METTag);
617
618 if (sc.isFailure())
619 ATH_MSG_INFO("failed to retrieve " << METTag);
620 else {
621 ATH_MSG_INFO("Accessing " << METTag << " with " << SpacePointCountsCont->size() << " elements");
622
623 std::string s; char buff[128];
624 std::vector<float> getVec;
625 float sum;
626
627 // Loop over container content
628 for(uint i = 0; i < SpacePointCountsCont->size(); i++) {
629 getVec = SpacePointCountsCont->at(i)->contentsPixelClusEndcapC();
630 sum = 0.;
631 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
632 snprintf(buff, sizeof(buff), "REGTEST %s SUM of contentsPixelClusEndcapC() = %10.2f ", s.c_str(), sum );
633 ATH_MSG_INFO(buff);
634
635 getVec = SpacePointCountsCont->at(i)->contentsPixelClusBarrel();
636 sum = 0.;
637 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
638 snprintf(buff, sizeof(buff), "REGTEST %s SUM of contentsPixelClusBarrel() = %10.2f ", s.c_str(), sum );
639 ATH_MSG_INFO(buff);
640
641 getVec = SpacePointCountsCont->at(i)->contentsPixelClusEndcapA();
642 sum = 0.;
643 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
644 snprintf(buff, sizeof(buff), "REGTEST %s SUM of contentsPixelClusEndcapA() = %10.2f ", s.c_str(), sum );
645 ATH_MSG_INFO(buff);
646
647 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusTotBins() = %u ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusTotBins() );
648 ATH_MSG_INFO(buff);
649
650 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusTotMin() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusTotMin() );
651 ATH_MSG_INFO(buff);
652
653 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusTotMax() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusTotMax() );
654 ATH_MSG_INFO(buff);
655
656 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusSizeBins() = %u ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusSizeBins() );
657 ATH_MSG_INFO(buff);
658
659 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusSizeMin() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusSizeMin() );
660 ATH_MSG_INFO(buff);
661
662 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusSizeMax() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusSizeMax() );
663 ATH_MSG_INFO(buff);
664
665 snprintf(buff, sizeof(buff), "REGTEST %s sctSpEndcapC() = %u ", s.c_str(), SpacePointCountsCont->at(i)->sctSpEndcapC() );
666 ATH_MSG_INFO(buff);
667
668 snprintf(buff, sizeof(buff), "REGTEST %s sctSpBarrel() = %u ", s.c_str(), SpacePointCountsCont->at(i)->sctSpBarrel() );
669 ATH_MSG_INFO(buff);
670
671 snprintf(buff, sizeof(buff), "REGTEST %s sctSpEndcapA() = %u ", s.c_str(), SpacePointCountsCont->at(i)->sctSpEndcapA() );
672 ATH_MSG_INFO(buff);
673 }
674 }
675}
unsigned int uint
const T * at(size_type n) const
Access an element, as an rvalue.
unsigned int sctSpEndcapA() const
unsigned int pixelClusTotBins() const
unsigned int sctSpBarrel() const
unsigned int pixelClusSizeBins() const
const std::vector< float > & contentsPixelClusEndcapC() const
getters
const std::vector< float > & contentsPixelClusEndcapA() const
unsigned int sctSpEndcapC() const
const std::vector< float > & contentsPixelClusBarrel() const
TrigSpacePointCountsContainer_v1 TrigSpacePointCountsContainer

◆ dumpTrigT2MBTSBits()

void TrigEDMChecker::dumpTrigT2MBTSBits ( )
private

Definition at line 677 of file TrigEDMChecker.cxx.

677 {
678 ATH_MSG_INFO("MinBias in dumpTrigT2MBTSBits()");
679
680 std::string METTag="HLT_xAOD__TrigT2MbtsBitsContainer_T2Mbts";
681
682 const xAOD::TrigT2MbtsBitsContainer* T2MbtsBitsCont=0;
683 StatusCode sc = evtStore()->retrieve(T2MbtsBitsCont,METTag);
684
685 if (sc.isFailure())
686 ATH_MSG_INFO("failed to retrieve " << METTag);
687 else {
688 ATH_MSG_INFO("Accessing " << METTag << " with " << T2MbtsBitsCont->size() << " elements");
689
690 std::string s; char buff[380];
691 std::vector<float> getVec;
692 float sum;
693
694 // Loop over container content
695 for(uint i = 0; i < T2MbtsBitsCont->size(); i++) {
696 getVec = T2MbtsBitsCont->at(i)->triggerEnergies();
697 sum = 0.;
698 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
699 snprintf(buff, sizeof(buff), "REGTEST %s SUM of triggerEnergies() = %10.2f ", s.c_str(), sum );
700 ATH_MSG_INFO(buff);
701
702 getVec = T2MbtsBitsCont->at(i)->triggerTimes();
703 sum = 0.;
704 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
705 snprintf(buff, sizeof(buff), "REGTEST %s SUM of triggerTimes() = %10.2f ", s.c_str(), sum );
706 ATH_MSG_INFO(buff);
707 }
708 }
709}
const std::vector< float > & triggerEnergies() const
Return the trigger energies of each counter.
const std::vector< float > & triggerTimes() const
Return the relative times of the triggers.

◆ dumpTrigTrackCounts()

void TrigEDMChecker::dumpTrigTrackCounts ( )
private

Definition at line 745 of file TrigEDMChecker.cxx.

745 {
746 ATH_MSG_INFO("MinBias in dumpTrigTrackCounts()");
747
748 std::string METTag="HLT_xAOD__TrigTrackCountsContainer_trackcounts";
749
750 const xAOD::TrigTrackCountsContainer* T2TrackCountsCont=0;
751 StatusCode sc = evtStore()->retrieve(T2TrackCountsCont,METTag);
752
753 if (sc.isFailure())
754 ATH_MSG_INFO("failed to retrieve " << METTag);
755 else {
756 ATH_MSG_INFO("Accessing " << METTag << " with " << T2TrackCountsCont->size() << " elements");
757
758 std::string s; char buff[380];
759 std::vector<float> getVec;
760 float sum;
761
762 // Loop over container content
763 for(uint i = 0; i < T2TrackCountsCont->size(); i++) {
764 getVec = T2TrackCountsCont->at(i)->z0_pt();
765 sum = 0.;
766 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
767 snprintf(buff, sizeof(buff), "REGTEST %s SUM of z0_pt = %10.2f ", s.c_str(), sum );
768 ATH_MSG_INFO(buff);
769
770 getVec = T2TrackCountsCont->at(i)->eta_phi();
771 sum = 0.;
772 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
773 snprintf(buff, sizeof(buff), "REGTEST %s SUM of eta_phi() = %10.2f ", s.c_str(), sum );
774 ATH_MSG_INFO(buff);
775
776 snprintf(buff, sizeof(buff), "REGTEST %s z0Bins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->z0Bins() );
777 ATH_MSG_INFO(buff);
778
779 snprintf(buff, sizeof(buff), "REGTEST %s z0Min() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->z0Min() );
780 ATH_MSG_INFO(buff);
781
782 snprintf(buff, sizeof(buff), "REGTEST %s z0Max() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->z0Max() );
783 ATH_MSG_INFO(buff);
784
785 snprintf(buff, sizeof(buff), "REGTEST %s ptBins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->ptBins() );
786 ATH_MSG_INFO(buff);
787
788 snprintf(buff, sizeof(buff), "REGTEST %s ptMin() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->ptMin() );
789 ATH_MSG_INFO(buff);
790
791 snprintf(buff, sizeof(buff), "REGTEST %s ptMax() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->ptMax() );
792 ATH_MSG_INFO(buff);
793
794 snprintf(buff, sizeof(buff), "REGTEST %s etaBins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->etaBins() );
795 ATH_MSG_INFO(buff);
796
797 snprintf(buff, sizeof(buff), "REGTEST %s etaMin() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->etaMin() );
798 ATH_MSG_INFO(buff);
799
800 snprintf(buff, sizeof(buff), "REGTEST %s etaMax() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->etaMax() );
801 ATH_MSG_INFO(buff);
802
803 snprintf(buff, sizeof(buff), "REGTEST %s phiBins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->phiBins() );
804 ATH_MSG_INFO(buff);
805
806 snprintf(buff, sizeof(buff), "REGTEST %s phiMin() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->phiMin() );
807 ATH_MSG_INFO(buff);
808
809 snprintf(buff, sizeof(buff), "REGTEST %s phiMax() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->phiMax() );
810 ATH_MSG_INFO(buff);
811 }
812 }
813}
const std::vector< float > & eta_phi() const
unsigned int phiBins() const
unsigned int etaBins() const
const std::vector< float > & z0_pt() const
getters
unsigned int z0Bins() const
unsigned int ptBins() const
TrigTrackCountsContainer_v1 TrigTrackCountsContainer

◆ dumpTrigVertexCounts()

void TrigEDMChecker::dumpTrigVertexCounts ( )
private

Definition at line 711 of file TrigEDMChecker.cxx.

711 {
712 ATH_MSG_INFO("MinBias in dumpTrigVertexCounts()");
713
714 std::string METTag="HLT_xAOD__TrigVertexCountsContainer_vertexcounts";
715
716 const xAOD::TrigVertexCountsContainer* T2VertexCountsCont=0;
717 StatusCode sc = evtStore()->retrieve(T2VertexCountsCont,METTag);
718
719 if (sc.isFailure())
720 ATH_MSG_INFO("failed to retrieve " << METTag);
721 else {
722 ATH_MSG_INFO("Accessing " << METTag << " with " << T2VertexCountsCont->size() << " elements");
723
724 std::string s; char buff[380];
725 std::vector<float> fgetVec;
726 float fsum(0.);
727 std::vector<unsigned int> ugetVec;
728 unsigned int usum(0);
729
730 // Loop over container content
731 for(uint i = 0; i < T2VertexCountsCont->size(); i++) {
732 ugetVec = T2VertexCountsCont->at(i)->vtxNtrks();
733 for (uint j = 0; j < ugetVec.size(); ++j) usum += ugetVec[j];
734 snprintf(buff, sizeof(buff), "REGTEST %s SUM of vtxNtrks() = %u ", s.c_str(), usum );
735 ATH_MSG_INFO(buff);
736
737 fgetVec = T2VertexCountsCont->at(i)->vtxTrkPtSqSum();
738 for (uint j = 0; j < fgetVec.size(); ++j) fsum += fgetVec[j];
739 snprintf(buff, sizeof(buff), "REGTEST %s SUM of vtxTrkPtSqSum() = %10.2f ", s.c_str(), fsum );
740 ATH_MSG_INFO(buff);
741 }
742 }
743}
const std::vector< float > & vtxTrkPtSqSum() const
const std::vector< unsigned int > & vtxNtrks() const
getters
TrigVertexCountsContainer_v1 TrigVertexCountsContainer

◆ dumpxAODElectronContainer()

StatusCode TrigEDMChecker::dumpxAODElectronContainer ( )
private

Definition at line 1760 of file TrigEDMChecker.cxx.

1760 {
1761
1762 ATH_MSG_DEBUG("In dumpxAODElectronContainer");
1763
1764 ATH_MSG_INFO( "REGTEST ==========START of xAOD::ElectronContainer DUMP===========" );
1765
1766 const xAOD::ElectronContainer* elCont=0;
1767 StatusCode sc = evtStore()->retrieve(elCont,"HLT_xAOD__ElectronContainer_egamma_Electrons");
1768 if (sc.isFailure()) {
1769 ATH_MSG_INFO("REGTEST No Electron container HLT_xAOD__ElectronContainer_egamma_Electrons");
1770 return StatusCode::SUCCESS;
1771 }
1772 float val_float=-99;
1773 unsigned int isEMbit=0;
1774 bool pid=false;
1775 //DEBUG output for Egamma container
1776 ATH_MSG_INFO(" REGTEST: xAOD Reconstruction variables: ");
1777 // //Cluster and ShowerShape info
1778 //
1779 static const SG::AuxElement::Accessor< float > accLH("LHValue");
1780 static const SG::AuxElement::Accessor< float > accLHCalo("LHCaloValue");
1781 for (const auto eg : *elCont){
1782 //REGTEST printout
1783 if (eg) {
1784 ATH_MSG_INFO(" REGTEST: egamma energy: " << eg->e() );
1785 ATH_MSG_INFO(" REGTEST: egamma eta: " << eg->eta() );
1786 ATH_MSG_INFO(" REGTEST: egamma phi: " << eg->phi() );
1787 if(eg->selectionisEM(isEMbit,"isEMVLoose"))
1788 ATH_MSG_INFO(" REGTEST: isEMVLoose " << std::hex << isEMbit << std::dec);
1789 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1790 if(eg->selectionisEM(isEMbit,"isEMLoose"))
1791 ATH_MSG_INFO(" REGTEST: isEMLoose " << std::hex << isEMbit << std::dec);
1792 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1793 if(eg->selectionisEM(isEMbit,"isEMMedium"))
1794 ATH_MSG_INFO(" REGTEST: isEMMedium " << std::hex << isEMbit << std::dec);
1795 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1796 if(eg->selectionisEM(isEMbit,"isEMTight"))
1797 ATH_MSG_INFO(" REGTEST: isEMTight " << std::hex << isEMbit << std::dec);
1798 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1799 if(eg->selectionisEM(isEMbit,"isEMLHVLoose"))
1800 ATH_MSG_INFO(" REGTEST: isEMLHVLoose " << std::hex << isEMbit << std::dec);
1801 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1802 if(eg->selectionisEM(isEMbit,"isEMLHLoose"))
1803 ATH_MSG_INFO(" REGTEST: isEMLHLoose " << std::hex << isEMbit << std::dec);
1804 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1805 if(eg->selectionisEM(isEMbit,"isEMLHMedium"))
1806 ATH_MSG_INFO(" REGTEST: isEMLHMedium " << std::hex << isEMbit << std::dec);
1807 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1808 if(eg->selectionisEM(isEMbit,"isEMLHTight"))
1809 ATH_MSG_INFO(" REGTEST: isEMLHTight " << std::hex << isEMbit << std::dec);
1810 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1811 if(accLH.isAvailable(*eg))
1812 ATH_MSG_INFO(" REGTEST: LHValue " << accLH(*eg));
1813 else
1814 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1815 if(accLHCalo.isAvailable(*eg))
1816 ATH_MSG_INFO(" REGTEST: LHValue " << accLHCalo(*eg));
1817 else
1818 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1819 if(eg->passSelection(pid,"LHVLoose"))
1820 ATH_MSG_INFO(" REGTEST: LHVLoose " << pid);
1821 else
1822 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1823 if(eg->passSelection(pid,"LHLoose"))
1824 ATH_MSG_INFO(" REGTEST: LHLoose " << pid);
1825 else
1826 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1827 if(eg->passSelection(pid,"LHMedium"))
1828 ATH_MSG_INFO(" REGTEST: LHMedium " << pid);
1829 else
1830 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1831 if(eg->passSelection(pid,"LHTight"))
1832 ATH_MSG_INFO(" REGTEST: LHTight " << pid);
1833 else
1834 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1835 } else{
1836 ATH_MSG_INFO(" REGTEST: problems with egamma pointer" );
1837 return StatusCode::SUCCESS;
1838 }
1839 ATH_MSG_INFO(" REGTEST: caloCluster variables ");
1840 if (eg->caloCluster()) {
1841 ATH_MSG_INFO(" REGTEST: egamma cluster transverse energy: " << eg->caloCluster()->et() );
1842 ATH_MSG_INFO(" REGTEST: egamma cluster eta: " << eg->caloCluster()->eta() );
1843 ATH_MSG_INFO(" REGTEST: egamma cluster phi: " << eg->caloCluster()->phi() );
1844 double tmpeta = -999.;
1845 double tmpphi = -999.;
1846 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::ETACALOFRAME,tmpeta);
1847 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::PHICALOFRAME,tmpphi);
1848 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. etaCalo = " << tmpeta);
1849 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. phiCalo = " << tmpphi);
1850 } else{
1851 ATH_MSG_INFO(" REGTEST: problems with egamma cluster pointer" );
1852 }
1853 ATH_MSG_INFO("REGTEST: Check the original (uncalibrated)");
1854 static const SG::AuxElement::Accessor<ElementLink<xAOD::CaloClusterContainer> > orig ("originalCaloCluster");
1855 if (!orig.isAvailable(*eg->caloCluster()) || !orig(*eg->caloCluster()).isValid()){
1856 ATH_MSG_INFO("Problem with original cluster link");
1857 }
1858 else {
1859 const xAOD::CaloCluster *origClus = *orig(*eg->caloCluster());
1860 ATH_MSG_INFO("REGTEST:: Compare new and old clusters");
1861 ATH_MSG_INFO("REGTEST:: Original Cluster e,eta,phi" << origClus->e() << " " << origClus->eta() << " " << origClus->phi());
1862 ATH_MSG_INFO("REGTEST:: MVA Cluster e,eta,phi" << eg->caloCluster()->e() << " " << eg->caloCluster()->eta() << " " << eg->caloCluster()->phi());
1863 }
1864 ATH_MSG_INFO(" REGTEST: trackmatch variables ");
1865 if(eg->trackParticle()){
1866 ATH_MSG_INFO(" REGTEST: pt= " << eg->trackParticle()->pt());
1867 ATH_MSG_INFO(" REGTEST: charge= " << eg->trackParticle()->charge());
1868 ATH_MSG_INFO(" REGTEST: E/p= " << eg->caloCluster()->et() / eg->trackParticle()->pt() );
1869 eg->trackCaloMatchValue(val_float,xAOD::EgammaParameters::deltaEta1);
1870 ATH_MSG_INFO(" REGTEST: Delta eta 1st sampling= " << val_float);
1871 eg->trackCaloMatchValue(val_float,xAOD::EgammaParameters::deltaPhi2);
1872 ATH_MSG_INFO(" REGTEST: Delta phi 2nd sampling= " << val_float);
1873 } else{
1874 ATH_MSG_INFO(" REGTEST: no electron eg->trackParticle() pointer");
1875 }
1876
1877 //msg() << MSG::VERBOSE << " REGTEST: cluster variables " << endmsg;
1878 //clus = eg->caloCluster();
1879 ATH_MSG_INFO(" REGTEST: EMShower variables ");
1880 eg->showerShapeValue(val_float,xAOD::EgammaParameters::ethad);
1881 ATH_MSG_INFO(" REGTEST: ethad = " << val_float);
1882 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e011);
1883 ATH_MSG_INFO(" REGTEST: e011 = " << val_float);
1884 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e132);
1885 ATH_MSG_INFO(" REGTEST: e132 = " << val_float);
1886 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e237);
1887 ATH_MSG_INFO(" REGTEST: e237 = " << val_float);
1888 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e335);
1889 ATH_MSG_INFO(" REGTEST: e335 = " << val_float);
1890 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2ts1);
1891 ATH_MSG_INFO(" REGTEST: e2ts1 = " << val_float);
1892 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2tsts1);
1893 ATH_MSG_INFO(" REGTEST: e2tsts1 = " << val_float);
1894 eg->isolationValue(val_float,xAOD::Iso::ptcone20);
1895 ATH_MSG_INFO(" REGTEST: ptcone20 = " << val_float);
1896 eg->isolationValue(val_float,xAOD::Iso::ptcone30);
1897 ATH_MSG_INFO(" REGTEST: ptcone30 = " << val_float);
1898 eg->isolationValue(val_float,xAOD::Iso::ptcone40);
1899 ATH_MSG_INFO(" REGTEST: ptcone40 = " << val_float);
1900 eg->isolationValue(val_float,xAOD::Iso::etcone20);
1901 ATH_MSG_INFO(" REGTEST: etcone20 = " << val_float);
1902 eg->isolationValue(val_float,xAOD::Iso::etcone30);
1903 ATH_MSG_INFO(" REGTEST: etcone30 = " << val_float);
1904 eg->isolationValue(val_float,xAOD::Iso::etcone40);
1905 ATH_MSG_INFO(" REGTEST: etcone40 = " << val_float);
1906 //DEBUG info for Electrons which by definition have a track match
1907
1908 }
1909 ATH_MSG_INFO( "REGTEST ==========END of xAOD::ElectronContainer DUMP===========" );
1910
1911 return StatusCode::SUCCESS;
1912
1913}
virtual double eta() const
The pseudorapidity ( ) of the particle.
virtual double e() const
The total energy of the particle.
virtual double phi() const
The azimuthal angle ( ) of the particle.
@ ETACALOFRAME
Eta in the calo frame (for egamma).
@ PHICALOFRAME
Phi in the calo frame (for egamma).
@ deltaPhi2
difference between the cluster phi (second sampling) and the phi of the track extrapolated to the sec...
@ deltaEta1
difference between the cluster eta (first sampling) and the eta of the track extrapolated to the firs...
@ e237
uncalibrated energy (sum of cells) of the middle sampling in a rectangle of size 3x7
Definition EgammaEnums.h:78
@ ethad
ET leakage into hadronic calorimeter with exclusion of energy in CaloSampling::TileGap3.
Definition EgammaEnums.h:46
@ e2ts1
2nd max in strips calc by summing 3 strips
@ e335
uncalibrated energy (sum of cells) of the third sampling in a rectangle of size 3x5
Definition EgammaEnums.h:87
@ e132
uncalibrated energy (sum of cells) in strips in a 3x2 window in cells in eta X phi
Definition EgammaEnums.h:37
@ e011
uncalibrated energy (sum of cells) in presampler in a 1x1 window in cells in eta X phi
Definition EgammaEnums.h:31
@ e2tsts1
energy of the cell corresponding to second energy maximum in the first sampling
@ etcone20
Calorimeter isolation.
@ ptcone20
Track isolation.
ElectronContainer_v1 ElectronContainer
Definition of the current "electron container version".
CaloCluster_v1 CaloCluster
Define the latest version of the calorimeter cluster class.

◆ dumpxAODJetContainer()

StatusCode TrigEDMChecker::dumpxAODJetContainer ( )
private

Definition at line 2529 of file TrigEDMChecker.cxx.

2529 {
2530
2531 ATH_MSG_DEBUG("in dumpxAODJetContainer()");
2532
2533 ATH_MSG_INFO("REGTEST ==========START of xAOD::JetContainer DUMP===========");
2534
2535 std::string containerName[30] = {"HLT_xAOD__JetContainer_a4tcemjesFS",
2536 "HLT_xAOD__JetContainer_a4tcemsubFS",
2537 "HLT_xAOD__JetContainer_a4tcemsubjesFS",
2538 "HLT_xAOD__JetContainer_a4tcemnojcalibFS",
2539 "HLT_xAOD__JetContainer_a4tcemjesPS",
2540 "HLT_xAOD__JetContainer_a4tcemnojcalibPS",
2541 "HLT_xAOD__JetContainer_a4tclcwjesFS",
2542 "HLT_xAOD__JetContainer_a4tclcwsubFS",
2543 "HLT_xAOD__JetContainer_a4tclcwsubjesFS",
2544 "HLT_xAOD__JetContainer_a4tclcwnojcalibFS",
2545 "HLT_xAOD__JetContainer_a4tclcwjesPS",
2546 "HLT_xAOD__JetContainer_a4tclcwnojcalibPS",
2547 "HLT_xAOD__JetContainer_a4TTemnojcalibFS",
2548 "HLT_xAOD__JetContainer_a4TThadnojcalibFS",
2549 "HLT_xAOD__JetContainer_a10tcemjesFS",
2550 "HLT_xAOD__JetContainer_a10tcemsubFS",
2551 "HLT_xAOD__JetContainer_a10tcemsubjesFS",
2552 "HLT_xAOD__JetContainer_a10tcemnojcalibFS",
2553 "HLT_xAOD__JetContainer_a10tcemjesPS",
2554 "HLT_xAOD__JetContainer_a10tcemnojcalibPS",
2555 "HLT_xAOD__JetContainer_a10tclcwjesFS",
2556 "HLT_xAOD__JetContainer_a10tclcwsubFS",
2557 "HLT_xAOD__JetContainer_a10tclcwsubjesFS",
2558 "HLT_xAOD__JetContainer_a10tclcwnojcalibFS",
2559 "HLT_xAOD__JetContainer_a10tclcwjesPS",
2560 "HLT_xAOD__JetContainer_a10tclcwnojcalibPS",
2561 "HLT_xAOD__JetContainer_a10TTemnojcalibFS",
2562 "HLT_xAOD__JetContainer_a10TThadnojcalibFS",
2563 "HLT_xAOD__JetContainer_a10r_tcemsubjesFS",
2564 "HLT_xAOD__JetContainer_TrigHLTJetDSSelectorCollection"};
2565 float containerSizeParameter[30] = {0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4,
2566 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.4};
2567 int containerInputType[30] = {1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 2, 2,
2568 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 2, 2, 1, 1};
2569 int containerSignalState[30] = {0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1,
2570 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 0, 0};
2571 bool onefilled = false;
2572
2573 for (int icont=0; icont<30; ++icont) {
2574 //retrieve jet collection
2575 const xAOD::JetContainer* jetCont = 0;
2576 StatusCode sc = evtStore()->retrieve(jetCont, containerName[icont]) ;
2577
2578 if (sc.isFailure()) {
2579 ATH_MSG_WARNING("REGTEST Cannot retrieve jet container");
2580 continue;
2581 }
2582
2583 int jetContsize = jetCont->size();
2584 ATH_MSG_INFO("REGTEST Got jet container " << containerName[icont] << ", size: " << jetContsize);
2585 if (jetContsize != 0) {
2586 onefilled = true;
2587 int i = 0;
2588 for(const auto thisjet : *jetCont) {
2589 ++i;
2590 ATH_MSG_INFO( "REGTEST Looking at jet " << i);
2591 if (thisjet) {
2592 //checks jet variables
2593 ATH_MSG_DEBUG("REGTEST Checking jet variables");
2594 ATH_MSG_INFO( "REGTEST pt: " << thisjet->pt() );
2595 ATH_MSG_INFO( "REGTEST eta: " << thisjet->eta() );
2596 ATH_MSG_INFO( "REGTEST phi: " << thisjet->phi() );
2597 ATH_MSG_INFO( "REGTEST m: " << thisjet->m() );
2598 ATH_MSG_INFO( "REGTEST e: " << thisjet->e() );
2599 ATH_MSG_INFO( "REGTEST rapidity: " << thisjet->rapidity() );
2600 ATH_MSG_INFO( "REGTEST px: " << thisjet->px() );
2601 ATH_MSG_INFO( "REGTEST py: " << thisjet->py() );
2602 ATH_MSG_INFO( "REGTEST pz: " << thisjet->pz() );
2603 ATH_MSG_INFO( "REGTEST type: " << thisjet->type() );
2604 ATH_MSG_INFO( "REGTEST algorithm (kt: 0, cam: 1, antikt: 2, ...): " << thisjet->getAlgorithmType() << "; should be 2");
2605 if(thisjet->getAlgorithmType() != 2) ATH_MSG_WARNING("Jet algorithm different from container");
2606 ATH_MSG_INFO( "REGTEST size parameter: " << thisjet->getSizeParameter() << "; should be " << containerSizeParameter[icont]);
2607 if(thisjet->getSizeParameter() != containerSizeParameter[icont]) ATH_MSG_WARNING("Jet size different from container");
2608 ATH_MSG_INFO( "REGTEST input (LCTopo: 0, EMTopo: 1, TopoTower: 2, ...): " << thisjet->getInputType() << "; should be " << containerInputType[icont]);
2609 if(thisjet->getInputType() != containerInputType[icont]) ATH_MSG_WARNING("Jet input different from container");
2610 ATH_MSG_INFO( "REGTEST constituents signal state (uncalibrated: 0, calibrated: 1): " << thisjet->getConstituentsSignalState() << "; should be " << containerSignalState[icont]);
2611 if(thisjet->getConstituentsSignalState() != containerSignalState[icont]) ATH_MSG_WARNING("Jet constituents' signal state different from container");
2612 ATH_MSG_INFO( "REGTEST number of constituents: " << thisjet->numConstituents() );
2613
2614
2615 //checks the constituents
2616 ATH_MSG_DEBUG("REGTEST Checking jet constituents");
2617
2618 xAOD::JetConstituentVector constitCont = thisjet->getConstituents();
2619 unsigned int constitContsize = constitCont.size();
2620 ATH_MSG_INFO("REGTEST Got constituent vector, size: " << constitContsize << "; should be " << thisjet->numConstituents());
2621 if(constitContsize != thisjet->numConstituents()) ATH_MSG_WARNING("Constituents container size different from number of constituents");
2622
2623 if (constitContsize != 0) {
2624// int j = 0;
2625 // for (const auto thisconstit : constitCont) {
2626 // ++j;
2627 // ATH_MSG_INFO( "REGTEST Looking at constituent " << j);
2628 // if(thisconstit){
2629 // ATH_MSG_INFO( "REGTEST constituent pt: " << thisconstit->pt() );
2630 // ATH_MSG_INFO( "REGTEST constituent eta: " << thisconstit->eta() );
2631 // ATH_MSG_INFO( "REGTEST constituent phi: " << thisconstit->phi() );
2632 // ATH_MSG_INFO( "REGTEST constituent m: " << thisconstit->m() );
2633 // ATH_MSG_INFO( "REGTEST constituent e: " << thisconstit->e() );
2634 // ATH_MSG_INFO( "REGTEST constituent type (CaloCluster: 1, Jet: 2, ...): " << thisconstit->type() );
2635 // }
2636 // else{
2637 // ATH_MSG_WARNING("REGTEST Problem with constituent pointer");
2638 // return StatusCode::SUCCESS;
2639 // }
2640 // }
2641 // ATH_MSG_INFO("REGTEST size of constituent vector == number of displayed constituents: "<< (constitContsize == j) );
2642 // if (constitContsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2643 }
2644 // else ATH_MSG_WARNING("REGTEST This jet has 0 constituents!");
2645
2646 //checks int attributes
2647 ATH_MSG_DEBUG("REGTEST Checking int attributes");
2648 int valueint;
2649 if( thisjet->getAttribute(xAOD::JetAttribute::GhostMuonSegmentCount, valueint)) ATH_MSG_INFO("REGTEST GhostMuonSegmentCount: " << valueint);
2650 if( thisjet->getAttribute(xAOD::JetAttribute::GhostTrackCount, valueint)) ATH_MSG_INFO("REGTEST GhostTrackCount: " << valueint);
2651 if( thisjet->getAttribute(xAOD::JetAttribute::GhostTruthParticleCount, valueint)) ATH_MSG_INFO("REGTEST GhostTruthParticleCount: " << valueint);
2652 if( thisjet->getAttribute(xAOD::JetAttribute::FracSamplingMaxIndex, valueint)) ATH_MSG_INFO( "REGTEST FracSamplingMaxIndex: " << valueint);
2653
2654
2655 //checks float attributes
2656 ATH_MSG_DEBUG("REGTEST Checking float attributes");
2657 float value;
2658 if( thisjet->getAttribute(xAOD::JetAttribute::ActiveArea, value)) ATH_MSG_INFO( "REGTEST ActiveArea: " << value );
2659 // Four-vector type if( thisjet->getAttribute(xAOD::JetAttribute::ActiveArea4vec, value)) ATH_MSG_INFO( "REGTEST ActiveArea4vec: " << value );
2660 if( thisjet->getAttribute(xAOD::JetAttribute::AverageLArQF, value)) ATH_MSG_INFO( "REGTEST AverageLArQF: " << value );
2661 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrCell, value)) ATH_MSG_INFO( "REGTEST BchCorrCell: " << value );
2662 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrDotx, value)) ATH_MSG_INFO( "REGTEST BchCorrDotx: " << value );
2663 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrJet, value)) ATH_MSG_INFO( "REGTEST BchCorrJet: " << value );
2664 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrJetForCell, value)) ATH_MSG_INFO( "REGTEST BchCorrJetForCell: " << value );
2665 if( thisjet->getAttribute(xAOD::JetAttribute::CentroidR, value)) ATH_MSG_INFO( "REGTEST CentroidR: " << value );
2666 if( thisjet->getAttribute(xAOD::JetAttribute::HECQuality, value)) ATH_MSG_INFO( "REGTEST HECQuality: " << value );
2667 if( thisjet->getAttribute(xAOD::JetAttribute::IsoKR20Par, value)) ATH_MSG_INFO( "REGTEST IsoKR20Par: " << value );
2668 if( thisjet->getAttribute(xAOD::JetAttribute::IsoKR20Perp, value)) ATH_MSG_INFO( "REGTEST IsoKR20Perp: " << value );
2669 // ElementLink<DataVector<xAOD::Vertex> > type if( thisjet->getAttribute(xAOD::JetAttribute::HighestJVFVtx, value)) ATH_MSG_INFO( "REGTEST HighestJVFVtx: " << value );
2670 // ??? type if( thisjet->getAttribute(xAOD::JetAttribute::JetLabel, value)) ATH_MSG_INFO( "REGTEST JetLabel: " << value );
2671 if( thisjet->getAttribute(xAOD::JetAttribute::KtDR, value)) ATH_MSG_INFO( "REGTEST KtDR: " << value );
2672 if( thisjet->getAttribute(xAOD::JetAttribute::LArBadHVEnergy, value)) ATH_MSG_INFO( "REGTEST LArBadHVEnergy: " << value );
2673 if( thisjet->getAttribute(xAOD::JetAttribute::LArBadHVRatio, value)) ATH_MSG_INFO( "REGTEST LArBadHVRatio: " << value );
2674 if( thisjet->getAttribute(xAOD::JetAttribute::LArQuality, value)) ATH_MSG_INFO( "REGTEST LArQuality: " << value );
2675 if( thisjet->getAttribute(xAOD::JetAttribute::NegativeE, value)) ATH_MSG_INFO( "REGTEST NegativeE: " << value );
2676 // no tools available yet if( thisjet->getAttribute(xAOD::JetAttribute::NumTowers, value)) ATH_MSG_INFO( "REGTEST NumTowers: " << value );
2677 if( thisjet->getAttribute(xAOD::JetAttribute::SamplingMax, value)) ATH_MSG_INFO( "REGTEST SamplingMax: " << value );
2678 if( thisjet->getAttribute(xAOD::JetAttribute::Timing, value)) ATH_MSG_INFO( "REGTEST Timing: " << value );
2679 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiArea, value)) ATH_MSG_INFO( "REGTEST VoronoiArea: " << value );
2680 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaE, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaE: " << value );
2681 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaPx, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaPx: " << value );
2682 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaPy, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaPy: " << value );
2683 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaPz, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaPz: " << value );
2684 if( thisjet->getAttribute(xAOD::JetAttribute::Width, value)) ATH_MSG_INFO( "REGTEST WIDTH: " << value );
2685 if( thisjet->getAttribute(xAOD::JetAttribute::FracSamplingMax, value)) ATH_MSG_INFO( "REGTEST FracSamplingMax: " << value );
2686 if( thisjet->getAttribute(xAOD::JetAttribute::EMFrac, value)) ATH_MSG_INFO( "REGTEST EMFrac: " << value );
2687 if( thisjet->getAttribute(xAOD::JetAttribute::HECFrac, value)) ATH_MSG_INFO( "REGTEST HECFrac: " << value );
2688 if( thisjet->getAttribute(xAOD::JetAttribute::isBadLoose, value)) ATH_MSG_INFO( "REGTEST isBadLoose: " << value );
2689 if( thisjet->getAttribute(xAOD::JetAttribute::isBadMedium, value)) ATH_MSG_INFO( "REGTEST isBadMedium: " << value );
2690 if( thisjet->getAttribute(xAOD::JetAttribute::isBadTight, value)) ATH_MSG_INFO( "REGTEST isBadTight: " << value );
2691 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::isUgly, value)) ATH_MSG_INFO( "REGTEST isUgly: " << value );
2692 if( thisjet->getAttribute(xAOD::JetAttribute::N90Constituents, value)) ATH_MSG_INFO( "REGTEST N90Constituents: " << value );
2693 if( thisjet->getAttribute(xAOD::JetAttribute::N90Cells, value)) ATH_MSG_INFO( "REGTEST N90Cells: " << value );
2694 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracClusters10, value)) ATH_MSG_INFO( "REGTEST OotFracClusters10: " << value );
2695 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracClusters5, value)) ATH_MSG_INFO( "REGTEST OotFracClusters5: " << value );
2696 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracCells5, value)) ATH_MSG_INFO( "REGTEST OotFracCells5: " << value );
2697 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracCells10, value)) ATH_MSG_INFO( "REGTEST OotFracCells10: " << value );
2698 if( thisjet->getAttribute(xAOD::JetAttribute::PtTruth, value)) ATH_MSG_INFO( "REGTEST PtTruth: " << value );
2699 if( thisjet->getAttribute(xAOD::JetAttribute::Tau1, value)) ATH_MSG_INFO( "REGTEST Tau1: " << value );
2700 if( thisjet->getAttribute(xAOD::JetAttribute::Tau2, value)) ATH_MSG_INFO( "REGTEST Tau2: " << value );
2701 if( thisjet->getAttribute(xAOD::JetAttribute::Tau3, value)) ATH_MSG_INFO( "REGTEST Tau3: " << value );
2702 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::Split12, value)) ATH_MSG_INFO( "REGTEST Split12: " << value );
2703 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::Split23, value)) ATH_MSG_INFO( "REGTEST Split23: " << value );
2704 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::Split34, value)) ATH_MSG_INFO( "REGTEST Split34: " << value );
2705 if( thisjet->getAttribute(xAOD::JetAttribute::Dip12, value)) ATH_MSG_INFO( "REGTEST Dip12: " << value );
2706 if( thisjet->getAttribute(xAOD::JetAttribute::Dip13, value)) ATH_MSG_INFO( "REGTEST Dip13: " << value );
2707 if( thisjet->getAttribute(xAOD::JetAttribute::Dip23, value)) ATH_MSG_INFO( "REGTEST Dip23: " << value );
2708 if( thisjet->getAttribute(xAOD::JetAttribute::DipExcl12, value)) ATH_MSG_INFO( "REGTEST DipExcl12: " << value );
2709 if( thisjet->getAttribute(xAOD::JetAttribute::ThrustMin, value)) ATH_MSG_INFO( "REGTEST ThrustMin: " << value );
2710 if( thisjet->getAttribute(xAOD::JetAttribute::ThrustMaj, value)) ATH_MSG_INFO( "REGTEST ThrustMaj: " << value );
2711 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram0, value)) ATH_MSG_INFO( "REGTEST FoxWolfram0: " << value );
2712 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram1, value)) ATH_MSG_INFO( "REGTEST FoxWolfram1: " << value );
2713 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram2, value)) ATH_MSG_INFO( "REGTEST FoxWolfram2: " << value );
2714 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram3, value)) ATH_MSG_INFO( "REGTEST FoxWolfram3: " << value );
2715 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram4, value)) ATH_MSG_INFO( "REGTEST FoxWolfram4: " << value );
2716 if( thisjet->getAttribute(xAOD::JetAttribute::Sphericity, value)) ATH_MSG_INFO( "REGTEST Sphericity: " << value );
2717 if( thisjet->getAttribute(xAOD::JetAttribute::Aplanarity, value)) ATH_MSG_INFO( "REGTEST Aplanarity: " << value );
2718
2719 //checks vector<int> attributes
2720 ATH_MSG_DEBUG("REGTEST Checking vector<int> attributes");
2721 std::vector<int> vecvalueint;
2722 if (thisjet->getAttribute(xAOD::JetAttribute::NumTrkPt1000, vecvalueint)) {
2723 int vecsize = vecvalueint.size();
2724 ATH_MSG_INFO("REGTEST Got NumTrkPt1000 vector, size: " << vecsize);
2725 if (vecsize != 0) {
2726 int j = 0;
2727 for(const auto & thisvalue : vecvalueint){
2728 ++j;
2729 ATH_MSG_INFO("REGTEST NumTrkPt1000 #" << j << ": " << thisvalue);
2730 }
2731 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2732 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2733 }
2734 }
2735 if (thisjet->getAttribute(xAOD::JetAttribute::NumTrkPt500, vecvalueint)) {
2736 int vecsize = vecvalueint.size();
2737 ATH_MSG_INFO("REGTEST Got Got NumTrkPt500 vector, size: " << vecsize);
2738 if (vecsize != 0) {
2739 int j = 0;
2740 for(const auto & thisvalue : vecvalueint){
2741 ++j;
2742 ATH_MSG_INFO("REGTEST NumTrkPt500 #" << j << ": " << thisvalue);
2743 }
2744 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2745 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2746 }
2747 }
2748
2749 //checks vector<float> attributes
2750 ATH_MSG_DEBUG("REGTEST Checking vector<float> attributes");
2751 std::vector<float> vecvalue;
2752 if (thisjet->getAttribute(xAOD::JetAttribute::JVF, vecvalue)) {
2753 int vecsize = vecvalue.size();
2754 ATH_MSG_INFO("REGTEST Got JVF vector, size: " << vecsize);
2755 if (vecsize != 0) {
2756 int j = 0;
2757 for(const auto & thisvalue : vecvalue){
2758 ++j;
2759 ATH_MSG_INFO("REGTEST JVF #" << j << ": " << thisvalue);
2760 }
2761 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2762 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2763 }
2764 }
2765 if (thisjet->getAttribute(xAOD::JetAttribute::SumPtTrkPt1000, vecvalue)) {
2766 int vecsize = vecvalue.size();
2767 ATH_MSG_INFO("REGTEST Got SumPtTrkPt1000 vector, size: " << vecsize);
2768 if (vecsize != 0) {
2769 int j = 0;
2770 for(const auto & thisvalue : vecvalue){
2771 ++j;
2772 ATH_MSG_INFO("REGTEST SumPtTrkPt1000 #" << j << ": " << thisvalue);
2773 }
2774 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2775 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2776 }
2777 }
2778 if (thisjet->getAttribute(xAOD::JetAttribute::SumPtTrkPt500, vecvalue)) {
2779 int vecsize = vecvalue.size();
2780 ATH_MSG_INFO("REGTEST Got SumPtTrkPt500 vector, size: " << vecsize);
2781 if (vecsize != 0) {
2782 int j = 0;
2783 for(const auto & thisvalue : vecvalue){
2784 ++j;
2785 ATH_MSG_INFO("REGTEST SumPtTrkPt500 #" << j << ": " << thisvalue);
2786 }
2787 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2788 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2789 }
2790 }
2791 if (thisjet->getAttribute(xAOD::JetAttribute::TrackWidthPt1000, vecvalue)) {
2792 int vecsize = vecvalue.size();
2793 ATH_MSG_INFO("REGTEST Got TrackWidthPt1000 vector, size: " << vecsize);
2794 if (vecsize != 0) {
2795 int j = 0;
2796 for(const auto & thisvalue : vecvalue){
2797 ++j;
2798 ATH_MSG_INFO("REGTEST TrackWidthPt1000 #" << j << ": " << thisvalue);
2799 }
2800 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2801 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2802 }
2803 }
2804 if (thisjet->getAttribute(xAOD::JetAttribute::TrackWidthPt500, vecvalue)) {
2805 int vecsize = vecvalue.size();
2806 ATH_MSG_INFO("REGTEST Got TrackWidthPt500 vector, size: " << vecsize);
2807 if (vecsize != 0) {
2808 int j = 0;
2809 for(const auto & thisvalue : vecvalue){
2810 ++j;
2811 ATH_MSG_INFO("REGTEST TrackWidthPt500 #" << j << ": " << thisvalue);
2812 }
2813 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2814 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2815 }
2816 }
2817 if (thisjet->getAttribute(xAOD::JetAttribute::EnergyPerSampling, vecvalue)) {
2818 int vecsize = vecvalue.size();
2819 ATH_MSG_INFO("REGTEST Got EnergyPerSampling vector, size: " << vecsize);
2820 if (vecsize != 0) {
2821 int j = 0;
2822 for(const auto & thisvalue : vecvalue){
2823 ++j;
2824 ATH_MSG_INFO("REGTEST EnergyPerSampling #" << j << ": " << thisvalue);
2825 }
2826 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2827 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2828 }
2829 }
2830
2831
2832 //checks associated objects
2833 // ATH_MSG_DEBUG("REGTEST Checking associated objects");
2834 // std::vector<const xAOD::TrackParticle*> track;
2835 // if( thisjet->getAssociatedObjects(xAOD::JetAttribute::GhostTrack, track) ){
2836 // int vecsize = track.size();
2837 // ATH_MSG_INFO("REGTEST Got GhostTrack vector, size: " << vecsize);
2838 // if (vecsize != 0) {
2839 // int j = 0;
2840 // for(const auto & thistrack : track){
2841 // ++j;
2842 // //checks only one associated variable, just making sure getting the object worked
2843 // if (thistrack) ATH_MSG_INFO("REGTEST z0 for GhostTrack #" << j << ": " << thistrack->z0());
2844 // else{
2845 // ATH_MSG_WARNING("REGTEST Problem with attribute pointer");
2846 // return StatusCode::SUCCESS;
2847 // }
2848 // }
2849 // ATH_MSG_INFO("REGTEST size of associated object vector == number of displayed attributes: " << (vecsize == j) );
2850 // if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this associated object");
2851 // }
2852 // }
2853 }
2854 else{
2855 ATH_MSG_WARNING("REGTEST Problem with jet pointer");
2856 return StatusCode::SUCCESS;
2857 }
2858 }
2859
2860 if (jetContsize == i) ATH_MSG_INFO("REGTEST size of jet container == number of displayed jets: " << (jetContsize == i) );
2861 else ATH_MSG_WARNING("REGTEST Problem with displaying jets");
2862 }
2863 }
2864
2865 if (!onefilled) ATH_MSG_DEBUG("There was no filled jet containers");
2866
2867 ATH_MSG_INFO("REGTEST ==========END of xAOD::JetContainer DUMP===========");
2868
2869 ATH_MSG_DEBUG("leaving dumpxAODJetContainer()");
2870
2871 return StatusCode::SUCCESS;
2872}
size_t size() const
number of constituents
JetContainer_v1 JetContainer
Definition of the current "jet container version".

◆ dumpxAODMuonContainer()

StatusCode TrigEDMChecker::dumpxAODMuonContainer ( )
private

Definition at line 1337 of file TrigEDMChecker.cxx.

1337 {
1338
1339 ATH_MSG_DEBUG("In dumpxAODMuonContainer");
1340
1341 ATH_MSG_INFO( "REGTEST ==========START of xAOD::MuonContainer DUMP===========" );
1342
1343 const xAOD::MuonContainer* muonCont=0;
1344 StatusCode sc = evtStore()->retrieve(muonCont,"HLT_xAOD__MuonContainer_MuonEFInfo");
1345 if (sc.isFailure()) {
1346 ATH_MSG_INFO("REGTEST No muon container HLT_xAOD__MuonContainer_MuonEFInfo");
1347 return StatusCode::SUCCESS;
1348 }
1349
1350 std::string output = m_muonPrinter->print( *muonCont );
1351 msg(MSG::INFO) << output << endmsg;
1352
1353 ATH_MSG_INFO( "REGTEST ==========END of xAOD::MuonContainer DUMP===========" );
1354
1355 return StatusCode::SUCCESS;
1356
1357}
ToolHandle< Rec::IMuonPrintingTool > m_muonPrinter
output
Definition merge.py:16
MuonContainer_v1 MuonContainer
Definition of the current "Muon container version".
MsgStream & msg
Definition testRead.cxx:32

◆ dumpxAODPhotonContainer()

StatusCode TrigEDMChecker::dumpxAODPhotonContainer ( )
private

Definition at line 1916 of file TrigEDMChecker.cxx.

1916 {
1917
1918 ATH_MSG_DEBUG("In dumpxAODPhotonContainer");
1919
1920 ATH_MSG_INFO( "REGTEST ==========START of xAOD::PhotonContainer DUMP===========" );
1921
1922 const xAOD::PhotonContainer* phCont=0;
1923 StatusCode sc = evtStore()->retrieve(phCont,"HLT_xAOD__PhotonContainer_egamma_Photons");
1924 if (sc.isFailure()) {
1925 ATH_MSG_INFO("REGTEST No Photon container HLT_xAOD__PhotonContainer_egamma_Photons");
1926 return StatusCode::SUCCESS;
1927 }
1928
1929 float val_float=-99;
1930 unsigned int isEMbit=0;
1931 //DEBUG output for xAOD::PhotonContainer
1932 ATH_MSG_INFO(" REGTEST: xAOD Reconstruction variables: ");
1933 // //Cluster and ShowerShape info
1934 for (const auto eg : *phCont){
1935 //REGTEST printout
1936 if (eg) {
1937 ATH_MSG_INFO(" REGTEST: egamma energy: " << eg->e() );
1938 ATH_MSG_INFO(" REGTEST: egamma eta: " << eg->eta() );
1939 ATH_MSG_INFO(" REGTEST: egamma phi: " << eg->phi() );
1940 ATH_MSG_INFO(" REGTEST: isEMLoose " << eg->selectionisEM(isEMbit,"isEMLoose"));
1941 ATH_MSG_INFO(" REGTEST: isEMLoose bit " << std::hex << isEMbit << std::dec);
1942 ATH_MSG_INFO(" REGTEST: isEMMedium " << eg->selectionisEM(isEMbit,"isEMMedium"));
1943 ATH_MSG_INFO(" REGTEST: isEMMedium bit " << std::hex << isEMbit << std::dec);
1944 ATH_MSG_INFO(" REGTEST: isEMTight " << eg->selectionisEM(isEMbit,"isEMTight"));
1945 ATH_MSG_INFO(" REGTEST: isEMTight bit " << std::hex << isEMbit << std::dec);
1946 } else{
1947 ATH_MSG_INFO(" REGTEST: problems with egamma pointer" );
1948 return StatusCode::SUCCESS;
1949 }
1950 ATH_MSG_INFO(" REGTEST: caloCluster variables ");
1951 if (eg->caloCluster()) {
1952 ATH_MSG_INFO(" REGTEST: egamma cluster transverse energy: " << eg->caloCluster()->et() );
1953 ATH_MSG_INFO(" REGTEST: egamma cluster eta: " << eg->caloCluster()->eta() );
1954 ATH_MSG_INFO(" REGTEST: egamma cluster phi: " << eg->caloCluster()->phi() );
1955 double tmpeta = -999.;
1956 double tmpphi = -999.;
1957 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::ETACALOFRAME,tmpeta);
1958 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::PHICALOFRAME,tmpphi);
1959 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. etaCalo = " << tmpeta);
1960 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. phiCalo = " << tmpphi);
1961 } else{
1962 ATH_MSG_INFO(" REGTEST: problems with egamma cluster pointer" );
1963 }
1964 ATH_MSG_INFO("REGTEST: Check the original (uncalibrated)");
1965 static const SG::AuxElement::Accessor<ElementLink<xAOD::CaloClusterContainer> > orig ("originalCaloCluster");
1966 if (!orig.isAvailable(*eg->caloCluster()) || !orig(*eg->caloCluster()).isValid()){
1967 ATH_MSG_INFO("Problem with original cluster link");
1968 }
1969 else {
1970 const xAOD::CaloCluster *origClus = *orig(*eg->caloCluster());
1971 ATH_MSG_INFO("REGTEST:: Compare new and old clusters");
1972 ATH_MSG_INFO("REGTEST:: Original Cluster e,eta,phi" << origClus->e() << " " << origClus->eta() << " " << origClus->phi());
1973 ATH_MSG_INFO("REGTEST:: MVA Cluster e,eta,phi" << eg->caloCluster()->e() << " " << eg->caloCluster()->eta() << " " << eg->caloCluster()->phi());
1974 }
1975 //msg() << MSG::VERBOSE << " REGTEST: cluster variables " << endmsg;
1976 //clus = eg->caloCluster();
1977 ATH_MSG_INFO(" REGTEST: EMShower variables ");
1978 eg->showerShapeValue(val_float,xAOD::EgammaParameters::ethad);
1979 ATH_MSG_INFO(" REGTEST: ethad = " << val_float);
1980 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e011);
1981 ATH_MSG_INFO(" REGTEST: e011 = " << val_float);
1982 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e132);
1983 ATH_MSG_INFO(" REGTEST: e132 = " << val_float);
1984 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e237);
1985 ATH_MSG_INFO(" REGTEST: e237 = " << val_float);
1986 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e335);
1987 ATH_MSG_INFO(" REGTEST: e335 = " << val_float);
1988 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2ts1);
1989 ATH_MSG_INFO(" REGTEST: e2ts1 = " << val_float);
1990 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2tsts1);
1991 ATH_MSG_INFO(" REGTEST: e2tsts1 = " << val_float);
1992 eg->isolationValue(val_float,xAOD::Iso::etcone20);
1993 ATH_MSG_INFO(" REGTEST: etcone20 = " << val_float);
1994 eg->isolationValue(val_float,xAOD::Iso::etcone30);
1995 ATH_MSG_INFO(" REGTEST: etcone30 = " << val_float);
1996 eg->isolationValue(val_float,xAOD::Iso::etcone40);
1997 ATH_MSG_INFO(" REGTEST: etcone40 = " << val_float);
1998 //DEBUG info for Electrons which by definition have a track match
1999
2000 }
2001 ATH_MSG_INFO( "REGTEST ==========END of xAOD::PhotonContainer DUMP===========" );
2002
2003 return StatusCode::SUCCESS;
2004
2005}
PhotonContainer_v1 PhotonContainer
Definition of the current "photon container version".

◆ dumpxAODTrackParticle()

StatusCode TrigEDMChecker::dumpxAODTrackParticle ( )
private

Definition at line 3857 of file TrigEDMChecker.cxx.

3857 {
3858
3859 ATH_MSG_DEBUG("In dumpxAODTrackParticle()");
3860
3861 ATH_MSG_INFO("REGTEST ==========START of xAOD::TrackParticle DUMP===========");
3862
3863 std::vector<std::string> SGkeys;
3864 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Bjet_EFID");
3865 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Bphysics_EFID");
3866 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Electron_EFID");
3867 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_FullScan_EFID");
3868 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Muon_EFID");
3869 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Photon_EFID");
3870 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Tau_EFID");
3871
3872 StatusCode returnsc = StatusCode::SUCCESS;
3873
3874 for (unsigned int SGkey = 0; SGkey < SGkeys.size(); ++SGkey) {
3875 const xAOD::TrackParticleContainer* trackParticleContainer=0;
3876 StatusCode sc = evtStore()->retrieve(trackParticleContainer,SGkeys.at(SGkey));
3877 if (sc.isFailure()) {
3878 ATH_MSG_INFO("REGTEST No track particle container found with key " << SGkeys.at(SGkey));
3879 continue;
3880 }
3881 ATH_MSG_INFO("REGTEST TrackParticleContainer retrieved with key " << SGkeys.at(SGkey)
3882 << " and size " << trackParticleContainer->size());
3883
3884 xAOD::TrackParticleContainer::const_iterator trackParticleItr = trackParticleContainer->begin();
3885 xAOD::TrackParticleContainer::const_iterator trackParticleLast = trackParticleContainer->end();
3886
3887 for (int index = 0; trackParticleItr != trackParticleLast; ++trackParticleItr, ++index) {
3888 ATH_MSG_INFO("REGTEST Looking at Track Particle " << index);
3889
3890 ATH_MSG_INFO("REGTEST IParticle functions:");
3891 ATH_MSG_INFO("REGTEST pt: " << (*trackParticleItr)->pt()
3892 << "/eta: " << (*trackParticleItr)->eta()
3893 << "/phi: " << (*trackParticleItr)->phi()
3894 << "/m: " << (*trackParticleItr)->m()
3895 << "/e: " << (*trackParticleItr)->e()
3896 << "/rapidity: " << (*trackParticleItr)->rapidity());
3897
3898 ATH_MSG_INFO("REGTEST Defining parameters functions:");
3899 ATH_MSG_INFO("REGTEST charge: " << (*trackParticleItr)->charge()
3900 << "/d0: " << (*trackParticleItr)->d0()
3901 << "/z0: " << (*trackParticleItr)->z0()
3902 << "/phi0: " << (*trackParticleItr)->phi0()
3903 << "/theta: " << (*trackParticleItr)->theta()
3904 << "/qOverP: " << (*trackParticleItr)->qOverP()
3905 << "/vx: " << (*trackParticleItr)->vx()
3906 << "/vy: " << (*trackParticleItr)->vy()
3907 << "/vz: " << (*trackParticleItr)->vz());
3908
3909 // Curvilinear functions skipped
3910
3911 ATH_MSG_INFO("REGTEST Fit quality functions:");
3912 ATH_MSG_INFO("REGTEST chiSquared: " << (*trackParticleItr)->chiSquared()
3913 << "/numberDoF: " << (*trackParticleItr)->numberDoF());
3914
3915 // TrackInfo functions skipped
3916
3917 ATH_MSG_INFO("REGTEST summaryValue variables:");
3918 msg() << MSG::INFO << "REGTEST ";
3920 if ( (*trackParticleItr)->summaryValue(numberOfBLayerHits, xAOD::numberOfBLayerHits) ) {
3921 msg() << "/numberOfBLayerHits: " << static_cast<int>(numberOfBLayerHits);
3922 } else {
3923 msg() << "/numberOfBLayerHits not found";
3924 }
3925
3927 if ( (*trackParticleItr)->summaryValue(numberOfPixelHits, xAOD::numberOfPixelHits) ) {
3928 msg() << "/numberOfPixelHits: " << static_cast<int>(numberOfPixelHits);
3929 } else {
3930 msg() << "/numberOfPixelHits not found";
3931 }
3932
3934 if ( (*trackParticleItr)->summaryValue(numberOfPixelHoles, xAOD::numberOfPixelHoles) ) {
3935 msg() << "/numberOfPixelHoles: " << static_cast<int>(numberOfPixelHoles);
3936 } else {
3937 msg() << "/numberOfPixelHoles not found";
3938 }
3939
3941 if ( (*trackParticleItr)->summaryValue(numberOfSCTHits, xAOD::numberOfSCTHits) ) {
3942 msg() << "/numberOfSCTHits: " << static_cast<int>(numberOfSCTHits);
3943 } else {
3944 msg() << "/numberOfSCTHits not found";
3945 }
3946
3948 if ( (*trackParticleItr)->summaryValue(numberOfSCTHoles, xAOD::numberOfSCTHoles) ) {
3949 msg() << "/numberOfSCTHoles: " << static_cast<int>(numberOfSCTHoles);
3950 } else {
3951 msg() << "/numberOfSCTHoles not found";
3952 }
3953
3955 if ( (*trackParticleItr)->summaryValue(numberOfTRTHits, xAOD::numberOfTRTHits) ) {
3956 msg() << "/numberOfTRTHits: " << static_cast<int>(numberOfTRTHits);
3957 } else {
3958 msg() << "/numberOfTRTHits not found";
3959 }
3960
3962 if ( (*trackParticleItr)->summaryValue(numberOfTRTHoles, xAOD::numberOfTRTHoles) ) {
3963 msg() << "/numberOfTRTHoles: " << static_cast<int>(numberOfTRTHoles);
3964 } else {
3965 msg() << "/numberOfTRTHoles not found";
3966 }
3967 msg() << endmsg;
3968 }
3969 }
3970
3971 ATH_MSG_INFO("REGTEST ==========END of xAOD::TrackParticle DUMP===========");
3972 ATH_MSG_DEBUG("dumpxAODTrackParticles() succeeded");
3973
3974 return returnsc;
3975}
str index
Definition DeMoScan.py:362
@ numberOfPixelHoles
number of pixel layers on track with absence of hits [unit8_t].
@ numberOfTRTHits
number of TRT hits [unit8_t].
@ numberOfTRTHoles
number of TRT holes [unit8_t].
@ numberOfBLayerHits
these are the hits in the first pixel layer, i.e.
@ numberOfSCTHits
number of hits in SCT [unit8_t].
@ numberOfPixelHits
these are the pixel hits, including the b-layer [unit8_t].
@ numberOfSCTHoles
number of SCT holes [unit8_t].

◆ dumpxAODTrigElectronContainer()

StatusCode TrigEDMChecker::dumpxAODTrigElectronContainer ( )
private

Definition at line 1659 of file TrigEDMChecker.cxx.

1659 {
1660
1661 ATH_MSG_DEBUG("In dumpxAODElectronContainer");
1662
1663 ATH_MSG_INFO( "REGTEST ==========START of xAOD::TrigElectronContainer DUMP===========" );
1664
1665 const xAOD::TrigElectronContainer* elCont=0;
1666 StatusCode sc = evtStore()->retrieve(elCont,"HLT_xAOD__TrigElectronContainer_L2ElectronFex");
1667 if (sc.isFailure()) {
1668 ATH_MSG_INFO("REGTEST No TrigElectron container HLT_xAOD__TrigElectronContainer_L2ElectronFex");
1669 return StatusCode::SUCCESS;
1670 }
1671
1672 for (const auto eg : *elCont){
1673 ATH_MSG_INFO("REGTEST TrigElectron->Phi() returns " << eg->phi());
1674 ATH_MSG_INFO("REGTEST TrigElectron->Eta() returns " << eg->eta());
1675 ATH_MSG_INFO("REGTEST TrigElectron->rEta returns " << eg->rcore());
1676 ATH_MSG_INFO("REGTEST TrigElectron->eratio() returns " << eg->eratio());
1677 ATH_MSG_INFO("REGTEST TrigElectron->pt() returns " << eg->pt());
1678 ATH_MSG_INFO("REGTEST TrigElectron->etHad() returns " << eg->etHad());
1679 ATH_MSG_INFO("REGTEST TrigElectron->f1() returns " << eg->f1());
1680 ATH_MSG_INFO("REGTEST TrigElectron caloEta = " << eg->caloEta());
1681 ATH_MSG_INFO("REGTEST TrigElectron dPhiCalo" << eg->trkClusDphi());
1682 ATH_MSG_INFO("REGTEST TrigElectron dEtaCalo" << eg->trkClusDeta());
1683 ATH_MSG_INFO("REGTEST TrigElectron pTcalo" << eg->pt());
1684 ATH_MSG_INFO("REGTEST TrigElectron eTOverPt" << eg->etOverPt());
1685 ATH_MSG_INFO("REGTEST TrigElectron nTRTHits" << eg->nTRTHits());
1686 ATH_MSG_INFO("REGTEST TrigElectron nStrawHits" << eg->nTRTHiThresholdHits());
1687 ATH_MSG_INFO("REGTEST TrigElectron Check EMCluster");
1688 if(eg->emCluster()){
1689 ATH_MSG_INFO("REGTEST TrigElectron EMCluster retrieved");
1690 ATH_MSG_INFO("REGTEST TrigElectron emCluster->energy() returns " << eg->emCluster()->energy());
1691 ATH_MSG_INFO("REGTEST TrigElectron emCluster->phi() returns " << eg->emCluster()->phi());
1692 ATH_MSG_INFO("REGTEST TrigElectron emCluster->eta() returns " << eg->emCluster()->eta());
1693 ATH_MSG_INFO("REGTEST TrigElectron emCluster check Element Link");
1694 ATH_MSG_INFO("REGTEST TrigElectron emCluster energy = " << eg->emCluster()->energy());
1695 ATH_MSG_INFO("REGTEST TrigElectron ElementLink emCluster energy = " << (*eg->emClusterLink())->energy());
1696 }
1697 else ATH_MSG_INFO("REGTEST TrigElectron No EMCluster retrieved!");
1698 ATH_MSG_INFO("REGTEST TrigElectron Check TrackParticle");
1699 if(eg->trackParticle()){
1700 ATH_MSG_INFO("REGTEST TrigElectron TrackParticle retrieved");
1701 ATH_MSG_INFO("REGTEST TrigElectron trackParticle->pt() returns " << eg->trackParticle()->pt());
1702 ATH_MSG_INFO("REGTEST TrigElectron trackParticle->phi() returns " << eg->trackParticle()->phi());
1703 ATH_MSG_INFO("REGTEST TrigElectron trackParticle->eta() returns " << eg->trackParticle()->eta());
1704 ATH_MSG_INFO("REGTEST TrigElectron check TrackParticle Element Link");
1705 ATH_MSG_INFO("REGTEST TrigElectron TrackParticle pt = " << eg->trackParticle()->pt());
1706 ATH_MSG_INFO("REGTEST TrigElectron ElementLink TrackParticle pt = " << (*eg->trackParticleLink())->pt());
1707 }
1708 else ATH_MSG_INFO("REGTEST TrigElectron No TrackParticle retrieved!");
1709 }
1710 ATH_MSG_INFO( "REGTEST ==========END of xAOD::TrigElectronContainer DUMP===========" );
1711
1712 return StatusCode::SUCCESS;
1713
1714}
TrigElectronContainer_v1 TrigElectronContainer
Declare the latest version of the container.

◆ dumpxAODTrigMinBias()

StatusCode TrigEDMChecker::dumpxAODTrigMinBias ( )
private

Definition at line 815 of file TrigEDMChecker.cxx.

815 {
816
821
822 return StatusCode::SUCCESS;
823}
void dumpTrigSpacePointCounts()

◆ dumpxAODTrigMissingET()

StatusCode TrigEDMChecker::dumpxAODTrigMissingET ( )
private

Definition at line 829 of file TrigEDMChecker.cxx.

829 {
830
831 ATH_MSG_INFO("dumpxAODTrigMissingET()");
832
833 int ntag=4;
834 std::string METTags[]={"HLT_xAOD__TrigMissingETContainer_EFJetEtSum","HLT_xAOD__TrigMissingETContainer_TrigEFMissingET", "HLT_xAOD__TrigMissingETContainer_TrigL2MissingET_FEB","HLT_xAOD__TrigMissingETContainer_TrigEFMissingET_topocl"};
835
836 for(int itag=0; itag <ntag; itag++) {
837
838 const xAOD::TrigMissingETContainer* MissingETCont=0;
839 StatusCode sc = evtStore()->retrieve(MissingETCont,METTags[itag]);
840 if (sc.isFailure())
841 ATH_MSG_INFO("failed to retrieve " << METTags[itag]);
842 else {
843 ATH_MSG_INFO("Accessing " << METTags[itag] << " with " << MissingETCont->size() << " elements");
844
845 // Loop over container content
846 for(uint i = 0; i < MissingETCont->size(); i++) {
847
848 std::string s; char buff[3000];
849
850 snprintf(buff, sizeof(buff), "REGTEST %s Ex = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->ex() );
851 ATH_MSG_INFO(buff);
852 snprintf(buff, sizeof(buff), "REGTEST %s Ey = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->ey() );
853 ATH_MSG_INFO(buff);
854 snprintf(buff, sizeof(buff), "REGTEST %s Ez = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->ez() );
855 ATH_MSG_INFO(buff);
856 snprintf(buff, sizeof(buff), "REGTEST %s SumET = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->sumEt() );
857 ATH_MSG_INFO(buff);
858 snprintf(buff, sizeof(buff), "REGTEST %s SumE = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->sumE() );
859 ATH_MSG_INFO(buff);
860 snprintf(buff, sizeof(buff), "REGTEST %s Flag = %d", s.c_str(), MissingETCont->at(i)->flag() );
861 ATH_MSG_INFO(buff);
862 snprintf(buff, sizeof(buff), "REGTEST %s Flag = %d", s.c_str(), MissingETCont->at(i)->roiWord() );
863 ATH_MSG_INFO(buff);
864
865 unsigned int Nc = MissingETCont->at(i)->getNumberOfComponents();
866 if (Nc > 0) {
867 s="REGTEST __name____status_usedChannels__sumOfSigns__calib1_calib0";
868 s+="/MeV__ex/MeV_____ey/MeV_____ez/MeV___sumE/MeV__sumEt/CLHEP::MeV";
869 ATH_MSG_INFO(s);
870 }
871
872 for(uint j = 0; j < Nc; j++) {
873
874 std::string name = MissingETCont->at(i)->nameOfComponent(j);
875 const short status = MissingETCont->at(i)->statusComponent(j);
876 const unsigned short usedChan = MissingETCont->at(i)->usedChannelsComponent(j);
877 const short sumOfSigns = MissingETCont->at(i)->sumOfSignsComponent(j);
878 const float calib0 = MissingETCont->at(i)->calib0Component(j);
879 const float calib1 = MissingETCont->at(i)->calib1Component(j);
880 const float ex = MissingETCont->at(i)->exComponent(j);
881 const float ey = MissingETCont->at(i)->eyComponent(j);
882 const float ez = MissingETCont->at(i)->ezComponent(j);
883 const float sumE = MissingETCont->at(i)->sumEComponent(j);
884 const float sumEt = MissingETCont->at(i)->sumEtComponent(j);
885
886 snprintf(buff, sizeof(buff),
887 "REGTEST %s %6d %12d %10d %6.2f %6.3f %10.2f %10.2f %10.2f %10.2f %10.2f",
888 name.c_str(), status, usedChan, sumOfSigns, calib1, calib0,
889 ex, ey, ez, sumE, sumEt);
890 ATH_MSG_INFO(buff);
891 }
892 }
893 }
894 }
895
896 return StatusCode::SUCCESS;
897}
int flag() const
Get the status flag.
float ex() const
Get the x component of the missing energy.
float exComponent(unsigned int index) const
Get the x component fo the energy of a component.
const std::string & nameOfComponent(unsigned int index) const
Get the name of a component.
float eyComponent(unsigned int index) const
Get the y component fo the energy of a component.
uint32_t roiWord() const
Get the ROI word.
float sumE() const
Get the sum of the E of the missing energy.
float calib0Component(unsigned int index) const
Get Calib0.
float calib1Component(unsigned int index) const
Get Calib1.
unsigned int getNumberOfComponents() const
Get the number of components.
float ezComponent(unsigned int index) const
Get the z component fo the energy of a component.
float sumEt() const
Get the sum of the ET of the missing energy.
short statusComponent(unsigned int index) const
Get Status.
float ez() const
Get the z component of the missing energy.
float sumOfSignsComponent(unsigned int index) const
Get SumOfSigns.
float sumEComponent(unsigned int index) const
Get SumE.
float ey() const
Get the y component of the missing energy.
float sumEtComponent(unsigned int index) const
Get SumEt.
unsigned short usedChannelsComponent(unsigned int index) const
Get used Channels.
status
Definition merge.py:16

◆ dumpxAODTrigPhotonContainer()

StatusCode TrigEDMChecker::dumpxAODTrigPhotonContainer ( )
private

Definition at line 1717 of file TrigEDMChecker.cxx.

1717 {
1718
1719 ATH_MSG_DEBUG("In dumpxAODTrigPhotonContainer");
1720
1721 ATH_MSG_INFO( "REGTEST ==========START of xAOD::TrigPhotonContainer DUMP===========" );
1722
1723 const xAOD::TrigPhotonContainer* phCont=0;
1724 StatusCode sc = evtStore()->retrieve(phCont,"HLT_xAOD__TrigPhotonContainer_L2PhotonFex");
1725 if (sc.isFailure()) {
1726 ATH_MSG_INFO("REGTEST No TrigPhoton container HLT_xAOD__TrigPhotonContainer_L2PhotonFex");
1727 return StatusCode::SUCCESS;
1728 }
1729
1730 for (const auto eg : *phCont){
1731
1732 ATH_MSG_INFO("REGTEST TrigPhoton->Phi() returns " << eg->phi());
1733 ATH_MSG_INFO("REGTEST TrigPhoton->Eta() returns " << eg->eta());
1734 ATH_MSG_INFO("REGTEST TrigPhoton->dPhi() returns " << eg->dPhi());
1735 ATH_MSG_INFO("REGTEST TrigPhoton->dEta() returns " << eg->dEta());
1736 ATH_MSG_INFO("REGTEST TrigPhoton->rEta returns " << eg->rcore());
1737 ATH_MSG_INFO("REGTEST TrigPhoton->eratio() returns " << eg->eratio());
1738 ATH_MSG_INFO("REGTEST TrigPhoton->pt() returns " << eg->pt());
1739 ATH_MSG_INFO("REGTEST TrigPhoton->etHad() returns " << eg->etHad());
1740 ATH_MSG_INFO("REGTEST TrigPhoton->f1() returns " << eg->f1());
1741 ATH_MSG_INFO("REGTEST TrigPhoton Check EMCluster");
1742 if(eg->emCluster()){
1743 ATH_MSG_INFO("REGTEST TrigPhoton EMCluster retrieved");
1744 ATH_MSG_INFO("REGTEST TrigPhoton emCluster->energy() returns " << eg->emCluster()->energy());
1745 ATH_MSG_INFO("REGTEST TrigPhoton emCluster->phi() returns " << eg->emCluster()->phi());
1746 ATH_MSG_INFO("REGTEST TrigPhoton emCluster->eta() returns " << eg->emCluster()->eta());
1747 ATH_MSG_INFO("REGTEST TrigPhoton emCluster check Element Link");
1748 ATH_MSG_INFO("REGTEST TrigPhoton emCluster energy = " << eg->emCluster()->energy());
1749 ATH_MSG_INFO("REGTEST TrigPhoton ElementLink emCluster energy = " << (*eg->emClusterLink())->energy());
1750 }
1751 else ATH_MSG_INFO("REGTEST TrigPhoton No EMCluster retrieved!");
1752 }
1753 ATH_MSG_INFO( "REGTEST ==========END of xAOD::TrigPhotonContainer DUMP===========" );
1754
1755 return StatusCode::SUCCESS;
1756
1757}
TrigPhotonContainer_v1 TrigPhotonContainer
Declare the latest version of the container.

◆ dumpxAODVertex()

StatusCode TrigEDMChecker::dumpxAODVertex ( )
private

Definition at line 3977 of file TrigEDMChecker.cxx.

3977 {
3978
3979 ATH_MSG_DEBUG("In dumpxAODVertex()");
3980
3981 ATH_MSG_INFO("REGTEST ==========START of xAOD::Vertex DUMP===========");
3982
3983 const xAOD::VertexContainer* vertexContainer=0;
3984 StatusCode sc = evtStore()->retrieve(vertexContainer,"HLT_xAOD__VertexContainer_xPrimVx");
3985 if (sc.isFailure()) {
3986 ATH_MSG_INFO("REGTEST No vertex container");
3987 return StatusCode::FAILURE;
3988 }
3989 ATH_MSG_INFO("REGTEST VertexContainer retrieved");
3990
3991 xAOD::VertexContainer::const_iterator vertexItr = vertexContainer->begin();
3992 xAOD::VertexContainer::const_iterator vertexLast = vertexContainer->end();
3993
3994 for (int index = 0; vertexItr != vertexLast; ++vertexItr, ++index) {
3995 ATH_MSG_INFO("REGTEST Looking at Vertex " << index);
3996
3997 ATH_MSG_INFO("REGTEST Public Member Functions:");
3998 ATH_MSG_INFO("REGTEST x: " << (*vertexItr)->x()
3999 << "/y: " << (*vertexItr)->y()
4000 << "/z: " << (*vertexItr)->z());
4001
4002 ATH_MSG_INFO("REGTEST Public Member Functions:");
4003 ATH_MSG_INFO("REGTEST chiSquared: " << (*vertexItr)->chiSquared()
4004 << "/numberDoF: " << (*vertexItr)->numberDoF());
4005 }
4006
4007 ATH_MSG_INFO("REGTEST ==========END of xAOD::Vertex DUMP===========");
4008 ATH_MSG_DEBUG("dumpxAODVertex() succeeded");
4009
4010 return StatusCode::SUCCESS;
4011}
VertexContainer_v1 VertexContainer
Definition of the current "Vertex container version".

◆ efficiency()

TEfficiency * AthHistogramming::efficiency ( const std::string & effName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered TEfficiency.

Definition at line 211 of file AthHistogramming.cxx.

212{
213 // Build a 32 bit hash out of the name
214 const hash_t effHash = this->hash(effName);
215
216 // See if this entry exists in the map
217 EffMap_t::const_iterator it = m_effMap.find( effHash );
218 if ( it == m_effMap.end() ) // It doesn't exist!
219 { // Let's see into the THistSvc if somebody else has registered the TEfficiency...
220
221 // Need to copy the strings as we will massage them from here on
222 std::string effNameCopy = effName;
223 std::string tDirCopy = tDir;
224 std::string streamCopy = stream;
225
226 // Massage the final string to book things
227 std::string bookingString("");
228 this->buildBookingString( bookingString, effNameCopy, tDirCopy, streamCopy ,false);
229
230 TEfficiency* effPointer(NULL);
231 if ( !((histSvc()->getEfficiency(bookingString, effPointer)).isSuccess()) )
232 {
233 // Massage the final string to book things
234 std::string bookingString("");
235 this->buildBookingString( bookingString, effNameCopy, tDirCopy, streamCopy, true );
236
237 if ( !((histSvc()->getEfficiency(bookingString, effPointer)).isSuccess()) )
238 {
239 m_msg << MSG::WARNING
240 << "Problem retrieving the TEfficiency with name (including pre- and post-fixes) "
241 << m_histNamePrefix + effNameCopy + m_histNamePostfix
242 << " or with name " << effNameCopy
243 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
244 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
245 return NULL;
246 }
247 // If we get to here, we actually found the TEfficiency in the THistSvc.
248 // So let's add it to the local cache map and return its pointer
249 m_effMap.insert( m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, effPointer ) );
250 return effPointer;
251 }
252 // If we get to here, we actually found the TEfficiency in the THistSvc.
253 // So let's add it to the local cache map and return its pointer
254 m_effMap.insert( m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, effPointer ) );
255 return effPointer;
256 }
257
258 // Return the pointer to the TEfficiency that we got from the local cache map
259 return it->second;
260}
std::pair< StatusCode, TEfficiency * > getEfficiency(ITHistSvc &svc, const std::string &name)

◆ endInputFile()

StatusCode AthAnalysisAlgorithm::endInputFile ( )
protectedvirtualinherited

Function called as an input file is being closed.

Dummy implementation that can be overridden by the derived tool.

Definition at line 122 of file AthAnalysisAlgorithm.cxx.

122 {
123
124 // Return gracefully:
125 return StatusCode::SUCCESS;
126}

◆ evtStore()

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

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

Definition at line 85 of file AthCommonDataStore.h.

◆ execute()

StatusCode TrigEDMChecker::execute ( const EventContext & ctx)
overridevirtual

Execute method.

Implements AthAlgorithm.

Definition at line 243 of file TrigEDMChecker.cxx.

243 {
244
245 /* fwinkl, Mar 20222:
246 Some attempt was made to make the code pass the thread-checker. Methods that
247 are clearly not thread-safe (e.g. use of DataHandle) are marked as such. Calling
248 these methods from within execute would still trigger a thread-checker warning.
249 Since this algorithm is only ever used for validation and in single-threaded athena,
250 we suppress these warnings by the following assignment. This has the advantage
251 (as opposed to disabling the checking for the entire file) that new code is still
252 being checked and will hopefully be written in a thread-safe manner, i.e. using
253 ReadHandleKeys. If someone is very eager they could migrate all uses of DataHandles...
254 */
255 StatusCode sc ATLAS_THREAD_SAFE = do_execute(ctx);
256 return sc;
257}
#define ATLAS_THREAD_SAFE

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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

◆ extraOutputDeps()

const DataObjIDColl & AthCommonAlgorithm< Gaudi::Algorithm >::extraOutputDeps ( ) const
overridevirtualinherited

Return the list of extra output dependencies.

This list is extended to include symlinks implied by inheritance relations.

Definition at line 89 of file AthCommonAlgorithm.cxx.

54{
55 // If we didn't find any symlinks to add, just return the collection
56 // from the base class. Otherwise, return the extended collection.
57 if (!m_extendedExtraObjects.empty()) {
59 }
61}
Common base class for algorithms.

◆ filterPassed()

virtual bool AthCommonAlgorithm< Gaudi::Algorithm >::filterPassed ( const EventContext & ctx) const
inlinevirtualinherited

Get filter decision:

Definition at line 93 of file AthCommonAlgorithm.h.

93 {
94 return execState( ctx ).filterPassed();
95 }
virtual bool filterPassed(const EventContext &ctx) const
Get filter decision:

◆ firstExecute()

StatusCode AthAnalysisAlgorithm::firstExecute ( )
protectedvirtualinherited

Function called when first execute is encountered user can read event information with evtStore().

Dummy implementation that can be overridden by the derived tool.

Reimplemented in CP::JetTileCorrectionAlg.

Definition at line 139 of file AthAnalysisAlgorithm.cxx.

139 {
140
141 // Return gracefully:
142 return StatusCode::SUCCESS;
143}

◆ graph()

TGraph * AthHistogramming::graph ( const std::string & graphName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered TGraphs.

Definition at line 453 of file AthHistogramming.cxx.

454{
455 // Build a 32 bit hash out of the name
456 const hash_t graphHash = this->hash(graphName);
457
458 // See if this entry exists in the map
459 GraphMap_t::const_iterator it = m_graphMap.find( graphHash );
460 if ( it == m_graphMap.end() ) // It doesn't exist!
461 { // Let's see into the THistSvc if somebody else has registered the TGraph...
462
463 // Need to copy the strings as we will massage them from here on
464 std::string graphNameCopy = graphName;
465 std::string tDirCopy = tDir;
466 std::string streamCopy = stream;
467
468 // Massage the final string to book things
469 std::string bookingString("");
470 this->buildBookingString( bookingString, graphNameCopy, tDirCopy, streamCopy, false);
471
472 TGraph* graphPointer(nullptr);
473 if ( !((histSvc()->getGraph(bookingString, graphPointer)).isSuccess()) )
474 {
475 // Massage the final string to book things
476 std::string bookingString("");
477 this->buildBookingString( bookingString, graphNameCopy, tDirCopy, streamCopy, true );
478
479 if ( !((histSvc()->getGraph(bookingString, graphPointer)).isSuccess()) )
480 {
481 m_msg << MSG::WARNING
482 << "Problem retrieving the TGraph with name (including pre- and post-fixes) "
483 << m_histNamePrefix + graphNameCopy + m_histNamePostfix
484 << " or with name " << graphNameCopy
485 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
486 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
487 return nullptr;
488 }
489 // If we get to here, we actually found the TGraph in the THistSvc.
490 // So let's add it to the local cache map and return its pointer
491 m_graphMap.insert( m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphPointer ) );
492 return graphPointer;
493 }
494 // If we get to here, we actually found the TGraph in the THistSvc.
495 // So let's add it to the local cache map and return its pointer
496 m_graphMap.insert( m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphPointer ) );
497 return graphPointer;
498 }
499
500
501 // Return the pointer to the TGraph that we got from the local cache map
502 return it->second;
503}
std::pair< StatusCode, TGraph * > getGraph(ITHistSvc &svc, const std::string &name)

◆ handle()

void AthAnalysisAlgorithm::handle ( const Incident & inc)
overrideprotectedvirtualinherited

Function receiving incidents from IncidentSvc/TEvent Experts can override but they should ensure they add AthAnalysisAlgorithm::handle(); to the end of their own implementation.

Definition at line 83 of file AthAnalysisAlgorithm.cxx.

83 {
84
85 // Tell the user what's happening:
86 ATH_MSG_VERBOSE( "Callback received with incident: " << inc.type() );
87
88 // Call the appropriate member function:
89 if( inc.type() == IncidentType::BeginInputFile ) {
91 if( beginInputFile().isFailure() ) {
92 ATH_MSG_FATAL( "Failed to call beginInputFile()" );
93 throw std::runtime_error( "Couldn't call beginInputFile()" );
94 }
95 } else if(inc.type() == IncidentType::EndInputFile ) {
96 if( endInputFile().isFailure() ) {
97 ATH_MSG_FATAL( "Failed to call endInputFile()" );
98 throw std::runtime_error( "Couldn't call endInputFile()" );
99 }
100 } else if(inc.type() == "MetaDataStop" ) {
101 if( metaDataStop().isFailure() ) {
102 ATH_MSG_FATAL( "Failed to call metaDataStop()" );
103 throw std::runtime_error( "Couldn't call metaDataStop()" );
104 }
105 } else {
106 ATH_MSG_WARNING( "Unknown incident type received: " << inc.type() );
107 }
108
109 return;
110}
#define ATH_MSG_FATAL(x)
virtual StatusCode beginInputFile()
Function called when a new input file is opened user can read input metadata from inputMetaStore().
virtual StatusCode endInputFile()
Function called as an input file is being closed.
virtual StatusCode metaDataStop()
Function called before finalize user can read output metadata from outputMetaStore().

◆ hash()

AthHistogramming::hash_t AthHistogramming::hash ( const std::string & histName) const
inlineprivateinherited

Method to calculate a 32-bit hash from a string.

Definition at line 430 of file AthHistogramming.h.

431{
432 const uint64_t hash64 = CxxUtils::crc64( histName );
433 return (hash_t)(hash64 & 0xFFFFFFFF);
434}
uint64_t crc64(const CRCTable &table, const char *data, size_t data_len)
Find the CRC-64 of a string,.
Definition crc64.cxx:696
std::uint64_t hash64(const void *data, std::size_t size)
Passthrough to XXH3_64bits.
Definition XXH.cxx:9

◆ hist()

TH1 * AthHistogramming::hist ( const std::string & histName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered histograms of any type.

Definition at line 164 of file AthHistogramming.cxx.

167{
168 std::string histNameCopy = histName;
169 std::string tDirCopy = tDir;
170 std::string streamCopy = stream;
171
172 std::string bookingString;
173 this->buildBookingString(bookingString, histNameCopy, tDirCopy, streamCopy, false);
174
175 const hash_t histHash = this->hash(histNameCopy);
176
177 HistMap_t::const_iterator it = m_histMap.find(histHash);
178 if (it == m_histMap.end()) {
179 TH1* histPointer(nullptr);
180
181 if (!histSvc()->getHist(bookingString, histPointer).isSuccess()) {
182 std::string prefixedHistNameCopy = histName;
183 std::string prefixedTDirCopy = tDir;
184 std::string prefixedStreamCopy = stream;
185
186 std::string prefixedBookingString;
187 this->buildBookingString(prefixedBookingString,
188 prefixedHistNameCopy,
189 prefixedTDirCopy,
190 prefixedStreamCopy,
191 true);
192
193 if (!histSvc()->getHist(prefixedBookingString, histPointer).isSuccess()) {
194 m_msg << MSG::WARNING
195 << "Problem retrieving the histogram with name (including pre- and post-fixes) "
196 << m_histNamePrefix + histNameCopy + m_histNamePostfix
197 << " or with name " << histNameCopy
198 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
199 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
200 return nullptr;
201 }
202 }
203
204 m_histMap.insert(m_histMap.end(), std::pair<const hash_t, TH1*>(histHash, histPointer));
205 return histPointer;
206 }
207
208 return it->second;
209}
std::pair< StatusCode, TH1 * > getHist(ITHistSvc &svc, const std::string &name, size_t index=0)

◆ hist2d()

TH2 * AthHistogramming::hist2d ( const std::string & histName,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the retrieval of registered 2-d histograms.

Definition at line 371 of file AthHistogramming.h.

372{
373 // Get the TH1 pointer
374 TH1* th1Pointer = this->hist(histName, tDir, stream);
375 if ( !th1Pointer )
376 {
377 m_msg << MSG::ERROR
378 << "Cannot get a 2-d histogram with name " << histName
379 << "... will probably seg-fault!" << endmsg;
380 return NULL;
381 }
382 // If the TH1 pointer is valid, simply return the dynamic_cast
383 return dynamic_cast<TH2*>( th1Pointer );
384}

◆ hist3d()

TH3 * AthHistogramming::hist3d ( const std::string & histName,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the retrieval of registered 3-d histograms.

Definition at line 388 of file AthHistogramming.h.

389{
390 // Get the TH1 pointer
391 TH1* th1Pointer = this->hist(histName, tDir, stream);
392 if ( !th1Pointer )
393 {
394 m_msg << MSG::ERROR
395 << "Cannot get a 3-d histogram with name " << histName
396 << "... will probably seg-fault!" << endmsg;
397 return NULL;
398 }
399 // If the TH1 pointer is valid, simply return the dynamic_cast
400 return dynamic_cast<TH3*>( th1Pointer );
401}

◆ histSvc()

const ServiceHandle< ITHistSvc > & AthHistogramAlgorithm::histSvc ( ) const
inlineinherited

The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a pointer to the THistSvc.

Definition at line 113 of file AthHistogramAlgorithm.h.

114{
115 return m_histSvc;
116}
ServiceHandle< ITHistSvc > m_histSvc
Default constructor: AthHistogramAlgorithm();.

◆ initialize()

StatusCode TrigEDMChecker::initialize ( )
overridevirtual

Definition at line 171 of file TrigEDMChecker.cxx.

171 {
172
173 ATH_CHECK( m_navigationHandleKey.initialize() );
174 ATH_CHECK( m_decisionsKey.initialize() );
175 ATH_CHECK( m_navigationTool.retrieve() );
176
177 ATH_MSG_DEBUG("Initializing TrigEDMChecker");
178
179 ATH_MSG_INFO("REGTEST Initializing...");
180 ATH_MSG_INFO("REGTEST m_doDumpAll = " << m_doDumpAll );
181 ATH_MSG_INFO("REGTEST m_doDumpLVL1_ROI = " << m_doDumpLVL1_ROI);
182 ATH_MSG_INFO("REGTEST m_doDumpTrigMissingET = " << m_doDumpTrigMissingET );
183 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigMissingET = " << m_doDumpxAODTrigMissingET );
184 ATH_MSG_INFO("REGTEST m_doDumpMuonFeature = " << m_doDumpMuonFeature );
185 ATH_MSG_INFO("REGTEST m_doDumpCombinedMuonFeature = " << m_doDumpCombinedMuonFeature );
186 ATH_MSG_INFO("REGTEST m_doDumpTileMuFeature = " << m_doDumpTileMuFeature);
187 ATH_MSG_INFO("REGTEST m_doDumpTileTrackMuFeature = " << m_doDumpTileTrackMuFeature);
188 ATH_MSG_INFO("REGTEST m_doDumpTrigPhotonContainer = " << m_doDumpTrigPhotonContainer );
189 ATH_MSG_INFO("REGTEST m_doDumpTrigL2BphysContainer = " << m_doDumpTrigL2BphysContainer );
190 ATH_MSG_INFO("REGTEST m_doDumpTrigEFBphysContainer = " << m_doDumpTrigEFBphysContainer );
191 ATH_MSG_INFO("REGTEST m_doDumpTrigEFBjetContainer = " << m_doDumpTrigEFBjetContainer );
192 ATH_MSG_INFO("REGTEST m_doDumpTrigL2BjetContainer = " << m_doDumpTrigL2BjetContainer );
193 ATH_MSG_INFO("REGTEST m_doDumpxAODJetContainer = " << m_doDumpxAODJetContainer );
194 ATH_MSG_INFO("REGTEST m_doDumpTrigMuonEFContainer = " << m_doDumpTrigMuonEFContainer );
195 ATH_MSG_INFO("REGTEST m_doDumpTrigMuonEFInfoContainer = " << m_doDumpTrigMuonEFInfoContainer );
196 ATH_MSG_INFO("REGTEST m_doDumpxAODMuonContainer = " << m_doDumpxAODMuonContainer );
197 ATH_MSG_INFO("REGTEST m_doDumpTrigElectronContainer = " << m_doDumpTrigElectronContainer );
198 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigElectronContainer= " << m_doDumpxAODTrigElectronContainer );
199 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigPhotonContainer = " << m_doDumpxAODTrigPhotonContainer );
200 ATH_MSG_INFO("REGTEST m_doDumpxAODElectronContainer = " << m_doDumpxAODElectronContainer );
201 ATH_MSG_INFO("REGTEST m_doDumpxAODPhotonContainer = " << m_doDumpxAODPhotonContainer );
202 ATH_MSG_INFO("REGTEST m_doDumpHLTResult = " << m_doDumpHLTResult );
203 ATH_MSG_INFO("REGTEST m_doDumpTrigTauContainer = " << m_doDumpTrigTauContainer );
204 ATH_MSG_INFO("REGTEST m_doDumpTrigTauTracksInfo = " << m_doDumpTrigTauTracksInfo );
205 ATH_MSG_INFO("REGTEST m_doDumpTrigInDetTrackCollection = " << m_doDumpTrigInDetTrackCollection );
206 ATH_MSG_INFO("REGTEST m_doDumpTrigVertexCollection = " << m_doDumpTrigVertexCollection );
207 ATH_MSG_INFO("REGTEST m_doDumpTrigEMCluster = " << m_doDumpTrigEMCluster );
208 ATH_MSG_INFO("REGTEST m_doDumpTrigEMClusterContainer = " << m_doDumpTrigEMClusterContainer );
209 ATH_MSG_INFO("REGTEST m_doDumpTrigTauClusterContainer = " << m_doDumpTrigTauClusterContainer );
210 ATH_MSG_INFO("REGTEST m_doDumpTrackParticleContainer = " << m_doDumpTrackParticleContainer );
211 ATH_MSG_INFO("REGTEST m_doDumpTauJetContainer = " << m_doDumpTauJetContainer );
212 ATH_MSG_INFO("REGTEST m_doDumpxAODTrackParticle = " << m_doDumpxAODTrackParticle );
213 ATH_MSG_INFO("REGTEST m_doDumpxAODVertex = " << m_doDumpxAODVertex );
214 ATH_MSG_INFO("REGTEST m_doDumpxAODTauJetContainer = " << m_doDumpxAODTauJetContainer );
215 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigMinBias = " << m_doDumpxAODTrigMinBias );
216 ATH_MSG_INFO("REGTEST m_doDumpStoreGate = " << m_doDumpStoreGate );
217 ATH_MSG_INFO("REGTEST m_doDumpAllTrigComposite = " << m_doDumpAllTrigComposite );
218 ATH_MSG_INFO("REGTEST m_dumpTrigCompositeContainers = " << m_dumpTrigCompositeContainers );
219 ATH_MSG_INFO("REGTEST m_doDumpTrigCompsiteNavigation = " << m_doDumpTrigCompsiteNavigation );
220 ATH_MSG_INFO("REGTEST m_doTDTCheck = " << m_doTDTCheck );
221
222 ATH_MSG_INFO("maxRepWarning = " << maxRepWarnings );
223
225 ATH_CHECK( m_muonPrinter.retrieve() );
226 }
227 else m_muonPrinter.disable(); // to avoid auto-retrieval
228
230 ATH_CHECK( m_clidSvc.retrieve() );
231 }
232
234 ATH_CHECK( m_trigDec.retrieve() );
235 ATH_MSG_INFO("TDT Executing with navigation format: " << m_trigDec->getNavigationFormat());
236 }
238
239 return StatusCode::SUCCESS;
240}

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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.

◆ inputMetaStore() [1/2]

ServiceHandle< StoreGateSvc > & AthAnalysisAlgorithm::inputMetaStore ( )
inlineinherited

Accessor for the input metadata store.

Definition at line 51 of file AthAnalysisAlgorithm.h.

51{ return m_inputMetaStore; }
ServiceHandle< StoreGateSvc > m_inputMetaStore
Object accessing the input metadata store.

◆ inputMetaStore() [2/2]

const ServiceHandle< StoreGateSvc > & AthAnalysisAlgorithm::inputMetaStore ( ) const
inlineinherited

Const accessor for the input metadata store.

Definition at line 49 of file AthAnalysisAlgorithm.h.

49{ return m_inputMetaStore; }

◆ isClonable()

virtual bool AthCommonAlgorithm< Gaudi::Algorithm >::isClonable ( ) const
inlineoverridevirtualinherited

Specify if the algorithm is clonable.

Only relevant for non-reentrant algorithms. Actual number of clones needs to be set via the "Cardinality" property.

Reimplemented in AFP_DigiTop, AlgB, AlgT, BCM_Digitization, CscDigitBuilder, CscDigitToCscRDO, G4AtlasAlg, G4RunAlg, HGTD_Digitization, HiveAlgBase, InDet::GNNSeedingTrackMaker, InDet::SCT_Clusterization, InDet::SiSPGNNTrackMaker, InDet::SiSPSeededTrackFinder, InDet::SiTrackerSpacePointFinder, ISF::SimKernelMT, ITk::StripDigitization, ITkPixelCablingAlg, ITkStripCablingAlg, LArHitEMapMaker, LArTTL1Maker, LUCID_DigiTop, LVL1::L1TopoSimulation, MergeCalibHits, MergeGenericMuonSimHitColl, MergeHijingPars, MergeMcEventCollection, MergeTrackRecordCollection, MergeTruthJets, MergeTruthParticles, MuonDigitizer, PileUpMTAlg, PixelDigitization, RoIBResultToxAOD, SCT_ByteStreamErrorsTestAlg, SCT_CablingCondAlgFromCoraCool, SCT_CablingCondAlgFromText, SCT_ConditionsParameterTestAlg, SCT_ConditionsSummaryTestAlg, SCT_ConfigurationConditionsTestAlg, SCT_Digitization, SCT_FlaggedConditionTestAlg, SCT_LinkMaskingTestAlg, SCT_MajorityConditionsTestAlg, SCT_ModuleVetoTestAlg, SCT_MonitorConditionsTestAlg, SCT_PrepDataToxAOD, SCT_RawDataToxAOD, SCT_ReadCalibChipDataTestAlg, SCT_ReadCalibDataTestAlg, SCT_RODVetoTestAlg, SCT_SensorsTestAlg, SCT_SiliconConditionsTestAlg, SCT_StripVetoTestAlg, SCT_TdaqEnabledTestAlg, SCT_TestCablingAlg, SCTEventFlagWriter, SCTRawDataProvider, SCTSiLorentzAngleTestAlg, SCTSiPropertiesTestAlg, SGInputLoader, Simulation::BeamEffectsAlg, TileHitVecToCnt, TileMuonFitter, TilePulseForTileMuonReceiver, TileRawChannelMaker, TRTDigitization, and ZDC_DigiTop.

Definition at line 68 of file AthCommonAlgorithm.h.

68 {
69 return true;
70 }

◆ isReEntrant()

virtual bool AthAlgorithm::isReEntrant ( ) const
inlinefinaloverrideprotectedvirtualinherited

Legacy algorithms are not thread-safe.

Definition at line 47 of file AthAlgorithm.h.

47{ return false; }

◆ metaDataStop()

StatusCode AthAnalysisAlgorithm::metaDataStop ( )
protectedvirtualinherited

Function called before finalize user can read output metadata from outputMetaStore().

Dummy implementation that can be overridden by the derived tool.

Definition at line 130 of file AthAnalysisAlgorithm.cxx.

130 {
131
132 // Return gracefully:
133 return StatusCode::SUCCESS;
134}

◆ msg()

MsgStream & AthCommonMsg< Gaudi::Algorithm >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

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

◆ msgLvl()

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

Definition at line 30 of file AthCommonMsg.h.

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

◆ myReplace()

void AthHistogramming::myReplace ( std::string & str,
const std::string & oldStr,
const std::string & newStr )
privateinherited

Helper method to replace sub-string.

Definition at line 551 of file AthHistogramming.cxx.

554{
555 size_t pos = 0;
556 while((pos = str.find(oldStr, pos)) != std::string::npos)
557 {
558 str.replace(pos, oldStr.length(), newStr);
559 pos += newStr.length();
560 }
561}

◆ outputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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.

◆ outputMetaStore() [1/2]

ServiceHandle< StoreGateSvc > & AthAnalysisAlgorithm::outputMetaStore ( )
inlineinherited

Accessor for the output metadata store.

Definition at line 55 of file AthAnalysisAlgorithm.h.

55{ return m_outputMetaStore; }
ServiceHandle< StoreGateSvc > m_outputMetaStore
Object accessing the output metadata store.

◆ outputMetaStore() [2/2]

const ServiceHandle< StoreGateSvc > & AthAnalysisAlgorithm::outputMetaStore ( ) const
inlineinherited

Const accessor for the output metadata store.

Definition at line 53 of file AthAnalysisAlgorithm.h.

53{ return m_outputMetaStore; }

◆ printMuonTrk() [1/2]

void TrigEDMChecker::printMuonTrk ( const TrigMuonEFCbTrack * muonTrack)
private

Definition at line 1558 of file TrigEDMChecker.cxx.

1558 {
1559 ATH_MSG_INFO(" POINTER TrigMuonEFCbTrack: " << muonTrack);
1560 //if(muonTrack) mLog << MSG::INFO << "REGTEST TrigMuonEFCbTrack: " << *muonTrack << endmsg;
1561
1562// printMuonTrk(mLog,(TrigMuonEFTrack*)muonTrack);
1563// mLog <<MSG::INFO << "REGTEST TrigMuonEFCbTrack " << muonTrack << endmsg;
1564// mLog <<MSG::INFO << "REGTEST NIdPixelHits() returns " << muonTrack->NIdPixelHits() << endmsg;
1565// mLog <<MSG::INFO << "REGTEST NIdSctHits() returns " << muonTrack->NIdSctHits() << endmsg;
1566// mLog <<MSG::INFO << "REGTEST NTrtHits() returns " << muonTrack->NTrtHits() << endmsg;
1567// mLog <<MSG::INFO << "REGTEST matchChi2() returns " << muonTrack->matchChi2() << endmsg;
1568}

◆ printMuonTrk() [2/2]

void TrigEDMChecker::printMuonTrk ( const TrigMuonEFTrack * muonTrack)
private

Definition at line 1532 of file TrigEDMChecker.cxx.

1532 {
1533 ATH_MSG_INFO("POINTER TrigMuonEFTrack: " << muonTrack);
1534 //if(muonTrack) mLog << MSG::INFO << "REGTEST TrigMuonEFTrack: " << *muonTrack << endmsg;
1535
1536// mLog <<MSG::INFO << "REGTEST TrigMuonEFTrack->charge() returns " << muonTrack->Charge() << endmsg;
1537// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->iPt() returns " << muonTrack->iPt() << endmsg;
1538// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->CotTh() returns " << muonTrack->cotTh() << endmsg;
1539// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->Phi() returns " << muonTrack->phi() << endmsg;
1540// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->m() returns " << muonTrack->m() << endmsg;
1541// mLog <<MSG::INFO << "REGTEST chi2() returns " << muonTrack->chi2() << endmsg;
1542// mLog <<MSG::INFO << "REGTEST chi2prob() returns " << muonTrack->chi2prob() << endmsg;
1543// mLog <<MSG::INFO << "REGTEST posX() returns " << muonTrack->posX() << endmsg;
1544// mLog <<MSG::INFO << "REGTEST posY() returns " << muonTrack->posY() << endmsg;
1545// mLog <<MSG::INFO << "REGTEST posZ() returns " << muonTrack->posZ() << endmsg;
1546// mLog <<MSG::INFO << "REGTEST NCscHitsEta() returns " << muonTrack->NCscHitsEta() << endmsg;
1547// mLog <<MSG::INFO << "REGTEST NCscHitsPhi() returns " << muonTrack->NCscHitsPhi() << endmsg;
1548// mLog <<MSG::INFO << "REGTEST NTgcHitsEta() returns " << muonTrack->NTgcHitsEta() << endmsg;
1549// mLog <<MSG::INFO << "REGTEST NTgcHitsPhi() returns " << muonTrack->NTgcHitsPhi() << endmsg;
1550// mLog <<MSG::INFO << "REGTEST NMdtHitsEta() returns " << muonTrack->NMdtHitsEta() << endmsg;
1551// mLog <<MSG::INFO << "REGTEST NMdtHitsPhi() returns " << muonTrack->NMdtHitsPhi() << endmsg;
1552// mLog <<MSG::INFO << "REGTEST NRpcHitsEta() returns " << muonTrack->NRpcHitsEta() << endmsg;
1553// mLog <<MSG::INFO << "REGTEST NRpcHitsPhi() returns " << muonTrack->NRpcHitsPhi() << endmsg;
1554// mLog <<MSG::INFO << "REGTEST d0() returns " << muonTrack->d0() << endmsg;
1555// mLog <<MSG::INFO << "REGTEST z0() returns " << muonTrack->z0() << endmsg;
1556}

◆ 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< Gaudi::Algorithm > >::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< Gaudi::Algorithm > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ retrieveMetadata() [1/2]

template<typename T>
StatusCode AthAnalysisAlgorithm::retrieveMetadata ( const std::string & folder,
const std::string & key,
T & out )
inlineinherited

Helper function to access IOVMetaDataContainer information helped in the MetaDataStore.

Definition at line 65 of file AthAnalysisAlgorithm.h.

65 {
66 try {
68 } catch(std::exception& e) {
69 ATH_MSG_WARNING(e.what());
70 return StatusCode::FAILURE;
71 }
72 }
static std::string retrieveMetadata(const std::string &folder, const std::string &key, const ServiceHandle< StoreGateSvc > &inputMetaStore)
method that always returns as a string you can use from, e.g, pyROOT with evt = ROOT....

◆ retrieveMetadata() [2/2]

template<typename T>
StatusCode AthAnalysisAlgorithm::retrieveMetadata ( const std::string & folder,
const std::string & key,
T & out,
const IOVTime & time,
int channel = -1 )
inlineinherited

Helper function to access IOVMetaDataContainer information held in InputMetaDataStore, but will check IOVTime.

Also can give a channel (leave as -1 to take first available) IOVTime(runNumber, eventNumber) is a valid constructor for example

Definition at line 76 of file AthAnalysisAlgorithm.h.

76 {
77 try {
78 return AthAnalysisHelper::retrieveMetadata(folder,key,out,inputMetaStore(),time,channel);
79 } catch(std::exception& e) {
80 ATH_MSG_WARNING(e.what());
81 return StatusCode::FAILURE;
82 }
83 }

◆ setFilterPassed()

virtual void AthCommonAlgorithm< Gaudi::Algorithm >::setFilterPassed ( bool state,
const EventContext & ctx ) const
inlinevirtualinherited

Set filter decision:

Reimplemented in AthFilterAlgorithm.

Definition at line 99 of file AthCommonAlgorithm.h.

99 {
101 }
virtual void setFilterPassed(bool state, const EventContext &ctx) const
Set filter decision:

◆ sysExecute()

StatusCode AthAnalysisAlgorithm::sysExecute ( const EventContext & ctx)
overridevirtualinherited

override to do firstEvent method

Reimplemented from AthCommonAlgorithm< Gaudi::Algorithm >.

Definition at line 72 of file AthAnalysisAlgorithm.cxx.

72 {
73 if(!m_doneFirstEvent) {
75 if( firstExecute().isFailure() ) {
76 ATH_MSG_FATAL("Failure in firstEvent method");
77 return StatusCode::FAILURE;
78 }
79 }
81}
virtual StatusCode firstExecute()
Function called when first execute is encountered user can read event information with evtStore().
virtual StatusCode sysExecute(const EventContext &ctx) override

◆ sysInitialize()

StatusCode AthAnalysisAlgorithm::sysInitialize ( )
overridevirtualinherited

Function initialising the tool in the correct way in Athena.

Reimplemented from AthHistogramAlgorithm.

Definition at line 50 of file AthAnalysisAlgorithm.cxx.

50 {
51
52 // Connect to the IncidentSvc:
53 ServiceHandle< IIncidentSvc > incSvc( "IncidentSvc", name() );
54 ATH_CHECK( incSvc.retrieve() );
55
56 // Set up the right callbacks: //but ensure we don't double-register if sysInitialize called twice (appears to be the case)
57 incSvc->removeListener( this, IncidentType::BeginInputFile );
58 incSvc->addListener( this, IncidentType::BeginInputFile, 0, true );
59 incSvc->removeListener( this, IncidentType::EndInputFile );
60 incSvc->addListener( this, IncidentType::EndInputFile, 0, true );
61 incSvc->removeListener( this, "MetaDataStop" );
62 incSvc->addListener( this, "MetaDataStop", 0, true );
63
64
65 // Let the base class do its thing:
67
68 // Return gracefully:
69 return StatusCode::SUCCESS;
70}
virtual StatusCode sysInitialize()
Initialization method invoked by the framework.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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.

◆ tree()

TTree * AthHistogramming::tree ( const std::string & treeName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered TTrees.

Definition at line 339 of file AthHistogramming.cxx.

340{
341 // Build a 32 bit hash out of the name
342 const hash_t treeHash = this->hash(treeName);
343
344 // See if this entry exists in the map
345 TreeMap_t::const_iterator it = m_treeMap.find( treeHash );
346 if ( it == m_treeMap.end() ) // It doesn't exist!
347 { // Let's see into the THistSvc if somebody else has registered the TTree...
348
349 // Need to copy the strings as we will massage them from here on
350 std::string treeNameCopy = treeName;
351 std::string tDirCopy = tDir;
352 std::string streamCopy = stream;
353
354 // Massage the final string to book things
355 std::string bookingString("");
356 this->buildBookingString( bookingString, treeNameCopy, tDirCopy, streamCopy );
357
358 TTree* treePointer(NULL);
359 if ( !((histSvc()->getTree(bookingString, treePointer)).isSuccess()) )
360 {
361 m_msg << MSG::WARNING
362 << "Problem retrieving the TTree with name " << treeNameCopy
363 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
364 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
365 return NULL;
366 }
367 // If we get to here, we actually found the TTree in the THistSvc.
368 // So let's add it to the local cache map and return its pointer
369 m_treeMap.insert( m_treeMap.end(), std::pair< const hash_t, TTree* >( treeHash, treePointer ) );
370 return treePointer;
371 }
372
373 // Return the pointer to the TTree that we got from the local cache map
374 return it->second;
375}
std::pair< StatusCode, TTree * > getTree(ITHistSvc &svc, const std::string &name)

◆ TrigCompositeNavigationToDot()

StatusCode TrigEDMChecker::TrigCompositeNavigationToDot ( std::string & returnValue,
bool & pass )
private

Construct graph of HLT navigation in Run-3.

Parameters
returnValueString to populate with dot graph.
passWhen using a chain filter, if the chain group passed raw.

Navigates all TrigComposite objects in store gate and forms a relational graph in the dot format

Definition at line 4210 of file TrigEDMChecker.cxx.

4210 {
4211
4212 using namespace TrigCompositeUtils;
4213
4214 // This constexpr is evaluated at compile time
4215 const CLID TrigCompositeCLID = static_cast<CLID>( ClassID_traits< xAOD::TrigCompositeContainer >::ID() );
4216 std::vector<std::string> keys;
4217 if ( m_dumpTrigCompositeContainers.size() == 0 ) {
4218 evtStore()->keys(TrigCompositeCLID, keys);
4219 }
4220 else {
4222 }
4223 std::string typeNameTC;
4224 ATH_CHECK(m_clidSvc->getTypeNameOfID(TrigCompositeCLID, typeNameTC));
4225 ATH_MSG_DEBUG("Got " << keys.size() << " keys for " << typeNameTC);
4226
4227 HLT::Identifier chainID(m_dumpNavForChain);
4228 DecisionIDContainer chainIDs;
4229 chainIDs.insert( chainID.numeric() );
4230
4231 std::set<int> converted;
4232
4233 const Trig::ChainGroup* cg = m_trigDec->getChainGroup(m_dumpNavForChain);
4235 std::vector<std::string> chains = cg->getListOfTriggers();
4236 for (const std::string& chain : chains) {
4237 const TrigConf::HLTChain* hltChain = m_trigDec->ExperimentalAndExpertMethods().getChainConfigurationDetails(chain);
4238 const HLT::Identifier chainID_tmp( hltChain->chain_name() );
4239 chainIDs.insert( chainID_tmp.numeric() );
4240 const std::vector<size_t> legMultiplicites = hltChain->leg_multiplicities();
4241 if (legMultiplicites.size() == 0) {
4242 ATH_MSG_ERROR("chain " << chainID_tmp << " has invalid configuration, no multiplicity data.");
4243 } else if (legMultiplicites.size() > 1) {
4244 // For multi-leg chains, the DecisionIDs are handled per leg.
4245 // We don't care here exactly how many objects are required per leg, just that there are two-or-more legs
4246 for (size_t legNumeral = 0; legNumeral < legMultiplicites.size(); ++legNumeral) {
4247 const HLT::Identifier legID = TrigCompositeUtils::createLegName(chainID_tmp, legNumeral);
4248 chainIDs.insert( legID.numeric() );
4249 }
4250 }
4251 }
4252
4253 // First retrieve them all (this should not be needed in future)
4254 const DecisionContainer* container = nullptr;
4255 for (const std::string& key : keys) ATH_CHECK( evtStore()->retrieve( container, key ) );
4256
4257 std::stringstream ss;
4258 ss << "digraph {" << std::endl;
4259 ss << " node [shape=rectangle]" << std::endl;
4260 ss << " rankdir = BT" << std::endl;
4261
4262 // Now process them
4263 for (const std::string& key : keys) {
4264 if ( not m_doDumpAllTrigComposite ) {
4265 if ( not key.starts_with( "HLTNav_") ) { // Nav containers should always start with HLTNav_
4266 continue;
4267 }
4268 }
4269 ATH_CHECK( evtStore()->retrieve( container, key ) );
4270 ATH_MSG_DEBUG("Processing collection " << key << " to be added to the navigation graph");
4271 // ss << " rank=same" << std::endl; // dot cannot handle this is seems
4272 bool writtenHeader = false;
4273 for (const Decision* tc : *container ) {
4274 // Output my ID in the graph.
4275 const DecisionContainer* container = dynamic_cast<const DecisionContainer*>( tc->container() );
4276 const ElementLink<DecisionContainer> selfEL = ElementLink<DecisionContainer>(*container, tc->index());
4277 std::vector<ElementLink<DecisionContainer>> seedELs = tc->objectCollectionLinks<DecisionContainer>("seed");
4278 const bool isHypoAlgNode = tc->name() == "H";
4279 const bool isComboHypoAlgNode = tc->name() == "CH";
4280 const std::vector<DecisionID>& decisions = tc->decisions();
4281 const uint32_t selfKey = selfEL.key();
4282 const uint32_t selfIndex = selfEL.index();
4283 if (m_dumpNavForChain != "") {
4284 bool doDump = false;
4285 // Check me
4286 for (DecisionID id : decisions) {
4287 if (chainIDs.count(id) == 1) {
4288 doDump = true;
4289 break;
4290 }
4291 }
4292 // Check my seeds
4293 if (!doDump and (isHypoAlgNode or isComboHypoAlgNode) and not m_excludeFailedHypoNodes) {
4294 for (const ElementLink<DecisionContainer>& s : seedELs) {
4295 const std::vector<DecisionID>& seedDecisions = (*s)->decisions();
4296 for (DecisionID id : seedDecisions) {
4297 if (chainIDs.count(id) == 1) {
4298 doDump = true;
4299 break;
4300 }
4301 }
4302 }
4303 }
4304 if (!doDump) {
4305 continue;
4306 }
4307 }
4308 if (!writtenHeader) {
4309 writtenHeader = true;
4310 ss << " subgraph " << key << " {" << std::endl;
4311 ss << " label=\"" << key << "\"" << std::endl;
4312 }
4313 const std::string scheme = "rdpu9";
4314 std::string color = "1";
4315 if (tc->name() == "L1") { color = "1"; }
4316 else if (tc->name() == "F") { color = "2"; }
4317 else if (tc->name() == "IM") { color = "3"; }
4318 else if (tc->name() == "H") { color = "4"; }
4319 else if (tc->name() == "CH") { color = "5"; }
4320 else if (tc->name() == "SF") { color = "6"; }
4321 else if (tc->name() == "HLTPassRaw") { color = "7"; }
4322 ss << " \"" << selfKey << "_" << selfIndex << "\" [colorscheme="<<scheme<<",style=filled,fillcolor="<<color<<",label=<<B>Container</B>=" << typeNameTC;
4323 if (tc->name() != "") ss << " <B>Name</B>=" << tc->name();
4324 ss << "<BR/><B>Key</B>=" << key << "<BR/><B>Index</B>=" << selfIndex;
4325 const bool isRemapped = tc->isRemapped();
4326 if (isHypoAlgNode) ss << " <B>linksRemapped</B>=" << (isRemapped ? "Y" : "N");
4327 if (decisions.size() > 0) {
4328 ss << "<BR/><B>Pass</B>=";
4329 size_t c = 0;
4330 for (unsigned decisionID : decisions) {
4331 HLT::Identifier dID(decisionID);
4332 std::string highlight = (dID.numeric() == chainID.numeric() ? "<B>[CHAIN:" : "");
4333 if (highlight == "" and chainIDs.count(dID.numeric()) == 1 and TrigCompositeUtils::isLegId(dID)) {
4334 highlight = "<B>[LEG" + std::to_string(TrigCompositeUtils::getIndexFromLeg(dID)) + ":";
4335 }
4336 ss << std::hex << highlight << decisionID << (!highlight.empty() ? "]</B>" : "") << std::dec << ",";
4337 if (c++ == 5) {
4338 ss << "<BR/>";
4339 c = 0;
4340 }
4341 }
4342 }
4343 ss << ">]" << std::endl;
4344 // Output all the things I link to
4345 size_t seedCount = 0;
4346 for (size_t i = 0; i < tc->linkColNames().size(); ++i) {
4347 const std::string link = tc->linkColNames().at(i);
4348 if (link == "seed" || link == "seed__COLL") {
4349 ElementLink<DecisionContainer> seedEL = seedELs.at(seedCount++);
4350 const uint32_t seedKey = tc->linkColKeys().at(i);
4351 const uint32_t seedIndex = tc->linkColIndices().at(i);
4352 ATH_CHECK( seedKey == seedEL.key() );
4353 ATH_CHECK( seedIndex == seedEL.index() );
4354 if (m_dumpNavForChain != "") { // Only print "seed" link to nodes we include in our search
4355 const std::vector<DecisionID> seedDecisions = (*seedEL)->decisions();
4356 bool doSeedLink = false;
4357 for (DecisionID id : seedDecisions) {
4358 if (chainIDs.count(id) == 1) {
4359 doSeedLink = true;
4360 break;
4361 }
4362 }
4363 if (!doSeedLink) {
4364 continue;
4365 }
4366 }
4367 ss << " \"" << selfKey << "_" << selfIndex << "\" -> \"" << seedKey << "_" << seedIndex << "\" [colorscheme="<<scheme<<",color=9,fontcolor=8,label=\"seed\"]" << std::endl;
4368 } else {
4369 // Start with my class ID
4370 std::string linkColour = "12";
4371 std::string linkBackground = "11";
4372 const std::string extScheme = "paired12";
4373 if (link == "roi") { linkColour="2"; linkBackground="1"; }
4374 else if (link == "initialRoI") { linkColour="2"; linkBackground="1"; }
4375 else if (link == "initialRecRoI") { linkColour="8"; linkBackground="7"; }
4376 else if (link == "feature") { linkColour="4"; linkBackground="3"; }
4377 else if (link == "view") { linkColour="10"; linkBackground="9"; }
4378 const CLID linkCLID = static_cast<CLID>( tc->linkColClids().at(i) );
4379 // Use it to get my class name
4380 std::string tname;
4381 ATH_CHECK(m_clidSvc->getTypeNameOfID(linkCLID, tname));
4382 // Now get the sgkey I'm linking to & the index
4383 const SG::sgkey_t key = (isRemapped ? static_cast<SG::sgkey_t>( tc->linkColKeysRemap().at(i) ) : static_cast<SG::sgkey_t>( tc->linkColKeys().at(i) ));
4384 const unsigned index = (isRemapped ? tc->linkColIndicesRemap().at(i) : tc->linkColIndices().at(i));
4385 // Look it up
4386 CLID checkCLID;
4387 const std::string* keyStr = evtStore()->keyToString(key, checkCLID); // I don't own this str
4388 if (keyStr != nullptr && checkCLID != linkCLID) {
4389 std::string tnameOfCheck;
4390 m_clidSvc->getTypeNameOfID(checkCLID, tnameOfCheck).ignore(); // Might be invalid. But we don't care.
4391 ATH_MSG_ERROR("Inconsistent CLID " << checkCLID << " [" << tnameOfCheck << "] stored in storegate for key " << key
4392 << ". We were expecting " << linkCLID << " [" << tname << "]");
4393 }
4394
4395 std::string tnameEscape;
4396 for (std::string::const_iterator i = tname.begin(); i != tname.end(); ++i) {
4397 unsigned char c = *i;
4398 if (c == '<') {
4399 tnameEscape += "&lt;";
4400 } else if (c == '>') {
4401 tnameEscape += "&gt;";
4402 } else {
4403 tnameEscape += c;
4404 }
4405 }
4406
4407 // Print
4408 ss << " \"" << selfKey << "_" << selfIndex << "\" -> \"" << key << "_" << index << "\" ";
4409 ss << "[colorscheme="<<extScheme<<",color="<<linkColour<<",fontcolor="<<linkColour<<",arrowhead=empty,label=\"" << link << "\"]" << std::endl;
4410
4411 // Check if we are linking to self (e.g. a dummy-feature), don't output a new box for this
4412 const bool linkToSelf = (selfKey == key and selfIndex == index);
4413
4414 if (converted.count(key + index) == 0 and not linkToSelf) {
4415 ss << " \"" << key << "_" << index << "\" [colorscheme="<<extScheme<<",style=filled,fillcolor="<<linkBackground<<",label=<<B>Container</B>=" << tnameEscape << "<BR/><B>Key</B>=";
4416 if (keyStr != nullptr) ss << *keyStr;
4417 else ss << "[<I>KEY "<< key <<" NOT IN STORE</I>] ";
4418 ss << "<BR/><B>Index</B>=" << index << ">]";
4419 }
4420
4421 converted.insert(key + index);
4422 }
4423 }
4424 }
4425 if (writtenHeader) {
4426 ss << " }" << std::endl;
4427 }
4428 }
4429
4430 ss << "}" << std::endl;
4431
4432 returnValue.assign( ss.str() );
4433 return StatusCode::SUCCESS;
4434}
static Double_t ss
unsigned int DecisionID
std::set< DecisionID > DecisionIDContainer
xAOD::TrigCompositeContainer DecisionContainer
TrigCompositeUtils::DecisionID numeric() const
numeric ID
const std::vector< size_t > & leg_multiplicities() const
Gaudi::Property< bool > m_excludeFailedHypoNodes
bool isPassed(unsigned int condition=TrigDefs::Physics) const
tells if chain group passed
std::vector< std::string > getListOfTriggers() const
uint32_t sgkey_t
Type used for hashed StoreGate key+CLID pairs.
Definition sgkey_t.h:32
pointer & link(pointer p) const
Return a reference to the link for an element.
const SG::AuxVectorData * container() const
Return the container holding this element.
HLT::Identifier createLegName(const HLT::Identifier &chainIdentifier, size_t counter)
Generate the HLT::Identifier which corresponds to a specific leg of a given chain.
int32_t getIndexFromLeg(const HLT::Identifier &legIdentifier)
Extract the numeric index of a leg identifier.
bool isLegId(const HLT::Identifier &legIdentifier)
Recognise whether the chain ID is a leg ID.
setEventNumber uint32_t

◆ updateEvtStore()

void AthAnalysisAlgorithm::updateEvtStore ( Gaudi::Details::PropertyBase & prop)
protectedinherited

Definition at line 45 of file AthAnalysisAlgorithm.cxx.

45 {
46 evtStore().release().ignore();
47 evtStore().setTypeAndName(prop.toString());
48}

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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 }

Member Data Documentation

◆ m_clidSvc

ServiceHandle< ::IClassIDSvc > TrigEDMChecker::m_clidSvc
private

Definition at line 216 of file TrigEDMChecker.h.

◆ m_currentFile

TFile* AthAnalysisAlgorithm::m_currentFile {nullptr}
privateinherited

Definition at line 120 of file AthAnalysisAlgorithm.h.

120{nullptr}; //used to cache the current file

◆ m_decisionsKey

SG::WriteHandleKey<TrigCompositeUtils::DecisionContainer> TrigEDMChecker::m_decisionsKey { this, "Decisions", "RoIDecisions", "Decisions created from TEs" }
private

Definition at line 220 of file TrigEDMChecker.h.

220{ this, "Decisions", "RoIDecisions", "Decisions created from TEs" };

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default).

Definition at line 393 of file AthCommonDataStore.h.

◆ m_doDumpAll

bool TrigEDMChecker::m_doDumpAll
private

a handle on Store Gate for access to the Event Store

Definition at line 48 of file TrigEDMChecker.h.

◆ m_doDumpAllTrigComposite

bool TrigEDMChecker::m_doDumpAllTrigComposite
private

Definition at line 180 of file TrigEDMChecker.h.

◆ m_doDumpCombinedMuonFeature

bool TrigEDMChecker::m_doDumpCombinedMuonFeature
private

Definition at line 95 of file TrigEDMChecker.h.

◆ m_doDumpHLTResult

bool TrigEDMChecker::m_doDumpHLTResult
private

Definition at line 146 of file TrigEDMChecker.h.

◆ m_doDumpLVL1_ROI

bool TrigEDMChecker::m_doDumpLVL1_ROI
private

Definition at line 52 of file TrigEDMChecker.h.

◆ m_doDumpMuonFeature

bool TrigEDMChecker::m_doDumpMuonFeature
private

Definition at line 99 of file TrigEDMChecker.h.

◆ m_doDumpNavigation

bool TrigEDMChecker::m_doDumpNavigation
private

Definition at line 183 of file TrigEDMChecker.h.

◆ m_doDumpStoreGate

bool TrigEDMChecker::m_doDumpStoreGate
private

Definition at line 167 of file TrigEDMChecker.h.

◆ m_doDumpTauJetContainer

bool TrigEDMChecker::m_doDumpTauJetContainer
private

Definition at line 158 of file TrigEDMChecker.h.

◆ m_doDumpTileMuFeature

bool TrigEDMChecker::m_doDumpTileMuFeature
private

Definition at line 102 of file TrigEDMChecker.h.

◆ m_doDumpTileTrackMuFeature

bool TrigEDMChecker::m_doDumpTileTrackMuFeature
private

Definition at line 105 of file TrigEDMChecker.h.

◆ m_doDumpTrackParticleContainer

bool TrigEDMChecker::m_doDumpTrackParticleContainer
private

Definition at line 55 of file TrigEDMChecker.h.

◆ m_doDumpTrigCompsiteNavigation

bool TrigEDMChecker::m_doDumpTrigCompsiteNavigation
private

Definition at line 203 of file TrigEDMChecker.h.

◆ m_doDumpTrigEFBjetContainer

bool TrigEDMChecker::m_doDumpTrigEFBjetContainer
private

Definition at line 73 of file TrigEDMChecker.h.

◆ m_doDumpTrigEFBphysContainer

bool TrigEDMChecker::m_doDumpTrigEFBphysContainer
private

Definition at line 70 of file TrigEDMChecker.h.

◆ m_doDumpTrigElectronContainer

bool TrigEDMChecker::m_doDumpTrigElectronContainer
private

Definition at line 125 of file TrigEDMChecker.h.

◆ m_doDumpTrigEMCluster

bool TrigEDMChecker::m_doDumpTrigEMCluster
private

Definition at line 82 of file TrigEDMChecker.h.

◆ m_doDumpTrigEMClusterContainer

bool TrigEDMChecker::m_doDumpTrigEMClusterContainer
private

Definition at line 85 of file TrigEDMChecker.h.

◆ m_doDumpTrigInDetTrackCollection

bool TrigEDMChecker::m_doDumpTrigInDetTrackCollection
private

Definition at line 149 of file TrigEDMChecker.h.

◆ m_doDumpTrigL2BjetContainer

bool TrigEDMChecker::m_doDumpTrigL2BjetContainer
private

Definition at line 76 of file TrigEDMChecker.h.

◆ m_doDumpTrigL2BphysContainer

bool TrigEDMChecker::m_doDumpTrigL2BphysContainer
private

Definition at line 67 of file TrigEDMChecker.h.

◆ m_doDumpTrigMissingET

bool TrigEDMChecker::m_doDumpTrigMissingET
private

Definition at line 58 of file TrigEDMChecker.h.

◆ m_doDumpTrigMuonEFContainer

bool TrigEDMChecker::m_doDumpTrigMuonEFContainer
private

Definition at line 111 of file TrigEDMChecker.h.

◆ m_doDumpTrigMuonEFInfoContainer

bool TrigEDMChecker::m_doDumpTrigMuonEFInfoContainer
private

Definition at line 114 of file TrigEDMChecker.h.

◆ m_doDumpTrigMuonEFIsolationContainer

bool TrigEDMChecker::m_doDumpTrigMuonEFIsolationContainer
private

Definition at line 122 of file TrigEDMChecker.h.

◆ m_doDumpTrigPassBits

bool TrigEDMChecker::m_doDumpTrigPassBits
private

Definition at line 50 of file TrigEDMChecker.h.

◆ m_doDumpTrigPhotonContainer

bool TrigEDMChecker::m_doDumpTrigPhotonContainer
private

Definition at line 108 of file TrigEDMChecker.h.

◆ m_doDumpTrigTauClusterContainer

bool TrigEDMChecker::m_doDumpTrigTauClusterContainer
private

Definition at line 79 of file TrigEDMChecker.h.

◆ m_doDumpTrigTauContainer

bool TrigEDMChecker::m_doDumpTrigTauContainer
private

Definition at line 140 of file TrigEDMChecker.h.

◆ m_doDumpTrigTauTracksInfo

bool TrigEDMChecker::m_doDumpTrigTauTracksInfo
private

Definition at line 143 of file TrigEDMChecker.h.

◆ m_doDumpTrigVertexCollection

bool TrigEDMChecker::m_doDumpTrigVertexCollection
private

Definition at line 152 of file TrigEDMChecker.h.

◆ m_doDumpxAODElectronContainer

bool TrigEDMChecker::m_doDumpxAODElectronContainer
private

Definition at line 134 of file TrigEDMChecker.h.

◆ m_doDumpxAODJetContainer

bool TrigEDMChecker::m_doDumpxAODJetContainer
private

Definition at line 64 of file TrigEDMChecker.h.

◆ m_doDumpxAODMuonContainer

bool TrigEDMChecker::m_doDumpxAODMuonContainer
private

Definition at line 119 of file TrigEDMChecker.h.

◆ m_doDumpxAODPhotonContainer

bool TrigEDMChecker::m_doDumpxAODPhotonContainer
private

Definition at line 137 of file TrigEDMChecker.h.

◆ m_doDumpxAODTauJetContainer

bool TrigEDMChecker::m_doDumpxAODTauJetContainer
private

Definition at line 155 of file TrigEDMChecker.h.

◆ m_doDumpxAODTrackParticle

bool TrigEDMChecker::m_doDumpxAODTrackParticle
private

Definition at line 161 of file TrigEDMChecker.h.

◆ m_doDumpxAODTrigElectronContainer

bool TrigEDMChecker::m_doDumpxAODTrigElectronContainer
private

Definition at line 128 of file TrigEDMChecker.h.

◆ m_doDumpxAODTrigEMCluster

bool TrigEDMChecker::m_doDumpxAODTrigEMCluster
private

Definition at line 89 of file TrigEDMChecker.h.

◆ m_doDumpxAODTrigEMClusterContainer

bool TrigEDMChecker::m_doDumpxAODTrigEMClusterContainer
private

Definition at line 92 of file TrigEDMChecker.h.

◆ m_doDumpxAODTrigMinBias

bool TrigEDMChecker::m_doDumpxAODTrigMinBias
private

Definition at line 173 of file TrigEDMChecker.h.

◆ m_doDumpxAODTrigMissingET

bool TrigEDMChecker::m_doDumpxAODTrigMissingET
private

Definition at line 61 of file TrigEDMChecker.h.

◆ m_doDumpxAODTrigPhotonContainer

bool TrigEDMChecker::m_doDumpxAODTrigPhotonContainer
private

Definition at line 131 of file TrigEDMChecker.h.

◆ m_doDumpxAODVertex

bool TrigEDMChecker::m_doDumpxAODVertex
private

Definition at line 164 of file TrigEDMChecker.h.

◆ m_doneFirstEvent

bool AthAnalysisAlgorithm::m_doneFirstEvent {false}
privateinherited

Definition at line 122 of file AthAnalysisAlgorithm.h.

122{false};

◆ m_doTDTCheck

bool TrigEDMChecker::m_doTDTCheck
private

Definition at line 170 of file TrigEDMChecker.h.

◆ m_dumpNavForChain

Gaudi::Property<std::string> TrigEDMChecker::m_dumpNavForChain {this, "DumpNavigationForChain", "", "Optional chain to restrict navigation dump info."}
private

Definition at line 185 of file TrigEDMChecker.h.

185{this, "DumpNavigationForChain", "", "Optional chain to restrict navigation dump info."};

◆ m_dumpTrigCompositeContainers

std::vector<std::string> TrigEDMChecker::m_dumpTrigCompositeContainers
private

Definition at line 181 of file TrigEDMChecker.h.

◆ m_effMap

EffMap_t AthHistogramming::m_effMap
privateinherited

The map of histogram names to their pointers.

Definition at line 210 of file AthHistogramming.h.

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default).

Definition at line 390 of file AthCommonDataStore.h.

◆ m_excludeFailedHypoNodes

Gaudi::Property<bool> TrigEDMChecker::m_excludeFailedHypoNodes
private
Initial value:
{this, "excludeFailedHypoNodes", false,
"Optional flag to exclude nodes which fail the hypothesis tool for a chain when dumping navigation graphs."}

Definition at line 186 of file TrigEDMChecker.h.

186 {this, "excludeFailedHypoNodes", false,
187 "Optional flag to exclude nodes which fail the hypothesis tool for a chain when dumping navigation graphs."};

◆ m_extendedExtraObjects

DataObjIDColl AthCommonAlgorithm< Gaudi::Algorithm >::m_extendedExtraObjects
privateinherited

Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.

Empty if no symlinks were found.

Definition at line 108 of file AthCommonAlgorithm.h.

◆ m_graphMap

GraphMap_t AthHistogramming::m_graphMap
privateinherited

The map of TGraph names to their pointers.

Definition at line 224 of file AthHistogramming.h.

◆ m_histMap

HistMap_t AthHistogramming::m_histMap
privateinherited

The map of histogram names to their pointers.

Definition at line 203 of file AthHistogramming.h.

◆ m_histNamePostfix

std::string AthHistogramAlgorithm::m_histNamePostfix
privateinherited

The postfix for the histogram THx name.

Definition at line 97 of file AthHistogramAlgorithm.h.

◆ m_histNamePrefix

std::string AthHistogramAlgorithm::m_histNamePrefix
privateinherited

The prefix for the histogram THx name.

Definition at line 94 of file AthHistogramAlgorithm.h.

◆ m_histSvc

ServiceHandle<ITHistSvc> AthHistogramAlgorithm::m_histSvc
privateinherited

Default constructor: AthHistogramAlgorithm();.

a handle on the Hist/TTree registration service

Definition at line 83 of file AthHistogramAlgorithm.h.

◆ m_histTitlePostfix

std::string AthHistogramAlgorithm::m_histTitlePostfix
privateinherited

The postfix for the histogram THx title.

Definition at line 103 of file AthHistogramAlgorithm.h.

◆ m_histTitlePrefix

std::string AthHistogramAlgorithm::m_histTitlePrefix
privateinherited

The prefix for the histogram THx title.

Definition at line 100 of file AthHistogramAlgorithm.h.

◆ m_inputMetaStore

ServiceHandle< StoreGateSvc > AthAnalysisAlgorithm::m_inputMetaStore
privateinherited

Object accessing the input metadata store.

Definition at line 116 of file AthAnalysisAlgorithm.h.

◆ m_msg

MsgStream AthHistogramming::m_msg
privateinherited

Cached Message Stream.

Definition at line 250 of file AthHistogramming.h.

◆ m_muonPrinter

ToolHandle<Rec::IMuonPrintingTool> TrigEDMChecker::m_muonPrinter {this, "MuonPrinter", "Rec::MuonPrintingTool/MuonPrintingTool"}
private

Definition at line 214 of file TrigEDMChecker.h.

214{this, "MuonPrinter", "Rec::MuonPrintingTool/MuonPrintingTool"};

◆ m_muonTracksKey

SG::ReadHandleKey< xAOD::TrackParticleContainer > TrigEDMChecker::m_muonTracksKey { this, "MuonTracksKey", "HLT_IDTrack_Muon_FTF"}
private

Definition at line 218 of file TrigEDMChecker.h.

218{ this, "MuonTracksKey", "HLT_IDTrack_Muon_FTF"};

◆ m_name

std::string AthHistogramming::m_name
privateinherited

Instance name.

Definition at line 247 of file AthHistogramming.h.

◆ m_navigationHandleKey

SG::ReadHandleKey< xAOD::TrigNavigation > TrigEDMChecker::m_navigationHandleKey { this, "TrigNavigation", "TrigNavigation", "" }
private

Definition at line 219 of file TrigEDMChecker.h.

219{ this, "TrigNavigation", "TrigNavigation", "" };

◆ m_navigationTool

ToolHandle< HLT::Navigation > TrigEDMChecker::m_navigationTool { this, "NavigationTool", "HLT::Navigation/Navigation", "" }
private

Definition at line 221 of file TrigEDMChecker.h.

221{ this, "NavigationTool", "HLT::Navigation/Navigation", "" };

◆ m_outputMetaStore

ServiceHandle< StoreGateSvc > AthAnalysisAlgorithm::m_outputMetaStore
privateinherited

Object accessing the output metadata store.

Definition at line 118 of file AthAnalysisAlgorithm.h.

◆ m_prefix

std::string AthHistogramAlgorithm::m_prefix
privateinherited

Name of the ROOT output stream (file).

Definition at line 88 of file AthHistogramAlgorithm.h.

◆ m_rootDir

std::string AthHistogramAlgorithm::m_rootDir
privateinherited

Name of the ROOT directory.

Definition at line 91 of file AthHistogramAlgorithm.h.

◆ m_streamName

std::string AthHistogramming::m_streamName
privateinherited

Name of the ROOT output stream (file).

Definition at line 228 of file AthHistogramming.h.

◆ m_trackWarningNum

int TrigEDMChecker::m_trackWarningNum {0}
private

Definition at line 224 of file TrigEDMChecker.h.

224{0};

◆ m_treeMap

TreeMap_t AthHistogramming::m_treeMap
privateinherited

The map of TTree names to their pointers.

Definition at line 217 of file AthHistogramming.h.

◆ m_trigDec

PublicToolHandle< Trig::TrigDecisionTool > TrigEDMChecker::m_trigDec { this, "TriggerDecisionTool", "Trig::TrigDecisionTool/TrigDecisionTool", ""}
private

Definition at line 222 of file TrigEDMChecker.h.

222{ this, "TriggerDecisionTool", "Trig::TrigDecisionTool/TrigDecisionTool", ""};

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vertexWarningNum

int TrigEDMChecker::m_vertexWarningNum {0}
private

Definition at line 225 of file TrigEDMChecker.h.

225{0};

◆ m_vhka

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

Definition at line 398 of file AthCommonDataStore.h.


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