LDMX Software
ReSimVerifier.cxx
1#include "DQM/ReSimVerifier.h"
2namespace dqm {
3
5 sim_pass_name_ = parameters.get<std::string>("sim_pass_name");
6 re_sim_pass_name_ = parameters.get<std::string>("resim_pass_name");
7 stop_on_error_ = parameters.get<bool>("stop_on_error");
8 collections_ = parameters.get<std::vector<std::string>>("collections");
9}
10bool ReSimVerifier::verifySimCalorimeterHits(
11 const std::vector<ldmx::SimCalorimeterHit>& simHits,
12 const std::vector<ldmx::SimCalorimeterHit>& reSimHits) {
13 for (auto i{0}; i < simHits.size(); ++i) {
14 auto hit{simHits[i]};
15 auto rehit{reSimHits[i]};
16
17 if (hit.getEdep() != rehit.getEdep()) {
18 return false;
19 }
20 if (hit.getID() != rehit.getID()) {
21 return false;
22 }
23 if (hit.getTime() != rehit.getTime()) {
24 return false;
25 }
26 if (hit.getNumberOfContribs() != rehit.getNumberOfContribs()) {
27 return false;
28 }
29 auto pos{hit.getPosition()};
30 auto repos{rehit.getPosition()};
31 if (pos[0] != repos[0] || pos[1] != repos[1] || pos[2] != repos[2]) {
32 return false;
33 }
34 }
35 return true;
36}
37
38bool ReSimVerifier::verifySimParticles(const framework::Event& event) {
39 const auto& sim_particles{
40 event.getMap<int, ldmx::SimParticle>("SimParticles", sim_pass_name_)};
41 const auto& re_sim_particles{
42 event.getMap<int, ldmx::SimParticle>("SimParticles", re_sim_pass_name_)};
43 for (auto [id, simParticle] : sim_particles) {
44 if (!re_sim_particles.count(id)) {
45 return false;
46 }
47 auto re_sim_particle{re_sim_particles.at(id)};
48 if (simParticle.getEnergy() != re_sim_particle.getEnergy()) {
49 return false;
50 }
51 if (simParticle.getPdgID() != re_sim_particle.getPdgID()) {
52 return false;
53 }
54 if (simParticle.getTime() != re_sim_particle.getTime()) {
55 return false;
56 }
57 }
58 return true;
59}
61 std::stringstream ss;
62 bool passing{true};
63 bool skipped{false};
64 auto event_number{event.getEventNumber()};
65 for (auto collection : collections_) {
66 const auto sim_hits = event.getCollection<ldmx::SimCalorimeterHit>(
67 collection, sim_pass_name_);
68 const auto re_sim_hits = event.getCollection<ldmx::SimCalorimeterHit>(
69 collection, re_sim_pass_name_);
70 if (re_sim_hits.size() == 0) {
71 skipped = true;
72 continue;
73 } else {
74 skipped = false;
75 }
76
77 if (!verifySimCalorimeterHits(sim_hits, re_sim_hits)) {
78 passing = false;
79 ss << "Event " << event_number << " has different simhits for "
80 << collection << std::endl;
81 }
82 }
83 if (skipped) {
84 ldmx_log(info) << "Skipping event " << event_number
85 << "since it was not resimulated";
86 }
87 if (!verifySimParticles(event)) {
88 passing = false;
89 ss << "Event " << event_number
90 << " has different SimParticles between the two passes" << std::endl;
91 }
92 if (!passing) {
93 if (stop_on_error_) {
94 EXCEPTION_RAISE("ReSimVerify", ss.str());
95 } else {
96 ldmx_log(info) << ss.str();
97 }
98 }
99
100} // Analyze
101} // namespace dqm
#define DECLARE_ANALYZER(CLASS)
Macro which allows the framework to construct an analyzer given its name during configuration.
void analyze(const framework::Event &event) override
Process the event and make histograms or summaries.
void configure(framework::config::Parameters &parameters) override
Callback for the EventProcessor to configure itself from the given set of parameters.
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
Stores simulated calorimeter hit information.
Class representing a simulated particle.
Definition SimParticle.h:23