CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Protected Types | Protected Attributes
CandMCMatchTableProducer Class Reference
Inheritance diagram for CandMCMatchTableProducer:
edm::global::EDProducer<> edm::global::EDProducerBase edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 CandMCMatchTableProducer (edm::ParameterSet const &params)
 
void produce (edm::StreamID id, edm::Event &iEvent, const edm::EventSetup &iSetup) const override
 
 ~CandMCMatchTableProducer () override
 
- Public Member Functions inherited from edm::global::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
 
EDProduceroperator= (const EDProducer &)=delete
 
bool wantsGlobalLuminosityBlocks () const final
 
bool wantsGlobalRuns () const final
 
bool wantsInputProcessBlocks () const final
 
bool wantsProcessBlocks () const final
 
bool wantsStreamLuminosityBlocks () const final
 
bool wantsStreamRuns () const final
 
- Public Member Functions inherited from edm::global::EDProducerBase
 EDProducerBase ()
 
ModuleDescription const & moduleDescription () const
 
 ~EDProducerBase () override
 
- Public Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
std::vector< edm::ProductResolverIndex > const & indiciesForPutProducts (BranchType iBranchType) const
 
 ProducerBase ()
 
std::vector< edm::ProductResolverIndex > const & putTokenIndexToProductResolverIndex () const
 
std::vector< bool > const & recordProvenanceList () const
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription const &)> registrationCallback () const
 used by the fwk to register list of products More...
 
void resolvePutIndicies (BranchType iBranchType, ModuleToResolverIndicies const &iIndicies, std::string const &moduleLabel)
 
TypeLabelList const & typeLabelList () const
 used by the fwk to register the list of products of this module More...
 
 ~ProducerBase () noexcept(false) override
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
void convertCurrentProcessAlias (std::string const &processName)
 Convert "@currentProcess" in InputTag process names to the actual current process name. More...
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase &&)=default
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
ESProxyIndex const * esGetTokenIndices (edm::Transition iTrans) const
 
std::vector< ESProxyIndex > const & esGetTokenIndicesVector (edm::Transition iTrans) const
 
std::vector< ESRecordIndex > const & esGetTokenRecordIndicesVector (edm::Transition iTrans) const
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector< ProductResolverIndexAndSkipBit > const & itemsToGetFrom (BranchType iType) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::array< std::vector< ModuleDescription const * > *, NumBranchTypes > &modulesAll, std::vector< ModuleProcessName > &modulesInPreviousProcesses, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
ProductResolverIndexAndSkipBit uncheckedIndexFrom (EDGetToken) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
void updateLookup (eventsetup::ESRecordsToProxyIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 
static int getParentHadronFlag (const reco::GenParticleRef match)
 
- Static Public Member Functions inherited from edm::global::EDProducerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 

Protected Types

enum  MatchType {
  MMuon, MElectron, MTau, MPhoton,
  MOther
}
 

Protected Attributes

const std::string branchName_
 
const edm::EDGetTokenT< edm::Association< reco::GenParticleCollection > > candMap_
 
edm::EDGetTokenT< edm::Association< reco::GenJetCollection > > candMapDressedLep_
 
edm::EDGetTokenT< edm::Association< reco::GenParticleCollection > > candMapVisTau_
 
const std::string doc_
 
std::string flavDoc_
 
edm::EDGetTokenT< reco::GenParticleCollectiongenPartsToken_
 
edm::EDGetTokenT< edm::ValueMap< bool > > mapTauAnc_
 
const std::string objName_
 
const edm::EDGetTokenT< reco::CandidateViewsrc_
 
enum CandMCMatchTableProducer::MatchType type_
 

Additional Inherited Members

- Public Types inherited from edm::global::EDProducerBase
typedef EDProducerBase ModuleType
 
- Public Types inherited from edm::ProducerBase
using ModuleToResolverIndicies = std::unordered_multimap< std::string, std::tuple< edm::TypeID const *, const char *, edm::ProductResolverIndex > >
 
typedef ProductRegistryHelper::TypeLabelList TypeLabelList
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Protected Member Functions inherited from edm::ProducerBase
template<class ProductType >
BranchAliasSetterT< ProductType > produces ()
 declare what type of product will make and with which optional label More...
 
template<typename ProductType , BranchType B>
BranchAliasSetterT< ProductType > produces ()
 
template<typename ProductType , Transition B>
BranchAliasSetterT< ProductType > produces ()
 
BranchAliasSetter produces (const TypeID &id, std::string instanceName=std::string(), bool recordProvenance=true)
 
template<BranchType B>
BranchAliasSetter produces (const TypeID &id, std::string instanceName=std::string(), bool recordProvenance=true)
 
template<Transition B>
BranchAliasSetter produces (const TypeID &id, std::string instanceName=std::string(), bool recordProvenance=true)
 
template<typename ProductType , Transition B>
BranchAliasSetterT< ProductType > produces (std::string instanceName)
 
template<class ProductType >
BranchAliasSetterT< ProductType > produces (std::string instanceName)
 
template<typename ProductType , BranchType B>
BranchAliasSetterT< ProductType > produces (std::string instanceName)
 
ProducesCollector producesCollector ()
 
- Protected Member Functions inherited from edm::EDConsumerBase
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
template<BranchType B = InEvent>
EDConsumerBaseAdaptor< B > consumes (edm::InputTag tag) noexcept
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes ()
 
template<Transition Tr = Transition::Event>
constexpr auto esConsumes () noexcept
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes (ESInputTag const &tag)
 
template<Transition Tr = Transition::Event>
auto esConsumes (ESInputTag tag) noexcept
 
template<Transition Tr = Transition::Event>
ESGetTokenGeneric esConsumes (eventsetup::EventSetupRecordKey const &iRecord, eventsetup::DataKey const &iKey)
 Used with EventSetupRecord::doGet. More...
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 

Detailed Description

Definition at line 16 of file CandMCMatchTableProducer.cc.

Member Enumeration Documentation

◆ MatchType

Enumerator
MMuon 
MElectron 
MTau 
MPhoton 
MOther 

Definition at line 259 of file CandMCMatchTableProducer.cc.

Constructor & Destructor Documentation

◆ CandMCMatchTableProducer()

CandMCMatchTableProducer::CandMCMatchTableProducer ( edm::ParameterSet const &  params)
inline

Definition at line 18 of file CandMCMatchTableProducer.cc.

19  : objName_(params.getParameter<std::string>("objName")),
20  branchName_(params.getParameter<std::string>("branchName")),
21  doc_(params.getParameter<std::string>("docString")),
22  src_(consumes<reco::CandidateView>(params.getParameter<edm::InputTag>("src"))),
24  produces<nanoaod::FlatTable>();
25  const std::string& type = params.getParameter<std::string>("objType");
26  if (type == "Muon")
27  type_ = MMuon;
28  else if (type == "Electron")
29  type_ = MElectron;
30  else if (type == "Tau")
31  type_ = MTau;
32  else if (type == "Photon")
33  type_ = MPhoton;
34  else if (type == "Other")
35  type_ = MOther;
36  else
37  throw cms::Exception("Configuration", "Unsupported objType '" + type + "'\n");
38 
39  switch (type_) {
40  case MMuon:
41  flavDoc_ =
42  "1 = prompt muon (including gamma*->mu mu), 15 = muon from prompt tau, " // continues below
43  "5 = muon from b, 4 = muon from c, 3 = muon from light or unknown, 0 = unmatched";
44  break;
45  case MElectron:
46  flavDoc_ =
47  "1 = prompt electron (including gamma*->mu mu), 15 = electron from prompt tau, 22 = prompt photon (likely "
48  "conversion), " // continues below
49  "5 = electron from b, 4 = electron from c, 3 = electron from light or unknown, 0 = unmatched";
50  break;
51  case MPhoton:
52  flavDoc_ = "1 = prompt photon, 11 = prompt electron, 0 = unknown or unmatched";
53  break;
54  case MTau:
55  flavDoc_ =
56  "1 = prompt electron, 2 = prompt muon, 3 = tau->e decay, 4 = tau->mu decay, 5 = hadronic tau decay, 0 = "
57  "unknown or unmatched";
58  break;
59  case MOther:
60  flavDoc_ = "1 = from hard scatter, 0 = unknown or unmatched";
61  break;
62  }
63 
64  if (type_ == MTau) {
66  consumes<edm::Association<reco::GenParticleCollection>>(params.getParameter<edm::InputTag>("mcMapVisTau"));
67  }
68 
69  if (type_ == MElectron) {
71  consumes<edm::Association<reco::GenJetCollection>>(params.getParameter<edm::InputTag>("mcMapDressedLep"));
72  mapTauAnc_ = consumes<edm::ValueMap<bool>>(params.getParameter<edm::InputTag>("mapTauAnc"));
73  genPartsToken_ = consumes<reco::GenParticleCollection>(params.getParameter<edm::InputTag>("genparticles"));
74  }
75  }

References candMapDressedLep_, candMapVisTau_, Exception, flavDoc_, genPartsToken_, mapTauAnc_, MElectron, MMuon, MOther, MPhoton, MTau, CalibrationSummaryClient_cfi::params, AlCaHLTBitMon_QueryRunRegistry::string, and type_.

◆ ~CandMCMatchTableProducer()

CandMCMatchTableProducer::~CandMCMatchTableProducer ( )
inlineoverride

Definition at line 77 of file CandMCMatchTableProducer.cc.

77 {}

Member Function Documentation

◆ fillDescriptions()

static void CandMCMatchTableProducer::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
inlinestatic

Definition at line 227 of file CandMCMatchTableProducer.cc.

227  {
229  desc.add<std::string>("objName")->setComment("name of the nanoaod::FlatTable to extend with this table");
230  desc.add<std::string>("branchName")
231  ->setComment(
232  "name of the column to write (the final branch in the nanoaod will be <objName>_<branchName>Idx and "
233  "<objName>_<branchName>Flav");
234  desc.add<std::string>("docString")->setComment("documentation to forward to the output");
235  desc.add<edm::InputTag>("src")->setComment(
236  "physics object collection for the reconstructed objects (e.g. leptons)");
237  desc.add<edm::InputTag>("mcMap")->setComment(
238  "tag to an edm::Association<GenParticleCollection> mapping src to gen, such as the one produced by MCMatcher");
239  desc.add<std::string>("objType")->setComment(
240  "type of object to match (Muon, Electron, Tau, Photon, Other), taylors what's in t Flav branch");
241  desc.addOptional<edm::InputTag>("mcMapVisTau")
242  ->setComment("as mcMap, but pointing to the visible gen taus (only if objType == Tau)");
243  desc.addOptional<edm::InputTag>("mcMapDressedLep")
244  ->setComment("as mcMap, but pointing to gen dressed leptons (only if objType == Electrons)");
245  desc.addOptional<edm::InputTag>("mapTauAnc")
246  ->setComment("Value map of matched gen electrons containing info on the tau ancestry");
247  desc.addOptional<edm::InputTag>("genparticles")->setComment("Collection of genParticles to be stored.");
248  descriptions.add("candMcMatchTable", desc);
249  }

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

◆ getParentHadronFlag()

static int CandMCMatchTableProducer::getParentHadronFlag ( const reco::GenParticleRef  match)
inlinestatic

Definition at line 204 of file CandMCMatchTableProducer.cc.

204  {
205  bool has4 = false;
206  for (unsigned int im = 0, nm = match->numberOfMothers(); im < nm; ++im) {
207  reco::GenParticleRef mom = match->motherRef(im);
208  assert(mom.isNonnull() && mom.isAvailable()); // sanity
209  if (mom.key() >= match.key())
210  continue; // prevent circular refs
211  int id = std::abs(mom->pdgId());
212  if (id / 1000 == 5 || id / 100 == 5 || id == 5)
213  return 5;
214  if (id / 1000 == 4 || id / 100 == 4 || id == 4)
215  has4 = true;
216  if (mom->status() == 2) {
217  id = getParentHadronFlag(mom);
218  if (id == 5)
219  return 5;
220  else if (id == 4)
221  has4 = true;
222  }
223  }
224  return has4 ? 4 : 3;
225  }

References funct::abs(), cms::cuda::assert(), edm::Ref< C, T, F >::isAvailable(), edm::Ref< C, T, F >::isNonnull(), edm::Ref< C, T, F >::key(), and match().

Referenced by produce().

◆ produce()

void CandMCMatchTableProducer::produce ( edm::StreamID  id,
edm::Event iEvent,
const edm::EventSetup iSetup 
) const
inlineoverridevirtual

Implements edm::global::EDProducerBase.

Definition at line 79 of file CandMCMatchTableProducer.cc.

79  {
81  iEvent.getByToken(src_, cands);
82  unsigned int ncand = cands->size();
83 
84  auto tab = std::make_unique<nanoaod::FlatTable>(ncand, objName_, false, true);
85 
87  iEvent.getByToken(candMap_, map);
88 
90  if (type_ == MTau) {
91  iEvent.getByToken(candMapVisTau_, mapVisTau);
92  }
93 
97  if (type_ == MElectron) {
98  iEvent.getByToken(candMapDressedLep_, mapDressedLep);
99  iEvent.getByToken(mapTauAnc_, mapTauAnc);
100  iEvent.getByToken(genPartsToken_, genParts);
101  }
102 
103  std::vector<int> key(ncand, -1), flav(ncand, 0);
104  for (unsigned int i = 0; i < ncand; ++i) {
105  //std::cout << "cand #" << i << ": pT = " << cands->ptrAt(i)->pt() << ", eta = " << cands->ptrAt(i)->eta() << ", phi = " << cands->ptrAt(i)->phi() << std::endl;
106  reco::GenParticleRef match = (*map)[cands->ptrAt(i)];
107  reco::GenParticleRef matchVisTau;
108  reco::GenJetRef matchDressedLep;
109  bool hasTauAnc = false;
110  if (type_ == MTau) {
111  matchVisTau = (*mapVisTau)[cands->ptrAt(i)];
112  }
113  if (type_ == MElectron) {
114  matchDressedLep = (*mapDressedLep)[cands->ptrAt(i)];
115  if (matchDressedLep.isNonnull()) {
116  hasTauAnc = (*mapTauAnc)[matchDressedLep];
117  }
118  }
119  if (match.isNonnull())
120  key[i] = match.key();
121  else if (matchVisTau.isNonnull())
122  key[i] = matchVisTau.key();
123  else if (type_ != MElectron)
124  continue; // go ahead with electrons, as those may be matched to a dressed lepton
125 
126  switch (type_) {
127  case MMuon:
128  if (match->isPromptFinalState())
129  flav[i] = 1; // prompt
130  else if (match->isDirectPromptTauDecayProductFinalState())
131  flav[i] = 15; // tau
132  else
133  flav[i] = getParentHadronFlag(match); // 3 = light, 4 = charm, 5 = b
134  break;
135  case MElectron:
136  if (matchDressedLep.isNonnull()) {
137  if (matchDressedLep->pdgId() == 22)
138  flav[i] = 22;
139  else
140  flav[i] = (hasTauAnc) ? 15 : 1;
141 
142  float minpt = 0;
143  const reco::GenParticle* highestPtConstituent = nullptr;
144  for (auto& consti : matchDressedLep->getGenConstituents()) {
145  if (abs(consti->pdgId()) != 11)
146  continue;
147  if (consti->pt() < minpt)
148  continue;
149  minpt = consti->pt();
150  highestPtConstituent = consti;
151  }
152  if (highestPtConstituent) {
153  auto iter =
154  std::find_if(genParts->begin(), genParts->end(), [highestPtConstituent](reco::GenParticle genp) {
155  return (abs(genp.pdgId()) == 11) && (deltaR(genp, *highestPtConstituent) < 0.01) &&
156  (abs(genp.pt() - highestPtConstituent->pt()) / highestPtConstituent->pt() < 0.01);
157  });
158  if (iter != genParts->end()) {
159  key[i] = iter - genParts->begin();
160  }
161  }
162  } else if (!match.isNonnull())
163  flav[i] = 0;
164  else if (match->isPromptFinalState())
165  flav[i] = (match->pdgId() == 22 ? 22 : 1); // prompt electron or photon
166  else if (match->isDirectPromptTauDecayProductFinalState())
167  flav[i] = 15; // tau
168  else
169  flav[i] = getParentHadronFlag(match); // 3 = light, 4 = charm, 5 = b
170  break;
171  case MPhoton:
172  if (match->isPromptFinalState() && match->pdgId() == 22)
173  flav[i] = 1; // prompt photon
174  else if ((match->isPromptFinalState() || match->isDirectPromptTauDecayProductFinalState()) &&
175  abs(match->pdgId()) == 11)
176  flav[i] = 11; // prompt electron
177  break;
178  case MTau:
179  // CV: assignment of status codes according to https://twiki.cern.ch/twiki/bin/viewauth/CMS/HiggsToTauTauWorking2016#MC_Matching
180  if (match.isNonnull() && match->statusFlags().isPrompt() && abs(match->pdgId()) == 11)
181  flav[i] = 1;
182  else if (match.isNonnull() && match->statusFlags().isPrompt() && abs(match->pdgId()) == 13)
183  flav[i] = 2;
184  else if (match.isNonnull() && match->isDirectPromptTauDecayProductFinalState() && abs(match->pdgId()) == 11)
185  flav[i] = 3;
186  else if (match.isNonnull() && match->isDirectPromptTauDecayProductFinalState() && abs(match->pdgId()) == 13)
187  flav[i] = 4;
188  else if (matchVisTau.isNonnull())
189  flav[i] = 5;
190  break;
191  default:
192  flav[i] = match->statusFlags().fromHardProcess();
193  };
194  }
195 
196  tab->addColumn<int>(branchName_ + "Idx", key, "Index into genParticle list for " + doc_);
197  tab->addColumn<uint8_t>(branchName_ + "Flav",
198  flav,
199  "Flavour of genParticle (DressedLeptons for electrons) for " + doc_ + ": " + flavDoc_);
200 
201  iEvent.put(std::move(tab));
202  }

References funct::abs(), branchName_, candMap_, candMapDressedLep_, candMapVisTau_, HLT_FULL_cff::cands, PbPb_ZMuSkimMuonDPG_cff::deltaR, doc_, flavDoc_, EgammaValidation_cff::genp, genPartsToken_, getParentHadronFlag(), electrons_cff::hasTauAnc, mps_fire::i, iEvent, edm::Ref< C, T, F >::isNonnull(), crabWrapper::key, edm::Ref< C, T, F >::key(), genParticles_cff::map, electrons_cff::mapTauAnc, mapTauAnc_, match(), MElectron, HiEvtPlane_cfi::minpt, MMuon, eostools::move(), MPhoton, MTau, objName_, reco::LeafCandidate::pt(), src_, and type_.

Member Data Documentation

◆ branchName_

const std::string CandMCMatchTableProducer::branchName_
protected

Definition at line 252 of file CandMCMatchTableProducer.cc.

Referenced by produce().

◆ candMap_

const edm::EDGetTokenT<edm::Association<reco::GenParticleCollection> > CandMCMatchTableProducer::candMap_
protected

Definition at line 254 of file CandMCMatchTableProducer.cc.

Referenced by produce().

◆ candMapDressedLep_

edm::EDGetTokenT<edm::Association<reco::GenJetCollection> > CandMCMatchTableProducer::candMapDressedLep_
protected

Definition at line 256 of file CandMCMatchTableProducer.cc.

Referenced by CandMCMatchTableProducer(), and produce().

◆ candMapVisTau_

edm::EDGetTokenT<edm::Association<reco::GenParticleCollection> > CandMCMatchTableProducer::candMapVisTau_
protected

Definition at line 255 of file CandMCMatchTableProducer.cc.

Referenced by CandMCMatchTableProducer(), and produce().

◆ doc_

const std::string CandMCMatchTableProducer::doc_
protected

Definition at line 252 of file CandMCMatchTableProducer.cc.

Referenced by produce().

◆ flavDoc_

std::string CandMCMatchTableProducer::flavDoc_
protected

Definition at line 260 of file CandMCMatchTableProducer.cc.

Referenced by CandMCMatchTableProducer(), and produce().

◆ genPartsToken_

edm::EDGetTokenT<reco::GenParticleCollection> CandMCMatchTableProducer::genPartsToken_
protected

Definition at line 258 of file CandMCMatchTableProducer.cc.

Referenced by CandMCMatchTableProducer(), and produce().

◆ mapTauAnc_

edm::EDGetTokenT<edm::ValueMap<bool> > CandMCMatchTableProducer::mapTauAnc_
protected

Definition at line 257 of file CandMCMatchTableProducer.cc.

Referenced by CandMCMatchTableProducer(), and produce().

◆ objName_

const std::string CandMCMatchTableProducer::objName_
protected

Definition at line 252 of file CandMCMatchTableProducer.cc.

Referenced by produce().

◆ src_

const edm::EDGetTokenT<reco::CandidateView> CandMCMatchTableProducer::src_
protected

Definition at line 253 of file CandMCMatchTableProducer.cc.

Referenced by produce().

◆ type_

enum CandMCMatchTableProducer::MatchType CandMCMatchTableProducer::type_
protected
mps_fire.i
i
Definition: mps_fire.py:428
CandMCMatchTableProducer::MPhoton
Definition: CandMCMatchTableProducer.cc:259
CandMCMatchTableProducer::candMap_
const edm::EDGetTokenT< edm::Association< reco::GenParticleCollection > > candMap_
Definition: CandMCMatchTableProducer.cc:254
reco::GenParticle
Definition: GenParticle.h:21
EgammaValidation_cff.genp
genp
produce generated paricles in acceptance #
Definition: EgammaValidation_cff.py:115
CalibrationSummaryClient_cfi.params
params
Definition: CalibrationSummaryClient_cfi.py:14
edm::Ref::isAvailable
bool isAvailable() const
Definition: Ref.h:537
CandMCMatchTableProducer::src_
const edm::EDGetTokenT< reco::CandidateView > src_
Definition: CandMCMatchTableProducer.cc:253
edm::ParameterSetDescription
Definition: ParameterSetDescription.h:52
cms::cuda::assert
assert(be >=bs)
CandMCMatchTableProducer::mapTauAnc_
edm::EDGetTokenT< edm::ValueMap< bool > > mapTauAnc_
Definition: CandMCMatchTableProducer.cc:257
reco::LeafCandidate::pt
double pt() const final
transverse momentum
Definition: LeafCandidate.h:146
edm::Handle
Definition: AssociativeIterator.h:50
HiEvtPlane_cfi.minpt
minpt
Definition: HiEvtPlane_cfi.py:17
edm::Ref< GenParticleCollection >
CandMCMatchTableProducer::flavDoc_
std::string flavDoc_
Definition: CandMCMatchTableProducer.cc:260
edm::ConfigurationDescriptions::add
void add(std::string const &label, ParameterSetDescription const &psetDescription)
Definition: ConfigurationDescriptions.cc:57
CandMCMatchTableProducer::type_
enum CandMCMatchTableProducer::MatchType type_
electrons_cff.hasTauAnc
hasTauAnc
Definition: electrons_cff.py:489
CandMCMatchTableProducer::branchName_
const std::string branchName_
Definition: CandMCMatchTableProducer.cc:252
CandMCMatchTableProducer::MElectron
Definition: CandMCMatchTableProducer.cc:259
PbPb_ZMuSkimMuonDPG_cff.deltaR
deltaR
Definition: PbPb_ZMuSkimMuonDPG_cff.py:63
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
HLT_FULL_cff.cands
cands
Definition: HLT_FULL_cff.py:15146
type
type
Definition: SiPixelVCal_PayloadInspector.cc:37
edm::Ref::isNonnull
bool isNonnull() const
Checks for non-null.
Definition: Ref.h:238
match
std::pair< typename Association::data_type::first_type, double > match(Reference key, Association association, bool bestMatchByMaxValue)
Generic matching function.
Definition: Utils.h:10
iEvent
int iEvent
Definition: GenABIO.cc:224
edm::Association
Definition: Association.h:18
CandMCMatchTableProducer::objName_
const std::string objName_
Definition: CandMCMatchTableProducer.cc:252
CandMCMatchTableProducer::candMapDressedLep_
edm::EDGetTokenT< edm::Association< reco::GenJetCollection > > candMapDressedLep_
Definition: CandMCMatchTableProducer.cc:256
submitPVResolutionJobs.desc
string desc
Definition: submitPVResolutionJobs.py:251
eostools.move
def move(src, dest)
Definition: eostools.py:511
CandMCMatchTableProducer::getParentHadronFlag
static int getParentHadronFlag(const reco::GenParticleRef match)
Definition: CandMCMatchTableProducer.cc:204
CandMCMatchTableProducer::candMapVisTau_
edm::EDGetTokenT< edm::Association< reco::GenParticleCollection > > candMapVisTau_
Definition: CandMCMatchTableProducer.cc:255
Exception
Definition: hltDiff.cc:245
CandMCMatchTableProducer::MTau
Definition: CandMCMatchTableProducer.cc:259
CandMCMatchTableProducer::doc_
const std::string doc_
Definition: CandMCMatchTableProducer.cc:252
CandMCMatchTableProducer::genPartsToken_
edm::EDGetTokenT< reco::GenParticleCollection > genPartsToken_
Definition: CandMCMatchTableProducer.cc:258
CandMCMatchTableProducer::MOther
Definition: CandMCMatchTableProducer.cc:259
edm::Ref::key
key_type key() const
Accessor for product key.
Definition: Ref.h:250
funct::abs
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
genParticles_cff.map
map
Definition: genParticles_cff.py:11
edm::EDConsumerBase::consumes
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
Definition: EDConsumerBase.h:155
crabWrapper.key
key
Definition: crabWrapper.py:19
CandMCMatchTableProducer::MMuon
Definition: CandMCMatchTableProducer.cc:259
edm::InputTag
Definition: InputTag.h:15
electrons_cff.mapTauAnc
mapTauAnc
Definition: electrons_cff.py:518