121 const auto& the_conditions{
124 std::vector<ldmx::HcalHit> hcalRecHits;
130 unsigned int iSOI = hcalDigis.getSampleOfInterestIndex();
134 while (iDigi < numDigiHits) {
135 auto digi_posend = hcalDigis.getDigi(iDigi);
142 auto position = hcalGeometry.getStripCenterPosition(
id);
143 double half_total_width =
144 hcalGeometry.getHalfTotalWidth(
id.section(),
id.layer());
145 double ecal_dx = hcalGeometry.getEcalDx();
146 double ecal_dy = hcalGeometry.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 amplT_posend(0.), amplTm1_posend(0.);
173 double amplT_negend(0.), amplTm1_negend(0.);
176 const auto orientation{hcalGeometry.getScintillatorOrientation(
id)};
177 int orientation_int =
static_cast<int>(orientation);
180 if (
id.section() == ldmx::HcalID::HcalSection::BACK) {
181 auto digi_negend = hcalDigis.getDigi(iDigi + 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().adc_t() - the_conditions.adcPedestal(id_posend);
196 digi_posend.soi().adc_tm1() - the_conditions.adcPedestal(id_posend);
198 digi_negend.soi().adc_t() - the_conditions.adcPedestal(id_negend);
200 digi_negend.soi().adc_tm1() - the_conditions.adcPedestal(id_negend);
211 voltage_posend = amplT_posend * the_conditions.adcGain(id_posend, 0);
212 voltage_negend = amplT_negend * the_conditions.adcGain(id_negend, 0);
217 getTOA(digi_posend, the_conditions.adcPedestal(id_posend), iSOI);
219 getTOA(digi_negend, the_conditions.adcPedestal(id_negend), iSOI);
222 int position_bar_sign = (TOA_posend - TOA_negend) > 0 ? 1 : -1;
236 double v = 299.792 / 1.6;
237 double position_bar =
238 position_bar_sign * fabs(TOA_posend - TOA_negend) * v / 2;
246 exp(-1. * ((distance_posend - position_bar) / 1000.) /
attlength_);
248 exp(-1. * ((distance_negend + position_bar) / 1000.) /
attlength_);
251 voltage = (voltage_posend + voltage_negend);
252 voltage_min = std::min(voltage_posend, voltage_negend);
255 amplT = (amplT_posend / att_posend + amplT_negend / att_negend) / 2;
259 ldmx::HcalGeometry::ScintillatorOrientation::horizontal) {
260 position.SetX(position_bar);
262 position.SetY(position_bar);
268 hitTime = fabs(TOA_posend + TOA_negend) / 2;
275 if (digi_posend.isTOT()) {
284 voltage_i = (digi_posend.tot() - the_conditions.totCalib(id_posend)) *
285 the_conditions.totCalib(id_posend);
291 digi_posend.soi().adc_t() - the_conditions.adcPedestal(id_posend);
293 digi_posend.soi().adc_tm1() - the_conditions.adcPedestal(id_posend);
294 voltage_i = amplT_posend * the_conditions.adcGain(id_posend);
299 double distance_end =
300 id_posend.
isNegativeEnd() ? distance_negend : distance_posend;
301 double att = exp(-1. * ((distance_end - fabs(half_total_width)) / 1000.) /
306 voltage_min = voltage_i;
309 amplT = amplT_posend / att;
313 getTOA(digi_posend, the_conditions.adcPedestal(id_posend), iSOI);
325 double energy_deposited = num_mips_equivalent *
mip_energy_;
345 double reconstructed_energy = energy_deposited;
352 recHit.
setID(
id.raw());
365 hcalRecHits.push_back(recHit);
373 std::set<int> real_hits;
374 for (
auto const& sim_hit : hcalSimHits) real_hits.insert(sim_hit.getID());
375 for (
auto& hit : hcalRecHits)
376 hit.setNoise(real_hits.find(hit.getID()) == real_hits.end());