CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes
PFJetMETcorrInputProducerT< T, Textractor > Class Template Reference

#include <PFJetMETcorrInputProducerT.h>

Inheritance diagram for PFJetMETcorrInputProducerT< T, Textractor >:
edm::stream::EDProducer<>

Classes

struct  type2BinningEntryType
 

Public Member Functions

 PFJetMETcorrInputProducerT (const edm::ParameterSet &cfg)
 
 ~PFJetMETcorrInputProducerT () override
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
 EDProducer (const EDProducer &)=delete
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginProcessBlocks () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndProcessBlocks () const final
 
bool hasAbilityToProduceInEndRuns () const final
 
const EDProduceroperator= (const EDProducer &)=delete
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 

Private Member Functions

void produce (edm::Event &evt, const edm::EventSetup &es) override
 

Private Attributes

double jetCorrEtaMax_
 
Textractor jetCorrExtractor_
 
edm::InputTag jetCorrLabel_
 
edm::InputTag jetCorrLabelRes_
 
edm::EDGetTokenT< reco::JetCorrectorjetCorrResToken_
 
edm::EDGetTokenT< reco::JetCorrectorjetCorrToken_
 
std::string moduleLabel_
 
edm::InputTag offsetCorrLabel_
 
edm::EDGetTokenT< reco::JetCorrectoroffsetCorrToken_
 
bool skipEM_
 
double skipEMfractionThreshold_
 
bool skipMuons_
 
StringCutObjectSelector< reco::Candidate > * skipMuonSelection_
 
edm::EDGetTokenT< std::vector< T > > token_
 
double type1JetPtThreshold_
 
std::vector< type2BinningEntryType * > type2Binning_
 

Additional Inherited Members

- Public Types inherited from edm::stream::EDProducer<>
using CacheTypes = CacheContexts< T... >
 
using GlobalCache = typename CacheTypes::GlobalCache
 
using HasAbility = AbilityChecker< T... >
 
using InputProcessBlockCache = typename CacheTypes::InputProcessBlockCache
 
using LuminosityBlockCache = typename CacheTypes::LuminosityBlockCache
 
using LuminosityBlockContext = LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCache >
 
using LuminosityBlockSummaryCache = typename CacheTypes::LuminosityBlockSummaryCache
 
using RunCache = typename CacheTypes::RunCache
 
using RunContext = RunContextT< RunCache, GlobalCache >
 
using RunSummaryCache = typename CacheTypes::RunSummaryCache
 

Detailed Description

template<typename T, typename Textractor>
class PFJetMETcorrInputProducerT< T, Textractor >

Produce Type 1 + 2 MET corrections corresponding to differences between raw PFJets and PFJets with jet energy corrections (JECs) applied

NOTE: class is templated to that it works with reco::PFJets as well as with pat::Jets of PF-type as input

Authors
Michael Schmitt, Richard Cavanaugh, The University of Florida Florent Lacroix, University of Illinois at Chicago Christian Veelken, LLR

Definition at line 77 of file PFJetMETcorrInputProducerT.h.

Constructor & Destructor Documentation

◆ PFJetMETcorrInputProducerT()

template<typename T , typename Textractor >
PFJetMETcorrInputProducerT< T, Textractor >::PFJetMETcorrInputProducerT ( const edm::ParameterSet cfg)
inlineexplicit

Definition at line 79 of file PFJetMETcorrInputProducerT.h.

References looper::cfg, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrEtaMax_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrLabel_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrLabelRes_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrResToken_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrToken_, PFJetMETcorrInputProducerT< T, Textractor >::offsetCorrLabel_, PFJetMETcorrInputProducerT< T, Textractor >::offsetCorrToken_, PFJetMETcorrInputProducerT< T, Textractor >::skipEM_, PFJetMETcorrInputProducerT< T, Textractor >::skipEMfractionThreshold_, PFJetMETcorrInputProducerT< T, Textractor >::skipMuons_, PFJetMETcorrInputProducerT< T, Textractor >::skipMuonSelection_, AlCaHLTBitMon_QueryRunRegistry::string, PFJetMETcorrInputProducerT< T, Textractor >::token_, PFJetMETcorrInputProducerT< T, Textractor >::type1JetPtThreshold_, and PFJetMETcorrInputProducerT< T, Textractor >::type2Binning_.

80  : moduleLabel_(cfg.getParameter<std::string>("@module_label")),
81  offsetCorrLabel_(""),
82  skipMuonSelection_(nullptr) {
83  token_ = consumes<std::vector<T> >(cfg.getParameter<edm::InputTag>("src"));
84 
85  if (cfg.exists("offsetCorrLabel")) {
86  offsetCorrLabel_ = cfg.getParameter<edm::InputTag>("offsetCorrLabel");
87  offsetCorrToken_ = consumes<reco::JetCorrector>(offsetCorrLabel_);
88  }
89  jetCorrLabel_ = cfg.getParameter<edm::InputTag>("jetCorrLabel"); //for MC
90  jetCorrLabelRes_ = cfg.getParameter<edm::InputTag>("jetCorrLabelRes"); //for data
91  jetCorrToken_ = mayConsume<reco::JetCorrector>(jetCorrLabel_);
92  jetCorrResToken_ = mayConsume<reco::JetCorrector>(jetCorrLabelRes_);
93 
94  jetCorrEtaMax_ = (cfg.exists("jetCorrEtaMax")) ? cfg.getParameter<double>("jetCorrEtaMax") : 9.9;
95 
96  type1JetPtThreshold_ = cfg.getParameter<double>("type1JetPtThreshold");
97 
98  skipEM_ = cfg.getParameter<bool>("skipEM");
99  if (skipEM_) {
100  skipEMfractionThreshold_ = cfg.getParameter<double>("skipEMfractionThreshold");
101  }
102 
103  skipMuons_ = cfg.getParameter<bool>("skipMuons");
104  if (skipMuons_) {
105  std::string skipMuonSelection_string = cfg.getParameter<std::string>("skipMuonSelection");
106  skipMuonSelection_ = new StringCutObjectSelector<reco::Candidate>(skipMuonSelection_string, true);
107  }
108 
109  if (cfg.exists("type2Binning")) {
110  typedef std::vector<edm::ParameterSet> vParameterSet;
111  vParameterSet cfgType2Binning = cfg.getParameter<vParameterSet>("type2Binning");
112  for (vParameterSet::const_iterator cfgType2BinningEntry = cfgType2Binning.begin();
113  cfgType2BinningEntry != cfgType2Binning.end();
114  ++cfgType2BinningEntry) {
115  type2Binning_.push_back(new type2BinningEntryType(*cfgType2BinningEntry));
116  }
117  } else {
118  type2Binning_.push_back(new type2BinningEntryType());
119  }
120 
121  produces<CorrMETData>("type1");
122  for (typename std::vector<type2BinningEntryType*>::const_iterator type2BinningEntry = type2Binning_.begin();
123  type2BinningEntry != type2Binning_.end();
124  ++type2BinningEntry) {
125  produces<CorrMETData>((*type2BinningEntry)->getInstanceLabel_full("type2"));
126  produces<CorrMETData>((*type2BinningEntry)->getInstanceLabel_full("offset"));
127  }
128  }
edm::EDGetTokenT< reco::JetCorrector > jetCorrResToken_
edm::EDGetTokenT< reco::JetCorrector > jetCorrToken_
StringCutObjectSelector< reco::Candidate > * skipMuonSelection_
edm::EDGetTokenT< reco::JetCorrector > offsetCorrToken_
std::vector< type2BinningEntryType * > type2Binning_
edm::EDGetTokenT< std::vector< T > > token_

◆ ~PFJetMETcorrInputProducerT()

template<typename T , typename Textractor >
PFJetMETcorrInputProducerT< T, Textractor >::~PFJetMETcorrInputProducerT ( )
inlineoverride

Definition at line 129 of file PFJetMETcorrInputProducerT.h.

References PFJetMETcorrInputProducerT< T, Textractor >::skipMuonSelection_, and PFJetMETcorrInputProducerT< T, Textractor >::type2Binning_.

129  {
130  delete skipMuonSelection_;
131 
132  for (typename std::vector<type2BinningEntryType*>::const_iterator it = type2Binning_.begin();
133  it != type2Binning_.end();
134  ++it) {
135  delete (*it);
136  }
137  }
StringCutObjectSelector< reco::Candidate > * skipMuonSelection_
std::vector< type2BinningEntryType * > type2Binning_

Member Function Documentation

◆ fillDescriptions()

template<typename T , typename Textractor >
static void PFJetMETcorrInputProducerT< T, Textractor >::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
inlinestatic

Definition at line 139 of file PFJetMETcorrInputProducerT.h.

References edm::ConfigurationDescriptions::add(), defaultModuleLabel(), submitPVResolutionJobs::desc, HLT_2022v11_cff::InputTag, and AlCaHLTBitMon_QueryRunRegistry::string.

139  {
141  desc.add<edm::InputTag>("src", edm::InputTag("ak4PFJetsCHS"));
142  desc.add<edm::InputTag>("offsetCorrLabel", edm::InputTag("ak4PFCHSL1FastjetCorrector"));
143  desc.add<edm::InputTag>("jetCorrLabel", edm::InputTag("ak4PFCHSL1FastL2L3Corrector"));
144  desc.add<edm::InputTag>("jetCorrLabelRes", edm::InputTag("ak4PFCHSL1FastL2L3ResidualCorrector"));
145  desc.add<double>("jetCorrEtaMax", 9.9);
146  desc.add<double>("type1JetPtThreshold", 15);
147  desc.add<bool>("skipEM", true);
148  desc.add<double>("skipEMfractionThreshold", 0.90);
149  desc.add<bool>("skipMuons", true);
150  desc.add<std::string>("skipMuonSelection", "isGlobalMuon | isStandAloneMuon");
152  }
std::string defaultModuleLabel()
void add(std::string const &label, ParameterSetDescription const &psetDescription)

◆ produce()

template<typename T , typename Textractor >
void PFJetMETcorrInputProducerT< T, Textractor >::produce ( edm::Event evt,
const edm::EventSetup es 
)
inlineoverrideprivate

Definition at line 155 of file PFJetMETcorrInputProducerT.h.

References HLT_2022v11_cff::cands, edm::Event::getByToken(), edm::EventBase::isRealData(), metsig::jet, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrEtaMax_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrExtractor_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrLabel_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrLabelRes_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrResToken_, PFJetMETcorrInputProducerT< T, Textractor >::jetCorrToken_, singleTopDQM_cfi::jets, edm::InputTag::label(), eostools::move(), amptDefaultParameters_cff::mu, PFJetMETcorrInputProducerT< T, Textractor >::offsetCorrLabel_, PFJetMETcorrInputProducerT< T, Textractor >::offsetCorrToken_, pfDeepBoostedJetPreprocessParams_cfi::pfcand, edm::Handle< T >::product(), edm::Event::put(), PFJetMETcorrInputProducerT< T, Textractor >::skipEM_, PFJetMETcorrInputProducerT< T, Textractor >::skipEMfractionThreshold_, PFJetMETcorrInputProducerT< T, Textractor >::skipMuons_, PFJetMETcorrInputProducerT< T, Textractor >::skipMuonSelection_, PFJetMETcorrInputProducerT< T, Textractor >::token_, PFJetMETcorrInputProducerT< T, Textractor >::type1JetPtThreshold_, and PFJetMETcorrInputProducerT< T, Textractor >::type2Binning_.

155  {
156  std::unique_ptr<CorrMETData> type1Correction(new CorrMETData());
157  for (typename std::vector<type2BinningEntryType*>::iterator type2BinningEntry = type2Binning_.begin();
158  type2BinningEntry != type2Binning_.end();
159  ++type2BinningEntry) {
160  (*type2BinningEntry)->binUnclEnergySum_ = CorrMETData();
161  (*type2BinningEntry)->binOffsetEnergySum_ = CorrMETData();
162  }
163 
165  //automatic switch for residual corrections
166  if (evt.isRealData()) {
168  evt.getByToken(jetCorrResToken_, jetCorr);
169  } else {
170  evt.getByToken(jetCorrToken_, jetCorr);
171  }
172 
173  typedef std::vector<T> JetCollection;
175  evt.getByToken(token_, jets);
176 
177  int numJets = jets->size();
178  for (int jetIndex = 0; jetIndex < numJets; ++jetIndex) {
179  const T& jet = jets->at(jetIndex);
180 
182  checkInputType(jet);
183 
184  double emEnergyFraction = jet.chargedEmEnergyFraction() + jet.neutralEmEnergyFraction();
185  if (skipEM_ && emEnergyFraction > skipEMfractionThreshold_)
186  continue;
187 
188  const static PFJetMETcorrInputProducer_namespace::RawJetExtractorT<T> rawJetExtractor{};
189  reco::Candidate::LorentzVector rawJetP4 = rawJetExtractor(jet);
190 
191  if (skipMuons_) {
192  const std::vector<reco::CandidatePtr>& cands = jet.daughterPtrVector();
193  for (std::vector<reco::CandidatePtr>::const_iterator cand = cands.begin(); cand != cands.end(); ++cand) {
194  const reco::PFCandidate* pfcand = dynamic_cast<const reco::PFCandidate*>(cand->get());
195  const reco::Candidate* mu =
196  (pfcand != nullptr ? (pfcand->muonRef().isNonnull() ? pfcand->muonRef().get() : nullptr) : cand->get());
197  if (mu != nullptr && (*skipMuonSelection_)(*mu)) {
198  reco::Candidate::LorentzVector muonP4 = (*cand)->p4();
199  rawJetP4 -= muonP4;
200  }
201  }
202  }
203 
205  if (checkInputType.isPatJet(jet))
206  corrJetP4 = jetCorrExtractor_(jet, jetCorrLabel_.label(), jetCorrEtaMax_, &rawJetP4);
207  else
208  corrJetP4 = jetCorrExtractor_(jet, jetCorr.product(), jetCorrEtaMax_, &rawJetP4);
209  // retrieve additional jet energy scales in case of pat::Jets (done via specialized template defined for pat::Jets) and apply them
210  const static PFJetMETcorrInputProducer_namespace::AdditionalScalesT<T> additionalScales{};
211  corrJetP4 *= additionalScales(jet);
212 
213  if (corrJetP4.pt() > type1JetPtThreshold_) {
214  reco::Candidate::LorentzVector rawJetP4offsetCorr = rawJetP4;
215  if (!offsetCorrLabel_.label().empty()) {
217  evt.getByToken(offsetCorrToken_, offsetCorr);
218  if (checkInputType.isPatJet(jet))
219  rawJetP4offsetCorr = jetCorrExtractor_(jet, offsetCorrLabel_.label(), jetCorrEtaMax_, &rawJetP4);
220  else
221  rawJetP4offsetCorr = jetCorrExtractor_(jet, offsetCorr.product(), jetCorrEtaMax_, &rawJetP4);
222 
223  for (typename std::vector<type2BinningEntryType*>::iterator type2BinningEntry = type2Binning_.begin();
224  type2BinningEntry != type2Binning_.end();
225  ++type2BinningEntry) {
226  if (!(*type2BinningEntry)->binSelection_ || (*(*type2BinningEntry)->binSelection_)(corrJetP4)) {
227  (*type2BinningEntry)->binOffsetEnergySum_.mex += (rawJetP4.px() - rawJetP4offsetCorr.px());
228  (*type2BinningEntry)->binOffsetEnergySum_.mey += (rawJetP4.py() - rawJetP4offsetCorr.py());
229  (*type2BinningEntry)->binOffsetEnergySum_.sumet += (rawJetP4.Et() - rawJetP4offsetCorr.Et());
230  }
231  }
232  }
233 
234  //--- MET balances momentum of reconstructed particles,
235  // hence correction to jets and corresponding Type 1 MET correction are of opposite sign
236  type1Correction->mex -= (corrJetP4.px() - rawJetP4offsetCorr.px());
237  type1Correction->mey -= (corrJetP4.py() - rawJetP4offsetCorr.py());
238  type1Correction->sumet += (corrJetP4.Et() - rawJetP4offsetCorr.Et());
239  } else {
240  for (typename std::vector<type2BinningEntryType*>::iterator type2BinningEntry = type2Binning_.begin();
241  type2BinningEntry != type2Binning_.end();
242  ++type2BinningEntry) {
243  if (!(*type2BinningEntry)->binSelection_ || (*(*type2BinningEntry)->binSelection_)(corrJetP4)) {
244  (*type2BinningEntry)->binUnclEnergySum_.mex += rawJetP4.px();
245  (*type2BinningEntry)->binUnclEnergySum_.mey += rawJetP4.py();
246  (*type2BinningEntry)->binUnclEnergySum_.sumet += rawJetP4.Et();
247  }
248  }
249  }
250  }
251 
252  //--- add
253  // o Type 1 MET correction (difference corrected-uncorrected jet energy for jets of (corrected) Pt > 10 GeV)
254  // o momentum sum of "unclustered energy" (jets of (corrected) Pt < 10 GeV)
255  // o momentum sum of "offset energy" (sum of energy attributed to pile-up/underlying event)
256  // to the event
257  evt.put(std::move(type1Correction), "type1");
258  for (typename std::vector<type2BinningEntryType*>::const_iterator type2BinningEntry = type2Binning_.begin();
259  type2BinningEntry != type2Binning_.end();
260  ++type2BinningEntry) {
261  evt.put(std::unique_ptr<CorrMETData>(new CorrMETData((*type2BinningEntry)->binUnclEnergySum_)),
262  (*type2BinningEntry)->getInstanceLabel_full("type2"));
263  evt.put(std::unique_ptr<CorrMETData>(new CorrMETData((*type2BinningEntry)->binOffsetEnergySum_)),
264  (*type2BinningEntry)->getInstanceLabel_full("offset"));
265  }
266  }
edm::EDGetTokenT< reco::JetCorrector > jetCorrResToken_
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:133
std::vector< Jet > JetCollection
Definition: Jet.h:53
edm::EDGetTokenT< reco::JetCorrector > jetCorrToken_
T const * product() const
Definition: Handle.h:70
StringCutObjectSelector< reco::Candidate > * skipMuonSelection_
edm::EDGetTokenT< reco::JetCorrector > offsetCorrToken_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:539
std::string const & label() const
Definition: InputTag.h:36
std::vector< type2BinningEntryType * > type2Binning_
edm::EDGetTokenT< std::vector< T > > token_
math::XYZTLorentzVector LorentzVector
Lorentz vector.
Definition: Candidate.h:36
a MET correction term
Definition: CorrMETData.h:14
Particle reconstructed by the particle flow algorithm.
Definition: PFCandidate.h:41
bool isRealData() const
Definition: EventBase.h:62
long double T
def move(src, dest)
Definition: eostools.py:511

Member Data Documentation

◆ jetCorrEtaMax_

template<typename T , typename Textractor >
double PFJetMETcorrInputProducerT< T, Textractor >::jetCorrEtaMax_
private

◆ jetCorrExtractor_

template<typename T , typename Textractor >
Textractor PFJetMETcorrInputProducerT< T, Textractor >::jetCorrExtractor_
private

◆ jetCorrLabel_

template<typename T , typename Textractor >
edm::InputTag PFJetMETcorrInputProducerT< T, Textractor >::jetCorrLabel_
private

◆ jetCorrLabelRes_

template<typename T , typename Textractor >
edm::InputTag PFJetMETcorrInputProducerT< T, Textractor >::jetCorrLabelRes_
private

◆ jetCorrResToken_

template<typename T , typename Textractor >
edm::EDGetTokenT<reco::JetCorrector> PFJetMETcorrInputProducerT< T, Textractor >::jetCorrResToken_
private

◆ jetCorrToken_

template<typename T , typename Textractor >
edm::EDGetTokenT<reco::JetCorrector> PFJetMETcorrInputProducerT< T, Textractor >::jetCorrToken_
private

◆ moduleLabel_

template<typename T , typename Textractor >
std::string PFJetMETcorrInputProducerT< T, Textractor >::moduleLabel_
private

◆ offsetCorrLabel_

template<typename T , typename Textractor >
edm::InputTag PFJetMETcorrInputProducerT< T, Textractor >::offsetCorrLabel_
private

◆ offsetCorrToken_

template<typename T , typename Textractor >
edm::EDGetTokenT<reco::JetCorrector> PFJetMETcorrInputProducerT< T, Textractor >::offsetCorrToken_
private

◆ skipEM_

template<typename T , typename Textractor >
bool PFJetMETcorrInputProducerT< T, Textractor >::skipEM_
private

◆ skipEMfractionThreshold_

template<typename T , typename Textractor >
double PFJetMETcorrInputProducerT< T, Textractor >::skipEMfractionThreshold_
private

◆ skipMuons_

template<typename T , typename Textractor >
bool PFJetMETcorrInputProducerT< T, Textractor >::skipMuons_
private

◆ skipMuonSelection_

template<typename T , typename Textractor >
StringCutObjectSelector<reco::Candidate>* PFJetMETcorrInputProducerT< T, Textractor >::skipMuonSelection_
private

◆ token_

template<typename T , typename Textractor >
edm::EDGetTokenT<std::vector<T> > PFJetMETcorrInputProducerT< T, Textractor >::token_
private

◆ type1JetPtThreshold_

template<typename T , typename Textractor >
double PFJetMETcorrInputProducerT< T, Textractor >::type1JetPtThreshold_
private

◆ type2Binning_

template<typename T , typename Textractor >
std::vector<type2BinningEntryType*> PFJetMETcorrInputProducerT< T, Textractor >::type2Binning_
private