ATLAS Offline Software
Loading...
Searching...
No Matches
DerivationFramework::SV1TrackThinning Class Reference

#include <SV1TrackThinning.h>

Inheritance diagram for DerivationFramework::SV1TrackThinning:
Collaboration diagram for DerivationFramework::SV1TrackThinning:

Public Member Functions

 SV1TrackThinning (const std::string &t, const std::string &n, const IInterface *p)
 ~SV1TrackThinning ()
virtual StatusCode initialize () override
virtual StatusCode finalize () override
virtual StatusCode doThinning () const override

Private Attributes

std::atomic< unsigned int > m_ntot
std::atomic< unsigned int > m_npass
StringProperty m_streamName { this, "StreamName", "", "Name of the stream being thinned" }
SG::ThinningHandleKey< xAOD::TrackParticleContainerm_inDetSGKey { this, "InDetTrackParticlesKey", "InDetTrackParticles", "" }
std::string m_jetSGKey
std::string m_selectionString

Detailed Description

Definition at line 25 of file SV1TrackThinning.h.

Constructor & Destructor Documentation

◆ SV1TrackThinning()

DerivationFramework::SV1TrackThinning::SV1TrackThinning ( const std::string & t,
const std::string & n,
const IInterface * p )

Definition at line 20 of file SV1TrackThinning.cxx.

22 :
23 base_class(t,n,p),
24 m_ntot(0),
25 m_npass(0),
26 m_jetSGKey(""),
28{
29 declareProperty("JetKey", m_jetSGKey);
30 declareProperty("SelectionString", m_selectionString);
31}
std::atomic< unsigned int > m_npass
std::atomic< unsigned int > m_ntot

◆ ~SV1TrackThinning()

DerivationFramework::SV1TrackThinning::~SV1TrackThinning ( )

Definition at line 34 of file SV1TrackThinning.cxx.

34 {
35}

Member Function Documentation

◆ doThinning()

StatusCode DerivationFramework::SV1TrackThinning::doThinning ( ) const
overridevirtual

Definition at line 65 of file SV1TrackThinning.cxx.

66{
67 const EventContext& ctx = Gaudi::Hive::currentContext();
68
69 // Retrieve main TrackParticle collection
70 SG::ThinningHandle<xAOD::TrackParticleContainer> importedTrackParticles
71 (m_inDetSGKey, ctx);
72
73 // Check the event contains tracks
74 unsigned int nTracks = importedTrackParticles->size();
75 if (nTracks==0) return StatusCode::SUCCESS;
76
77 // Set up a mask with the same entries as the full TrackParticle collection
78 std::vector<bool> mask;
79 mask.assign(nTracks, false); // default: don't keep any tracks
80 m_ntot += nTracks;
81
82 const xAOD::JetContainer* importedJets(0);
83 if (evtStore()->retrieve(importedJets,m_jetSGKey).isFailure()) {
84 ATH_MSG_ERROR("No jet collection with name " << m_jetSGKey << " found in StoreGate!");
85 return StatusCode::FAILURE;
86 }
87
88 unsigned int nJets(importedJets->size());
89 std::vector<const xAOD::Jet*> jetToCheck; jetToCheck.clear();
90
91 // Execute the text parser if requested
92 if (!m_selectionString.empty()) {
93 std::vector<int> entries = m_parser->evaluateAsVector();
94 unsigned int nEntries = entries.size();
95 // check the sizes are compatible
96 if (nJets != nEntries ) {
97 ATH_MSG_ERROR("Sizes incompatible! Are you sure your selection string used jets??");
98 return StatusCode::FAILURE;
99 } else {
100 // identify which jets to keep for the thinning check
101 for (unsigned int i=0; i<nJets; ++i) if (entries[i]==1) jetToCheck.push_back((*importedJets)[i]);
102 }
103 }
104
105 // Retrieve containers
106 // ... jets
107 if (m_selectionString=="") { // check all jets as user didn't provide a selection string
108 for (xAOD::JetContainer::const_iterator jetIt=importedJets->begin(); jetIt!=importedJets->end(); ++jetIt) {
110 const std::vector< ElementLink<xAOD::TrackParticleContainer> >& SV1_trackParticleLinks =
112
113
114 for (const ElementLink<xAOD::TrackParticleContainer> &tp : SV1_trackParticleLinks) {
115 int index = (*tp)->index();
116 mask[index] = true;
117 }
118 }
119 } else { // check only jets passing user selection string
120 for (std::vector<const xAOD::Jet*>::iterator jetIt = jetToCheck.begin(); jetIt!=jetToCheck.end(); ++jetIt) {
122 const std::vector< ElementLink<xAOD::TrackParticleContainer> >& SV1_trackParticleLinks =
124
125
126 for (const ElementLink<xAOD::TrackParticleContainer> &tp : SV1_trackParticleLinks) {
127 int index = (*tp)->index();
128 mask[index] = true;
129 }
130 }
131 }
132
133 // Count up the mask contents
134 for (unsigned int i=0; i<nTracks; ++i) {
135 if (mask[i]) ++m_npass;
136 }
137
138 // Execute the thinning service based on the mask. Finish.
139 importedTrackParticles.keep (mask);
140
141 return StatusCode::SUCCESS;
142}
#define ATH_MSG_ERROR(x)
DataModel_detail::const_iterator< DataVector > const_iterator
Definition DataVector.h:838
SG::ThinningHandleKey< xAOD::TrackParticleContainer > m_inDetSGKey
const TPELVec_t & SV1_TrackParticleLinks() const
get vector of SV1 TrackParticle ElementLinks
double entries
Definition listroot.cxx:49
str index
Definition DeMoScan.py:362
retrieve(aClass, aKey=None)
Definition PyKernel.py:110
const BTagging * getBTagging(const SG::AuxElement &part)
Access the default xAOD::BTagging object associated to an object.
BTagging_v1 BTagging
Definition of the current "BTagging version".
Definition BTagging.h:17
JetContainer_v1 JetContainer
Definition of the current "jet container version".

◆ finalize()

StatusCode DerivationFramework::SV1TrackThinning::finalize ( )
overridevirtual

Definition at line 56 of file SV1TrackThinning.cxx.

57{
58 ATH_MSG_VERBOSE("finalize() ...");
59 ATH_MSG_INFO("Processed "<< m_ntot <<" tracks, "<< m_npass<< " were retained ");
60 ATH_CHECK(finalizeParser() );
61 return StatusCode::SUCCESS;
62}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_INFO(x)
#define ATH_MSG_VERBOSE(x)

◆ initialize()

StatusCode DerivationFramework::SV1TrackThinning::initialize ( )
overridevirtual

Definition at line 38 of file SV1TrackThinning.cxx.

39{
40 // Decide which collections need to be checked for ID TrackParticles
41 ATH_MSG_VERBOSE("initialize() ...");
42 ATH_CHECK( m_inDetSGKey.initialize (m_streamName) );
43 ATH_MSG_INFO("Using " << m_inDetSGKey << "as the source collection for inner detector track particles");
44 if (m_jetSGKey=="") {
45 ATH_MSG_FATAL("No jet collection provided for thinning.");
46 return StatusCode::FAILURE;
47 } else { ATH_MSG_INFO("Inner detector track particles associated with objects in " << m_jetSGKey << " will be retained in this format with the rest being thinned away");}
48
49 // Set up the text-parsing machinery for selectiong the jet directly according to user cuts
50 if (!m_selectionString.empty()) {
51 ATH_CHECK(initializeParser(m_selectionString) );
52 }
53 return StatusCode::SUCCESS;
54}
#define ATH_MSG_FATAL(x)

Member Data Documentation

◆ m_inDetSGKey

SG::ThinningHandleKey<xAOD::TrackParticleContainer> DerivationFramework::SV1TrackThinning::m_inDetSGKey { this, "InDetTrackParticlesKey", "InDetTrackParticles", "" }
private

Definition at line 37 of file SV1TrackThinning.h.

38{ this, "InDetTrackParticlesKey", "InDetTrackParticles", "" };

◆ m_jetSGKey

std::string DerivationFramework::SV1TrackThinning::m_jetSGKey
private

Definition at line 39 of file SV1TrackThinning.h.

◆ m_npass

std::atomic<unsigned int> DerivationFramework::SV1TrackThinning::m_npass
private

Definition at line 34 of file SV1TrackThinning.h.

◆ m_ntot

std::atomic<unsigned int> DerivationFramework::SV1TrackThinning::m_ntot
mutableprivate

Definition at line 34 of file SV1TrackThinning.h.

◆ m_selectionString

std::string DerivationFramework::SV1TrackThinning::m_selectionString
private

Definition at line 39 of file SV1TrackThinning.h.

◆ m_streamName

StringProperty DerivationFramework::SV1TrackThinning::m_streamName { this, "StreamName", "", "Name of the stream being thinned" }
private

Definition at line 35 of file SV1TrackThinning.h.

36{ this, "StreamName", "", "Name of the stream being thinned" };

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