Belle II Software  release-08-01-10
EvtGenInputModule.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 #include <generators/modules/GeneratorBaseModule.h>
12 #include <generators/evtgen/EvtGenInterface.h>
13 
14 #include <generators/utilities/InitialParticleGeneration.h>
15 #include <mdst/dataobjects/MCParticleGraph.h>
16 
17 
18 #include <Math/Vector3D.h>
19 
20 #include <string>
21 
22 namespace Belle2 {
36 
37  public:
38 
44 
46  virtual ~EvtGenInputModule() {}
47 
49  virtual void generatorInitialize() override;
50 
52  virtual void beginRun() override;
53 
55  virtual void generatorEvent() override;
56 
57  protected:
58 
66  MCInitialParticles createBeamParticle(double minMass = 0.0,
67  double maxMass = std::numeric_limits<double>::infinity());
68 
71  std::string m_DECFileName;
72  std::string m_userDECFileName;
73  std::string m_parentParticle;
75  bool m_coherentMixing = true;
76  std::string m_inclusiveParticle;
77  int m_maxTries;
78  EvtId m_parentId;
80  private:
81 
83  void initializeGenerator();
84 
85  bool m_initialized{false};
89  };
90 
92 } // end namespace Belle2
93 
Class for accessing objects in the database.
Definition: DBObjPtr.h:21
The EvtGenInput module.
std::string m_parentParticle
Standard input parent particle.
EvtGenInterface m_Ievtgen
An instance of the EvtGen Interface.
bool m_coherentMixing
Decay the B's in coherent or incoherent mode.
DBObjPtr< BeamParameters > m_beamParams
BeamParameter.
bool m_initialized
True if generator has been initialized.
virtual ~EvtGenInputModule()
Destructor.
std::string m_userDECFileName
Standard input user decay file.
MCInitialParticles createBeamParticle(double minMass=0.0, double maxMass=std::numeric_limits< double >::infinity())
Create a "beam particle" from LER and HER direction, energy and energy spread and make sure it's insi...
int m_maxTries
Maximum number of tries for generating the parent particle.
virtual void generatorInitialize() override
Initializes the module.
std::string m_DECFileName
Standard input decay file.
virtual void beginRun() override
Method is called for each run.
std::string m_inclusiveParticle
inclusive Particle
int m_inclusiveType
Inclusive type 0 : generic, 1 : m_inclusiveParticle inclusive, 2 : m_inclusiveParticle + c....
InitialParticleGeneration m_initial
initial particle used by BeamParameter class
MCParticleGraph mpg
An instance of the MCParticle graph.
EvtId m_parentId
EvtGen Id of the parent particle we want to generate.
void initializeGenerator()
Method is called to initialize the generator.
virtual void generatorEvent() override
Method is called for each event.
Class to interface EvtGen.
The base module for generator modules, which sets the generator information as EventExtraInfo.
This class contains the initial state for the given event.
Class to build, validate and sort a particle decay chain.
Abstract base class for different kinds of events.