CaloRecHitCandidate

component

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
#ifndef RecoCandidate_CaloRecHitCandidate_h
#define RecoCandidate_CaloRecHitCandidate_h
/** \class reco::CaloRecHitCandidate
 *
 * Reco Candidates with a CaloRecHit component
 *
 * \author Luca Lista, INFN
 *
 *
 */
#include "DataFormats/RecoCandidate/interface/RecoCandidate.h"
#include "DataFormats/CaloRecHit/interface/CaloRecHit.h"
#include "DataFormats/Common/interface/Ptr.h"

namespace reco {

  class CaloRecHitCandidate : public LeafCandidate {
  public:
    typedef edm::Ptr<CaloRecHit> CaloRecHitRef;
    /// default constructor
    CaloRecHitCandidate() : LeafCandidate() {}
    /// constructor from values
    CaloRecHitCandidate(const LorentzVector& p4, Charge q = 0, const Point& vtx = Point(0, 0, 0))
        : LeafCandidate(q, p4, vtx) {}
    /// constructor from values
    CaloRecHitCandidate(const PolarLorentzVector& p4, Charge q = 0, const Point& vtx = Point(0, 0, 0))
        : LeafCandidate(q, p4, vtx) {}
    /// destructor
    ~CaloRecHitCandidate() override;
    /// returns a clone of the candidate
    CaloRecHitCandidate* clone() const override;
    /// set CaloRecHit reference
    void setCaloRecHit(const CaloRecHitRef& r) { caloRecHit_ = r; }
    /// reference to a CaloRecHit
    CaloRecHitRef caloRecHit() const { return caloRecHit_; }

  private:
    /// check overlap with another candidate
    bool overlap(const Candidate&) const override;
    /// reference to a CaloRecHit
    CaloRecHitRef caloRecHit_;
  };
  /// get default Track component
  GET_DEFAULT_CANDIDATE_COMPONENT(CaloRecHitCandidate, edm::Ptr<CaloRecHit>, caloRecHit);

}  // namespace reco

#endif