CMS 3D CMS Logo

CorrMETDataExtractor.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 
3 //____________________________________________________________________________||
12 
14 
15 #include <vector>
16 
17 //____________________________________________________________________________||
19 
20 public:
21 
23  std::vector<edm::InputTag> corrInputTags = cfg.getParameter<std::vector<edm::InputTag> >("corrections");
24  std::vector<edm::EDGetTokenT<CorrMETData> > corrTokens;
25  for (std::vector<edm::InputTag>::const_iterator inputTag = corrInputTags.begin(); inputTag != corrInputTags.end(); ++inputTag) {
26  corrTokens_.push_back(consumes<CorrMETData>(*inputTag));
27  }
28 
29  produces<float>("corX");
30  produces<float>("corY");
31  produces<float>("corSumEt");
32 
33  }
34 
35  ~CorrMETDataExtractor() override { }
36 
37 private:
38 
39  std::vector<edm::EDGetTokenT<CorrMETData> > corrTokens_;
40 
41 
42  void produce(edm::Event& evt, const edm::EventSetup& es) override
43  {
44 
45  CorrMETData sumCor;
47  for (std::vector<edm::EDGetTokenT<CorrMETData> >::const_iterator corrToken = corrTokens_.begin(); corrToken != corrTokens_.end(); ++corrToken) {
48 
49  evt.getByToken(*corrToken, corr);
50  sumCor += (*corr);
51  }
52 
53  float cX=(float)sumCor.mex;
54  float cY=(float)sumCor.mey;
55  float cSEt=(float)sumCor.sumet;
56 
57  std::unique_ptr<float> corX(new float(0));
58  std::unique_ptr<float> corY(new float(0));
59  std::unique_ptr<float> corSumEt(new float(0));
60 
61  *corX = cX;
62  *corY = cY;
63  *corSumEt = cSEt;
64 
65  evt.put(std::move(corX),"corX");
66  evt.put(std::move(corY),"corY");
67  evt.put(std::move(corSumEt),"corSumEt");
68  }
69 
70 };
71 
72 //____________________________________________________________________________||
73 
T getParameter(std::string const &) const
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:125
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:517
std::vector< edm::EDGetTokenT< CorrMETData > > corrTokens_
void produce(edm::Event &evt, const edm::EventSetup &es) override
CorrMETDataExtractor(const edm::ParameterSet &cfg)
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
double sumet
Definition: CorrMETData.h:20
JetCorrectorParameters corr
Definition: classes.h:5
a MET correction term
Definition: CorrMETData.h:14
double mey
Definition: CorrMETData.h:18
double mex
Definition: CorrMETData.h:17
def move(src, dest)
Definition: eostools.py:511