CMS 3D CMS Logo

EgammaHcalPFClusterIsolationProducer.cc
Go to the documentation of this file.
3 
5 
10 
14 
16 
19 
20 #include <typeinfo>
21 
22 template <typename T1>
24  :
25 
26  emObjectProducer_(consumes<T1Collection>(config.getParameter<edm::InputTag>("candidateProducer"))),
27  pfClusterProducerHCAL_(
28  consumes<reco::PFClusterCollection>(config.getParameter<edm::InputTag>("pfClusterProducerHCAL"))),
29  pfClusterProducerHFEM_(
30  consumes<reco::PFClusterCollection>(config.getParameter<edm::InputTag>("pfClusterProducerHFEM"))),
31  pfClusterProducerHFHAD_(
32  consumes<reco::PFClusterCollection>(config.getParameter<edm::InputTag>("pfClusterProducerHFHAD"))),
33  useHF_(config.getParameter<bool>("useHF")),
34  drMax_(config.getParameter<double>("drMax")),
35  drVetoBarrel_(config.getParameter<double>("drVetoBarrel")),
36  drVetoEndcap_(config.getParameter<double>("drVetoEndcap")),
37  etaStripBarrel_(config.getParameter<double>("etaStripBarrel")),
38  etaStripEndcap_(config.getParameter<double>("etaStripEndcap")),
39  energyBarrel_(config.getParameter<double>("energyBarrel")),
40  energyEndcap_(config.getParameter<double>("energyEndcap")),
41  useEt_(config.getParameter<bool>("useEt")) {
42  produces<edm::ValueMap<float>>();
43 }
44 
45 template <typename T1>
47 
48 template <typename T1>
51  desc.add<edm::InputTag>("candidateProducer", edm::InputTag("gedGsfElectrons"));
52  desc.add<edm::InputTag>("pfClusterProducerHCAL", edm::InputTag("particleFlowClusterHCAL"));
53  desc.ifValue(
54  edm::ParameterDescription<bool>("useHF", false, true),
56  "pfClusterProducerHFEM", edm::InputTag("hltParticleFlowClusterHFEM"), true) and
58  "pfClusterProducerHFHAD", edm::InputTag("hltParticleFlowClusterHFHAD"), true)) or
59  false >> (edm::ParameterDescription<edm::InputTag>("pfClusterProducerHFEM", edm::InputTag(""), true) and
60  edm::ParameterDescription<edm::InputTag>("pfClusterProducerHFHAD", edm::InputTag(""), true)));
61  desc.add<double>("drMax", 0.3);
62  desc.add<double>("drVetoBarrel", 0.0);
63  desc.add<double>("drVetoEndcap", 0.0);
64  desc.add<double>("etaStripBarrel", 0.0);
65  desc.add<double>("etaStripEndcap", 0.0);
66  desc.add<double>("energyBarrel", 0.0);
67  desc.add<double>("energyEndcap", 0.0);
68  desc.add<bool>("useEt", true);
70 }
71 
72 template <typename T1>
74  edm::Handle<T1Collection> emObjectHandle;
75  iEvent.getByToken(emObjectProducer_, emObjectHandle);
76 
77  auto isoMap = std::make_unique<edm::ValueMap<float>>();
79  std::vector<float> retV(emObjectHandle->size(), 0);
80 
81  std::vector<edm::Handle<reco::PFClusterCollection>> clusterHandles;
83  iEvent.getByToken(pfClusterProducerHCAL_, clusterHandle);
84  clusterHandles.push_back(clusterHandle);
85 
86  if (useHF_) {
88  iEvent.getByToken(pfClusterProducerHFEM_, clusterHandle);
89  clusterHandles.push_back(clusterHandle);
90 
91  iEvent.getByToken(pfClusterProducerHFHAD_, clusterHandle);
92  clusterHandles.push_back(clusterHandle);
93  }
94 
97 
98  for (unsigned int iReco = 0; iReco < emObjectHandle->size(); iReco++) {
99  T1Ref candRef(emObjectHandle, iReco);
100  retV[iReco] = isoAlgo.getSum(candRef, clusterHandles);
101  }
102 
103  filler.insert(emObjectHandle, retV.begin(), retV.end());
104  filler.fill();
105 
106  iEvent.put(std::move(isoMap));
107 }
108 
111 
ParameterDescriptionNode * ifValue(ParameterDescription< T > const &switchParameter, std::unique_ptr< ParameterDescriptionCases< T >> cases)
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:131
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:525
Definition: config.py:1
std::string defaultModuleLabel()
int iEvent
Definition: GenABIO.cc:224
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
const edm::EDGetTokenT< reco::PFClusterCollection > pfClusterProducerHFEM_
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
Definition: Activities.doc:12
void produce(edm::Event &, const edm::EventSetup &) override
EgammaHcalPFClusterIsolationProducer< reco::GsfElectron > ElectronHcalPFClusterIsolationProducer
ParameterDescriptionBase * add(U const &iLabel, T const &value)
double getSum(const T1Ref candRef, const std::vector< edm::Handle< reco::PFClusterCollection >> &clusterHandles)
const edm::EDGetTokenT< T1Collection > emObjectProducer_
void add(std::string const &label, ParameterSetDescription const &psetDescription)
EgammaHcalPFClusterIsolationProducer< reco::Photon > PhotonHcalPFClusterIsolationProducer
fixed size matrix
HLT enums.
std::vector< PFCluster > PFClusterCollection
collection of PFCluster objects
Definition: PFClusterFwd.h:9
const edm::EDGetTokenT< reco::PFClusterCollection > pfClusterProducerHFHAD_
const edm::EDGetTokenT< reco::PFClusterCollection > pfClusterProducerHCAL_
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
def move(src, dest)
Definition: eostools.py:511