Belle II Software  release-08-01-10
EvtGenDecayModule.h
1 /**************************************************************************
2  * basf2 (Belle II Analysis Software Framework) *
3  * Author: The Belle II Collaboration *
4  * *
5  * See git log for contributors and copyright holders. *
6  * This file is licensed under LGPL-3.0, see LICENSE.md. *
7  **************************************************************************/
8 
9 #pragma once
10 
11 /* Basf2 headers. */
12 #include <framework/core/Module.h>
13 #include <generators/evtgen/EvtGenInterface.h>
14 #include <generators/utilities/InitialParticleGeneration.h>
15 #include <mdst/dataobjects/MCParticleGraph.h>
16 
17 /* C++ headers. */
18 #include <string>
19 
20 namespace Belle2 {
32  class EvtGenDecayModule : public Module {
33 
34  public:
35 
40 
44  virtual ~EvtGenDecayModule();
45 
49  virtual void initialize() override;
50 
54  virtual void beginRun() override;
55 
59  virtual void event() override;
60 
64  virtual void endRun() override;
65 
69  virtual void terminate() override;
70 
71  private:
72 
76  void initializeGenerator();
77 
79  std::string m_DecFile;
80 
82  std::string m_UserDecFile;
83 
85  std::string m_MCParticleColName;
86 
89 
92 
95 
97  std::set<int> m_DecayableParticles;
98 
101 
102  };
103 
105 }
106 
107 
Class for accessing objects in the database.
Definition: DBObjPtr.h:21
This module decays unstable particles using EvtGen.
virtual void initialize() override
Initialization.
virtual void event() override
This method is called for each event.
virtual void endRun() override
This method is called if the current run ends.
virtual void terminate() override
This method is called at the end of the event processing.
bool m_Initialized
Whether the generator is initialized or not.
std::string m_DecFile
Decay file.
virtual void beginRun() override
This method is called when entering a new run.
DBObjPtr< BeamParameters > m_BeamParameters
Beam parameters.
std::string m_UserDecFile
User decay file.
MCParticleGraph m_Graph
MCParticle graph.
std::string m_MCParticleColName
MCParticle collection name.
EvtGenInterface m_EvtGenInterface
Evtgen interface.
std::set< int > m_DecayableParticles
Monte-Carlo codes of particles that can be decayed by EvtGen.
virtual ~EvtGenDecayModule()
Destructor.
void initializeGenerator()
Generator initialization.
Class to interface EvtGen.
Class to build, validate and sort a particle decay chain.
Base class for Modules.
Definition: Module.h:72
Abstract base class for different kinds of events.