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
|