Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 12:01:10

0001 #ifndef RecoAlgos_PFClusterToRefCandidate_h
0002 #define RecoAlgos_PFClusterToRefCandidate_h
0003 #include "CommonTools/RecoAlgos/interface/MassiveCandidateConverter.h"
0004 #include "CommonTools/RecoAlgos/interface/CandidateProducer.h"
0005 #include "DataFormats/ParticleFlowReco/interface/PFCluster.h"
0006 #include "DataFormats/ParticleFlowReco/interface/RecoPFClusterRefCandidate.h"
0007 #include "DataFormats/ParticleFlowReco/interface/RecoPFClusterRefCandidateFwd.h"
0008 #include "DataFormats/Candidate/interface/CandidateFwd.h"
0009 
0010 namespace converter {
0011 
0012   struct PFClusterToRefCandidate : public MassiveCandidateConverter {
0013     typedef reco::PFCluster value_type;
0014     typedef reco::PFClusterCollection Components;
0015     typedef reco::RecoPFClusterRefCandidate Candidate;
0016     PFClusterToRefCandidate(const edm::ParameterSet& cfg, edm::ConsumesCollector iC)
0017         : MassiveCandidateConverter(cfg, iC) {}
0018     void convert(reco::PFClusterRef pfclusterRef, reco::RecoPFClusterRefCandidate& c) const {
0019       c = reco::RecoPFClusterRefCandidate(pfclusterRef, sqrt(massSqr_));
0020     }
0021   };
0022 
0023   namespace helper {
0024     template <>
0025     struct CandConverter<reco::PFCluster> {
0026       typedef PFClusterToRefCandidate type;
0027     };
0028   }  // namespace helper
0029 
0030 }  // namespace converter
0031 
0032 #endif