48 bool LLRW(
float pqcd,
float ptop,
float phbb,
float &
w) {
53 double denom = pqcd*(1.-topfrac)+ptop*topfrac;
63 bool CalcRelPt (
float muonPt,
float muonEta,
float muonPhi,
float jetPt,
float jetEta,
float jetPhi,
float &RelPt) {
68 float muonT, muonX, muonY, muonZ,
muon, jetT, jetX, jetY, jetZ,
jet, scprod;
70 muonT = 2.*
atan(
exp(-muonEta) );
72 if ( (std::abs(muonT) > 0.) && (std::abs(jetT) > 0.) ) {
73 muon = muonPt/std::abs(
sin(muonT) );
74 muonX = muonPt*
cos(muonPhi);
75 muonY = muonPt*
sin(muonPhi);
77 jet = jetPt/std::abs(
sin(jetT) );
78 jetX = jetPt*
cos(jetPhi);
79 jetY = jetPt*
sin(jetPhi);
81 scprod = (muonX*jetX + muonY*jetY + muonZ*jetZ)/(
muon*
jet);
83 if ( (1. - scprod) > 0. ) {
84 RelPt =
muon * sqrt(1. - scprod);
103 if(
m_trigDecTool->ExperimentalAndExpertMethods().isHLTTruncated()) {
105 return StatusCode::SUCCESS;
111 bool Eofflinepv(
false);
112 float offlinepvz(-1.e6);
113 float offlinepvx(-1.e6);
114 float offlinepvy(-1.e6);
125 return StatusCode::FAILURE;
128 if ( offlinepv->
size() ) {
130 offlinepvz = offlinepv->
front()->z();
131 offlinepvx = offlinepv->
front()->x();
132 offlinepvy = offlinepv->
front()->y();
133 OffNVtx = offlinepv->
size() ;
134 for (
unsigned int j = 0; j<offlinepv->
size(); j++) {
135 if ( (*(offlinepv))[j]->nTrackParticles()==0 )
continue;
136 if ( (*(offlinepv))[j]->
vertexType()==0 )
continue;
137 OffxVtx = (*(offlinepv))[j]->x();
138 OffyVtx = (*(offlinepv))[j]->y();
139 OffzVtx = (*(offlinepv))[j]->z();
140 fill(
"TrigBjetMonitor",OffxVtx,OffyVtx,OffzVtx);
142 fill(
"TrigBjetMonitor",OffNVtx);
151 ATH_MSG_DEBUG(
" Size of the AllChains trigger container: " << size_AllChains );
152 for (
int i =0;
i<size_AllChains;
i++) {
159 bool mujetChain(
false);
160 bool bjetChain(
true);
161 bool L2bjetChain(
false);
168 ATH_MSG_DEBUG(
" Trigger chain from AllChains list: " << trigName <<
" has fired !!! " );
173 const bool expressPass =
passBits & TrigDefs::Express_passed;
184 std::size_t
found = trigName.find(
"HLT_mu");
185 if (
found!=std::string::npos) mujetChain =
true;
187 found = trigName.find(
"a10sd_cssk");
188 if (
found!=std::string::npos) L2bjetChain =
true;
189 else bjetChain =
true;
192 ATH_MSG_DEBUG(
" ===> Run 3 access to Trigger Item: " << trigName );
193 ATH_MSG_DEBUG(
" bjetChain: " << bjetChain <<
" mujetChain: " << mujetChain <<
" L2bjetChain: " << L2bjetChain );
213 std::string NameH =
"PVz_tr_"+trigName;
219 fill(
"TrigBjetMonitor",PVz_tr);
221 NameH =
"DiffOnOffPVz_tr_"+trigName;
224 DiffOnOffPVz_tr = vtx->z()-offlinepvz;
226 fill(
"TrigBjetMonitor",DiffOnOffPVz_tr);
228 NameH =
"PVx_tr_"+trigName;
233 fill(
"TrigBjetMonitor",PVx_tr);
235 NameH =
"DiffOnOffPVx_tr_"+trigName;
238 DiffOnOffPVx_tr = vtx->x()-offlinepvx;
240 fill(
"TrigBjetMonitor",DiffOnOffPVx_tr);
242 NameH =
"PVy_tr_"+trigName;
247 fill(
"TrigBjetMonitor",PVy_tr);
249 NameH =
"DiffOnOffPVy_tr_"+trigName;
252 DiffOnOffPVy_tr = vtx->y()-offlinepvy;
254 fill(
"TrigBjetMonitor",DiffOnOffPVy_tr);
258 std::string NpvH =
"nPV_tr_"+trigName;
262 fill(
"TrigBjetMonitor",nPV_tr);
271 std::string nJetH =
"LargeR_nJet_"+trigName;
273 nJet = onlinejets.size();
275 fill(
"TrigBjetMonitor",nJet);
276 for(
const auto& jetLinkInfo : onlinejets) {
285 std::string NameH =
"GN2XTrig_pqcd_tr_"+trigName;
288 GN2XTrig_pqcd = isGN2XTrigAvailable ? pqcd_accessor(*
jet) : -1.;
289 fill(
"TrigBjetMonitor",GN2XTrig_pqcd);
291 NameH =
"GN2XTrig_ptop_tr_"+trigName;
294 GN2XTrig_ptop = isGN2XTrigAvailable ? ptop_accessor(*
jet) : -1.;
295 fill(
"TrigBjetMonitor",GN2XTrig_ptop);
297 NameH =
"GN2XTrig_phbb_tr_"+trigName;
300 GN2XTrig_phbb = isGN2XTrigAvailable ? phbb_accessor(*
jet) : -1.;
301 fill(
"TrigBjetMonitor",GN2XTrig_phbb);
303 NameH =
"GN2XTrig_mv_tr_"+trigName;
306 ATH_MSG_DEBUG(
" GN2XTrig_pqcd: " << GN2XTrig_pqcd <<
" GN2XTrig_ptop: " << GN2XTrig_ptop <<
" GN2XTrig_phbb: " << GN2XTrig_phbb );
307 bool theLLRW =
LLRW (GN2XTrig_pqcd, GN2XTrig_ptop, GN2XTrig_phbb, GN2XTrig_mv);
308 ATH_MSG_DEBUG(
" GN2XTrig_mv: " << GN2XTrig_mv <<
" LLRW: " << theLLRW);
309 if ( theLLRW )
fill(
"TrigBjetMonitor",GN2XTrig_mv);
312 NameH =
"LargeR_jetPt_"+trigName;
315 LargeR_jetPt = (
jet->pt())*1.
e-3;
317 fill(
"TrigBjetMonitor",LargeR_jetPt);
320 NameH =
"LargeR_jetEta_"+trigName;
323 LargeR_jetEta =
jet->eta();
326 NameH =
"LargeR_jetPhi_"+trigName;
329 LargeR_jetPhi =
jet->phi();
330 ATH_MSG_DEBUG(
" LargeR_jetEta: " << LargeR_jetEta <<
" LargeR_jetPhi : " << LargeR_jetPhi);
331 fill(
"TrigBjetMonitor",LargeR_jetEta,LargeR_jetPhi);
334 NameH =
"LargeR_jetMass_"+trigName;
337 LargeR_jetMass = (
jet->m())*1.
e-3;
339 fill(
"TrigBjetMonitor",LargeR_jetMass);
347 NameH =
"GN2Xv01_pqcd_tr_"+trigName;
350 GN2Xv01_pqcd = isGN2Xv01Available ? pqcd_accessor0(*
jet) : -1.;
351 fill(
"TrigBjetMonitor",GN2Xv01_pqcd);
353 NameH =
"GN2Xv01_ptop_tr_"+trigName;
356 GN2Xv01_ptop = isGN2Xv01Available ? ptop_accessor0(*
jet) : -1.;
357 fill(
"TrigBjetMonitor",GN2Xv01_ptop);
359 NameH =
"GN2Xv01_phbb_tr_"+trigName;
362 GN2Xv01_phbb = isGN2Xv01Available ? phbb_accessor0(*
jet) : -1.;
363 fill(
"TrigBjetMonitor",GN2Xv01_phbb);
365 NameH =
"GN2Xv01_mv_tr_"+trigName;
368 ATH_MSG_DEBUG(
" GN2Xv01_pqcd: " << GN2Xv01_pqcd <<
" GN2Xv01_ptop: " << GN2Xv01_ptop <<
" GN2Xv01_phbb: " << GN2Xv01_phbb );
369 theLLRW =
LLRW (GN2Xv01_pqcd, GN2Xv01_ptop, GN2Xv01_phbb, GN2Xv01_mv);
370 ATH_MSG_DEBUG(
" GN2Xv01_mv: " << GN2Xv01_mv <<
" LLRW: " << theLLRW);
371 if ( theLLRW )
fill(
"TrigBjetMonitor",GN2Xv01_mv);
381 std::string nMuonH =
"nMuon_"+trigName;
383 nMuon = onlinemuons.size();
384 fill(
"TrigBjetMonitor",nMuon);
388 std::string nJetH =
"nJet_"+trigName;
390 nJet = onlinejets.size();
391 fill(
"TrigBjetMonitor",nJet);
393 if (nMuon*nJet > 0) {
395 float muonPt1(0.), muonEta1(0.), muonPhi1(0.), muonZ1(0.), jetPt1(0.), jetEta1(0.), jetPhi1(0.), jetZ1(0.), muonZ(0.);
396 double GN1_mv(0.), GN2_mv(0.);
397 bool theLLR_GN1(
false), theLLR_GN2(
false);
398 bool plotDeltaZ(
false);
400 for(
const auto& muonLinkInfo : onlinemuons) {
403 std::string NameH =
"muonPt_"+trigName;
406 muonPt = (
muon->pt())*1.
e-3;
408 fill(
"TrigBjetMonitor",muonPt);
410 NameH =
"muonEta_"+trigName;
413 muonEta =
muon->eta();
415 fill(
"TrigBjetMonitor",muonEta);
417 NameH =
"muonPhi_"+trigName;
420 muonPhi =
muon->phi();
423 auto link =
muon->combinedTrackParticleLink();
424 if (link.isValid()) {
442 for(
const auto& jetLinkInfo : onlinejets) {
445 NameH =
"jetPt_"+trigName;
448 jetPt = (
jet->pt())*1.
e-3;
450 fill(
"TrigBjetMonitor",jetPt);
452 NameH =
"jetEta_"+trigName;
457 fill(
"TrigBjetMonitor",jetEta);
459 NameH =
"jetPhi_"+trigName;
473 auto btaggingLinkInfo = TrigCompositeUtils::findLink<xAOD::BTaggingContainer>(jetLinkInfo.source,
m_btaggingLinkName);
475 if ( btaggingLinkInfo.isValid() ) {
476 obj_storing_btag = *(btaggingLinkInfo.link);
479 obj_storing_btag = *(jetLinkInfo.link);
491 if (GN1pu_accessor.
isAvailable(*obj_storing_btag)) {
492 double GN1_pu(-1.), GN1_pc(-1.), GN1_pb(-1.);
493 GN1_pu = GN1pu_accessor(*obj_storing_btag);
495 GN1_pc = GN1pc_accessor(*obj_storing_btag);
497 GN1_pb = GN1pb_accessor(*obj_storing_btag);
499 theLLR_GN1 =
LLR (GN1_pu, GN1_pc, GN1_pb, GN1_mv);
500 ATH_MSG_DEBUG(
" GN1_mv: " << GN1_mv <<
" LLR: " << theLLR_GN1);
502 if (GN2pu_accessor.
isAvailable(*obj_storing_btag)) {
503 double GN2_pu(-1.), GN2_pc(-1.), GN2_pb(-1.);
504 GN2_pu = GN2pu_accessor(*obj_storing_btag);
506 GN2_pc = GN2pc_accessor(*obj_storing_btag);
508 GN2_pb = GN2pb_accessor(*obj_storing_btag);
510 theLLR_GN2 =
LLR (GN2_pu, GN2_pc, GN2_pb, GN2_mv);
511 ATH_MSG_DEBUG(
" GN2_mv: " << GN2_mv <<
" LLR: " << theLLR_GN2);
526 std::string DeltaRH =
"DeltaR_"+trigName;
529 float DeltaEta = muonEta1 - jetEta1;
531 DeltaR = sqrt( DeltaEta*DeltaEta + DeltaPhi*DeltaPhi );
536 std::string DeltaZH =
"DeltaZ_"+trigName;
539 DeltaZ = std::abs(muonZ1-jetZ1);
541 if (plotDeltaZ)
fill(
"TrigBjetMonitor",DeltaZ);
544 std::string RatioPtH =
"RatioPt_"+trigName;
548 if (jetPt1 > 0.) RatioPt = muonPt1/jetPt1;
550 if (RatioPt > 0.)
fill(
"TrigBjetMonitor",RatioPt);
553 std::string RelPtH =
"RelPt_"+trigName;
557 bool calc_relpt =
CalcRelPt (muonPt1, muonEta1, muonPhi1, jetPt1, jetEta1, jetPhi1, RelPt);
561 std::string wGN1H =
"wGN1_"+trigName;
564 wGN1 =
float(GN1_mv);
566 if (calc_relpt && theLLR_GN1)
fill(
"TrigBjetMonitor",wGN1,RelPt);
569 std::string wGN2H =
"wGN2_"+trigName;
572 wGN2 =
float(GN2_mv);
574 if (calc_relpt && theLLR_GN2)
fill(
"TrigBjetMonitor",wGN2,RelPt);
589 std::string nJetH =
"nJet_"+trigName;
591 nJet = onlinejets.size();
592 fill(
"TrigBjetMonitor",nJet);
596 for(
const auto& jetLinkInfo : onlinejets) {
599 std::string NameH =
"jetPt_"+trigName;
602 jetPt = (
jet->pt())*1.
e-3;
604 fill(
"TrigBjetMonitor",jetPt);
606 NameH =
"jetEta_"+trigName;
611 NameH =
"jetPhi_"+trigName;
615 ATH_MSG_DEBUG(
" jetEta: " << jetEta <<
" jetPhi : " << jetPhi);
616 fill(
"TrigBjetMonitor",jetEta,jetPhi);
624 if ( vtxname.compare(0, 4,
"HLT_")==0 ) vtxname.erase(0,4);
625 auto vertexLinkInfo = TrigCompositeUtils::findLink<xAOD::VertexContainer>(jetLinkInfo.source, vtxname );
628 NameH =
"PVz_jet_"+trigName;
633 fill(
"TrigBjetMonitor",PVz_jet);
634 NameH =
"PVx_jet_"+trigName;
639 fill(
"TrigBjetMonitor",PVx_jet);
640 NameH =
"PVy_jet_"+trigName;
645 fill(
"TrigBjetMonitor",PVy_jet);
654 auto btaggingLinkInfo = TrigCompositeUtils::findLink<xAOD::BTaggingContainer>(jetLinkInfo.source,
m_btaggingLinkName);
655 if ( btaggingLinkInfo.isValid() ) {
656 obj_storing_btag = *(btaggingLinkInfo.link);
659 obj_storing_btag = *(jetLinkInfo.link);
670 bool GN1_available = GN1pu_accessor.
isAvailable(*obj_storing_btag);
671 bool GN2_available = GN2pu_accessor.
isAvailable(*obj_storing_btag);
672 NameH =
"GN1_pu_tr_"+trigName;
675 GN1_pu = GN1_available ? GN1pu_accessor(*obj_storing_btag) : -1.0;
677 fill(
"TrigBjetMonitor",GN1_pu);
679 NameH =
"GN1_pc_tr_"+trigName;
682 GN1_pc = GN1_available ? GN1pc_accessor(*obj_storing_btag) : -1.0;
684 fill(
"TrigBjetMonitor",GN1_pc);
686 NameH =
"GN1_pb_tr_"+trigName;
689 GN1_pb = GN1_available ? GN1pb_accessor(*obj_storing_btag) : -1.0;
691 fill(
"TrigBjetMonitor",GN1_pb);
693 NameH =
"GN1_mv_tr_"+trigName;
696 theLLR =
LLR (GN1_pu, GN1_pc, GN1_pb, GN1_mv);
697 if ( theLLR )
fill(
"TrigBjetMonitor",GN1_mv);
701 NameH =
"GN2_pu_tr_"+trigName;
704 GN2_pu = GN2_available ? GN2pu_accessor(*obj_storing_btag) : -1.0;
706 fill(
"TrigBjetMonitor",GN2_pu);
708 NameH =
"GN2_pc_tr_"+trigName;
711 GN2_pc = GN2_available ? GN2pc_accessor(*obj_storing_btag) : -1.0;
713 fill(
"TrigBjetMonitor",GN2_pc);
715 NameH =
"GN2_pb_tr_"+trigName;
718 GN2_pb = GN2_available ? GN2pb_accessor(*obj_storing_btag) : -1.0;
720 fill(
"TrigBjetMonitor",GN2_pb);
722 NameH =
"GN2_mv_tr_"+trigName;
725 theLLR =
LLR (GN2_pu, GN2_pc, GN2_pb, GN2_mv);
726 if ( theLLR )
fill(
"TrigBjetMonitor",GN2_mv);
731 const auto track_it_pair =
m_trigDecTool->associateToEventView(theTracks, jetLinkInfo.source,
"roi");
738 ATH_MSG_DEBUG(
" Track " <<
count <<
" with pT " << (*it)->pt() <<
" from BJet with pT " << (*jetLinkInfo.link)->pt() );
739 ATH_MSG_DEBUG(
" Track " <<
count <<
" with pT/eta/phi " << (*it)->pt() <<
"/" << (*it)->eta() <<
"/" << (*it)->phi() );
742 std::string NameH =
"trkPt_"+trigName;
745 trkPt = ((*it)->pt())*1.
e-3;
747 fill(
"TrigBjetMonitor",trkPt);
748 NameH =
"trkEta_"+trigName;
751 trkEta = (*it)->eta();
752 NameH =
"trkPhi_"+trigName;
755 trkPhi = (*it)->phi();
756 ATH_MSG_DEBUG(
" trkEta: " << trkEta <<
" trkPhi : " << trkPhi);
757 fill(
"TrigBjetMonitor",trkEta,trkPhi);
758 NameH =
"d0_"+trigName;
763 fill(
"TrigBjetMonitor",
d0);
764 NameH =
"z0_"+trigName;
769 fill(
"TrigBjetMonitor",
z0);
770 NameH =
"ed0_"+trigName;
773 ed0 =
Amg::error((*it)->definingParametersCovMatrix(), 0);
775 fill(
"TrigBjetMonitor",ed0);
776 NameH =
"sd0_"+trigName;
780 if (ed0 > 0.) sd0 = std::abs(
d0)/ed0;
782 fill(
"TrigBjetMonitor",sd0);
783 NameH =
"ez0_"+trigName;
786 ez0 =
Amg::error((*it)->definingParametersCovMatrix(), 1);
788 fill(
"TrigBjetMonitor",ez0);
795 ATH_MSG_DEBUG(
" Total number of triggered b-jets: " << ijet <<
" nJet : " << nJet);
796 ATH_MSG_DEBUG(
" Total number of triggered tracks associated to the b-jets: " << itrack);
797 std::string nTrackH =
"nTrack_"+trigName;
800 fill(
"TrigBjetMonitor",nTrack);
807 ATH_MSG_DEBUG(
" Chain " << trigName <<
" is declared for the Express Stream but it is NOT in the Express Stream in an Express Job");
811 ATH_MSG_DEBUG(
" Trigger chain from AllChains list: " << trigName <<
" has not fired " );
817 return StatusCode::SUCCESS;