34 std::vector<edm::InputTag> corrInputTags = cfg.
getParameter<std::vector<edm::InputTag> >(
"srcCorrections");
35 std::vector<edm::EDGetTokenT<CorrMETData> > corrTokens;
36 for (std::vector<edm::InputTag>::const_iterator
inputTag = corrInputTags.begin();
inputTag != corrInputTags.end(); ++
inputTag) {
37 corrTokens.push_back(consumes<CorrMETData>(*
inputTag));
42 produces<METCollection>(
"");
50 std::vector<edm::InputTag> tmpv;
52 desc.
add<std::vector<edm::InputTag> >(
"srcCorrections",tmpv);
53 descriptions.
add(defaultModuleLabel<CorrectedPFMETProducer>(),desc);
74 std::unique_ptr<METCollection> product(
new METCollection);
75 product->push_back(outMET);
T getParameter(std::string const &) const
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
~CorrectedPFMETProducer() override
bool getByToken(EDGetToken token, Handle< PROD > &result) const
AddCorrectionsToGenericMET corrector
reco::PFMET getCorrectedPFMET(const reco::PFMET &srcMET, edm::Event &evt, const edm::EventSetup &es)
void produce(edm::Event &evt, const edm::EventSetup &es) override
#define DEFINE_FWK_MODULE(type)
ParameterDescriptionBase * add(U const &iLabel, T const &value)
void add(std::string const &label, ParameterSetDescription const &psetDescription)
std::vector< reco::PFMET > METCollection
CorrectedPFMETProducer(const edm::ParameterSet &cfg)
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
edm::EDGetTokenT< METCollection > token_
void setCorTokens(std::vector< edm::EDGetTokenT< CorrMETData > > const &corrTokens)