![]() |
ATLAS Offline Software
|
The last step of the electron and photon reconstruction algorithm. More...
#include <xAODEgammaBuilder.h>
Public Member Functions | |
| xAODEgammaBuilder (const std::string &name, ISvcLocator *pSvcLocator) | |
| StatusCode | initialize () override final |
| StatusCode | finalize () override final |
| StatusCode | execute (const EventContext &ctx) const override final |
| virtual StatusCode | sysInitialize () override |
| Override sysInitialize. | |
| virtual bool | isClonable () const override |
| Specify if the algorithm is clonable. | |
| virtual unsigned int | cardinality () const override |
| Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant. | |
| virtual StatusCode | sysExecute (const EventContext &ctx) override |
| Execute an algorithm. | |
| virtual const DataObjIDColl & | extraOutputDeps () const override |
| Return the list of extra output dependencies. | |
| virtual bool | filterPassed (const EventContext &ctx) const |
| virtual void | setFilterPassed (bool state, const EventContext &ctx) const |
| 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 |
Protected Member Functions | |
| 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. | |
Private Types | |
| typedef ServiceHandle< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
| bool | getElectron (const egammaRec *egRec, xAOD::ElectronContainer *electronContainer, const unsigned int author, const uint8_t type) const |
| Given an egammaRec object, a pointer to the electron container and the author, create and dress an electron, pushing it back to the container and calling the relevant tools. | |
| bool | getPhoton (const egammaRec *egRec, xAOD::PhotonContainer *photonContainer, const unsigned int author, uint8_t type) const |
| Given an egammaRec object, a pointer to the photon container and the author, create and dress a photon, pushing it back to the container and calling the relevant tools. | |
| template<typename T> | |
| StatusCode | CallTool (const EventContext &ctx, const ToolHandle< IegammaBaseTool > &tool, DataVector< T > *container) const |
| Call a tool using contExecute and an electron or photon container. | |
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &) |
| specialization for handling Gaudi::Property<SG::VarHandleKey> | |
Private Attributes | |
| ToolHandleArray< IegammaBaseTool > | m_electronTools |
| Vector of tools for dressing ONLY electrons. | |
| ToolHandleArray< IegammaBaseTool > | m_photonTools |
| Vector of tools for dressing ONLY photons. | |
| ToolHandle< IEMClusterTool > | m_clusterTool |
| Tool to do the final electron/photon cluster building. | |
| ToolHandle< IEMShowerBuilder > | m_ShowerTool |
| Tool to compute shower shapes. | |
| ToolHandle< IEGammaAmbiguityTool > | m_ambiguityTool |
| Tool to resolve electron/photon ambiguity. | |
| ToolHandle< IegammaOQFlagsBuilder > | m_egammaOQTool |
| Tool to add electron/photon Object Quality info. | |
| SG::WriteHandleKey< xAOD::ElectronContainer > | m_electronOutputKey |
| Name of the electron output collection. | |
| SG::WriteHandleKey< xAOD::PhotonContainer > | m_photonOutputKey |
| Name of the photon output collection. | |
| SG::ReadHandleKey< EgammaRecContainer > | m_electronClusterRecContainerKey |
| Name of input super cluster electron egammaRec container. | |
| SG::ReadHandleKey< EgammaRecContainer > | m_photonClusterRecContainerKey |
| Name of input super cluster photon egammaRec container. | |
| SG::ReadCondHandleKey< CaloDetDescrManager > | m_caloDetDescrMgrKey |
| SG::WriteHandleKey< xAOD::ElectronContainer > | m_dummyElectronOutputKey |
| Name of the dummy electron output collection. | |
| Gaudi::Property< bool > | m_isTruth {this, "isTruth", false, "is truth"} |
| Option to do truth. | |
| Gaudi::Property< bool > | m_doPhotons {this, "doPhotons", true, "Run the Photon reconstruction"} |
| Gaudi::Property< bool > | m_doElectrons {this, "doElectrons", true, "Run the Electron reconstruction"} |
| std::unique_ptr< electronPearShapeAlignmentCorrection > | m_deltaEta1Pear |
| bool | m_doAmbiguity {} |
| bool | m_doOQ {} |
| bool | m_doDummyElectrons = false |
| 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 |
The last step of the electron and photon reconstruction algorithm.
The algorithm builds physics objects (xAOD::Electron, xAOD::Photon) from the egammaRec containers built by the previous algorithms. In the step of the chain electron and photon reconstruction are merged again and the ambiguity resolution is applied.
Input collections:
Output collections:
If the algorithm runs on both electrons and photons, which is the default (see doPhotons and doElectrons properties), the ambiguity resolution is applied. If there are two egammaRec, one coming from the electron input container, one coming from the photon input container, with the same eta and phi of the hottest cells then the ambiguity tool decides if to save only one or both. The author and the ambiguityType are set accordingly to that decision. If both particles are saved a link between them is saved (ambiguityLink). All the properties of electrons are set:
All the properties of photons are set:
Several tools are then applied to the particle:
Definition at line 87 of file xAODEgammaBuilder.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
| xAODEgammaBuilder::xAODEgammaBuilder | ( | const std::string & | name, |
| ISvcLocator * | pSvcLocator ) |
Definition at line 32 of file xAODEgammaBuilder.cxx.
|
private |
Call a tool using contExecute and an electron or photon container.
Definition at line 278 of file xAODEgammaBuilder.cxx.
|
overridevirtualinherited |
Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant.
Override this to return 0 for reentrant algorithms.
Definition at line 75 of file AthCommonReentrantAlgorithm.cxx.
|
inlineprivateinherited |
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
|
inlineinherited |
Definition at line 145 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
Definition at line 95 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
Definition at line 85 of file AthCommonDataStore.h.
|
finaloverride |
Definition at line 84 of file xAODEgammaBuilder.cxx.
|
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
|
overridevirtualinherited |
Return the list of extra output dependencies.
This list is extended to include symlinks implied by inheritance relations.
Definition at line 94 of file AthCommonReentrantAlgorithm.cxx.
|
inlinevirtualinherited |
Definition at line 96 of file AthCommonReentrantAlgorithm.h.
|
finaloverride |
Definition at line 78 of file xAODEgammaBuilder.cxx.
|
private |
Given an egammaRec object, a pointer to the electron container and the author, create and dress an electron, pushing it back to the container and calling the relevant tools.
Definition at line 293 of file xAODEgammaBuilder.cxx.
|
private |
Given an egammaRec object, a pointer to the photon container and the author, create and dress a photon, pushing it back to the container and calling the relevant tools.
Definition at line 333 of file xAODEgammaBuilder.cxx.
|
finaloverride |
Definition at line 38 of file xAODEgammaBuilder.cxx.
|
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.
|
overridevirtualinherited |
Specify if the algorithm is clonable.
Reentrant algorithms are clonable.
Reimplemented in InDet::GNNSeedingTrackMaker, InDet::SCT_Clusterization, InDet::SiSPGNNTrackMaker, InDet::SiSPSeededTrackFinder, InDet::SiTrackerSpacePointFinder, ITkPixelCablingAlg, ITkStripCablingAlg, RoIBResultToxAOD, SCT_ByteStreamErrorsTestAlg, SCT_CablingCondAlgFromCoraCool, SCT_CablingCondAlgFromText, SCT_ConditionsParameterTestAlg, SCT_ConditionsSummaryTestAlg, SCT_ConfigurationConditionsTestAlg, 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, and Simulation::BeamEffectsAlg.
Definition at line 68 of file AthCommonReentrantAlgorithm.cxx.
|
inlineinherited |
Definition at line 24 of file AthCommonMsg.h.
|
inlineinherited |
Definition at line 30 of file AthCommonMsg.h.
|
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.
|
inlineprotectedinherited |
Definition at line 380 of file AthCommonDataStore.h.
|
inlineprotectedinherited |
remove all handles from I/O resolution
Definition at line 364 of file AthCommonDataStore.h.
|
inlinevirtualinherited |
Definition at line 100 of file AthCommonReentrantAlgorithm.h.
|
overridevirtualinherited |
Execute an algorithm.
We override this in order to work around an issue with the Algorithm base class storing the event context in a member variable that can cause crashes in MT jobs.
Definition at line 85 of file AthCommonReentrantAlgorithm.cxx.
|
overridevirtualinherited |
Override sysInitialize.
Override sysInitialize from the base class.
Loop through all output handles, and if they're WriteCondHandles, automatically register them and this Algorithm with the CondSvc
Scan through all outputHandles, and if they're WriteCondHandles, register them with the CondSvc
Reimplemented from AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >.
Reimplemented in HypoBase, and InputMakerBase.
Definition at line 61 of file AthCommonReentrantAlgorithm.cxx.
|
overridevirtualinherited |
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
|
inlineinherited |
Definition at line 308 of file AthCommonDataStore.h.
|
private |
Tool to resolve electron/photon ambiguity.
Definition at line 135 of file xAODEgammaBuilder.h.
|
private |
Definition at line 168 of file xAODEgammaBuilder.h.
|
private |
Tool to do the final electron/photon cluster building.
Definition at line 125 of file xAODEgammaBuilder.h.
|
private |
Definition at line 186 of file xAODEgammaBuilder.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
private |
Definition at line 187 of file xAODEgammaBuilder.h.
|
private |
Definition at line 189 of file xAODEgammaBuilder.h.
|
private |
Definition at line 185 of file xAODEgammaBuilder.h.
|
private |
Definition at line 188 of file xAODEgammaBuilder.h.
|
private |
Definition at line 184 of file xAODEgammaBuilder.h.
|
private |
Name of the dummy electron output collection.
Definition at line 176 of file xAODEgammaBuilder.h.
|
private |
Tool to add electron/photon Object Quality info.
Definition at line 140 of file xAODEgammaBuilder.h.
|
private |
Name of input super cluster electron egammaRec container.
Definition at line 157 of file xAODEgammaBuilder.h.
|
private |
Name of the electron output collection.
Definition at line 147 of file xAODEgammaBuilder.h.
|
private |
Vector of tools for dressing ONLY electrons.
Definition at line 117 of file xAODEgammaBuilder.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
privateinherited |
Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.
Empty if no symlinks were found.
Definition at line 114 of file AthCommonReentrantAlgorithm.h.
|
private |
Option to do truth.
Definition at line 183 of file xAODEgammaBuilder.h.
|
private |
Name of input super cluster photon egammaRec container.
Definition at line 163 of file xAODEgammaBuilder.h.
|
private |
Name of the photon output collection.
Definition at line 152 of file xAODEgammaBuilder.h.
|
private |
Vector of tools for dressing ONLY photons.
Definition at line 121 of file xAODEgammaBuilder.h.
|
private |
Tool to compute shower shapes.
Definition at line 130 of file xAODEgammaBuilder.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.