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

#include <TrackMeasurementThinning.h>

Inheritance diagram for DerivationFramework::TrackMeasurementThinning:
Collaboration diagram for DerivationFramework::TrackMeasurementThinning:

Public Member Functions

 TrackMeasurementThinning (const std::string &t, const std::string &n, const IInterface *p)
 Constructor with parameters.
virtual ~TrackMeasurementThinning ()
 Destructor.
virtual StatusCode initialize () override
virtual StatusCode finalize () override
virtual StatusCode doThinning () const override
 Check that the current event passes this filter.

Private Attributes

Gaudi::Property< std::string > m_selectionString { this, "SelectionString", "", ""}
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::TrackMeasurementValidationContainerm_SGKey { this, "TrackMeasurementValidationKey", "PixelClusters", "" }

Detailed Description

Author
David Salek -at- cern.ch

Definition at line 32 of file TrackMeasurementThinning.h.

Constructor & Destructor Documentation

◆ TrackMeasurementThinning()

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

Constructor with parameters.

Definition at line 19 of file TrackMeasurementThinning.cxx.

21 :
22 base_class(t,n,p)
23 {
24 }

◆ ~TrackMeasurementThinning()

DerivationFramework::TrackMeasurementThinning::~TrackMeasurementThinning ( )
virtualdefault

Destructor.

Member Function Documentation

◆ doThinning()

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

Check that the current event passes this filter.

Definition at line 57 of file TrackMeasurementThinning.cxx.

58{
59 const EventContext& ctx = Gaudi::Hive::currentContext();
60
61 // Get the cluster container
62 SG::ThinningHandle<xAOD::TrackMeasurementValidationContainer> clusters
63 (m_SGKey, ctx);
64
65 // Check the event contains clusters
66 unsigned int nClusters = clusters->size();
67 if (nClusters==0) return StatusCode::SUCCESS;
68
69 // Set up a mask with the same entries as the full collection
70 std::vector<bool> mask;
71 mask.assign(nClusters,false); // default: don't keep anything
72 m_ntot += nClusters;
73
74 // Execute the text parser and update the mask
75 if (m_parser) {
76 std::vector<int> entries = m_parser->evaluateAsVector();
77 unsigned int nEntries = entries.size();
78 // check the sizes are compatible
79 if (nClusters != nEntries ) {
80 ATH_MSG_ERROR("Sizes incompatible! Are you sure your selection string used the same collection as the input collection??");
81 return StatusCode::FAILURE;
82 } else {
83 // set mask
84 for (unsigned int i=0; i<nClusters; ++i) if (entries[i]==1) mask[i]=true;
85 }
86 }
87 // Count the mask
88 unsigned int n_pass=0;
89 for (unsigned int i=0; i<nClusters; ++i) {
90 if (mask[i]) ++n_pass;
91 }
92 m_npass += n_pass;
93
94 // Execute the thinning service based on the mask. Finish.
95 clusters.keep (mask);
96
97 return StatusCode::SUCCESS;
98}
#define ATH_MSG_ERROR(x)
SG::ThinningHandleKey< xAOD::TrackMeasurementValidationContainer > m_SGKey
double entries
Definition listroot.cxx:49

◆ finalize()

StatusCode DerivationFramework::TrackMeasurementThinning::finalize ( )
overridevirtual

Definition at line 48 of file TrackMeasurementThinning.cxx.

49{
50 ATH_MSG_VERBOSE("finalize() ...");
51 ATH_MSG_INFO("Processed "<< m_ntot <<" measurements, "<< m_npass<< " were retained ");
52 ATH_CHECK( finalizeParser());
53 return StatusCode::SUCCESS;
54}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_INFO(x)
#define ATH_MSG_VERBOSE(x)

◆ initialize()

StatusCode DerivationFramework::TrackMeasurementThinning::initialize ( )
overridevirtual

Definition at line 30 of file TrackMeasurementThinning.cxx.

31{
32 ATH_MSG_VERBOSE("initialize() ...");
33 if (m_selectionString.empty()) {
34 ATH_MSG_FATAL("No inner detector track selection string provided!");
35 return StatusCode::FAILURE;
36 } else {ATH_MSG_INFO("Track thinning selection string: " << m_selectionString);}
37
38 //check xAOD::InDetTrackParticle collection
39 ATH_CHECK( m_SGKey.initialize (m_streamName) );
40 ATH_MSG_INFO("Using " << m_SGKey << "as the source collection for thinning.");
41
42 // Set up the text-parsing machinery for thinning the tracks directly according to user cuts
43 if (!m_selectionString.empty()) {
44 ATH_CHECK( initializeParser(m_selectionString) );
45 }
46 return StatusCode::SUCCESS;
47}
#define ATH_MSG_FATAL(x)

Member Data Documentation

◆ m_npass

std::atomic<unsigned int> DerivationFramework::TrackMeasurementThinning::m_npass {}
mutableprivate

Definition at line 53 of file TrackMeasurementThinning.h.

53{};

◆ m_ntot

std::atomic<unsigned int> DerivationFramework::TrackMeasurementThinning::m_ntot {}
mutableprivate

Definition at line 52 of file TrackMeasurementThinning.h.

52{};

◆ m_selectionString

Gaudi::Property<std::string> DerivationFramework::TrackMeasurementThinning::m_selectionString { this, "SelectionString", "", ""}
private

Definition at line 49 of file TrackMeasurementThinning.h.

50{ this, "SelectionString", "", ""};

◆ m_SGKey

SG::ThinningHandleKey<xAOD::TrackMeasurementValidationContainer> DerivationFramework::TrackMeasurementThinning::m_SGKey { this, "TrackMeasurementValidationKey", "PixelClusters", "" }
private

Definition at line 57 of file TrackMeasurementThinning.h.

58{ this, "TrackMeasurementValidationKey", "PixelClusters", "" };

◆ m_streamName

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

Definition at line 54 of file TrackMeasurementThinning.h.

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

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