12#include "TLorentzVector.h"
22#include "GaudiKernel/IInterface.h"
48 ISvcLocator* pSvcLocator):
57 m_selTool(
"InDet::InDetTrackSelectionTool/TrackSelectionTool"),
182 return StatusCode::FAILURE;
191 return StatusCode::FAILURE;
199 return StatusCode::FAILURE;
210 return StatusCode::FAILURE;
233 ATH_MSG_INFO(
" -- IDPerfMonZmumu::initialize() -- init m_beamSpotKey ");
260 m_4mu.setDebugMode(
true);
271 return StatusCode::FAILURE;
279 return StatusCode::FAILURE;
287 return StatusCode::FAILURE;
294 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::Initialize ** Completed **");
295 return StatusCode::SUCCESS;
303 m_h_cutflow =
new TH1F(
"h_cutflow",
"cut flow histogram",11, -0.5, 9.5);
423 bool isTreeNone =
false;
424 if (
m_IDTreeName.find(
"none") != std::string::npos) isTreeNone =
true;
598 if (
m_combTreeName.find(
"none") != std::string::npos) isTreeNone =
true;
654 if (
m_MSTreeName.find(
"none") != std::string::npos) isTreeNone =
true;
656 ATH_MSG_INFO(
"initialize() ** defining IDPerfMon MSTree ");
819 ATH_MSG_INFO(
"initialize() Going to register the mu+mu- trees");
821 if (tHistSvc.retrieve().isFailure()){
822 ATH_MSG_ERROR(
"initialize() Could not find Hist Service -> Switching ValidationMode Off !");
828 ATH_MSG_INFO(
"initialize() commonTree succesfully registered!");
831 ATH_MSG_ERROR(
"initialize() Could not register the validation commonTree -> Switching ValidationMode Off !");
839 ATH_MSG_INFO(
"initialize() IDTree succesfully registered!");
842 ATH_MSG_ERROR(
"initialize() Could not register the validation IDTree -> Switching ValidationMode Off !");
855 ATH_MSG_INFO(
"initialize() CBTree succesfully registered!");
858 ATH_MSG_ERROR(
"initialize() Could not register the validation CBTree -> Switching ValidationMode Off !");
872 ATH_MSG_INFO(
"initialize() MSTree succesfully registered!");
875 ATH_MSG_ERROR(
"initialize() Could not register the validation MSTree -> Switching ValidationMode Off !");
885 ATH_MSG_INFO(
"initialize() Refit1 Tree succesfully registered!");
888 ATH_MSG_ERROR(
"initialize() Could not register the validation Tree -> Switching ValidationMode Off !");
896 ATH_MSG_INFO(
"initialize() Refit2 Tree succesfully registered!");
899 ATH_MSG_ERROR(
"initialize() Could not register the validation Tree -> Switching ValidationMode Off !");
908 ATH_MSG_INFO(
"initialize() truthTree Tree succesfully registered!");
911 ATH_MSG_ERROR(
"initialize() Could not register the validation truth Tree -> Switching ValidationMode Off !");
919 ATH_MSG_INFO(
"initialize() FourMu Tree succesfully registered!");
922 ATH_MSG_ERROR(
"initialize() Could not register the validation FourMu Tree -> Switching ValidationMode Off !");
928 return StatusCode::SUCCESS;
949 m_event_mu = eventInfo->actualInteractionsPerCrossing();
950 if (eventInfo->mcEventWeights().size()>0) {
959 ATH_MSG_DEBUG(
" IDPerfMonZmumu::execute evtStore->retrieve (eventInfo) failed .. trying another strategy.. ");
965 m_event_mu = eventInfo2->actualInteractionsPerCrossing();
966 if (eventInfo->mcEventWeights().size()>0) {
975 ATH_MSG_ERROR(
"** IDPerfMonZmumu::execute ** Could not retrieve event info.");
981 ATH_MSG_DEBUG(
" ** IDPerfMonZmumu::execute ** calling FourLeptonAnalysis()...");
983 if (fourLeptAnaStatus.isSuccess())
ATH_MSG_INFO (
" ** IDPerfMonZmumu::execute ** RunFourLeptonAnalysis() SUCCESS -> found a new event");
989 ATH_MSG_DEBUG(
" ** IDPerfMonZmumu::execute ** calling dimuon analysis m_xZmm.Reco()...");
994 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV "
996 <<
" ** SUCCESS **");
1002 <<
" Failed dimuon reconstruction. m_xZmm.Reco() returned FALSE ");
1003 return StatusCode::SUCCESS;
1012 if (isTriggerPassed == StatusCode::SUCCESS) {
1016 ATH_MSG_DEBUG(
"Trigger Failed -> reject event --> leave event");
1017 return StatusCode::SUCCESS;
1029 StatusCode success_pos = StatusCode::FAILURE;
1030 StatusCode success_neg = StatusCode::FAILURE;
1032 if (muon_pos && muon_neg) {
1036 ATH_MSG_INFO(
"** IDPerfMonZmumu::execute ** Retrieving InnerDetectorTrackParticles of the accepted muons");
1037 ppos_comb = muon_pos->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle);
1038 pneg_comb = muon_neg->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle);
1040 if (!ppos_comb || !pneg_comb) {
1041 ATH_MSG_WARNING(
"** IDPerfMonZmumu::execute ** InnerDetectorTrackParticles are requested but they are not present. Exiting event.");
1042 return StatusCode::SUCCESS;
1047 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Retrieving CombinedTrackParticles of the accepted muons");
1048 ppos_comb = muon_pos->
trackParticle(xAOD::Muon::CombinedTrackParticle);
1049 pneg_comb = muon_neg->
trackParticle(xAOD::Muon::CombinedTrackParticle);
1051 if (!ppos_comb || !pneg_comb){
1052 ATH_MSG_WARNING(
"** IDPerfMonZmumu::execute ** CombinedTrackParticles are requested but they are not present. Exiting event.");
1053 return StatusCode::SUCCESS;
1059 if (ppos_comb && pneg_comb) {
1068 const EventContext& ctx = Gaudi::Hive::currentContext();
1070 for (
const auto V : *vertices) {
1080 if (!ppos_comb_v || !pneg_comb_v){
1081 ATH_MSG_WARNING(
"Some or all of the requested particles have no vertex. Exiting event");
1082 return StatusCode::SUCCESS;
1086 ATH_MSG_WARNING(
"** IDPerfMonZmumu::execute ** Could not find CombinedMuon pos/neg in event"
1090 return StatusCode::SUCCESS;
1097 if (
m_xZmm.AcceptEvent() ) {
1101 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ** some preliminaries are due though...");
1106 ATH_MSG_DEBUG(
"Exiting because the ID segment of muon_pos do not pass the TrackSelection");
1107 return StatusCode::SUCCESS;
1110 ATH_MSG_DEBUG(
"Exiting because the ID segment of muon_neg do not pass the TrackSelection");
1111 return StatusCode::SUCCESS;
1113 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Good news ** pos and neg muon->trackParticle(xAOD::Muon::InnerDetectorTrackParticle) pass the trackSelection :)");
1116 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track selection is not in use ");
1128 muon_pos->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle),
1132 muon_neg->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle),
1136 if (success_pos && success_neg) {
1146 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ");
1151 <<
" pt: " << muon_pos->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle)->
pt()
1159 <<
" pt: " << muon_neg->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle)->
pt()
1191 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** not filling IDTracks in combTree due to problems with muon_xxx->trackParticle(xAOD::Muon::InnerDetectorTrackParticle)");
1199 muon_pos->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle),
1204 muon_neg->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle),
1209 if (success_pos && success_neg) {
1215 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ");
1264 muon_pos->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle),
1269 muon_neg->
trackParticle(xAOD::Muon::InnerDetectorTrackParticle),
1272 if (success_pos && success_neg) {
1277 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ");
1305 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Going to build TrackCollections: muonTrks, muonTrksRefit1 and muonTrksRefit2");
1310 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Going to refit and store the track parameters ");
1318 StatusCode fitStatus;
1320 const EventContext& ctx = Gaudi::Hive::currentContext();
1321 if( ppos_comb->
track() ) {
1326 if (fitStatus.isFailure()) {
1327 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track Refit1 Failed for ppos_comb->track(). Skipping Event");
1328 return StatusCode::SUCCESS;
1331 muonTrksRefit1->
push_back(refit1MuonTrk1);
1332 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track Refit1 Success of ppos_comb->track()."
1339 if (fitStatus.isFailure()) {
1340 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track Refit2 Failed for ppos_comb->track(). Skipping Event");
1341 return StatusCode::SUCCESS;
1344 muonTrksRefit2->
push_back(refit2MuonTrk1);
1345 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track Refit2 Success of ppos_comb->track()."
1351 if( pneg_comb->
track() ) {
1356 if (fitStatus.isFailure()) {
1357 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track Refit1 Failed. Skipping Event");
1358 return StatusCode::SUCCESS;
1361 muonTrksRefit1->
push_back(refit1MuonTrk2);
1362 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track Refit1 Success of pneg_comb->track()."
1369 if (fitStatus.isFailure()) {
1371 return StatusCode::SUCCESS;
1374 muonTrksRefit2->
push_back(refit2MuonTrk2);
1375 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** Track Refit2 Success of pneg_comb->track()."
1380 if (muonTrksRefit1->
size() != 2)
ATH_MSG_WARNING(
"** IDPerfMonZmumu::execute ** WARNING ** size of muonTrksRefit1: " << muonTrksRefit1->
size());
1381 if (muonTrksRefit2->
size() != 2)
ATH_MSG_WARNING(
"** IDPerfMonZmumu::execute ** WARNING ** size of muonTrksRefit2: " << muonTrksRefit2->
size());
1389 if (
sc.isSuccess()) {
1396 if (muonTrksRefit1->
size() > 1) {
1398 if (
sc.isSuccess()) {
1405 if (muonTrksRefit2->
size() > 1) {
1407 if (
sc.isSuccess()) {
1416 if (muonTrksRefit1->
size()<2) {
1417 ATH_MSG_WARNING(
"** IDPerfMonZmumu::execute ** Refit1 muon tracks are missing!");
1420 ATH_MSG_DEBUG(
"** IDPerfMonZmumu::execute ** going to fill refit1tree ");
1425 if (success_pos && success_neg) {
1431 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ");
1471 if (muonTrksRefit2->
size()<2) {
1472 ATH_MSG_WARNING(
"** IDPerfMonZmumu::execute ** Refit2 muon tracks are missing!");
1480 if (success_pos && success_neg) {
1486 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ");
1529 if ( !
m_xZmm.AcceptEvent() ) {
1533 return StatusCode::SUCCESS;
1540 bool truthStatusIsGood =
true;
1542 truthStatusIsGood =
false;
1546 truthStatusIsGood =
false;
1549 if (truthStatusIsGood) {
1554 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ");
1596 bool dofill =
false;
1608 <<
" Invariant mass = " <<
m_xZmm.GetInvMass() <<
" GeV ");
1632 for (
auto muon : *muons) {
1633 const xAOD::TrackParticle* tp = muon->trackParticle(xAOD::Muon::InnerDetectorTrackParticle);
1635 ATH_MSG_DEBUG(
" - tpb = "<< tp <<
" -> is null? " << (!tp));
1643 const Trk::Perigee* tPerigee = t->perigeeParameters() ;
1656 StatusCode scid =
evtStore()->record(IDTracks,
"IDTracks");
1657 if (scid.isSuccess()) {
1668 return StatusCode::SUCCESS;
1679 return StatusCode::FAILURE;
1683 return StatusCode::FAILURE;
1700 double sigma_pt = 0;
1702 double sigma_qOverP = 1.;
1705 px = trackp->
p4().Px();
1706 py = trackp->
p4().Py();
1707 pt = trackp->
p4().Pt();
1708 pz = trackp->
p4().Pz();
1709 phi= trackp->
p4().Phi();
1710 eta= trackp->
p4().Eta();
1713 qoverp = trackp->
qOverP();
1722 double sigma_pt_term1 = (sin(trackp->
theta()) /
pow(qoverp,2)) * sigma_qOverP;
1723 double sigma_pt_term2 = (1./qoverp) * cos(trackp->
theta()) * sigma_theta;
1724 double sigma_pt_term3 = (cos(trackp->
theta()) /
pow(qoverp,2)) * sigma_theta * sigma_qOverP;
1728 if (vertex ==
nullptr) {
1730 return StatusCode::FAILURE;
1733 ATH_MSG_WARNING(
"in FillRecParametersTP. WARNING: m_trackToVertexIPEstimator is NULL");
1734 return StatusCode::FAILURE;
1738 std::unique_ptr<Trk::ImpactParametersAndSigma> iPandSigma(
nullptr);
1745 ATH_MSG_DEBUG(
"return from the trackToVertexIPEstimator->estimate()");
1748 ATH_MSG_WARNING (
"FillRecParametersTP::trackToVertexIPEstimator failed !");
1749 return StatusCode::FAILURE;
1752 ATH_MSG_DEBUG(
"FillRecParametersTP::trackToVertexIPEstimator success !");
1753 PVd0 = iPandSigma->IPd0;
1754 PVd0res = iPandSigma->PVsigmad0;
1755 d0res = iPandSigma->sigmad0;
1756 PVz0 = iPandSigma->IPz0;
1757 PVz0res = iPandSigma->PVsigmaz0;
1758 z0res = iPandSigma->sigmaz0;
1782 ATH_MSG_DEBUG(
"(Filled charge == 1 ) (reco)-> px : "<< px <<
" py: "<<py <<
" pt: "<<pt <<
" pz: "<<pz
1783 <<
" d0: "<<
m_positive_d0 <<
" d0res : "<< d0res <<
" PVd0res : "<< PVd0res <<
" z0: "<<
m_positive_z0 <<
" z0res : " << z0res <<
" PVz0res : "<< PVz0res );
1785 }
else if (
charge == -1) {
1805 ATH_MSG_DEBUG(
"(Filled charge == -1 ) (reco)-> px : "<< px <<
" py: "<< py <<
" pt: " << pt <<
" pz: "<<pz
1806 <<
" d0: "<<
m_negative_d0 <<
" d0res : "<< d0res <<
" PVd0res : "<< PVd0res <<
" z0: "<<
m_negative_z0 <<
" z0res : " << z0res <<
" PVz0res : "<< PVz0res );
1809 return StatusCode::SUCCESS;
1817 ATH_MSG_DEBUG(
"* FillRecParameters * Empty Track: track. Skipping.");
1818 return StatusCode::FAILURE;
1822 ATH_MSG_DEBUG(
"* FillRecParameters * Empty Track: trackp_for_unbias. Skipping.");
1823 return StatusCode::FAILURE;
1826 const Trk::Perigee* trkPerigee = track->perigeeParameters();
1839 double d0_err = 999.;
1840 double z0_err = 999.;
1848 if (trkPerigee !=
nullptr){
1849 double qOverP = trkPerigee->parameters()[
Trk::qOverP];
1853 pt = std::abs(trkPerigee->
pT());
1857 d0 = trkPerigee->parameters()[
Trk::d0];
1858 z0 = trkPerigee->parameters()[
Trk::z0];
1876 pt = std::abs(atBL->
pT());
1880 d0 = atBL->parameters()[
Trk::d0];
1881 z0 = atBL->parameters()[
Trk::z0];
1888 ATH_MSG_WARNING(
"FillRecParameters::Failed extrapolation to the BeamLine");
1892 TLorentzVector vtrack = TLorentzVector (trkPerigee->
momentum().x(),
1896 float trkd0 = trkPerigee->parameters()[
Trk::d0];
1897 float trkz0 = trkPerigee->parameters()[
Trk::z0];
1898 float bsX = position.x();
1899 float bsY = position.y();
1900 float bsZ = position.z();
1901 float btiltX = beamSpotHandleRec->beamTilt(0);
1902 float btiltY = beamSpotHandleRec->beamTilt(1);
1904 float beamX = bsX + std::tan(btiltX) * (trkz0-bsZ);
1905 float beamY = bsY + std::tan(btiltY) * (trkz0-bsZ);
1906 float beamD0 = ( -std::sin(vtrack.Phi())*beamX + std::cos(vtrack.Phi())*beamY );
1907 float d0bscorr = trkd0 - beamD0;
1908 float z0bscorr = trkz0 - bsZ;
1911 std::unique_ptr<Trk::ImpactParametersAndSigma> iPandSigma(
nullptr);
1914 if( iPandSigma==0 ){
1915 ATH_MSG_WARNING (
"FillRecParameters::trackToVertexIPEstimator failed !");
1916 return StatusCode::FAILURE;
1919 ATH_MSG_DEBUG(
"FillRecParameters::trackToVertexIPEstimator success !");
1920 PVd0 = iPandSigma->IPd0;
1921 PVd0res = iPandSigma->PVsigmad0;
1923 PVz0 = iPandSigma->IPz0;
1924 PVz0res = iPandSigma->PVsigmaz0;
1928 ATH_MSG_INFO(
" FillRecParameters::trackToVertexIPEstimator vertex does exist ");
1957 ATH_MSG_DEBUG(
"(Filled charge == 1 ) (reco)-> px : "<< px <<
" py: "<<py <<
" pz: "<<pz <<
" d0: "<<d0<<
" z0: "<< z0);
1978 ATH_MSG_DEBUG(
"(Filled charge == -1 ) (reco)-> px : "<< px <<
" py: "<<py <<
" pz: "<<pz <<
" d0: "<<d0<<
" z0: "<<z0 );
1981 return StatusCode::SUCCESS;
1987 ATH_MSG_DEBUG(
"* FillRecParametersSimple * Empty Track: track. Skipping.");
1988 return StatusCode::FAILURE;
1991 const Trk::Perigee* trkPerigee = track->perigeeParameters();
1992 if (not trkPerigee) {
1993 ATH_MSG_ERROR(
"trkPerigee pointer is null in IDPerfMonZmumu::FillRecParametersSimple");
1994 return StatusCode::FAILURE;
2005 double d0_err = 999.;
2006 double z0_err = 999.;
2009 double qOverP = trkPerigee->parameters()[
Trk::qOverP];
2013 pt = std::abs(trkPerigee->
pT());
2017 d0 = trkPerigee->parameters()[
Trk::d0];
2018 z0 = trkPerigee->parameters()[
Trk::z0];
2024 Amg::Vector3D position (eventInfo->beamPosX(), eventInfo->beamPosY(), eventInfo->beamPosZ());
2025 TLorentzVector vtrack = TLorentzVector (trkPerigee->
momentum().x(),
2029 float trkd0 = trkPerigee->parameters()[
Trk::d0];
2030 float trkz0 = trkPerigee->parameters()[
Trk::z0];
2031 float bsX = position.x();
2032 float bsY = position.y();
2033 float bsZ = position.z();
2034 float btiltX = eventInfo->beamTiltXZ();
2035 float btiltY = eventInfo->beamTiltYZ();
2037 float beamX = bsX + std::tan(btiltX) * (trkz0-bsZ);
2038 float beamY = bsY + std::tan(btiltY) * (trkz0-bsZ);
2039 float beamD0 = ( -std::sin(vtrack.Phi())*beamX + std::cos(vtrack.Phi())*beamY );
2040 float d0bscorr = trkd0 - beamD0;
2041 float z0bscorr = trkz0 - bsZ - vertex->z();
2072 ATH_MSG_DEBUG(
"-- FillRecParametersSimple -- charge " <<
charge <<
" pt: " << pt <<
" d0: " << d0 <<
" z0: " << z0);
2074 return StatusCode::SUCCESS;
2081 if (!trackParticle ){
2082 ATH_MSG_WARNING(
"-- FillTruthParameters -- Empty Trackparticle. Skipping.");
2083 return StatusCode::FAILURE;
2089 ATH_MSG_DEBUG(
" -- FillTruthParameters -- Failure while retrieving the truth particle. Returning FAILURE.");
2090 return StatusCode::FAILURE;
2093 if ( particle->pdgId() == 13)
charge = -1.;
2094 if ( particle->pdgId() == -13)
charge = 1.;
2095 if ( particle->isNeutral() ) {
2096 ATH_MSG_DEBUG(
" -- FillTruthParameters -- reco muon associated to a truth neutral!! Returning FAILURE.");
2097 return StatusCode::FAILURE;
2100 ATH_MSG_DEBUG(
" -- FillTruthParameters -- reco muon associated to a non true muon!! Returning FAILURE.");
2101 return StatusCode::FAILURE;
2104 const Amg::Vector3D momentum(particle->px(), particle->py(), particle->pz());
2106 ptruthVertex=particle->prodVtx();
2108 ATH_MSG_DEBUG(
"A production vertex pointer was retrieved, but it is NULL");
2109 return StatusCode::FAILURE;
2113 if (particle->parent(0) !=
nullptr) {
2117 ATH_MSG_DEBUG(
" -- FillTruthParameters -- truth particle is good. pdg: " << particle->pdgId()
2118 <<
" type: " << particle->type()
2119 <<
" nparents " << particle->nParents()
2120 <<
" parent->pdg: " << particle->parent(0)->pdgId()
2121 <<
" truthType: " << truthTypeAcc(*particle)
2122 <<
" truthOrigin: " << truthOriginAcc(*particle)
2127 ATH_MSG_DEBUG(
" -- FillTruthParameters -- truth particle is good. pdg: " << particle->pdgId()
2128 <<
" type: " << particle->type()
2129 <<
" nparents " << particle->nParents()
2130 <<
" parent->pdg: " << particle->parent(0)->pdgId()
2131 <<
" truthType & truthOrigin: " <<
" NOT AVAILABLE "
2136 const auto xPos=ptruthVertex->
x();
2137 const auto yPos=ptruthVertex->
y();
2138 const auto z_truth=ptruthVertex->
z();
2146 const EventContext& ctx = Gaudi::Hive::currentContext();
2167 ATH_MSG_DEBUG(
"reco IPs (pos): > d0 : "<<d0recoPos <<
" z0: " << z0recoPos <<
" trackp z0 : " << trackParticle->
z0() <<
" trackp d0 : " << trackParticle->
d0());
2168 ATH_MSG_DEBUG(
"reco IPs (neg): > d0 : "<<d0recoNeg <<
" z0: " << z0recoNeg <<
" trackp z0 : " << trackParticle->
z0() <<
" trackp d0 : " << trackParticle->
d0() );
2170 double qOverP_truth = 0.;
2175 px = tP->momentum().x();
2176 py = tP->momentum().y();
2178 pz = tP->momentum().z();
2181 d0 = tP->parameters()[
Trk::d0];
2182 z0 = tP->parameters()[
Trk::z0];
2184 ATH_MSG_DEBUG(
"cand perig HEP particle (truth) px : "<< tP->momentum().x());
2185 ATH_MSG_DEBUG(
"cand perig HEP particle (truth) py : "<< tP->momentum().y());
2186 ATH_MSG_DEBUG(
"cand perig HEP particle (truth) pz : "<< tP->momentum().z());
2209 bool parentfound =
false;
2210 if (particle->nParents()>0) {
2211 if (particle->parent(0) !=
nullptr) {
2226 }
else if (
charge == -1) {
2241 bool parentfound =
false;
2242 if (particle->nParents()>0) {
2243 if (particle->parent(0) !=
nullptr) {
2258 return StatusCode::SUCCESS;
2269 if( ! acc.isAvailable( p ) ) {
2273 const Link_t& link = acc( p );
2275 if( ! link.isValid() ) {
2286 return StatusCode::SUCCESS;
2297 return StatusCode::FAILURE;
2303 float thisEventTriggerPrescale = 999999.9;
2304 float thisHLTTriggerPrescale = 999999.9;
2305 bool thisHLTIsPassed =
false;
2306 std::string thisHLTTriggerName;
2307 std::string thisEventTriggerName;
2310 const std::vector<std::string> myHLTtriglist =
m_triggerDecision->getChainGroup(
"HLT_mu.*, HLT_2mu.*")->getListOfTriggers();
2311 for (
int i=0; i < (int) myHLTtriglist.size(); i++) {
2313 ATH_MSG_DEBUG(
"HLT trigger = " << i <<
" out of " << myHLTtriglist.size() <<
" --> " << myHLTtriglist.at(i) <<
" isPassed? " <<
m_triggerDecision->isPassed(myHLTtriglist.at(i)) <<
" prescale: " <<
m_triggerDecision->getChainGroup(myHLTtriglist.at(i))->getPrescale() );
2316 thisHLTIsPassed =
true;
2317 float thisprescale =
m_triggerDecision->getChainGroup(myHLTtriglist.at(i))->getPrescale();
2318 if (thisprescale < thisHLTTriggerPrescale) {
2319 thisHLTTriggerPrescale = thisprescale;
2320 thisHLTTriggerName = myHLTtriglist.at(i);
2324 if (thisHLTTriggerPrescale < 1) thisHLTTriggerPrescale = 1;
2325 ATH_MSG_DEBUG(
"Event HLT trigger prescale = " << thisHLTTriggerPrescale);
2328 if (thisHLTIsPassed) {
2333 return StatusCode::FAILURE;
2337 thisEventTriggerPrescale = thisHLTTriggerPrescale;
2338 thisEventTriggerName = thisHLTTriggerName;
2339 ATH_MSG_DEBUG(
"CheckTriggerStatusAndPrescale -- Event trigger prescale = " << thisEventTriggerPrescale);
2340 ATH_MSG_DEBUG(
"CheckTriggerStatusAndPrescale -- Event trigger name = " << thisEventTriggerName);
2346 return StatusCode::SUCCESS;
2360 for (
int ivtx=0; ivtx< (int) vxContainer->
size();ivtx++) {
2361 myVtx = (*vxContainer)[ivtx];
2533 StatusCode thisStatus = StatusCode::SUCCESS;
2554 if( electronTruth) {
2555 ATH_MSG_DEBUG (
"retrieving electron Truth container with key: \"egammaTruthParticles\" SUCCESS ");
2557 if( electronTruth->hasStore() ) {
2559 auto tr_itr = electronTruth->
begin();
2560 auto tr_end = electronTruth->
end();
2561 int electronCount = 0;
2562 for(
int i = 0; tr_itr != tr_end; ++tr_itr, ++i ) {
2563 ATH_MSG_DEBUG(
"Truth : Investigating truth electron #" << i <<
" pdgID= " << ( *tr_itr )->pdgId());
2564 if (fabs(( *tr_itr )->pdgId()) == 11) {
2565 if (( *tr_itr )->pt() > 10000 && fabs(( *tr_itr )->eta()) < 2.47) {
2566 ATH_MSG_INFO(
" central electron found --> pt: " << ( *tr_itr )->charge()*( *tr_itr )->pt() <<
" eta " <<( *tr_itr )->eta() );
2571 ATH_MSG_INFO(
"#central electrons: " << electronCount );
2574 ATH_MSG_WARNING (
"electronTruth container has no Store !!! FAILURE");
2578 ATH_MSG_WARNING (
"retrieve electron Truth container with key: \"egammaTruthParticles\" FAILURE");
2582 if (
m_doDebug) std::cout <<
" ** RunFourLeptonAnalysis ** calling m_4mu.Reco() .... " << std::endl;
2583 bool statusOf4LeptReco =
m_4mu.Reco();
2586 if(statusOf4LeptReco) {
2587 thisStatus = StatusCode::SUCCESS;
2588 ATH_MSG_INFO (
"4-lepton reconstruction SUCCESS. # accepted events " <<
m_4mu.getAcceptedEvents() <<
" Invariant mass = " <<
m_4mu.GetInvMass() <<
" GeV ");
2589 if (
m_doDebug) std::cout <<
" ** RunFourLeptonAnalysis ** 4-lepton reconstruction SUCCESS. # accepted events " <<
m_4mu.getAcceptedEvents() <<
" Invariant mass = " <<
m_4mu.GetInvMass() <<
" GeV " << std::endl;
2592 thisStatus = StatusCode::FAILURE;
2593 ATH_MSG_DEBUG (
"4-lepton reconstruction FAILURE. m_4mu.Reco() returned FALSE --> event failed selection");
2594 if (
m_doDebug) std::cout <<
" ** RunFourLeptonAnalysis ** 4-lepton reconstruction FAILURE. m_4mu.Reco() returned FALSE --> event failed selection" << std::endl;
2597 if(statusOf4LeptReco) {
2598 if (
m_4mu.EventPassed() ) {
2705 std::string metName =
"MET_Reference_AntiKt4LCTopo";
2706 std::string metRefFinalName =
"FinalClus";
2713 ATH_MSG_WARNING (
"No Collection with name " << metName <<
" found in StoreGate");
2717 StatusCode
sc =
evtStore()->retrieve(final_met, metName);
2718 if (
sc.isFailure()) {
2719 ATH_MSG_DEBUG (
"Could not retrieve Collection " << metName <<
" from StoreGate");
2724 if (final_met)
met = (*final_met)[metRefFinalName];
2731 ATH_MSG_INFO (
" -- IDPerfMonZmumu::execute -- Accepted event " <<
m_4mu.getAcceptedEvents() <<
" with m_4mu.GetInvMass= " <<
m_4mu_minv);
2736 <<
" Invariant mass = " <<
m_4mu_minv <<
" GeV ");
2737 if (muon1_pos !=
nullptr)
ATH_MSG_DEBUG(
"mu1+ --> pxyz " << muon1_pos->
p4().Px()
2738 <<
", " << muon1_pos->
p4().Py()
2739 <<
", " << muon1_pos->
p4().Pz()
2740 <<
" pt: " << muon1_pos->
pt()
2741 <<
" d0: " << muon1_pos->
d0()
2742 <<
" z0: " << muon1_pos->
z0()
2745 if (muon1_neg !=
nullptr)
ATH_MSG_DEBUG(
"mu1- --> pxyz " << muon1_neg->
p4().Px()
2746 <<
", " << muon1_neg->
p4().Py()
2747 <<
", " << muon1_neg->
p4().Pz()
2748 <<
" pt: " << muon1_neg->
pt()
2749 <<
" d0: " << muon1_neg->
d0()
2750 <<
" z0: " << muon1_neg->
z0()
2753 if (elec1_pos !=
nullptr)
ATH_MSG_DEBUG(
"el1+ --> pxyz " << elec1_pos->
p4().Px()
2754 <<
", " << elec1_pos->
p4().Py()
2755 <<
", " << elec1_pos->
p4().Pz()
2756 <<
" pt: " << elec1_pos->
pt()
2757 <<
" d0: " << elec1_pos->
d0()
2758 <<
" z0: " << elec1_pos->
z0()
2779 int nBLhits, nhitsPIX, nhitsSCT, nhitsTRT, nContribPixLayers;
2780 int nPIXholes, nSCTholes;
2781 if (IDTrkMuPos && IDTrkMuNeg) {
2799 <<
" nBLhits: " << nBLhits
2800 <<
" nhitsPIX: " << nhitsPIX
2801 <<
" nPIXLayers: " << nContribPixLayers
2802 <<
" nhitsSCT: " << nhitsSCT
2803 <<
" Silicon holes: " << nPIXholes + nSCTholes
2804 <<
" nhitsTRT: " << nhitsTRT);
2820 <<
" nBLhits: " << nBLhits
2821 <<
" nhitsPIX: " << nhitsPIX
2822 <<
" nPIXLayers: " << nContribPixLayers
2823 <<
" nhitsSCT: " << nhitsSCT
2824 <<
" Silicon holes: " << nPIXholes + nSCTholes
2825 <<
" nhitsTRT: " << nhitsTRT);
Scalar eta() const
pseudorapidity method
Scalar phi() const
phi method
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_WARNING(x)
double charge(const T &p)
Helper class to provide constant type-safe access to aux data.
DataVector< Trk::Track > TrackCollection
This typedef represents a collection of Trk::Track objects.
constexpr int pow(int base, int exp) noexcept
AthAlgorithm(const std::string &name, ISvcLocator *pSvcLocator)
Constructor with parameters:
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
ServiceHandle< StoreGateSvc > & evtStore()
value_type push_back(value_type pElem)
Add an element to the end of the collection.
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
size_type size() const noexcept
Returns the number of elements in the collection.
double m_el_negative1_z0_err
ToolHandle< Trig::TrigDecisionTool > m_triggerDecision
std::vector< float > m_Refit1_qoverp
StatusCode CheckTriggerStatusAndPrescale()
virtual StatusCode finalize()
StatusCode FillTruthParameters(const xAOD::TrackParticle *track)
StatusCode RunFourLeptonAnalysis()
bool m_useCustomMuonSelector
std::vector< float > m_Refit1_sigma_qoverp
double m_el_positive1_d0_err
double m_el_positive2_z0_err
double m_positive_d0_PVerr
std::string m_truthTreeFolder
double m_negative_2_z0_err
double m_positive_sigma_qoverp
double m_negative_sigma_qoverp
const xAOD::Vertex * GetDiMuonVertex(const xAOD::TrackParticle *, const xAOD::TrackParticle *)
double m_positive_2_d0_err
double m_positive_d0_manualBS
void ResetCommonNtupleVectors()
std::vector< float > m_Refit2_sigma_d0
std::vector< float > m_CBTrack_sigma_z0
TH1F * m_h_cutflow
link vector to map HepMC onto xAOD truth
ToolHandle< Reco::ITrackToVertex > m_trackToVertexTool
tool to extrapolate tracks to BL
std::vector< float > m_Refit1_sigma_d0
std::vector< float > m_CBTrack_d0
std::string m_refit1TreeFolder
std::string m_ValidationTreeDescription
< validation tree description - second argument in TTree
std::vector< float > m_Refit2_qoverp
std::string m_outputTracksName
SG::ReadHandleKey< xAOD::TrackParticleContainer > m_trackContainerName
IDTtacks.
std::vector< float > m_Refit1_eta
ToolHandle< Trig::IMatchingTool > m_triggerMatching
std::vector< float > m_CBTrack_sigma_d0
unsigned int m_lumi_block
std::vector< float > m_IDTrack_d0
std::string m_MSTreeFolder
std::string m_trackParticleName
Track(Particle)TruthCollection input name.
std::string m_combTreeFolder
ToolHandle< IegammaTrkRefitterTool > m_TrackRefitter1
The track refitter.
double m_negative_2_d0_err
double m_positive_z0_PVerr
std::vector< float > m_Truth_phi
std::vector< float > m_Truth_pt
ToolHandle< Trk::ITrackToVertexIPEstimator > m_trackToVertexIPEstimator
Needed for IP resolution studies.
std::vector< float > m_Refit2_d0
std::string m_MuonQualityName
double m_el_positive1_z0_err
double m_negative_z0_manualBS
ToolHandle< Trk::IExtrapolator > m_extrapolator
bool m_validationMode
< boolean to switch to validation mode
std::vector< float > m_Refit1_phi
std::vector< float > m_Refit2_eta
bool m_useTrackSelectionTool
std::string m_FourMuTreeFolder
Root Validation Tree.
std::vector< float > m_IDTrack_pt
std::vector< float > m_CBTrack_sigma_pt
std::vector< float > m_Truth_z0
double m_negative_z0_PVerr
ToolHandle< IegammaTrkRefitterTool > m_TrackRefitter2
The track refitter.
std::vector< float > m_IDTrack_sigma_d0
std::vector< float > m_Refit2_pt
double m_positive_sigma_pt
std::string m_truthTreeName
std::string m_refit1TreeName
double m_el_negative2_z0_err
std::vector< float > m_CBTrack_z0
std::string m_FourMuTreeName
std::vector< float > m_CBTrack_pt
std::vector< float > m_Refit1_sigma_pt
std::string m_triggerName
std::string m_refit2TreeName
virtual StatusCode initialize()
virtual StatusCode execute()
std::vector< float > m_Refit1_d0
std::vector< float > m_Truth_eta
ToolHandle< CP::ITrackVertexAssociationTool > m_Trk2VtxAssociationTool
std::string m_defaultTreeName
double m_negative_d0_PVerr
double m_positive_2_z0_err
std::vector< float > m_CBTrack_sigma_qoverp
std::vector< int > m_nSCThits
std::vector< int > m_nTRThits
std::vector< float > m_IDTrack_qoverp
std::vector< float > m_Refit2_z0
std::string m_truthLinkVecName
TrackParticle input name.
double m_positive_z0_manualBS
std::vector< float > m_Truth_d0
std::vector< int > m_nBLhits
std::vector< float > m_Refit1_pt
double m_LeadingMuonPtCut
std::string m_defaultTreeFolder
std::string m_IDTreeFolder
double m_el_positive2_d0_err
SG::ReadCondHandleKey< InDet::BeamSpotData > m_beamSpotKey
used for truth parameters
std::vector< float > m_IDTrack_phi
std::vector< float > m_Refit2_sigma_pt
std::string m_sTriggerChainName
SG::ReadHandleKey< xAOD::VertexContainer > m_vertexKey
std::string m_commonTreeFolder
std::vector< float > m_IDTrack_sigma_z0
double m_negative_sigma_pt
StatusCode FillRecParametersSimple(const Trk::Track *track, float charge, const xAOD::Vertex *vertex)
std::string m_combTreeName
void ExtractIDHitsInformation(const xAOD::Muon *muon_pos, const xAOD::Muon *muon_neg)
const xAOD::TruthParticle * getTruthParticle(const xAOD::IParticle &p)
ToolHandle< CP::IMuonSelectionTool > m_muonSelector
used to pass a custom muon selector
std::vector< float > m_Refit2_sigma_qoverp
std::string m_commonTreeName
std::vector< float > m_Refit1_z0
std::vector< float > m_Truth_qoverp
std::vector< float > m_IDTrack_z0
StatusCode FillRecParameters(const Trk::Track *track, const xAOD::TrackParticle *trackp_for_unbias, double charge, const xAOD::Vertex *vertex, const EventContext &ctx)
std::vector< float > m_Refit2_phi
double m_el_negative2_d0_err
std::vector< int > m_nPIXhits
std::vector< float > m_IDTrack_sigma_pt
StatusCode FillRecParametersTP(const xAOD::TrackParticle *trackp, const xAOD::TrackParticle *trackp_for_unbias, double charge, const xAOD::Vertex *vertex=nullptr)
double m_negative_d0_manualBS
std::vector< float > m_CBTrack_eta
void RegisterHistograms()
std::string m_refit2TreeFolder
std::vector< int > m_Truth_parent
std::vector< float > m_IDTrack_sigma_qoverp
SG::ReadHandleKey< xAOD::EventInfo > m_EventInfoKey
ToolHandle< InDet::IInDetTrackSelectionTool > m_selTool
The track selection Tool.
std::vector< float > m_Refit1_sigma_z0
std::vector< float > m_CBTrack_qoverp
double m_el_negative1_d0_err
std::vector< float > m_Refit2_sigma_z0
std::vector< float > m_IDTrack_eta
std::vector< float > m_CBTrack_phi
void Clear4MuNtupleVariables()
IDPerfMonZmumu(const std::string &name, ISvcLocator *pSvcLocator)
needed for IP resolution studies
static const T * getContainer(CONTAINERS eContainer)
Helper class to provide constant type-safe access to aux data.
bool isAvailable(const ELT &e) const
Test to see if this variable exists in the store.
const_pointer_type cptr()
virtual bool isValid() override final
Can the handle be successfully dereferenced?
double eta() const
Access method for pseudorapidity - from momentum.
const Amg::Vector3D & momentum() const
Access method for the momentum.
double pT() const
Access method for transverse momentum.
Class describing the Line to which the Perigee refers to.
const Perigee * perigeeParameters() const
return Perigee.
Class providing the definition of the 4-vector interface.
const TrackParticle * trackParticle(TrackParticleType type) const
Returns a pointer (which can be NULL) to the TrackParticle used in identification of this muon.
float z0() const
Returns the parameter.
float theta() const
Returns the parameter, which has range 0 to .
virtual FourMom_t p4() const override final
The full 4-momentum of the particle.
const Trk::Perigee & perigeeParameters() const
Returns the Trk::MeasuredPerigee track parameters.
const Trk::Track * track() const
Returns a pointer (which can be NULL) to the Trk::Track which was used to make this TrackParticle.
const ParametersCovMatrix_t definingParametersCovMatrix() const
Returns the 5x5 symmetric matrix containing the defining parameters covariance matrix.
float d0() const
Returns the parameter.
bool summaryValue(uint8_t &value, const SummaryType &information) const
Accessor for TrackSummary values.
float qOverP() const
Returns the parameter.
std::vector< float > definingParametersCovMatrixVec() const
Returns the length 6 vector containing the elements of defining parameters covariance matrix.
virtual double pt() const override final
The transverse momentum ( ) of the particle.
float charge() const
Returns the charge.
float z() const
Vertex longitudinal distance along the beam line form the origin.
float y() const
Vertex y displacement.
float x() const
Vertex x displacement.
VxType::VertexType vertexType() const
The type of the vertex.
bool contains(const std::string &s, const std::string ®x)
does a string contain the substring
double error(const Amg::MatrixX &mat, int index)
return diagonal error of the matrix caller should ensure the matrix is symmetric and the index is in ...
Eigen::Matrix< double, 3, 1 > Vector3D
@ OWN_ELEMENTS
this data object owns its elements
ParametersT< TrackParametersDim, Charged, PerigeeSurface > Perigee
ParametersT< TrackParametersDim, Charged, StraightLineSurface > AtaStraightLine
CurvilinearParametersT< TrackParametersDim, Charged, PlaneSurface > CurvilinearParameters
MissingET_v1 MissingET
Version control by type defintion.
TruthVertex_v1 TruthVertex
Typedef to implementation.
TrackParticle_v1 TrackParticle
Reference the current persistent version:
VertexContainer_v1 VertexContainer
Definition of the current "Vertex container version".
Vertex_v1 Vertex
Define the latest version of the vertex class.
MissingETContainer_v1 MissingETContainer
TruthParticle_v1 TruthParticle
Typedef to implementation.
Muon_v1 Muon
Reference the current persistent version:
MuonContainer_v1 MuonContainer
Definition of the current "Muon container version".
@ numberOfPixelHoles
number of pixel layers on track with absence of hits [unit8_t].
@ numberOfContribPixelLayers
number of contributing layers of the pixel detector [unit8_t].
@ numberOfTRTHits
number of TRT hits [unit8_t].
@ numberOfBLayerHits
these are the hits in the first pixel layer, i.e.
@ numberOfSCTHits
number of hits in SCT [unit8_t].
@ numberOfPixelHits
these are the pixel hits, including the b-layer [unit8_t].
@ numberOfSCTHoles
number of SCT holes [unit8_t].
TruthParticleContainer_v1 TruthParticleContainer
Declare the latest version of the truth particle container.