ATLAS Offline Software
Loading...
Searching...
No Matches
GenericObjectThinning.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2021 CERN for the benefit of the ATLAS collaboration
3*/
4
6// GenericObjectThinning.cxx, (c) ATLAS Detector software
8// Author: James Catmore (James.Catmore@cern.ch)
9// Removes all ID tracks which do not pass a user-defined cut
10
13#include <vector>
14#include <string>
15
16// Constructor
18 const std::string& n,
19 const IInterface* p ) :
20base_class(t,n,p),
22m_ntot(0),
23m_npass(0)
24{
25 declareProperty("SelectionString", m_selectionString);
26}
27
28// Destructor
31
32// Athena initialize and finalize
34{
35 ATH_MSG_VERBOSE("initialize() ...");
36 if (m_selectionString.empty()) {
37 ATH_MSG_FATAL("No selection string provided!");
38 return StatusCode::FAILURE;
39 } else {ATH_MSG_INFO("Selection string: " << m_selectionString);}
40
41 // Set up the text-parsing machinery for thinning the tracks directly according to user cuts
42 if (!m_selectionString.empty()) {
43 ATH_CHECK(initializeParser( m_selectionString) );
44 }
45
46 //check xAOD::InDetTrackParticle collection
47 ATH_CHECK( m_SGKey.initialize (m_streamName) );
48 ATH_MSG_INFO("Using " << m_SGKey << "as the source collection");
49
50 return StatusCode::SUCCESS;
51}
52
54{
55 ATH_MSG_VERBOSE("finalize() ...");
56 ATH_MSG_INFO("Processed "<< m_ntot <<" objects, "<< m_npass<< " were retained ");
57 ATH_CHECK(finalizeParser());
58 return StatusCode::SUCCESS;
59}
60
61// The thinning itself
62StatusCode DerivationFramework::GenericObjectThinning::doThinning(const EventContext& ctx) const
63{
64
65 // Retrieve main object collection
67
68 // Check the event contains objects
69 unsigned int nObjects = particles->size();
70 if (nObjects==0) return StatusCode::SUCCESS;
71
72 // Set up a mask with the same entries as the full collection
73 std::vector<bool> mask;
74 mask.assign(nObjects,false); // default: don't keep any tracks
75 m_ntot += nObjects;
76
77 // Execute the text parser and update the mask
78 if (m_parser) {
79 std::vector<int> entries = m_parser->evaluateAsVector();
80 unsigned int nEntries = entries.size();
81 // check the sizes are compatible
82 if (nObjects != nEntries ) {
83 ATH_MSG_ERROR("Sizes incompatible! Are you sure your selection string used the same collection as the input collection??");
84 return StatusCode::FAILURE;
85 } else {
86 // set mask
87 for (unsigned int i=0; i<nObjects; ++i) if (entries[i]==1) mask[i]=true;
88 }
89 }
90 // Count the mask
91 m_npass += std::count (mask.begin(), mask.end(), true);
92
93 // Execute the thinning based on the mask. Finish.
94 particles.keep (mask);
95
96 return StatusCode::SUCCESS;
97}
98
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_ERROR(x)
#define ATH_MSG_FATAL(x)
#define ATH_MSG_INFO(x)
#define ATH_MSG_VERBOSE(x)
Handle for requesting thinning for a data object.
SG::ThinningHandleKey< xAOD::IParticleContainer > m_SGKey
GenericObjectThinning(const std::string &t, const std::string &n, const IInterface *p)
virtual StatusCode doThinning(const EventContext &ctx) const override
Handle for requesting thinning for a data object.
double entries
Definition listroot.cxx:49