187 std::string trace_buf{};
188 auto trace = std::back_inserter(trace_buf);
190 const EventContext& ctx = Gaudi::Hive::currentContext();
191 const auto& evtID = ctx.eventID();
194 setFilterPassed(
false);
198 std::unique_ptr<const xAOD::EventInfo> hsEvt =
nullptr;
199 std::unique_ptr<xAOD::EventAuxInfo> hsEvtAux =
nullptr;
205 std::make_unique<xAOD::EventAuxInfo>()));
206 *overlaidEvt = *hsEvt;
208 overlaidEvt->clearSubEvents();
212 overlaidEvt->setRunNumber(evtID.run_number());
213 overlaidEvt->setLumiBlock(evtID.lumi_block());
214 overlaidEvt->setEventNumber(evtID.event_number());
215 overlaidEvt->setBCID(evtID.bunch_crossing_id());
216 overlaidEvt->setTimeStamp(evtID.time_stamp());
217 overlaidEvt->setTimeStampNSOffset(evtID.time_stamp_ns_offset());
220 if (!beamSpotHandle.
isValid()) {
222 return StatusCode::FAILURE;
225 overlaidEvt->setBeamPos(beamSpotHandle->beamPos()[
Amg::x],
226 beamSpotHandle->beamPos()[
Amg::y],
227 beamSpotHandle->beamPos()[
Amg::z]);
228 overlaidEvt->setBeamPosSigma(beamSpotHandle->beamSigma(0),
229 beamSpotHandle->beamSigma(1),
230 beamSpotHandle->beamSigma(2));
231 overlaidEvt->setBeamPosSigmaXY(beamSpotHandle->beamSigmaXY());
232 overlaidEvt->setBeamTiltXZ(beamSpotHandle->beamTilt(0));
233 overlaidEvt->setBeamTiltYZ(beamSpotHandle->beamTilt(1));
234 overlaidEvt->setBeamStatus(beamSpotHandle->beamStatus());
239 std::make_unique<xAOD::EventInfoAuxContainer>()));
242 m_beamInt->selectT0(evtID.run_number(), evtID.event_number());
243 overlaidEvt->setBCID(
m_beamInt->getCurrentT0BunchCrossing());
246 overlaidEvt->setEventTypeBitmask(hsEvt->eventTypeBitmask() |
250 bool sf_updated =
false;
251 float lumi_sf =
m_beamLumi->scaleFactor(evtID.run_number(),
252 evtID.lumi_block(), sf_updated);
253 float cur_avg_mu = lumi_sf *
m_avgMu;
254 overlaidEvt->setAverageInteractionsPerCrossing(cur_avg_mu);
255 overlaidEvt->setActualInteractionsPerCrossing(
m_beamInt->normFactor(0) *
260 std::format_to(trace,
261 "Idx: {} Run: {} LB: {} EVT: {} "
263 ctx.evt(), evtID.run_number(), evtID.lumi_block(),
268 [
this](
int bc) {
return int(
m_beamInt->normFactor(bc)); }) |
269#
if RANGE_V3_VERSION >= 1200
270 rv::chunk_by(std::equal_to{}) |
272 rv::group_by(std::equal_to{}) |
274 rv::transform([](
const auto& rng) {
275 return std::format(
"{}{}", rng.size(), rng[0] == 0 ?
'E' :
'F');
277 ranges::to<std::vector<std::string>>;
279 std::string joined_pattern;
280 for (
size_t i = 0; i < bunch_pattern.size(); ++i) {
281 joined_pattern += bunch_pattern[i];
282 if (i + 1 < bunch_pattern.size()) {
283 joined_pattern +=
" ";
287 std::format_to(trace,
288 "mu = {}, central BCID = {}, bunch pattern = [{}]\n",
289 cur_avg_mu,
m_beamInt->getCurrentT0BunchCrossing(),
293 if (!hsEvt->subEvents().empty()) {
294 for (
const SubEvent& se : hsEvt->subEvents()) {
321 std::uint32_t central_bcid = overlaidEvt->bcid();
322 std::vector<std::uint32_t> bcid{};
326 bcid.push_back(
get_BCID(bc, central_bcid));
336 std::uint64_t low_pt_count = 0;
337 std::uint64_t high_pt_count = 0;
338 std::uint64_t cavern_count = 0;
339 std::uint64_t beam_halo_count = 0;
340 std::uint64_t beam_gas_count = 0;
341 auto now = std::chrono::high_resolution_clock::now();
347 std::vector<std::uint64_t> subevts_vec{};
350 std::format_to(trace,
"\tBC {:03} : LOW PT {} ", bc,
353 for (std::size_t i = 0; i <
m_lowptMBSvc->getNumForBunch(ctx, bc); ++i) {
355 PUType::MinimumBias, bc, ctx, low_pt_count,
362 std::format_to(trace,
"HIGH PT {} | ",
365 for (std::size_t i = 0; i <
m_highptMBSvc->getNumForBunch(ctx, bc); ++i) {
367 PUType::HighPtMinimumBias, bc, ctx, high_pt_count,
374 std::format_to(trace,
"CAVERN {} | ",
377 for (std::size_t i = 0; i <
m_cavernMBSvc->getNumForBunch(ctx, bc); ++i) {
379 PUType::Cavern, bc, ctx, cavern_count,
386 std::format_to(trace,
"BEAM HALO {} | ",
392 PUType::HaloGas, bc, ctx, beam_halo_count,
399 std::format_to(trace,
"BEAM GAS {} | ",
402 for (std::size_t i = 0; i <
m_beamgasMBSvc->getNumForBunch(ctx, bc);
405 PUType::HaloGas, bc, ctx, beam_gas_count,
411 std::format_to(trace,
"TOTAL {} | HASH {:08X}\n", subevts_vec.size(),
416 std::format_to(trace,
"\n");
417 m_pileupTrace.print(trace_buf);
422 ATH_CHECK(tool->processAllSubEvents(ctx));
423 }
catch (
const std::exception& e) {
424 ATH_MSG_ERROR(
"Caught exception running " << tool.name() <<
": "
426 return StatusCode::FAILURE;
429 if (!tool->filterPassed()) {
430 setFilterPassed(
false);
433 ATH_MSG_DEBUG(std::format(
"***** Took {:%OMm %OSs} to process all subevents",
434 std::chrono::high_resolution_clock::now() - now));
444 overlaidEvt->setPileUpMixtureID(
446 ATH_MSG_DEBUG(
"PileUpMixtureID = " << overlaidEvt->pileUpMixtureID());
448 setFilterPassed(
true);
464 return StatusCode::SUCCESS;