120 const auto& the_conditions{
123 std::vector<ldmx::HcalHit> hcal_rec_hits;
129 unsigned int i_soi = hcal_digis.getSampleOfInterestIndex();
133 while (i_digi < num_digi_hits) {
134 auto digi_posend = hcal_digis.getDigi(i_digi);
137 bool is_adc_mode =
false;
144 auto position = hcal_geometry.getStripCenterPosition(
id);
145 double half_total_width =
146 hcal_geometry.getHalfTotalWidth(
id.section(),
id.layer());
147 double ecal_dx = hcal_geometry.getEcalDx();
148 double ecal_dy = hcal_geometry.getEcalDy();
154 float distance_posend, distance_negend, distance_ecal;
155 if (
id.section() == ldmx::HcalID::HcalSection::BACK) {
156 distance_posend = half_total_width;
157 distance_negend = half_total_width;
159 if ((
id.section() == ldmx::HcalID::HcalSection::TOP) ||
160 (
id.section() == ldmx::HcalID::HcalSection::BOTTOM)) {
161 distance_ecal = ecal_dx;
163 distance_ecal = ecal_dy;
165 distance_posend = 2 * half_total_width - distance_ecal / 2.;
166 distance_negend = distance_ecal / 2.;
171 double voltage_min(0.);
175 double ampl_t_posend(0.), ampl_tm1_posend(0.);
176 double ampl_t_negend(0.), ampl_tm1_negend(0.);
179 const auto orientation{hcal_geometry.getScintillatorOrientation(
id)};
180 int orientation_int =
static_cast<int>(orientation);
183 if (
id.section() == ldmx::HcalID::HcalSection::BACK) {
184 auto digi_negend = hcal_digis.getDigi(i_digi + 1);
187 double voltage_posend, voltage_negend;
189 if (digi_posend.isTOT()) {
192 (digi_posend.tot() - the_conditions.totCalib(id_posend, 0)) *
193 the_conditions.totCalib(id_posend, 1);
195 (digi_negend.tot() - the_conditions.totCalib(id_negend, 0)) *
196 the_conditions.totCalib(id_negend, 1);
201 digi_posend.soi().adcT() - the_conditions.adcPedestal(id_posend);
203 digi_posend.soi().adcTm1() - the_conditions.adcPedestal(id_posend);
205 digi_negend.soi().adcT() - the_conditions.adcPedestal(id_negend);
207 digi_negend.soi().adcTm1() - the_conditions.adcPedestal(id_negend);
220 voltage_posend = ampl_t_posend * the_conditions.adcGain(id_posend, 0);
221 voltage_negend = ampl_t_negend * the_conditions.adcGain(id_negend, 0);
226 getTOA(digi_posend, the_conditions.adcPedestal(id_posend), i_soi);
228 getTOA(digi_negend, the_conditions.adcPedestal(id_negend), i_soi);
231 int position_bar_sign = (toa_posend - toa_negend) > 0 ? 1 : -1;
245 double v = 299.792 / 1.6;
246 double position_bar =
247 position_bar_sign * fabs(toa_posend - toa_negend) * v / 2;
255 exp(-1. * ((distance_posend - position_bar) / 1000.) /
attlength_);
257 exp(-1. * ((distance_negend + position_bar) / 1000.) /
attlength_);
260 voltage = (voltage_posend + voltage_negend);
261 voltage_min = std::min(voltage_posend, voltage_negend);
264 ampl_t = (ampl_t_posend / att_posend + ampl_t_negend / att_negend) / 2;
268 ldmx::HcalGeometry::ScintillatorOrientation::horizontal) {
269 position.SetX(position_bar);
271 position.SetY(position_bar);
277 hit_time = fabs(toa_posend + toa_negend) / 2;
284 if (digi_posend.isTOT()) {
294 voltage_i = (digi_posend.tot() - the_conditions.totCalib(id_posend)) *
295 the_conditions.totCalib(id_posend);
303 digi_posend.soi().adcT() - the_conditions.adcPedestal(id_posend);
305 digi_posend.soi().adcTm1() - the_conditions.adcPedestal(id_posend);
306 voltage_i = ampl_t_posend * the_conditions.adcGain(id_posend);
311 double distance_end =
312 id_posend.
isNegativeEnd() ? distance_negend : distance_posend;
313 double att = exp(-1. * ((distance_end - fabs(half_total_width)) / 1000.) /
318 voltage_min = voltage_i;
321 ampl_t = ampl_t_posend / att;
325 getTOA(digi_posend, the_conditions.adcPedestal(id_posend), i_soi);
337 double energy_deposited = num_mips_equivalent *
mip_energy_;
357 double reconstructed_energy = energy_deposited;
364 rec_hit.
setID(
id.raw());
373 rec_hit.
setIsADC(is_adc_mode ? 1 : 0);
378 hcal_rec_hits.push_back(rec_hit);
387 std::set<int> real_hits;
388 for (
auto const& sim_hit : hcal_sim_hits) real_hits.insert(sim_hit.getID());
389 for (
auto& hit : hcal_rec_hits)
390 hit.setNoise(real_hits.find(hit.getID()) == real_hits.end());