RecoChargedRefCandidate

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
#ifndef RecoCandidate_RecoChargedRefCandidate_h
#define RecoCandidate_RecoChargedRefCandidate_h

#include "DataFormats/Candidate/interface/LeafRefCandidateT.h"
#include "DataFormats/TrackReco/interface/TrackFwd.h"
#include "DataFormats/TrackReco/interface/Track.h"

namespace reco {

  typedef LeafRefCandidateT RecoChargedRefCandidateBase;

  class RecoChargedRefCandidate : public LeafRefCandidateT {
  public:
    RecoChargedRefCandidate() {}
    RecoChargedRefCandidate(TrackRef ref, float m) : LeafRefCandidateT(ref, m) {}

    ~RecoChargedRefCandidate() override {}

    RecoChargedRefCandidate* clone() const override { return new RecoChargedRefCandidate(*this); }

    reco::TrackRef track() const { return getRef<reco::TrackRef>(); }
    // return a pointer to the best track, if available.
    // otherwise, return a null pointer
    const reco::Track* bestTrack() const override {
      if (track().isNonnull() && track().isAvailable())
        return &(*track());
      else
        return nullptr;
    }

    /// uncertainty on dz
    float dzError() const override {
      const Track* tr = bestTrack();
      if (tr != nullptr)
        return tr->dzError();
      else
        return 0;
    }
    /// uncertainty on dxy
    float dxyError() const override {
      const Track* tr = bestTrack();
      if (tr != nullptr)
        return tr->dxyError();
      else
        return 0;
    }
  };
}  // namespace reco

#endif