File indexing completed on 2024-04-06 12:04:05
0001 #ifndef EgammaCandidates_Electron_h
0002 #define EgammaCandidates_Electron_h
0003
0004
0005
0006
0007
0008
0009
0010
0011 #include "DataFormats/RecoCandidate/interface/RecoCandidate.h"
0012 #include "DataFormats/GsfTrackReco/interface/GsfTrack.h"
0013
0014 namespace reco {
0015
0016 class Electron : public RecoCandidate {
0017 public:
0018
0019 Electron() : RecoCandidate() {}
0020
0021 Electron(Charge q, const LorentzVector& p4, const Point& vtx = Point(0, 0, 0))
0022 : RecoCandidate(q, p4, vtx, -11 * q) {}
0023
0024 ~Electron() override;
0025
0026 Electron* clone() const override;
0027
0028 using reco::RecoCandidate::track;
0029 reco::TrackRef track() const override;
0030
0031 reco::SuperClusterRef superCluster() const override;
0032
0033 reco::GsfTrackRef gsfTrack() const override;
0034
0035 void setSuperCluster(const reco::SuperClusterRef& r) { superCluster_ = r; }
0036
0037 void setTrack(const reco::TrackRef& r) { track_ = r; }
0038
0039 void setGsfTrack(const reco::GsfTrackRef& r) { gsfTrack_ = r; }
0040
0041 bool isElectron() const override;
0042
0043 private:
0044
0045 bool overlap(const Candidate&) const override;
0046
0047 reco::SuperClusterRef superCluster_;
0048
0049 reco::TrackRef track_;
0050
0051 reco::GsfTrackRef gsfTrack_;
0052 };
0053
0054 }
0055
0056 #endif