File indexing completed on 2024-04-06 12:04:54
0001
0002
0003
0004 #ifndef DataFormats_PatCandidates_Muon_h
0005 #define DataFormats_PatCandidates_Muon_h
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021 #include "DataFormats/MuonReco/interface/Muon.h"
0022 #include "DataFormats/MuonReco/interface/MuonFwd.h"
0023 #include "DataFormats/MuonReco/interface/MuonSelectors.h"
0024 #include "DataFormats/MuonReco/interface/MuonMETCorrectionData.h"
0025 #include "DataFormats/MuonReco/interface/MuonTimeExtra.h"
0026
0027 #include "DataFormats/TrackReco/interface/Track.h"
0028 #include "DataFormats/PatCandidates/interface/Lepton.h"
0029 #include "DataFormats/ParticleFlowCandidate/interface/IsolatedPFCandidateFwd.h"
0030 #include "DataFormats/ParticleFlowCandidate/interface/IsolatedPFCandidate.h"
0031 #include "DataFormats/MuonReco/interface/MuonSimInfo.h"
0032
0033
0034 namespace pat {
0035 class Muon;
0036 typedef std::vector<Muon> MuonCollection;
0037 typedef edm::Ref<MuonCollection> MuonRef;
0038 typedef edm::RefVector<MuonCollection> MuonRefVector;
0039 }
0040
0041 namespace reco {
0042
0043 std::ostream& operator<<(std::ostream& out, const pat::Muon& obj);
0044 }
0045
0046
0047 namespace pat {
0048
0049 class PATMuonSlimmer;
0050
0051 class Muon : public Lepton<reco::Muon> {
0052 public:
0053
0054 Muon();
0055
0056 Muon(const reco::Muon& aMuon);
0057
0058 Muon(const edm::RefToBase<reco::Muon>& aMuonRef);
0059
0060 Muon(const edm::Ptr<reco::Muon>& aMuonRef);
0061
0062 ~Muon() override;
0063
0064
0065 Muon* clone() const override { return new Muon(*this); }
0066
0067
0068
0069 reco::TrackRef track() const override;
0070 using reco::RecoCandidate::track;
0071
0072 reco::TrackRef innerTrack() const override { return track(); }
0073
0074 reco::TrackRef standAloneMuon() const override;
0075
0076 reco::TrackRef outerTrack() const override { return standAloneMuon(); }
0077
0078 reco::TrackRef combinedMuon() const override;
0079
0080 reco::TrackRef globalTrack() const override { return combinedMuon(); }
0081
0082 const reco::Track* bestTrack() const override { return muonBestTrack().get(); }
0083
0084 reco::TrackRef muonBestTrack() const override;
0085
0086 reco::TrackRef tunePMuonBestTrack() const override;
0087
0088
0089
0090 void embedMuonBestTrack(bool force = false);
0091
0092
0093 void embedTunePMuonBestTrack(bool force = false);
0094
0095 void embedTrack();
0096
0097 void embedStandAloneMuon();
0098
0099 void embedCombinedMuon();
0100
0101 void rekeyEmbeddedTracks(std::vector<edm::Handle<edm::Association<reco::TrackExtraCollection>>> const& assocs);
0102
0103
0104
0105 reco::MuonMETCorrectionData caloMETMuonCorrs() const {
0106 return (embeddedCaloMETMuonCorrs_ ? caloMETMuonCorrs_.front() : reco::MuonMETCorrectionData());
0107 };
0108 void embedCaloMETMuonCorrs(const reco::MuonMETCorrectionData& t);
0109
0110 reco::MuonMETCorrectionData tcMETMuonCorrs() const {
0111 return (embeddedTCMETMuonCorrs_ ? tcMETMuonCorrs_.front() : reco::MuonMETCorrectionData());
0112 };
0113 void embedTcMETMuonCorrs(const reco::MuonMETCorrectionData& t);
0114
0115
0116
0117
0118 reco::TrackRef pickyTrack() const override;
0119
0120 reco::TrackRef tpfmsTrack() const override;
0121
0122 reco::TrackRef dytTrack() const override;
0123
0124 reco::TrackRef pickyMuon() const { return pickyTrack(); }
0125 reco::TrackRef tpfmsMuon() const { return tpfmsTrack(); }
0126
0127 void embedPickyMuon();
0128
0129 void embedTpfmsMuon();
0130
0131 void embedDytMuon();
0132
0133
0134 void readTimeExtra(const reco::MuonTimeExtra& t);
0135
0136
0137
0138
0139 reco::PFCandidateRef pfCandidateRef() const;
0140
0141 void setPFCandidateRef(const reco::PFCandidateRef& ref) { pfCandidateRef_ = ref; }
0142
0143 void embedPFCandidate();
0144
0145 size_t numberOfSourceCandidatePtrs() const override {
0146 size_t res = 0;
0147 if (pfCandidateRef_.isNonnull())
0148 res++;
0149 if (refToOrig_.isNonnull())
0150 res++;
0151 return res;
0152 }
0153
0154 reco::CandidatePtr sourceCandidatePtr(size_type i) const override;
0155
0156
0157
0158
0159
0160 bool muonID(const std::string& name) const;
0161
0162
0163 bool isGood(const std::string& name) const { return muonID(name); }
0164
0165
0166
0167
0168
0169
0170 bool isTightMuon(const reco::Vertex&) const;
0171 bool isLooseMuon() const;
0172 bool isMediumMuon() const;
0173 bool isSoftMuon(const reco::Vertex&) const;
0174 bool isHighPtMuon(const reco::Vertex&) const;
0175
0176
0177
0178
0179 float trackIso() const { return isolationR03().sumPt; }
0180
0181
0182
0183 float ecalIso() const { return isolationR03().emEt; }
0184
0185
0186
0187 float hcalIso() const { return isolationR03().hadEt; }
0188
0189
0190 float caloIso() const { return ecalIso() + hcalIso(); }
0191
0192
0193 float puppiChargedHadronIso() const { return puppiChargedHadronIso_; }
0194 float puppiNeutralHadronIso() const { return puppiNeutralHadronIso_; }
0195 float puppiPhotonIso() const { return puppiPhotonIso_; }
0196
0197 float puppiNoLeptonsChargedHadronIso() const { return puppiNoLeptonsChargedHadronIso_; }
0198 float puppiNoLeptonsNeutralHadronIso() const { return puppiNoLeptonsNeutralHadronIso_; }
0199 float puppiNoLeptonsPhotonIso() const { return puppiNoLeptonsPhotonIso_; }
0200
0201 void setIsolationPUPPI(float chargedhadrons, float neutralhadrons, float photons) {
0202 puppiChargedHadronIso_ = chargedhadrons;
0203 puppiNeutralHadronIso_ = neutralhadrons;
0204 puppiPhotonIso_ = photons;
0205 }
0206
0207 void setIsolationPUPPINoLeptons(float chargedhadrons, float neutralhadrons, float photons) {
0208 puppiNoLeptonsChargedHadronIso_ = chargedhadrons;
0209 puppiNoLeptonsNeutralHadronIso_ = neutralhadrons;
0210 puppiNoLeptonsPhotonIso_ = photons;
0211 }
0212
0213
0214
0215
0216
0217
0218
0219
0220
0221
0222
0223
0224
0225
0226
0227
0228
0229
0230
0231
0232
0233
0234
0235
0236
0237 typedef enum IPTYPE { PV2D = 0, PV3D = 1, BS2D = 2, BS3D = 3, PVDZ = 4, IpTypeSize = 5 } IpType;
0238 void initImpactParameters(void);
0239 double dB(IPTYPE type) const;
0240 double edB(IPTYPE type) const;
0241
0242
0243 double dB() const { return std::abs(dB(PV2D)); }
0244
0245 double edB() const { return std::abs(edB(PV2D)); }
0246
0247 void setDB(double dB, double edB, IPTYPE type = PV2D) {
0248 ip_[type] = dB;
0249 eip_[type] = edB;
0250 cachedIP_ |= (1 << int(type));
0251 }
0252
0253
0254 unsigned int numberOfValidHits() const;
0255 void setNumberOfValidHits(unsigned int numberOfValidHits) {
0256 numberOfValidHits_ = numberOfValidHits;
0257 cachedNumberOfValidHits_ = true;
0258 }
0259
0260
0261 double normChi2() const;
0262 void setNormChi2(double normChi2) {
0263 normChi2_ = normChi2;
0264 cachedNormChi2_ = true;
0265 }
0266
0267
0268 double segmentCompatibility(
0269 reco::Muon::ArbitrationType arbitrationType = reco::Muon::SegmentAndTrackArbitration) const;
0270
0271
0272 friend std::ostream& reco::operator<<(std::ostream& out, const pat::Muon& obj);
0273
0274 friend class PATMuonSlimmer;
0275
0276 float pfEcalEnergy() const { return pfEcalEnergy_; }
0277 void setPfEcalEnergy(float pfEcalEnergy) { pfEcalEnergy_ = pfEcalEnergy; }
0278
0279
0280 float jetPtRatio() const { return jetPtRatio_; }
0281 float jetPtRel() const { return jetPtRel_; }
0282 void setJetPtRatio(float jetPtRatio) { jetPtRatio_ = jetPtRatio; }
0283 void setJetPtRel(float jetPtRel) { jetPtRel_ = jetPtRel; }
0284
0285
0286 float softMvaValue() const { return softMvaValue_; }
0287 void setSoftMvaValue(float softmva) { softMvaValue_ = softmva; }
0288 float softMvaRun3Value() const { return softMvaRun3Value_; }
0289 void setSoftMvaRun3Value(float softmva) { softMvaRun3Value_ = softmva; }
0290
0291
0292 float mvaIDValue() const { return mvaIDValue_; }
0293 void setMvaIDValue(float mvaID) { mvaIDValue_ = mvaID; }
0294
0295
0296
0297 float inverseBeta() const { return inverseBeta_; }
0298 float inverseBetaErr() const { return inverseBetaErr_; }
0299
0300
0301 reco::MuonSimType simType() const { return simType_; }
0302 reco::ExtendedMuonSimType simExtType() const { return simExtType_; }
0303
0304
0305
0306
0307 int simFlavour() const { return simFlavour_; }
0308 int simHeaviestMotherFlavour() const { return simHeaviestMotherFlavour_; }
0309 int simPdgId() const { return simPdgId_; }
0310 int simMotherPdgId() const { return simMotherPdgId_; }
0311 int simBX() const { return simBX_; }
0312 int simTpEvent() const { return simTpEvent_; }
0313 float simProdRho() const { return simProdRho_; }
0314 float simProdZ() const { return simProdZ_; }
0315 float simPt() const { return simPt_; }
0316 float simEta() const { return simEta_; }
0317 float simPhi() const { return simPhi_; }
0318 float simMatchQuality() const { return simMatchQuality_; }
0319
0320 void initSimInfo(void);
0321 void setSimType(reco::MuonSimType type) { simType_ = type; }
0322 void setExtSimType(reco::ExtendedMuonSimType type) { simExtType_ = type; }
0323 void setSimFlavour(int f) { simFlavour_ = f; }
0324 void setSimHeaviestMotherFlavour(int id) { simHeaviestMotherFlavour_ = id; }
0325 void setSimPdgId(int id) { simPdgId_ = id; }
0326 void setSimMotherPdgId(int id) { simMotherPdgId_ = id; }
0327 void setSimBX(int bx) { simBX_ = bx; }
0328 void setSimTpEvent(int tpEvent) { simTpEvent_ = tpEvent; }
0329 void setSimProdRho(float rho) { simProdRho_ = rho; }
0330 void setSimProdZ(float z) { simProdZ_ = z; }
0331 void setSimPt(float pt) { simPt_ = pt; }
0332 void setSimEta(float eta) { simEta_ = eta; }
0333 void setSimPhi(float phi) { simPhi_ = phi; }
0334 void setSimMatchQuality(float quality) { simMatchQuality_ = quality; }
0335
0336
0337 const pat::TriggerObjectStandAlone* l1Object(const size_t idx = 0) const {
0338 return triggerObjectMatchByType(trigger::TriggerL1Mu, idx);
0339 }
0340 const pat::TriggerObjectStandAlone* hltObject(const size_t idx = 0) const {
0341 return triggerObjectMatchByType(trigger::TriggerMuon, idx);
0342 }
0343 bool triggered(const char* pathName) const { return triggerObjectMatchByPath(pathName, true, true) != nullptr; }
0344
0345 protected:
0346
0347
0348
0349 bool embeddedMuonBestTrack_;
0350 std::vector<reco::Track> muonBestTrack_;
0351
0352 bool embeddedTunePMuonBestTrack_;
0353 std::vector<reco::Track> tunePMuonBestTrack_;
0354
0355 bool embeddedTrack_;
0356 std::vector<reco::Track> track_;
0357
0358 bool embeddedStandAloneMuon_;
0359 std::vector<reco::Track> standAloneMuon_;
0360
0361 bool embeddedCombinedMuon_;
0362 std::vector<reco::Track> combinedMuon_;
0363
0364
0365 bool embeddedTCMETMuonCorrs_;
0366 std::vector<reco::MuonMETCorrectionData> tcMETMuonCorrs_;
0367
0368 bool embeddedCaloMETMuonCorrs_;
0369 std::vector<reco::MuonMETCorrectionData> caloMETMuonCorrs_;
0370
0371
0372 bool embeddedPickyMuon_;
0373 bool embeddedTpfmsMuon_;
0374 bool embeddedDytMuon_;
0375 std::vector<reco::Track> pickyMuon_;
0376 std::vector<reco::Track> tpfmsMuon_;
0377 std::vector<reco::Track> dytMuon_;
0378
0379
0380
0381 bool embeddedPFCandidate_;
0382
0383
0384 reco::PFCandidateCollection pfCandidate_;
0385
0386
0387 reco::PFCandidateRef pfCandidateRef_;
0388
0389
0390 bool cachedNormChi2_;
0391 double normChi2_;
0392
0393 bool cachedNumberOfValidHits_;
0394 unsigned int numberOfValidHits_;
0395
0396
0397 uint8_t cachedIP_;
0398 float ip_[IpTypeSize];
0399 float eip_[IpTypeSize];
0400
0401
0402 float puppiChargedHadronIso_;
0403 float puppiNeutralHadronIso_;
0404 float puppiPhotonIso_;
0405
0406 float puppiNoLeptonsChargedHadronIso_;
0407 float puppiNoLeptonsNeutralHadronIso_;
0408 float puppiNoLeptonsPhotonIso_;
0409
0410 float pfEcalEnergy_;
0411
0412
0413 float jetPtRatio_;
0414 float jetPtRel_;
0415
0416
0417 float mvaIDValue_;
0418 float softMvaValue_;
0419 float softMvaRun3Value_ = 0;
0420
0421
0422 float inverseBeta_;
0423 float inverseBetaErr_;
0424
0425
0426 reco::MuonSimType simType_;
0427 reco::ExtendedMuonSimType simExtType_;
0428 int simFlavour_;
0429 int simHeaviestMotherFlavour_;
0430 int simPdgId_;
0431 int simMotherPdgId_;
0432 int simBX_;
0433 int simTpEvent_;
0434 float simProdRho_;
0435 float simProdZ_;
0436 float simPt_;
0437 float simEta_;
0438 float simPhi_;
0439 float simMatchQuality_;
0440 };
0441
0442 }
0443
0444 #endif