LDMX Software
TrackerVetoProcessor.cxx
1
8
9namespace tracking {
10
13 ps.get<std::string>("tagger_track_collection", "TaggerTracks");
15 ps.get<std::string>("recoil_track_collection", "RecoilTracks");
16 input_tagger_pass_name_ = ps.get<std::string>("input_tagger_pass_name", "");
17 input_recoil_pass_name_ = ps.get<std::string>("input_recoil_pass_name", "");
18 output_collection_ = ps.get<std::string>("output_collection", "");
19 inverse_skim_ = ps.get<bool>("inverse_skim", false);
20 max_d0_ = ps.get<double>("max_d0", 10.);
21 max_z0_ = ps.get<double>("max_z0", 40.);
22 max_chi2_per_ndf_ = ps.get<double>("max_chi2_per_ndf", 5.);
23 min_tagger_momentum_ = ps.get<double>("min_tagger_momentum", 5600.);
24 min_recoil_n_ = ps.get<int>("min_recoil_n", 1);
25 max_recoil_n_ = ps.get<int>("max_recoil_n", 1);
26 min_tagger_hits_ = ps.get<int>("min_tagger_hits", 4);
27 min_recoil_hits_ = ps.get<int>("min_recoil_hits", 4);
28}
29
31 auto tagger_track_collection{event.getCollection<ldmx::Track>(
33 auto recoil_track_collection{event.getCollection<ldmx::Track>(
35
36 bool passes_veto{false}, passes_tagger_veto{false}, passes_recoil_veto{false};
37
38 // Start with tagger tracks
39 int tagger_n{0};
40 for (const auto& trk : tagger_track_collection) {
41 if ((std::abs(trk.getD0()) < max_d0_) &&
42 (std::abs(trk.getZ0()) < max_z0_)) {
43 auto charge_over_momentum = trk.getQoP();
44 auto tagger_momentum = 1000. / std::abs(charge_over_momentum);
45 float chi2_per_ndf = trk.getChi2() / trk.getNdf();
46 if ((tagger_momentum > min_tagger_momentum_) &&
47 (chi2_per_ndf < max_chi2_per_ndf_) &&
48 (trk.getNhits() > min_tagger_hits_)) {
49 tagger_n++;
50 passes_tagger_veto = true;
51 }
52 }
53 }
54
55 ldmx_log(info) << "Tagger requirements passed for " << tagger_n << " tracks";
56
57 // Recoil tracks now
58 int recoil_n{0};
59 for (const auto& trk : recoil_track_collection) {
60 float chi2_per_ndf = trk.getChi2() / trk.getNdf();
61 if ((std::abs(trk.getD0()) < max_d0_) &&
62 (std::abs(trk.getZ0()) < max_z0_) &&
63 (chi2_per_ndf < max_chi2_per_ndf_) &&
64 (trk.getNhits() > min_recoil_hits_)) {
65 // we may wanna use these in the future, keeping them commented
66 // auto charge_over_momentum = trk.getQoP();
67 // recoil_momentum = 1000. / abs(charge_over_momentum);
68 recoil_n++;
69 };
70 }
71
72 ldmx_log(info) << "Recoil requirements passed for " << recoil_n << " tracks";
73
74 if ((min_recoil_n_ <= recoil_n) && (recoil_n <= max_recoil_n_)) {
75 passes_recoil_veto = true;
76 }
77
78 passes_veto = passes_tagger_veto && passes_recoil_veto;
79
81 result.setVetoResult(passes_veto);
82 result.setTaggerVetoResult(passes_tagger_veto);
83 result.setRecoilVetoResult(passes_recoil_veto);
84
85 event.add(output_collection_, result);
86
87 if (!inverse_skim_) {
88 if (passes_veto) {
89 ldmx_log(info) << "Tracker veto passed, skim will keep the event";
91 } else {
92 ldmx_log(info) << "Tracker veto failed";
94 }
95 } else {
96 if (passes_veto) {
97 ldmx_log(info) << "Inverse tracker veto passed";
99 } else {
100 ldmx_log(info) << "Inverse tracker veto failed, skim will keep the event";
102 }
103 }
104} // produce
105} // namespace tracking
106
#define DECLARE_PRODUCER(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
const T & get(const std::string &name) const
Retrieve the parameter of the given name.
Definition Parameters.h:78
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.
Flags events that pass the tracker veto by applying specific selection criteria.
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_SHOULD_DROP
storage control hint alias for backwards compatibility
constexpr StorageControl::Hint HINT_SHOULD_KEEP
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...