TkMuon

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
#ifndef DataFormatsL1TCorrelator_TkMuon_h
#define DataFormatsL1TCorrelator_TkMuon_h

#include "DataFormats/L1Trigger/interface/L1Candidate.h"
#include "DataFormats/Common/interface/Ref.h"
#include "DataFormats/Common/interface/Ptr.h"
#include "DataFormats/L1TrackTrigger/interface/TTTypes.h"
#include "DataFormats/L1TMuon/interface/RegionalMuonCand.h"
#include "DataFormats/L1TMuon/interface/RegionalMuonCandFwd.h"
#include "DataFormats/L1TMuon/interface/EMTFTrack.h"

namespace l1t {
  class TkMuon : public L1Candidate {
  public:
    typedef TTTrack<Ref_Phase2TrackerDigi_> L1TTTrackType;
    typedef std::vector<L1TTTrackType> L1TTTrackCollection;

    TkMuon() : theIsolation(-999.), TrkzVtx_(999.), quality_(999), pattern_(0) {}

    TkMuon(const LorentzVector& p4,
           const edm::Ref<l1t::RegionalMuonCandBxCollection>& muRef,
           const edm::Ptr<L1TTTrackType>& trkPtr,
           float tkisol = -999.);

    TkMuon(const LorentzVector& p4,
           const edm::Ref<l1t::EMTFTrackCollection>& emtfTrk,
           const edm::Ptr<L1TTTrackType>& trkPtr,
           float tkisol = -999.);

    //One more constructor for Tracker+ Stubs algorithm not requiring the Muon candidate
    TkMuon(const LorentzVector& p4, const edm::Ptr<L1TTTrackType>& trkPtr, float tkisol = -999.);

    //! more basic constructor, in case refs/ptrs can't be set or to be set separately
    TkMuon(const L1Candidate& cand) : L1Candidate(cand), theIsolation(-999.), TrkzVtx_(999.), quality_(999) {}

    const edm::Ptr<L1TTTrackType>& trkPtr() const { return trkPtr_; }

    const edm::Ref<l1t::RegionalMuonCandBxCollection>& muRef() const { return muRef_; }
    const edm::Ref<l1t::EMTFTrackCollection>& emtfTrk() const { return emtfTrk_; }

    float trkIsol() const { return theIsolation; }
    float trkzVtx() const { return TrkzVtx_; }

    float dR() const { return dR_; }
    int nTracksMatched() const { return nTracksMatch_; }
    double trackCurvature() const { return trackCurvature_; }

    unsigned int quality() const { return quality_; }
    unsigned int pattern() const { return pattern_; }

    unsigned int muonDetector() const { return muonDetector_; }

    void setTrkPtr(const edm::Ptr<L1TTTrackType>& p) { trkPtr_ = p; }

    void setTrkzVtx(float TrkzVtx) { TrkzVtx_ = TrkzVtx; }
    void setTrkIsol(float TrkIsol) { theIsolation = TrkIsol; }
    void setQuality(unsigned int q) { quality_ = q; }
    void setPattern(unsigned int p) { pattern_ = p; }

    void setdR(float dR) { dR_ = dR; }
    void setNTracksMatched(int nTracksMatch) { nTracksMatch_ = nTracksMatch; }
    void setTrackCurvature(double trackCurvature) { trackCurvature_ = trackCurvature; }  // this is signed
    void setMuonDetector(unsigned int detector) { muonDetector_ = detector; }

  private:
    // used for the Naive producer
    edm::Ref<l1t::RegionalMuonCandBxCollection> muRef_;
    edm::Ref<l1t::EMTFTrackCollection> emtfTrk_;

    edm::Ptr<L1TTTrackType> trkPtr_;

    float theIsolation;
    float TrkzVtx_;
    float dR_;
    int nTracksMatch_;
    double trackCurvature_;

    unsigned int quality_;
    unsigned int pattern_;

    int muonDetector_;
  };
}  // namespace l1t

#endif