CandConverter

TrackToRefCandidate

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
#ifndef RecoAlgos_TrackToRefCandidate_h
#define RecoAlgos_TrackToRefCandidate_h
#include "CommonTools/RecoAlgos/interface/MassiveCandidateConverter.h"
#include "CommonTools/RecoAlgos/interface/CandidateProducer.h"
#include "DataFormats/TrackReco/interface/Track.h"
#include "DataFormats/RecoCandidate/interface/RecoChargedRefCandidate.h"
#include "DataFormats/RecoCandidate/interface/RecoChargedRefCandidateFwd.h"
#include "DataFormats/Candidate/interface/CandidateFwd.h"

namespace converter {

  struct TrackToRefCandidate : public MassiveCandidateConverter {
    typedef reco::Track value_type;
    typedef reco::TrackCollection Components;
    typedef reco::RecoChargedRefCandidate Candidate;
    TrackToRefCandidate(const edm::ParameterSet& cfg, edm::ConsumesCollector iC) : MassiveCandidateConverter(cfg, iC) {}
    void convert(reco::TrackRef trkRef, reco::RecoChargedRefCandidate& c) const {
      c = reco::RecoChargedRefCandidate(trkRef, sqrt(massSqr_));
    }
  };

  namespace helper {
    template <>
    struct CandConverter<reco::Track> {
      typedef TrackToRefCandidate type;
    };
  }  // namespace helper

}  // namespace converter

#endif