56{
57
58 const EventContext& ctx = Gaudi::Hive::currentContext();
59
60
61 SG::ThinningHandle<xAOD::TrackParticleContainer> importedTrackParticles
63
64
65 unsigned int nTracks = importedTrackParticles->size();
66 if (nTracks==0) return StatusCode::SUCCESS;
67
68
69 std::vector<bool>
mask;
70 mask.assign(nTracks,
false);
72
73
74
75 SG::ReadHandle<xAOD::DiTauJetContainer> importedDiTaus(
m_ditauKey,ctx);
76 if (!importedDiTaus.isValid()) {
78 return StatusCode::FAILURE;
79 }
80 unsigned int nDiTaus(importedDiTaus->size());
81 std::vector<const xAOD::DiTauJet*> ditauToCheck; ditauToCheck.clear();
82
83
85 std::vector<int>
entries = m_parser->evaluateAsVector();
87
88 if (nDiTaus != nEntries ) {
89 ATH_MSG_ERROR(
"Sizes incompatible! Are you sure your selection string used ditaus??");
90 return StatusCode::FAILURE;
91 } else {
92
93 for (
unsigned int i=0;
i<nDiTaus; ++
i)
if (
entries[i]==1) ditauToCheck.push_back((*importedDiTaus)[i]);
94 }
95 }
96
97
98
100 for (const auto *ditauIt : *importedDiTaus) {
101 for (
unsigned int i=0;
i<ditauIt->nTracks(); ++
i) {
102 int index = ditauIt->trackLinks().at(i).index();
104 }
105 for (
unsigned int i=0;
i<ditauIt->nIsoTracks(); ++
i) {
106 int index = ditauIt->isoTrackLinks().at(i).index();
108 }
109 }
110 } else {
111 for (auto & ditauIt : ditauToCheck) {
112 for (
unsigned int i=0;
i<ditauIt->nTracks(); ++
i) {
113 int index = ditauIt->trackLinks().at(i).index();
115 }
116 for (
unsigned int i=0;
i<ditauIt->nIsoTracks(); ++
i) {
117 int index = ditauIt->isoTrackLinks().at(i).index();
119 }
120 }
121 }
122
123
124 unsigned int n_pass=0;
125 for (
unsigned int i=0;
i<nTracks; ++
i) {
126 if (mask[i]) ++n_pass;
127 }
129
130
131 importedTrackParticles.keep (mask);
132
133 return StatusCode::SUCCESS;
134}
std::atomic< unsigned int > m_npass
Gaudi::Property< std::string > m_selectionString
SG::ReadHandleKey< xAOD::DiTauJetContainer > m_ditauKey
SG::ThinningHandleKey< xAOD::TrackParticleContainer > m_inDetSGKey
std::atomic< unsigned int > m_ntot