25 emObjectProducer_ (consumes<
T1Collection>(config.getParameter<edm::
InputTag>(
"candidateProducer"))),
29 useHF_ (config.getParameter<bool>(
"useHF")),
30 drMax_ (config.getParameter<double>(
"drMax")),
31 drVetoBarrel_ (config.getParameter<double>(
"drVetoBarrel")),
32 drVetoEndcap_ (config.getParameter<double>(
"drVetoEndcap")),
33 etaStripBarrel_ (config.getParameter<double>(
"etaStripBarrel")),
34 etaStripEndcap_ (config.getParameter<double>(
"etaStripEndcap")),
35 energyBarrel_ (config.getParameter<double>(
"energyBarrel")),
36 energyEndcap_ (config.getParameter<double>(
"energyEndcap")),
37 useEt_ (config.getParameter<bool>(
"useEt")) {
39 produces <edm::ValueMap<float>>();
57 desc.
add<
double>(
"drMax", 0.3);
58 desc.
add<
double>(
"drVetoBarrel", 0.0);
59 desc.
add<
double>(
"drVetoEndcap", 0.0);
60 desc.
add<
double>(
"etaStripBarrel", 0.0);
61 desc.
add<
double>(
"etaStripEndcap", 0.0);
62 desc.
add<
double>(
"energyBarrel", 0.0);
63 desc.
add<
double>(
"energyEndcap", 0.0);
64 desc.
add<
bool>(
"useEt",
true);
72 iEvent.
getByToken(emObjectProducer_, emObjectHandle);
74 auto isoMap = std::make_unique<edm::ValueMap<float>>();
76 std::vector<float> retV(emObjectHandle->size(),0);
78 std::vector<edm::Handle<reco::PFClusterCollection>> clusterHandles;
80 iEvent.
getByToken(pfClusterProducerHCAL_, clusterHandle);
81 clusterHandles.push_back(clusterHandle);
85 iEvent.
getByToken(pfClusterProducerHFEM_, clusterHandle);
86 clusterHandles.push_back(clusterHandle);
88 iEvent.
getByToken(pfClusterProducerHFHAD_, clusterHandle);
89 clusterHandles.push_back(clusterHandle);
92 HcalPFClusterIsolation<T1> isoAlgo(drMax_, drVetoBarrel_, drVetoEndcap_, etaStripBarrel_, etaStripEndcap_, energyBarrel_, energyEndcap_, useEt_);
94 for (
unsigned int iReco = 0; iReco < emObjectHandle->size(); iReco++) {
95 T1Ref candRef(emObjectHandle, iReco);
96 retV[iReco] = isoAlgo.
getSum(candRef, clusterHandles);
99 filler.insert(emObjectHandle,retV.begin(),retV.end());
std::string defaultModuleLabel()
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
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::EventIDconst &, edm::Timestampconst & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
bool getByToken(EDGetToken token, Handle< PROD > &result) const
#define DEFINE_FWK_MODULE(type)
~EgammaHcalPFClusterIsolationProducer()
ParameterDescriptionNode * ifValue(ParameterDescription< T > const &switchParameter, std::unique_ptr< ParameterDescriptionCases< T > > cases)
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)
void add(std::string const &label, ParameterSetDescription const &psetDescription)
EgammaHcalPFClusterIsolationProducer< reco::Photon > PhotonHcalPFClusterIsolationProducer
std::vector< T1 > T1Collection
virtual void produce(edm::Event &, const edm::EventSetup &)
std::vector< PFCluster > PFClusterCollection
collection of PFCluster objects
EgammaHcalPFClusterIsolationProducer(const edm::ParameterSet &)
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)