CMS 3D CMS Logo

GenPUProtonProducer.cc
Go to the documentation of this file.
1 /* \class GenPUProtonProducer
2  *
3  * Modification of GenParticleProducer.
4  * Saves final state protons from HepMC events in Crossing Frame, in the generator-particle format.
5  *
6  * Note: Use the option USER_CXXFLAGS=-DEDM_ML_DEBUG with SCRAM in order to enable debug messages.
7  *
8  * March 9, 2017 : Initial version.
9  * March 14, 2017 : Updated debug messages.
10  * July 27, 2017 : Removed extra loop initially inherited from GenParticleProducer.
11  * August 17, 2017 : Replaced std::auto_ptr with std::unique_ptr.
12  * September 6, 2017 : Updated module to edm::global::EDProducer with ConvertParticle as RunCache following GenParticleProducer.
13  *
14  */
15 
20 
21 #include <vector>
22 #include <string>
23 #include <unordered_map>
24 
25 namespace {
26 
27  class ConvertParticle {
28  public:
29  static constexpr int PDGCacheMax = 32768;
30  static constexpr double mmToCm = 0.1;
31 
32  ConvertParticle()
33  : abortOnUnknownPDGCode_(true), initialized_(false), chargeP_(PDGCacheMax, 0), chargeM_(PDGCacheMax, 0){};
34 
35  ConvertParticle(bool abortOnUnknownPDGCode)
36  : abortOnUnknownPDGCode_(abortOnUnknownPDGCode),
37  initialized_(false),
38  chargeP_(PDGCacheMax, 0),
39  chargeM_(PDGCacheMax, 0){};
40 
41  ~ConvertParticle(){};
42 
43  bool initialized() const { return initialized_; }
44 
45  void init(HepPDT::ParticleDataTable const& pdt) {
46  if (!initialized_) {
47  for (HepPDT::ParticleDataTable::const_iterator p = pdt.begin(); p != pdt.end(); ++p) {
48  HepPDT::ParticleID const& id = p->first;
49  int pdgId = id.pid(), apdgId = std::abs(pdgId);
50  int q3 = id.threeCharge();
51  if (apdgId < PDGCacheMax && pdgId > 0) {
52  chargeP_[apdgId] = q3;
53  chargeM_[apdgId] = -q3;
54  } else if (apdgId < PDGCacheMax) {
55  chargeP_[apdgId] = -q3;
56  chargeM_[apdgId] = q3;
57  } else {
58  chargeMap_.emplace(pdgId, q3);
59  chargeMap_.emplace(-pdgId, -q3);
60  }
61  }
62  initialized_ = true;
63  }
64  }
65 
66  bool operator()(reco::GenParticle& cand, HepMC::GenParticle const* part) const {
68  int pdgId = part->pdg_id();
69  cand.setThreeCharge(chargeTimesThree(pdgId));
70  cand.setPdgId(pdgId);
71  cand.setStatus(part->status());
72  cand.setP4(p4);
73  cand.setCollisionId(0);
74  HepMC::GenVertex const* v = part->production_vertex();
75  if (v != nullptr) {
76  HepMC::ThreeVector vtx = v->point3d();
78  cand.setVertex(vertex);
79  } else {
80  cand.setVertex(reco::Candidate::Point(0, 0, 0));
81  }
82  return true;
83  }
84 
85  private:
86  bool abortOnUnknownPDGCode_;
87  bool initialized_;
88  std::vector<int> chargeP_, chargeM_;
89  std::unordered_map<int, int> chargeMap_;
90 
91  int chargeTimesThree(int id) const {
92  if (std::abs(id) < PDGCacheMax)
93  return id > 0 ? chargeP_[id] : chargeM_[-id];
94 
95  auto f = chargeMap_.find(id);
96  if (f == chargeMap_.end()) {
97  if (abortOnUnknownPDGCode_)
98  throw edm::Exception(edm::errors::LogicError) << "invalid PDG id: " << id << std::endl;
99  else
100  return HepPDT::ParticleID(id).threeCharge();
101  }
102  return f->second;
103  }
104  };
105 
106  class SelectProton {
107  public:
108  bool operator()(HepMC::GenParticle const* part, double minPz) const {
109  bool selection = ((!part->end_vertex() && part->status() == 1) && (part->pdg_id() == 2212) &&
110  (TMath::Abs(part->momentum().pz()) >= minPz));
111  return selection;
112  }
113  };
114 
115 } // Anonymous namespace
116 
122 
128 
129 namespace edm {
130  class ParameterSet;
131 }
132 
133 class GenPUProtonProducer : public edm::global::EDProducer<edm::RunCache<ConvertParticle> > {
134 public:
136  ~GenPUProtonProducer() override;
137 
138  void produce(edm::StreamID, edm::Event& e, const edm::EventSetup&) const override;
139  std::shared_ptr<ConvertParticle> globalBeginRun(const edm::Run&, const edm::EventSetup&) const override;
140  void globalEndRun(edm::Run const&, edm::EventSetup const&) const override{};
141 
142 private:
146  std::vector<int> bunchList_;
147  double minPz_;
148  SelectProton select_;
149 };
150 
158 
161 
162 #include <algorithm>
163 
164 using namespace edm;
165 using namespace reco;
166 using namespace std;
167 using namespace HepMC;
168 
170  : abortOnUnknownPDGCode_(cfg.getUntrackedParameter<bool>("abortOnUnknownPDGCode", true)),
171  bunchList_(cfg.getParameter<vector<int> >("bunchCrossingList")),
172  minPz_(cfg.getParameter<double>("minPz")) {
173  produces<GenParticleCollection>();
174  mixToken_ =
175  consumes<CrossingFrame<HepMCProduct> >(InputTag(cfg.getParameter<std::string>("mix"), "generatorSmeared"));
176  pdtToken_ = esConsumes<HepPDT::ParticleDataTable, edm::DefaultRecord, edm::Transition::BeginRun>();
177 }
178 
180 
181 std::shared_ptr<ConvertParticle> GenPUProtonProducer::globalBeginRun(const Run&, const EventSetup& es) const {
183  auto convert_ptr = std::make_shared<ConvertParticle>(abortOnUnknownPDGCode_);
184  if (!convert_ptr->initialized())
185  convert_ptr->init(*pdt);
186 
187  return convert_ptr;
188 }
189 
191  size_t totalSize = 0;
192  size_t npiles = 1;
193 
195  evt.getByToken(mixToken_, cf);
196  std::unique_ptr<MixCollection<HepMCProduct> > cfhepmcprod(new MixCollection<HepMCProduct>(cf.product()));
197  npiles = cfhepmcprod->size();
198 
199  LogDebug("GenPUProtonProducer") << " Number of pile-up events : " << npiles << endl;
200 
201  for (size_t icf = 0; icf < npiles; ++icf) {
202  LogDebug("GenPUProtonProducer") << "CF " << icf
203  << " size : " << cfhepmcprod->getObject(icf).GetEvent()->particles_size() << endl;
204  totalSize += cfhepmcprod->getObject(icf).GetEvent()->particles_size();
205  }
206  LogDebug("GenPUProtonProducer") << "Total size : " << totalSize << endl;
207 
208  // Initialise containers
209  auto candsPtr = std::make_unique<GenParticleCollection>();
210  GenParticleCollection& cands = *candsPtr;
211 
212  // Loop over pile-up events
213  ConvertParticle const& convertParticle_ = *runCache(evt.getRun().index());
214 
216  unsigned int total_number_of_protons = 0;
217  size_t idx_mix = 0;
218  // Fill collection
219  for (mixHepMC_itr = cfhepmcprod->begin(); mixHepMC_itr != cfhepmcprod->end(); ++mixHepMC_itr, ++idx_mix) {
220  int bunch = mixHepMC_itr.bunch();
221 
222  if (find(bunchList_.begin(), bunchList_.end(), bunch) != bunchList_.end()) {
223  auto event = (*mixHepMC_itr).GetEvent();
224 
225  size_t num_particles = event->particles_size();
226 
227  // Fill output collection
228  unsigned int number_of_protons = 0;
229  for (auto p = event->particles_begin(); p != event->particles_end(); ++p) {
230  HepMC::GenParticle const* part = *p;
231  if (select_(part, minPz_)) {
233  convertParticle_(cand, part);
234  ++number_of_protons;
235  cands.push_back(cand);
236  }
237  }
238  LogDebug("GenPUProtonProducer") << "Idx : " << idx_mix << " Bunch : " << bunch
239  << " Number of particles : " << num_particles
240  << " Number of protons : " << number_of_protons << endl;
241 
242  total_number_of_protons += number_of_protons;
243  }
244  }
245  LogDebug("GenPUProtonProducer") << "Total number of protons : " << total_number_of_protons << endl;
246  LogDebug("GenPUProtonProducer") << "Output collection size : " << cands.size() << endl;
247 
248  evt.put(std::move(candsPtr));
249 }
250 
252 
edm::StreamID
Definition: StreamID.h:30
Handle.h
init
int init
Definition: HydjetWrapper.h:64
electrons_cff.bool
bool
Definition: electrons_cff.py:393
funct::false
false
Definition: Factorize.h:29
edm::Handle::product
T const * product() const
Definition: Handle.h:70
ESHandle.h
f
double f[11][100]
Definition: MuScleFitUtils.cc:78
GenPUProtonProducer::select_
SelectProton select_
Definition: GenPUProtonProducer.cc:148
edm::errors::LogicError
Definition: EDMException.h:37
reco::GenParticle
Definition: GenParticle.h:21
edm::Run
Definition: Run.h:45
edm::EDGetTokenT
Definition: EDGetToken.h:33
edm::Run::index
RunIndex index() const
Definition: Run.cc:25
edm
HLT enums.
Definition: AlignableModifier.h:19
AlCaHLTBitMon_ParallelJobs.p
p
Definition: AlCaHLTBitMon_ParallelJobs.py:153
CrossingFrame.h
HLT_FULL_cff.InputTag
InputTag
Definition: HLT_FULL_cff.py:89287
reco::GenParticleCollection
std::vector< GenParticle > GenParticleCollection
collection of GenParticles
Definition: GenParticleFwd.h:13
GenPUProtonProducer::globalEndRun
void globalEndRun(edm::Run const &, edm::EventSetup const &) const override
Definition: GenPUProtonProducer.cc:140
GenPUProtonProducer::abortOnUnknownPDGCode_
bool abortOnUnknownPDGCode_
Definition: GenPUProtonProducer.cc:145
GenPUProtonProducer::mixToken_
edm::EDGetTokenT< CrossingFrame< edm::HepMCProduct > > mixToken_
Definition: GenPUProtonProducer.cc:140
GenPUProtonProducer::produce
void produce(edm::StreamID, edm::Event &e, const edm::EventSetup &) const override
Definition: GenPUProtonProducer.cc:190
reco
fixed size matrix
Definition: AlignmentAlgorithmBase.h:45
GenPUProtonProducer
Definition: GenPUProtonProducer.cc:133
findQualityFiles.v
v
Definition: findQualityFiles.py:179
spr::find
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:19
edm::Handle
Definition: AssociativeIterator.h:50
genPUProtons_cfi.minPz
minPz
Definition: genPUProtons_cfi.py:6
MixCollection::MixItr
Definition: MixCollection.h:62
ESGetToken.h
GenParticle.h
CandidateFwd.h
EDMException.h
MakerMacros.h
MixCollection::MixItr::bunch
int bunch() const
Definition: MixCollection.h:91
part
part
Definition: HCALResponse.h:20
GeneratorMix_cff.abortOnUnknownPDGCode
abortOnUnknownPDGCode
Definition: GeneratorMix_cff.py:10
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
Abs
T Abs(T a)
Definition: MathUtil.h:49
MixCollection.h
MixCollection
Definition: MixCollection.h:11
GenPUProtonProducer::pdtToken_
edm::ESGetToken< HepPDT::ParticleDataTable, edm::DefaultRecord > pdtToken_
Definition: GenPUProtonProducer.cc:144
GenPUProtonProducer::~GenPUProtonProducer
~GenPUProtonProducer() override
Definition: GenPUProtonProducer.cc:179
GenParticleFwd.h
corrVsCorr.selection
selection
main part
Definition: corrVsCorr.py:100
Run.h
edm::ESHandle< HepPDT::ParticleDataTable >
edm::Event::getByToken
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:531
edm::global::EDProducer
Definition: EDProducer.h:32
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
funct::true
true
Definition: Factorize.h:173
HLT_FULL_cff.cands
cands
Definition: HLT_FULL_cff.py:15142
bphysicsOniaDQM_cfi.vertex
vertex
Definition: bphysicsOniaDQM_cfi.py:7
LogDebug
#define LogDebug(id)
Definition: MessageLogger.h:223
edm::ParameterSet
Definition: ParameterSet.h:47
Event.h
ParticleDataTable.h
cand
Definition: decayParser.h:32
createfilelist.int
int
Definition: createfilelist.py:10
p4
double p4[4]
Definition: TauolaWrapper.h:92
edm::Event::put
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:133
edm::EventSetup::getHandle
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
Definition: EventSetup.h:148
trackerHitRTTI::vector
Definition: trackerHitRTTI.h:21
GenPUProtonProducer::GenPUProtonProducer
GenPUProtonProducer(const edm::ParameterSet &)
Definition: GenPUProtonProducer.cc:169
EgammaValidation_cff.pdgId
pdgId
Definition: EgammaValidation_cff.py:118
edm::EventSetup
Definition: EventSetup.h:57
edm::ESGetToken< HepPDT::ParticleDataTable, edm::DefaultRecord >
InputTag.h
PDGCacheMax
static constexpr int PDGCacheMax
Definition: GenParticleProducer.cc:32
looper.cfg
cfg
Definition: looper.py:297
GenPUProtonProducer::bunchList_
std::vector< int > bunchList_
Definition: GenPUProtonProducer.cc:146
GenParticle.GenParticle
GenParticle
Definition: GenParticle.py:18
eostools.move
def move(src, dest)
Definition: eostools.py:511
std
Definition: JetResolutionObject.h:76
mmToCm
static const double mmToCm
Definition: GenParticleProducer.cc:145
extraflags_cff.vtx
vtx
Definition: extraflags_cff.py:18
triggerObjects_cff.id
id
Definition: triggerObjects_cff.py:31
HepMC
Definition: GenParticle.h:15
Exception
Definition: hltDiff.cc:246
EventSetup.h
funct::abs
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
ParameterSet.h
HepMCProduct.h
EDProducer.h
reco::Candidate::LorentzVector
math::XYZTLorentzVector LorentzVector
Lorentz vector.
Definition: Candidate.h:36
reco::Candidate::Point
math::XYZPoint Point
point in the space
Definition: Candidate.h:40
event
Definition: event.py:1
edm::Event
Definition: Event.h:73
LHEGenericFilter_cfi.ParticleID
ParticleID
Definition: LHEGenericFilter_cfi.py:6
ParticleDataTable
HepPDT::ParticleDataTable ParticleDataTable
Definition: ParticleDataTable.h:8
GenPUProtonProducer::globalBeginRun
std::shared_ptr< ConvertParticle > globalBeginRun(const edm::Run &, const edm::EventSetup &) const override
Definition: GenPUProtonProducer.cc:181
edm::Event::getRun
Run const & getRun() const
Definition: Event.cc:111
GenPUProtonProducer::minPz_
double minPz_
Definition: GenPUProtonProducer.cc:147
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37