10 #include <background/modules/BeamBkgGenerator/BeamBkgGeneratorModule.h> 
   13 #include <framework/datastore/StoreArray.h> 
   14 #include <framework/datastore/StoreObjPtr.h> 
   17 #include <framework/gearbox/Unit.h> 
   18 #include <framework/gearbox/Const.h> 
   19 #include <framework/logging/Logger.h> 
   20 #include <framework/gearbox/GearDir.h> 
   23 #include <framework/dataobjects/EventMetaData.h> 
   24 #include <mdst/dataobjects/MCParticle.h> 
   25 #include <generators/SAD/dataobjects/SADMetaHit.h> 
   30 #include <Math/VectorUtil.h> 
   34 #include <TGeoMatrix.h> 
   35 #include <generators/SAD/ReaderSAD.h> 
   50 BeamBkgGeneratorModule::BeamBkgGeneratorModule() : 
Module()
 
   54                  "The generator picks up particles from the SAD file randomly " 
   55                  "according to their rates. " 
   56                  "Number of events is determined from 'realTime' and overall rate, and " 
   57                  "the generator terminates the execution when this number is reached.");
 
   64            "equivalent superKEKB running time to generate sample [ns].");
 
   85     B2ERROR(
"ringName can only be LER or HER");
 
   88     B2ERROR(
"realTime must be positive");
 
  100     B2ERROR(
m_treeName << 
": no such TTree in the SAD file");
 
  124   int numEntries = 
m_tree->GetEntries();
 
  125   if (numEntries <= 0) {
 
  126     B2ERROR(
"SAD tree is empty");
 
  133   for (
int i = 0; i < numEntries; i++) {
 
  144     GearDir ring(
"/Detector/SuperKEKB/LER/");
 
  148     GearDir ring(
"/Detector/SuperKEKB/HER/");
 
  153   m_sectionOrdering.insert(
m_sectionOrdering.end(), {1, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2});
 
  155   B2RESULT(
"BG rate: " << 
m_rates.back() / 1e6 << 
" MHz, events to generate: " 
  171     eventMetaData->setEndOfData(); 
 
  183   int ring_section = -1;
 
  185   if (
m_sad.
ss < 0) ssraw += 3016.;
 
  186   int section = (int)(ssraw * 12 / 3016.);
 
  217   part->setPDG(pdgCode);
 
  219   part->setProductionVertex(position);
 
  220   part->setProductionTime(0);
 
  221   part->setMomentum(momentum);
 
  222   part->setEnergy(
sqrt(momentum.Mag2() + mass * mass));
 
  223   part->setValidVertex(
true);
 
  233     double particlePosGeant4[] = {0.0, 0.0, 0.0};
 
  234     double particleMomGeant4[] = {0.0, 0.0, 0.0};
 
  237     TGeoHMatrix transMatrix; 
 
  245     transMatrix.LocalToMaster(particlePosSADfar, particlePosGeant4); 
 
  246     transMatrix.LocalToMasterVect(particleMomSADfar, particleMomGeant4); 
 
  248     part->setMomentum(ROOT::Math::XYZVector(particleMomGeant4[0], particleMomGeant4[1], particleMomGeant4[2]));
 
  249     part->setProductionVertex(ROOT::Math::XYZVector(particlePosGeant4[0], particlePosGeant4[1], particlePosGeant4[2]));
 
  262   B2RESULT(
"BG rate: " << 
m_rates.back() / 1e6 << 
" MHz, equivalent time: " 
  266     B2ERROR(
"Number of generated events does not match the equivalent running time: " 
  272   for (
unsigned i = 0; i < 
m_counters.size(); i++) {
 
  277   B2RESULT(
"SAD particle usage: on average " << average << 
" times, max " 
  278            << 
m_counters[imax] << 
" times (entry " << imax << 
")");
 
  285   double rate = gRandom->Uniform(
m_rates.back());
 
  288   while (i2 - i1 > 1) {
 
  289     int i = (i1 + i2) / 2;
 
SADTree m_sad
TTree entry data.
TTree * m_tree
root tree pointer
std::vector< int > m_counters
counters: how many times SAD particles are used
virtual void initialize() override
Initialize the Module.
virtual ~BeamBkgGeneratorModule()
Destructor.
virtual void event() override
Event processor.
virtual void endRun() override
End-of-run action.
ReaderSAD m_readerSAD
the transformation from SAD to Belle II system for the far beamline
std::vector< double > m_rates
cumulative rates of SAD particles [Hz]
virtual void terminate() override
Termination action.
ROOT::Math::RotationY m_rotation
rotation from SAD to Belle II frame
std::string m_fileName
name of the SAD file converted to root
int generateEntry() const
Pick up particle randomly from the SAD file according to its rate.
int m_ring
ring number, 1-HER, 2-LER
int m_numEvents
number of events to generate
double m_realTime
equivalent SuperKEKB running time in [ns]
virtual void beginRun() override
Called when entering a new run.
std::vector< int > m_sectionOrdering
superKEKB section ordering
TFile * m_file
root file pointer
int m_eventCounter
event counter
std::string m_ringName
name of the superKEKB ring (LER or HER)
std::string m_treeName
name of the TTree in the SAD file
int getPDGCode() const
PDG code.
double getMass() const
Particle mass.
static const ChargedStable electron
electron particle
GearDir is the basic class used for accessing the parameter store.
A Class to store the Monte Carlo particle information.
@ c_PrimaryParticle
bit 0: Particle is primary particle.
@ c_StableInGenerator
bit 1: Particle is stable, i.e., not decaying in the generator.
void setDescription(const std::string &description)
Sets the description of the module.
TGeoHMatrix SADtoGeant(ReaderSAD::AcceleratorRings accRing, double s)
Transformation matrix.
@ c_HER
High Energy Ring (electrons)
@ c_LER
Low Energy Ring (positrons)
bool registerInDataStore(DataStore::EStoreFlags storeFlags=DataStore::c_WriteOut)
Register the object/array in the DataStore.
T * appendNew()
Construct a new T object at the end of the array.
Type-safe access to single objects in the data store.
static const double us
[microsecond]
static const double m
[meters]
static const double s
[second]
static const double GeV
Standard of [energy, momentum, mass].
double getAngle(const std::string &path="") const noexcept(false)
Get the parameter path as a double converted to the standard angle unit.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
double sqrt(double a)
sqrt for double
Abstract base class for different kinds of events.
int nturn
number of turns from scattered to lost
double E
E at lost position [GeV] (in fact momentum magnitude!)
double sraw
s at lost position [m] before matching G4 beam pipe inner surface
double ss
scattered position (|s|<Ltot/2) [m]
double rate
lost rate [Hz]
double ssraw
scattered position [m]
double yraw
y at lost position [m] before matching G4 beam pipe inner surface
double rr
sqrt(xraw*xraw+yraw*yraw) [m]
double r
sqrt(x*x+y*y) [m]
double px
px at lost position [GeV]
double dp_over_p0
momentum deviation of the lost particle
double y
y at lost position [m]
double xraw
x at lost position [m] before matching G4 beam pipe inner surface
double py
py at lost position [GeV]
double s
lost position measured from IP along the ring [m]
double watt
loss wattage [W]
double x
x at lost position [m]