Belle II Software
release-08-01-10
|
geant4e-based track extrapolation. More...
#include <TrackExtrapolateG4e.h>
Public Member Functions | |
~TrackExtrapolateG4e () | |
destructor | |
void | initialize (double minPt, double minKE, std::vector< Const::ChargedStable > &hypotheses) |
Initialize for track extrapolation by the EXT module. More... | |
void | initialize (double meanDt, double maxDt, double maxSeparation, double maxKLMTrackClusterDistance, double maxECLTrackClusterDistance, double minPt, double minKE, bool addHitsToRecoTrack, std::vector< Const::ChargedStable > &hypotheses) |
Initialize for track extrapolation by the MUID module. More... | |
void | beginRun (bool flag) |
Perform beginning-of-run actions. More... | |
void | event (bool flag) |
Performs track extrapolation for all tracks in one event. More... | |
void | endRun (bool flag) |
Perform end-of-run actions. More... | |
void | terminate (bool flag) |
Terminates this singleton. More... | |
void | extrapolate (int pdgCode, double tof, const G4ThreeVector &position, const G4ThreeVector &momentum, const G4ErrorSymMatrix &covariance) |
Performs track extrapolation for a single track (specified in genfit2 units). More... | |
Static Public Member Functions | |
static TrackExtrapolateG4e * | getInstance () |
Get the singleton's address. | |
Private Member Functions | |
TrackExtrapolateG4e () | |
constructor is hidden; user calls TrackExtrapolateG4e::getInstance() instead | |
TrackExtrapolateG4e (TrackExtrapolateG4e &) | |
copy constructor is hidden; user calls TrackExtrapolateG4e::getInstance() instead | |
void | swim (ExtState &, G4ErrorFreeTrajState &, const std::vector< std::pair< ECLCluster *, G4ThreeVector > > *, const std::vector< std::pair< KLMCluster *, G4ThreeVector > > *, std::vector< std::map< const Track *, double > > *) |
Swim a single track (MUID) until it stops or leaves the target cylinder. | |
void | swim (ExtState &, G4ErrorFreeTrajState &) |
Swim a single track (EXT) until it stops or leaves the target cylinder. | |
void | registerVolumes () |
Register the list of geant4 physical volumes whose entry/exit points will be saved during extrapolation. | |
void | getVolumeID (const G4TouchableHandle &, Const::EDetector &, int &) |
Get the physical volume information for a geant4 physical volume. | |
void | fromG4eToPhasespace (const G4ErrorFreeTrajState &, G4ErrorSymMatrix &) |
Convert the geant4e 5x5 covariance to phasespace 6x6 covariance. | |
void | fromPhasespaceToG4e (const G4ThreeVector &, const G4ErrorSymMatrix &, G4ErrorTrajErr &) |
Convert the phasespace covariance to geant4e covariance. | |
void | fromPhasespaceToG4e (const TVector3 &, const TMatrixDSym &, G4ErrorTrajErr &) |
Convert the phasespace covariance to geant4e covariance. | |
ExtState | getStartPoint (const Track &, int, G4ErrorFreeTrajState &) |
Get the start point for a new reconstructed track with specific PDG hypothesis. | |
void | createExtHit (ExtHitStatus, const ExtState &, const G4ErrorFreeTrajState &, const G4StepPoint *, const G4TouchableHandle &) |
Create another EXT extrapolation hit for a track candidate. | |
void | createECLHit (const ExtState &, const G4ErrorFreeTrajState &, const G4StepPoint *, const G4StepPoint *, const G4TouchableHandle &, const std::pair< ECLCluster *, G4ThreeVector > &, double, double) |
Create another EXT ECL-crystal-crossing hit for a track candidate. | |
bool | createMuidHit (ExtState &, G4ErrorFreeTrajState &, KLMMuidLikelihood *, std::vector< std::map< const Track *, double > > *) |
Create another MUID extrapolation hit for a track candidate. | |
bool | findBarrelIntersection (ExtState &, const G4ThreeVector &, Intersection &) |
Find the intersection point of the track with the crossed BKLM plane. | |
bool | findEndcapIntersection (ExtState &, const G4ThreeVector &, Intersection &) |
Find the intersection point of the track with the crossed EKLM plane. | |
bool | findMatchingBarrelHit (Intersection &, const Track *) |
Find the matching BKLM 2D hit nearest the intersection point of the track with the crossed BKLM plane. | |
bool | findMatchingEndcapHit (Intersection &, const Track *) |
Find the matching EKLM 2D hit nearest the intersection point of the track with the crossed EKLM plane. | |
void | adjustIntersection (Intersection &, const double *, const G4ThreeVector &, const G4ThreeVector &) |
Nudge the track using the matching hit. | |
void | finishTrack (const ExtState &, KLMMuidLikelihood *, bool) |
Complete muon identification after end of track extrapolation. | |
Private Attributes | |
bool | m_ExtInitialized |
Flag to indicate that EXT initialize() has been called. | |
bool | m_MuidInitialized |
Flag to indicate that MUID initialize() has been called. | |
double | m_MeanDt |
Mean hit - trigger time (ns) | |
double | m_MaxDt |
Coincidence window half-width for in-time KLM hits (ns) | |
double | m_MagneticField |
Magnetic field z component (gauss) at origin. | |
double | m_MaxDistSqInVariances |
user-defined maximum squared-distance (in number of variances) for matching hit to extrapolation | |
double | m_MaxKLMTrackClusterDistance |
user-defined maximum distance (mm) between KLMCluster and associated track (for KLID) | |
double | m_MaxECLTrackClusterDistance |
user-defined maximum distance (mm) between ECLCluster and associated track (for EID) | |
double | m_MinPt |
Minimum transverse momentum in MeV/c for extrapolation to be started. | |
double | m_MinKE |
Minimum kinetic energy in MeV for extrapolation to continue. | |
Simulation::ExtManager * | m_ExtMgr |
Pointer to the ExtManager singleton. | |
const std::vector< Const::ChargedStable > * | m_HypothesesExt |
ChargedStable hypotheses for EXT. | |
const std::vector< Const::ChargedStable > * | m_HypothesesMuid |
ChargedStable hypotheses for MUID. | |
std::vector< Const::ChargedStable > * | m_DefaultHypotheses |
Default ChargedStable hypotheses (needed as call argument but not used) | |
std::map< G4VPhysicalVolume *, enum VolTypes > * | m_EnterExit |
Pointers to geant4 physical volumes whose entry/exit points will be saved. | |
std::vector< G4VPhysicalVolume * > * | m_BKLMVolumes |
Pointers to BKLM geant4 sensitive (physical) volumes. | |
Simulation::ExtCylSurfaceTarget * | m_TargetExt |
virtual "target" cylinder for EXT (boundary beyond which extrapolation ends) | |
Simulation::ExtCylSurfaceTarget * | m_TargetMuid |
virtual "target" cylinder for MUID (boundary beyond which extrapolation ends) | |
DBObjPtr< COILGeometryPar > | m_COILGeometryPar |
Conditions-database object for COIL geometry. | |
DBObjPtr< BeamPipeGeo > | m_BeamPipeGeo |
Conditions-database object for beam pipe geometry. | |
double | m_MinRadiusSq |
Minimum squared radius (cm) outside of which extrapolation will continue. | |
double | m_OffsetZ |
offset (cm) along z axis of KLM midpoint from IP | |
int | m_BarrelNSector |
Number of barrel sectors. | |
double | m_BarrelMaxR |
maximum radius (cm) of the barrel | |
double | m_BarrelMinR |
minimum radius (cm) of the barrel | |
double | m_BarrelHalfLength |
half-length (cm) of the barrel | |
int | m_OutermostActiveBarrelLayer |
outermost barrel layer that is active for muon identification (user-defined) | |
double | m_BarrelPhiStripVariance [BKLMElementNumbers::getMaximalLayerNumber()+1] |
BKLM RPC phi-measuring strip position variance (cm^2) by layer. | |
double | m_BarrelZStripVariance [BKLMElementNumbers::getMaximalLayerNumber()+1] |
BKLM RPC z-measuring strip position variance (cm^2) by layer. | |
double | m_BarrelScintVariance |
BKLM scintillator strip position variance (cm^2) | |
double | m_BarrelModuleMiddleRadius [2][BKLMElementNumbers::getMaximalSectorNumber()+1][BKLMElementNumbers::getMaximalLayerNumber()+1] |
hit-plane radius (cm) at closest distance to IP of each barrel end | sector | layer | |
G4ThreeVector | m_BarrelSectorPerp [BKLMElementNumbers::getMaximalSectorNumber()+1] |
normal unit vector of each barrel sector | |
G4ThreeVector | m_BarrelSectorPhi [BKLMElementNumbers::getMaximalSectorNumber()+1] |
azimuthal unit vector of each barrel sector | |
double | m_EndcapMaxR |
maximum radius (cm) of the endcaps | |
double | m_EndcapMinR |
minimum radius (cm) of the endcaps | |
double | m_EndcapMiddleZ |
midpoint along z (cm) of the forward endcap from the KLM midpoint | |
double | m_EndcapHalfLength |
half-length (cm) of either endcap | |
int | m_OutermostActiveForwardEndcapLayer |
outermost forward-endcap layer that is active for muon identification (user-defined) | |
int | m_OutermostActiveBackwardEndcapLayer |
outermost backward-endcap layer that is active for muon identification (user-defined) | |
double | m_EndcapScintVariance |
EKLM scintillator strip position variance (cm^2) | |
double | m_EndcapModuleMiddleZ [BKLMElementNumbers::getMaximalLayerNumber()+1] |
hit-plane z (cm) of each IP layer relative to KLM midpoint | |
bool | m_addHitsToRecoTrack = false |
Parameter to add the found hits also to the reco tracks or not. Is turned off by default. | |
std::map< int, MuidBuilder * > | m_MuidBuilderMap |
PDF for the charged final state particle hypotheses. | |
const EKLMElementNumbers * | m_eklmElementNumbers |
EKLM element numbers. | |
const KLMElementNumbers * | m_klmElementNumbers |
KLM element numbers. | |
const EKLM::TransformDataGlobalAligned * | m_eklmTransformData |
EKLM transformation data. | |
DBObjPtr< KLMChannelStatus > | m_klmChannelStatus |
Conditions-database object for KLM channel status. | |
DBObjPtr< KLMStripEfficiency > | m_klmStripEfficiency |
Conditions-database object for KLM strip efficiency. | |
DBObjPtr< KLMLikelihoodParameters > | m_klmLikelihoodParameters |
Conditions-database object for KLM likelihood parameters. | |
StoreArray< ECLCluster > | m_eclClusters |
ECL clusters. | |
StoreArray< ExtHit > | m_extHits |
Ext hits. | |
StoreArray< KLMHit2d > | m_klmHit2ds |
KLM 2d hits. | |
StoreArray< KLMCluster > | m_klmClusters |
KLM clusters. | |
StoreArray< KLMMuidHit > | m_klmMuidHits |
KLM muid hits. | |
StoreArray< KLMMuidLikelihood > | m_klmMuidLikelihoods |
KLM muid likelihoods. | |
StoreArray< RecoTrack > | m_recoTracks |
Reco tracks. | |
StoreArray< Track > | m_tracks |
Tracks. | |
StoreArray< TrackClusterSeparation > | m_trackClusterSeparations |
Track cluster sepration. | |
Static Private Attributes | |
static TrackExtrapolateG4e * | m_Singleton = nullptr |
Stores pointer to the singleton class. | |
geant4e-based track extrapolation.
This class extrapolates tracks outward from the outer perimeter of the CDC using geant4e.
This class requires a valid geometry in memory (gGeoManager). Therefore, a geometry building module should have been executed before this module is called.
This class has the same functions as a module - and these are called from the ExtModule's so-named functions - but also has an entry that can be called to extrapolate a single user-defined track.
Definition at line 168 of file TrackExtrapolateG4e.h.
void beginRun | ( | bool | flag | ) |
Perform beginning-of-run actions.
flag | True if called by Muid module, false if called by Ext module. |
Definition at line 333 of file TrackExtrapolateG4e.cc.
void endRun | ( | bool | flag | ) |
Perform end-of-run actions.
flag | True if called by Muid module, false if called by Ext module. |
Definition at line 413 of file TrackExtrapolateG4e.cc.
void event | ( | bool | flag | ) |
Performs track extrapolation for all tracks in one event.
flag | True if called by Muid module, false if called by Ext module. |
Definition at line 357 of file TrackExtrapolateG4e.cc.
void extrapolate | ( | int | pdgCode, |
double | tof, | ||
const G4ThreeVector & | position, | ||
const G4ThreeVector & | momentum, | ||
const G4ErrorSymMatrix & | covariance | ||
) |
Performs track extrapolation for a single track (specified in genfit2 units).
pdgCode | Signed PDG identifier of the particle hypothesis to be used for the extrapolation. |
tof | Starting time, i.e., time of flight from the IP, at the starting point (ns). |
position | Starting point of the extrapolation (cm). |
momentum | Momentum of the track at the starting point (GeV/c). |
covariance | Phase-space covariance matrix (6x6) at the starting point (cm, GeV/c). |
Definition at line 439 of file TrackExtrapolateG4e.cc.
void initialize | ( | double | meanDt, |
double | maxDt, | ||
double | maxSeparation, | ||
double | maxKLMTrackClusterDistance, | ||
double | maxECLTrackClusterDistance, | ||
double | minPt, | ||
double | minKE, | ||
bool | addHitsToRecoTrack, | ||
std::vector< Const::ChargedStable > & | hypotheses | ||
) |
Initialize for track extrapolation by the MUID module.
meanDt | Mean value of the in-time window (ns). |
maxDt | Half-width of the in-time window (ns). |
maxSeparation | Maximum separation between track crossing and matching hit in detector plane (number of sigmas). |
maxKLMTrackClusterDistance | Maximum distance between associated track and KLMCluster (cm), criterion for matching relation Track->KLMCluster on MDST. |
maxECLTrackClusterDistance | Maximum distance between associated track and ECLCluster (cm). |
minPt | Minimum transverse momentum to begin extrapolation (GeV/c). |
minKE | Minimum kinetic energy to continue extrapolation (GeV/c). |
addHitsToRecoTrack | Parameter to add the found hits also to the reco tracks or not. Is turned off by default. |
hypotheses | Vector of charged-particle hypotheses used in extrapolation of each track. |
Definition at line 191 of file TrackExtrapolateG4e.cc.
void initialize | ( | double | minPt, |
double | minKE, | ||
std::vector< Const::ChargedStable > & | hypotheses | ||
) |
Initialize for track extrapolation by the EXT module.
minPt | Minimum transverse momentum to begin extrapolation (GeV/c). |
minKE | Minimum kinetic energy to continue extrapolation (GeV/c). |
hypotheses | Vector of charged-particle hypotheses used in extrapolation of each track. |
Definition at line 138 of file TrackExtrapolateG4e.cc.
void terminate | ( | bool | flag | ) |
Terminates this singleton.
flag | True if called by Muid module, false if called by Ext module. |
Definition at line 417 of file TrackExtrapolateG4e.cc.