12 #include <klm/bklm/geometry/GeometryPar.h>
13 #include <klm/bklm/geometry/Module.h>
14 #include <klm/dataobjects/eklm/EKLMElementNumbers.h>
15 #include <klm/dataobjects/KLMSimHit.h>
16 #include <klm/dbobjects/bklm/BKLMSimulationPar.h>
19 #include <framework/datastore/StoreArray.h>
20 #include <framework/datastore/RelationArray.h>
21 #include <framework/database/DBObjPtr.h>
22 #include <mdst/dataobjects/MCParticle.h>
23 #include <simulation/kernel/SensitiveDetectorBase.h>
31 class BkgSensitiveDetector;
52 bool step(G4Step*, G4TouchableHistory*)
override;
59 bool stepBKLM(G4Step*, G4TouchableHistory*);
64 bool stepEKLM(G4Step*, G4TouchableHistory*);
The Class for BeamBackground Sensitive Detector.
Class for accessing objects in the database.
KLM sensitive-detector class.
bool stepBKLM(G4Step *, G4TouchableHistory *)
Step in BKLM.
DBObjPtr< BKLMSimulationPar > m_SimPar
Simulation parameters (from DB).
bool stepEKLM(G4Step *, G4TouchableHistory *)
Step in EKLM.
SensitiveDetector(const G4String &name, KLMSubdetectorNumber subdetector)
Constructor.
bool m_FirstCall
Flag to enforce once-only initializations in Initialize().
KLMSubdetectorNumber m_Subdetector
Subdetector.
RelationArray m_MCParticlesToKLMSimHits
Relation array between MCPartices and KLMSimHits.
static constexpr int m_DepthSection
Section depth.
static constexpr int m_DepthSector
Sector depth.
bklm::GeometryPar * m_GeoPar
Pointer to GeometryPar singleton.
const EKLMElementNumbers * m_ElementNumbers
EKLM element numbers.
bool step(G4Step *, G4TouchableHistory *) override
Process each step and store KLMSimHits.
double m_HitTimeMax
Maximum permissible hit time based on overflow of LeCroy 1877 TDC.
BkgSensitiveDetector * m_BkgSensitiveDetector
Pointer to a sensitive-detector object used for beam-background steps.
static constexpr int m_DepthScintillator
Scintillator depth.
static constexpr int m_DepthPlane
Plane depth.
void convertHitToRPCStrips(const CLHEP::Hep3Vector &, const bklm::Module *, int &, int &, int &, int &)
Find the ranges of matching RPC strips for BKLM hits.
StoreArray< MCParticle > m_MCParticles
MC particles.
static constexpr int m_DepthLayer
Layer depth.
StoreArray< KLMSimHit > m_KLMSimHits
Simulation hits.
Low-level class to create/modify relations between StoreArrays.
Base class for all Sensitive Detectors to create hits during simulation.
Provides BKLM geometry parameters for simulation, reconstruction etc (from Gearbox or DataBase)
Define the geometry of a BKLM module Each sector [octant] contains Modules.
uint16_t KLMSubdetectorNumber
Subdetector number.
Abstract base class for different kinds of events.