![]() |
ATLAS Offline Software
|
#include <FourLeptonVertexingAlgorithm.h>
Public Types | |
| using | LeptonQuadruplet = std::array<const xAOD::IParticle*, 4> |
Public Member Functions | |
| FourLeptonVertexingAlgorithm (const std::string &n, ISvcLocator *p) | |
| StatusCode | initialize () override |
| StatusCode | execute (const EventContext &ctx) const override |
| StatusCode | finalize () override |
| 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 | |
| using | MuonTrk = xAOD::Muon::TrackParticleType |
| typedef ServiceHandle< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
| bool | passSelection (const xAOD::Electron *elec) const |
| bool | passSelection (const xAOD::Muon *muon) const |
| bool | passSelection (const LeptonQuadruplet &quad) const |
| std::vector< LeptonQuadruplet > | buildAllQuadruplets (const EventContext &ctx) const |
| std::unique_ptr< xAOD::Vertex > | fitQuadruplet (const EventContext &ctx, const LeptonQuadruplet &quad) const |
| const xAOD::TrackParticle * | trackParticle (const xAOD::IParticle *part) const |
| int | charge (const xAOD::IParticle *part) const |
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &) |
| specialization for handling Gaudi::Property<SG::VarHandleKey> | |
Private Attributes | |
| SG::ReadHandleKey< xAOD::MuonContainer > | m_muonKey |
| Input containers. | |
| SG::ReadHandleKey< xAOD::ElectronContainer > | m_elecKey |
| SG::ReadHandleKey< xAOD::EventInfo > | m_evtKey {this, "EventInfoKey", "EventInfo"} |
| ToolHandle< CP::IMuonSelectionTool > | m_muonSelTool |
| ToolHandle< IAsgElectronLikelihoodTool > | m_elecSelTool |
| ToolHandle< Trk::IVertexFitter > | m_fitter {this, "VertexFitter", "", "Vertex fitter tool"} |
| Gaudi::Property< float > | m_minMuonPt |
| Gaudi::Property< float > | m_minElecPt {this, "MinElecPt", 4.5 * Gaudi::Units::GeV, " Minimum pt cut applied on the electron"} |
| Gaudi::Property< int > | m_muonTrkProp |
| MuonTrk | m_muonTrk {MuonTrk::Primary} |
| Gaudi::Property< bool > | m_elecUseGSF |
| Gaudi::Property< float > | m_z0Cut |
| Gaudi::Property< float > | m_lowSFOS_Cut {this, "LowSFOSMass", 3.5 * Gaudi::Units::GeV, "Minimal mass for the lower SFOS pair"} |
| Gaudi::Property< float > | m_highPair_Cut {this, "HighMassPair", 40.*Gaudi::Units::GeV, "Minimum mass for the largest lepton pair"} |
| Gaudi::Property< float > | m_LeadPtCut {this, "LeadingLeptonPt", 15. *Gaudi::Units::GeV,"Minimal momentum of the leading lepton in the quad "} |
| Gaudi::Property< float > | m_SubLeadPtCut {this, "SubLeadingLeptonPt", 10. *Gaudi::Units::GeV,"Minimal momentum of the leading lepton in the quad "} |
| Gaudi::Property< float > | m_VtxChi2Cut {this, "VertexChi2Cut", 20, "Maximal chii n.D.o.F cut on the reconstructed vertex" } |
| SG::WriteHandleKey< xAOD::VertexContainer > | m_vtxKey {this, "OutVertexContainer", "FourLeptonVertices", "Output vertex container"} |
| Gaudi::Property< bool > | m_pruneCov {this, "PruneCovariance", true, "Clears the covariance vector"} |
| Gaudi::Property< bool > | m_pruneWeight {this, "PruneTrackWeights", true, "Clears the track weight vector"} |
| std::array< std::atomic< unsigned int >, 8 > m_num_lep | ATLAS_THREAD_SAFE {} |
| Simple counter to evaluate the number of leptons per event. | |
| std::array< std::atomic< unsigned int >, 8 > m_num_ele | ATLAS_THREAD_SAFE {} |
| std::array< std::atomic< unsigned int >, 8 > m_num_muo | ATLAS_THREAD_SAFE {} |
| std::atomic< unsigned int > | m_tried_fits {0} |
| How many vertex fits were attempted. | |
| std::atomic< unsigned int > | m_good_fits {0} |
| How many vertex fits were actually successful. | |
| 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 |
Definition at line 26 of file FourLeptonVertexingAlgorithm.h.
| using DerivationFramework::FourLeptonVertexingAlgorithm::LeptonQuadruplet = std::array<const xAOD::IParticle*, 4> |
Definition at line 33 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 65 of file FourLeptonVertexingAlgorithm.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
| DerivationFramework::FourLeptonVertexingAlgorithm::FourLeptonVertexingAlgorithm | ( | const std::string & | n, |
| ISvcLocator * | p ) |
Definition at line 43 of file FourLeptonVertexingAlgorithm.cxx.
|
private |
Retrieve the container from the store gate
Dump the leptons in a common vector to build all possible quadruplets
Increment the lepton counter
None of the leptons has enough momentum to be selected in the offline analysis
The leading lepton has too little momentum. All subsequent combinations will have even less. Bail out of the loop
Definition at line 95 of file FourLeptonVertexingAlgorithm.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.
|
private |
Definition at line 176 of file FourLeptonVertexingAlgorithm.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.
|
override |
Setup the output container
Definition at line 74 of file FourLeptonVertexingAlgorithm.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.
|
override |
Definition at line 62 of file FourLeptonVertexingAlgorithm.cxx.
|
private |
Use the beam spot as an initial constraint
Definition at line 181 of file FourLeptonVertexingAlgorithm.cxx.
|
override |
Definition at line 45 of file FourLeptonVertexingAlgorithm.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.
|
private |
Check the di lepton masses in the quad
If the pair is SFOS check the mass
The high mass pair must at least satisfy a certain threshold
Definition at line 221 of file FourLeptonVertexingAlgorithm.cxx.
|
private |
Definition at line 88 of file FourLeptonVertexingAlgorithm.cxx.
|
private |
Definition at line 92 of file FourLeptonVertexingAlgorithm.cxx.
|
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.
|
private |
Definition at line 169 of file FourLeptonVertexingAlgorithm.cxx.
|
inlineinherited |
Definition at line 308 of file AthCommonDataStore.h.
|
mutableprivate |
Simple counter to evaluate the number of leptons per event.
Definition at line 91 of file FourLeptonVertexingAlgorithm.h.
|
mutableprivate |
Definition at line 92 of file FourLeptonVertexingAlgorithm.h.
|
mutableprivate |
Definition at line 93 of file FourLeptonVertexingAlgorithm.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
private |
Definition at line 50 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 56 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 70 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 52 of file FourLeptonVertexingAlgorithm.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 |
Definition at line 59 of file FourLeptonVertexingAlgorithm.h.
|
mutableprivate |
How many vertex fits were actually successful.
Definition at line 98 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 78 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 80 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 77 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 63 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 61 of file FourLeptonVertexingAlgorithm.h.
|
private |
Input containers.
Definition at line 48 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 54 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 68 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 66 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 87 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 88 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 81 of file FourLeptonVertexingAlgorithm.h.
|
mutableprivate |
How many vertex fits were attempted.
Definition at line 96 of file FourLeptonVertexingAlgorithm.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.
|
private |
Definition at line 83 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 86 of file FourLeptonVertexingAlgorithm.h.
|
private |
Definition at line 73 of file FourLeptonVertexingAlgorithm.h.