121 const auto& the_conditions{
124 std::vector<ldmx::HcalHit> hcal_rec_hits;
130 unsigned int i_soi = hcal_digis.getSampleOfInterestIndex();
134 while (i_digi < num_digi_hits) {
135 auto digi_posend = hcal_digis.getDigi(i_digi);
142 auto position = hcal_geometry.getStripCenterPosition(
id);
143 double half_total_width =
144 hcal_geometry.getHalfTotalWidth(
id.section(),
id.layer());
145 double ecal_dx = hcal_geometry.getEcalDx();
146 double ecal_dy = hcal_geometry.getEcalDy();
152 float distance_posend, distance_negend, distance_ecal;
153 if (
id.section() == ldmx::HcalID::HcalSection::BACK) {
154 distance_posend = half_total_width;
155 distance_negend = half_total_width;
157 if ((
id.section() == ldmx::HcalID::HcalSection::TOP) ||
158 (
id.section() == ldmx::HcalID::HcalSection::BOTTOM))
159 distance_ecal = ecal_dx;
161 distance_ecal = ecal_dy;
162 distance_posend = 2 * half_total_width - distance_ecal / 2.;
163 distance_negend = distance_ecal / 2.;
168 double voltage_min(0.);
172 double ampl_t_posend(0.), ampl_tm1_posend(0.);
173 double ampl_t_negend(0.), ampl_tm1_negend(0.);
176 const auto orientation{hcal_geometry.getScintillatorOrientation(
id)};
177 int orientation_int =
static_cast<int>(orientation);
180 if (
id.section() == ldmx::HcalID::HcalSection::BACK) {
181 auto digi_negend = hcal_digis.getDigi(i_digi + 1);
184 double voltage_posend, voltage_negend;
185 if (digi_posend.isTOT()) {
187 (digi_posend.tot() - the_conditions.totCalib(id_posend, 0)) *
188 the_conditions.totCalib(id_posend, 1);
190 (digi_negend.tot() - the_conditions.totCalib(id_negend, 0)) *
191 the_conditions.totCalib(id_negend, 1);
194 digi_posend.soi().adcT() - the_conditions.adcPedestal(id_posend);
196 digi_posend.soi().adcTm1() - the_conditions.adcPedestal(id_posend);
198 digi_negend.soi().adcT() - the_conditions.adcPedestal(id_negend);
200 digi_negend.soi().adcTm1() - the_conditions.adcPedestal(id_negend);
213 voltage_posend = ampl_t_posend * the_conditions.adcGain(id_posend, 0);
214 voltage_negend = ampl_t_negend * the_conditions.adcGain(id_negend, 0);
219 getTOA(digi_posend, the_conditions.adcPedestal(id_posend), i_soi);
221 getTOA(digi_negend, the_conditions.adcPedestal(id_negend), i_soi);
224 int position_bar_sign = (toa_posend - toa_negend) > 0 ? 1 : -1;
238 double v = 299.792 / 1.6;
239 double position_bar =
240 position_bar_sign * fabs(toa_posend - toa_negend) * v / 2;
248 exp(-1. * ((distance_posend - position_bar) / 1000.) /
attlength_);
250 exp(-1. * ((distance_negend + position_bar) / 1000.) /
attlength_);
253 voltage = (voltage_posend + voltage_negend);
254 voltage_min = std::min(voltage_posend, voltage_negend);
257 ampl_t = (ampl_t_posend / att_posend + ampl_t_negend / att_negend) / 2;
261 ldmx::HcalGeometry::ScintillatorOrientation::horizontal) {
262 position.SetX(position_bar);
264 position.SetY(position_bar);
270 hit_time = fabs(toa_posend + toa_negend) / 2;
277 if (digi_posend.isTOT()) {
286 voltage_i = (digi_posend.tot() - the_conditions.totCalib(id_posend)) *
287 the_conditions.totCalib(id_posend);
293 digi_posend.soi().adcT() - the_conditions.adcPedestal(id_posend);
295 digi_posend.soi().adcTm1() - the_conditions.adcPedestal(id_posend);
296 voltage_i = ampl_t_posend * the_conditions.adcGain(id_posend);
301 double distance_end =
302 id_posend.
isNegativeEnd() ? distance_negend : distance_posend;
303 double att = exp(-1. * ((distance_end - fabs(half_total_width)) / 1000.) /
308 voltage_min = voltage_i;
311 ampl_t = ampl_t_posend / att;
315 getTOA(digi_posend, the_conditions.adcPedestal(id_posend), i_soi);
327 double energy_deposited = num_mips_equivalent *
mip_energy_;
347 double reconstructed_energy = energy_deposited;
354 rec_hit.
setID(
id.raw());
367 hcal_rec_hits.push_back(rec_hit);
375 std::set<int> real_hits;
376 for (
auto const& sim_hit : hcal_sim_hits) real_hits.insert(sim_hit.getID());
377 for (
auto& hit : hcal_rec_hits)
378 hit.setNoise(real_hits.find(hit.getID()) == real_hits.end());