LDMX Software
TrackerVetoProcessor.cxx
1
8
9namespace tracking {
10
13 ps.getParameter<std::string>("tagger_track_collection", "TaggerTracks");
15 ps.getParameter<std::string>("recoil_track_collection", "RecoilTracks");
17 ps.getParameter<std::string>("input_tagger_pass_name", "");
19 ps.getParameter<std::string>("input_recoil_pass_name", "");
20 output_collection_ = ps.getParameter<std::string>("output_collection", "");
21 inverse_skim_ = ps.getParameter<bool>("inverse_skim", false);
22 max_d0_ = ps.getParameter<double>("max_d0", 10.);
23 max_z0_ = ps.getParameter<double>("max_z0", 40.);
24 max_chi2_per_ndf_ = ps.getParameter<double>("max_chi2_per_ndf", 5.);
25 min_tagger_momentum_ = ps.getParameter<double>("min_tagger_momentum", 5600.);
26 min_recoil_n_ = ps.getParameter<int>("min_recoil_n", 1);
27 max_recoil_n_ = ps.getParameter<int>("max_recoil_n", 1);
28 min_tagger_hits_ = ps.getParameter<int>("min_tagger_hits", 4);
29 min_recoil_hits_ = ps.getParameter<int>("min_recoil_hits", 4);
30}
31
33 auto tagger_track_collection{event.getCollection<ldmx::Track>(
35 auto recoil_track_collection{event.getCollection<ldmx::Track>(
37
38 bool passes_veto{false}, passes_tagger_veto{false}, passes_recoil_veto{false};
39
40 // Start with tagger tracks
41 int tagger_n{0};
42 for (const auto& trk : tagger_track_collection) {
43 if ((std::abs(trk.getD0()) < max_d0_) &&
44 (std::abs(trk.getZ0()) < max_z0_)) {
45 auto charge_over_momentum = trk.getQoP();
46 auto tagger_momentum = 1000. / std::abs(charge_over_momentum);
47 float chi2_per_ndf = trk.getChi2() / trk.getNdf();
48 if ((tagger_momentum > min_tagger_momentum_) &&
49 (chi2_per_ndf < max_chi2_per_ndf_) &&
50 (trk.getNhits() > min_tagger_hits_)) {
51 tagger_n++;
52 passes_tagger_veto = true;
53 }
54 }
55 }
56
57 ldmx_log(info) << "Tagger requirements passed for " << tagger_n << " tracks";
58
59 // Recoil tracks now
60 int recoil_n{0};
61 for (const auto& trk : recoil_track_collection) {
62 float chi2_per_ndf = trk.getChi2() / trk.getNdf();
63 if ((std::abs(trk.getD0()) < max_d0_) &&
64 (std::abs(trk.getZ0()) < max_z0_) &&
65 (chi2_per_ndf < max_chi2_per_ndf_) &&
66 (trk.getNhits() > min_recoil_hits_)) {
67 // we may wanna use these in the future, keeping them commented
68 // auto charge_over_momentum = trk.getQoP();
69 // recoil_momentum = 1000. / abs(charge_over_momentum);
70 recoil_n++;
71 };
72 }
73
74 ldmx_log(info) << "Recoil requirements passed for " << recoil_n << " tracks";
75
76 if ((min_recoil_n_ <= recoil_n) && (recoil_n <= max_recoil_n_)) {
77 passes_recoil_veto = true;
78 }
79
80 passes_veto = passes_tagger_veto && passes_recoil_veto;
81
83 result.setVetoResult(passes_veto);
84 result.setTaggerVetoResult(passes_tagger_veto);
85 result.setRecoilVetoResult(passes_recoil_veto);
86
87 event.add(output_collection_, result);
88
89 if (!inverse_skim_) {
90 if (passes_veto) {
91 ldmx_log(info) << "Tracker veto passed, skim will keep the event";
93 } else {
94 ldmx_log(info) << "Tracker veto failed";
96 }
97 } else {
98 if (passes_veto) {
99 ldmx_log(info) << "Inverse tracker veto passed";
101 } else {
102 ldmx_log(info) << "Inverse tracker veto failed, skim will keep the event";
104 }
105 }
106} // produce
107} // namespace tracking
108
109DECLARE_PRODUCER_NS(tracking, TrackerVetoProcessor);
#define DECLARE_PRODUCER_NS(NS, CLASS)
Macro which allows the framework to construct a producer given its name during configuration.
Class that flags events if they pass the tracker veto.
void setStorageHint(framework::StorageControl::Hint hint)
Mark the current event as having the given storage control hint from this module.
Implements an event buffer system for storing event data.
Definition Event.h:42
Class encapsulating parameters for configuring a processor.
Definition Parameters.h:29
Implementation of a track object.
Definition Track.h:53
Class that holds reco-level tracking veto decision.
void setRecoilVetoResult(bool passes_recoil_veto)
Sets whether the Recoil Tracker veto was passed or not.
void setTaggerVetoResult(bool passes_tagger_veto)
Sets whether the Tagger Tracker veto was passed or not.
void setVetoResult(bool passes_veto)
Sets whether the Tracker veto was passed or not.
std::string input_tagger_pass_name_
The pass name of the input tagger collections.
float max_d0_
Maximum allowed transverse impact parameter (d0) for tracks.
int min_recoil_n_
Minimum number of recoil tracks required.
int min_tagger_hits_
Min number of hits for tagger tracks required.
void configure(framework::config::Parameters &parameters) override
Configure the processor using the given user-specified parameters.
void produce(framework::Event &event) override
Process an event and apply tracker veto selection criteria.
bool inverse_skim_
Boolean flag to invert the selection criteria for skimming purposes.
float max_z0_
Maximum allowed longitudinal impact parameter (z0) for tracks.
std::string input_recoil_pass_name_
The pass name of the input recoil collections.
int max_recoil_n_
Maximum number of recoil tracks allowed.
std::string recoil_track_collection_name_
The name of the recoil track collection.
int min_recoil_hits_
Min number of hits for recoil tracks required.
float min_tagger_momentum_
Minimum required momentum for tagger tracks.
std::string tagger_track_collection_name_
The name of the tagger track collection.
float max_chi2_per_ndf_
Max chi2/ndf required for tracks.
constexpr StorageControl::Hint hint_shouldKeep
storage control hint alias for backwards compatibility
constexpr StorageControl::Hint hint_shouldDrop
storage control hint alias for backwards compatibility
The measurement calibrator can be a function or a class/struct able to retrieve the sim hits containe...