KaliVeda
Toolkit for HIC analysis
KVGeoNavigator Class Reference

Detailed Description

Base class for propagation of particles through array geometry.

This is a base class for propagation of charged particles (KVNucleus) in events (KVEvent) through any TGeoManager ROOT geometry. Classes derived from this one must override the method

virtual void ParticleEntersNewVolume(KVNucleus *)
Description of properties and kinematics of atomic nuclei.
Definition: KVNucleus.h:126

in order to do something useful every time that a particle of the event enters a new volume (absorber, detector, etc.) of the geometry.

Then to use your derived class do something like:

MyGeoNavigator nav( gGeoManager );
while( nevents-- ) {
nav.PropagateEvent( event );
}
See also
KVRangeTableGeoNavigator, KVGeoImport

Definition at line 46 of file KVGeoNavigator.h.

#include <KVGeoNavigator.h>

Inheritance diagram for KVGeoNavigator:

Classes

class  KVGeoDetectorPath
 Link physical path to node in geometry with detector. More...
 

Public Member Functions

 KVGeoNavigator (TGeoManager *)
 Constructor. Call with pointer to geometry. More...
 
virtual ~KVGeoNavigator ()
 Destructor. More...
 
void AbsorbDetectorPaths (KVGeoNavigator *GN)
 
virtual void AddPointToCurrentTrack (Double_t, Double_t, Double_t)
 
const TClonesArray & CurrentStructures () const
 
void DrawTracks (KVNumberList *=nullptr)
 
void ExtractDetectorNameFromPath (KVString &)
 
TGeoVolume * GetCurrentDetectorNameAndVolume (KVString &, Bool_t &)
 
TGeoNode * GetCurrentDetectorNode () const
 
const TGeoHMatrix * GetCurrentMatrix () const
 Returns pointer to internal copy of current global transformation matrix. More...
 
TGeoNode * GetCurrentNode () const
 
TString GetCurrentPath () const
 
TGeoVolume * GetCurrentVolume () const
 
const Char_t * GetDetectorNameFormat () const
 
const TVector3 & GetEntryPoint () const
 
const TVector3 & GetExitPoint () const
 
TGeoManager * GetGeometry () const
 
Bool_t GetNameCorrespondance (const Char_t *, TString &)
 
Double_t GetStepSize () const
 
Int_t GetTrackID () const
 
void IncrementTrackID ()
 
Bool_t IsTracking () const
 
virtual void ParticleEntersNewVolume (KVNucleus *)
 
void PrintDetectorPaths ()
 
void PropagateEvent (KVEvent *, TVector3 *TheOrigin=0)
 
virtual void PropagateParticle (KVNucleus *, TVector3 *TheOrigin=0)
 
void ResetTrackID (Int_t id=0)
 
void SetDetectorNameFormat (const Char_t *fmt)
 
void SetNameCorrespondanceList (const Char_t *)
 
void SetNameCorrespondanceList (const TEnv *)
 copy TEnv of name correspondances More...
 
void SetStopPropagation (Bool_t stop=kTRUE)
 
void SetStructureNameFormat (const Char_t *type, const Char_t *fmt)
 
void SetTracking (Bool_t on=kTRUE)
 
Bool_t StopPropagation () const
 
- Public Member Functions inherited from KVBase
 KVBase ()
 Default constructor. More...
 
 KVBase (const Char_t *name, const Char_t *title="")
 Ctor for object with given name and type. More...
 
 KVBase (const KVBase &)
 copy ctor More...
 
virtual ~ KVBase ()
 
virtual void Clear (Option_t *opt="")
 Clear object properties : name, type/title, number, label. More...
 
virtual void Copy (TObject &) const
 Make a copy of this object. More...
 
const Char_t * GetLabel () const
 
UInt_t GetNumber () const
 
UInt_t GetNumberOfObjects () const
 
virtual TObject * GetObject () const
 
virtual const Char_t * GetType () const
 
Bool_t HasLabel () const
 
virtual Bool_t IsCalled (const Char_t *name) const
 
Bool_t IsLabelled (const Char_t *l) const
 
virtual Bool_t IsType (const Char_t *typ) const
 
virtual void List ()
 
KVBaseoperator= (const KVBase &)
 copy assignment operator More...
 
virtual void Print (Option_t *option="") const
 
Double_t ProtectedGetX (const TF1 *func, Double_t val, int &status, Double_t xmin=0.0, Double_t xmax=0.0) const
 
void SetLabel (const Char_t *lab)
 
virtual void SetNumber (UInt_t num)
 
virtual void SetType (const Char_t *str)
 

Private Member Functions

void FormatDetectorName (const Char_t *basename, KVString &name)
 
void FormatStructureName (const Char_t *type, Int_t number, KVString &name)
 
KVDetectorGetDetectorFromPath (const Char_t *p)
 

Private Attributes

TGeoNode * fCurrentDetectorNode
 node for current detector More...
 
TGeoHMatrix fCurrentMatrix
 current global transformation matrix More...
 
TGeoNode * fCurrentNode
 current node More...
 
TString fCurrentPath
 current full path to physical node More...
 
TClonesArray fCurrentStructures
 list of current structures deduced from path More...
 
TGeoVolume * fCurrentVolume
 current volume More...
 
Int_t fCurStrucNumber
 number of current parent structures More...
 
KVUniqueNameList fDetectorPaths
 correspondance between physical node and detector objects More...
 
KVString fDetNameFmt
 user-defined format for detector names More...
 
TEnv * fDetStrucNameCorrespList
 list(s) of correspondance for renaming structures/detectors More...
 
TVector3 fEntryPoint
 position of particle on entering volume More...
 
TVector3 fExitPoint
 position of particle on exiting volume More...
 
TGeoManager * fGeometry
 geometry to navigate More...
 
TGeoNode * fMotherNode
 mother node of current node More...
 
Double_t fStepSize
 distance to travel in volume More...
 
Bool_t fStopPropagation
 flag set by user when particle propagation should stop More...
 
KVNameValueList fStrucNameFmt
 list of user-defined formats for structure names More...
 
Int_t fTrackID
 track counter More...
 
Bool_t fTracking
 set to true when tracking particles More...
 

Additional Inherited Members

- Public Types inherited from KVBase
enum  EKaliVedaBits { kIsKaliVedaObject = BIT(23) }
 
- Static Public Member Functions inherited from KVBase
static Bool_t AreEqual (Double_t x, Double_t y, Long64_t maxdif=1)
 Comparison between two 64-bit floating-point values. More...
 
static void BackupFileWithDate (const Char_t *path)
 
static void CombineFiles (const Char_t *file1, const Char_t *file2, const Char_t *newfilename, Bool_t keep=kTRUE)
 
static void Deprecated (const char *method, const char *advice)
 
static Bool_t FindClassSourceFiles (const Char_t *class_name, KVString &imp_file, KVString &dec_file, const Char_t *dir_name=".")
 
static Bool_t FindExecutable (TString &exec, const Char_t *path="$(PATH)")
 
static const Char_t * FindFile (const Char_t *search, TString &wfil)
 
static const Char_t * GetBINDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetDATABASEFilePath ()
 
static const Char_t * GetDATADIRFilePath (const Char_t *namefile="")
 
static Bool_t GetDataSetEnv (const Char_t *dataset, const Char_t *type, Bool_t defval)
 
static const Char_t * GetDataSetEnv (const Char_t *dataset, const Char_t *type, const Char_t *defval)
 
static Double_t GetDataSetEnv (const Char_t *dataset, const Char_t *type, Double_t defval)
 
static const Char_t * GetETCDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetExampleFilePath (const Char_t *library, const Char_t *namefile)
 Return full path to example file for given library (="KVMultiDet", "BackTrack", etc.) More...
 
static const Char_t * GetINCDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetKVBuildDate ()
 Returns KaliVeda build date. More...
 
static const Char_t * GetKVBuildDir ()
 Returns top-level directory used for build. More...
 
static const Char_t * GetKVBuildTime ()
 Returns KaliVeda build time. More...
 
static const Char_t * GetKVBuildType ()
 Returns KaliVeda build type (cmake build: Release, Debug, RelWithDebInfo, ...) More...
 
static const Char_t * GetKVBuildUser ()
 Returns username of person who performed build. More...
 
static const Char_t * GetKVSourceDir ()
 Returns top-level directory of source tree used for build. More...
 
static const Char_t * GetKVVersion ()
 Returns KaliVeda version string. More...
 
static const Char_t * GetLIBDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetListOfPlugins (const Char_t *base)
 
static const Char_t * GetListOfPluginURIs (const Char_t *base)
 
static const Char_t * GetPluginURI (const Char_t *base, const Char_t *plugin)
 
static void GetTempFileName (TString &base)
 
static const Char_t * GetTEMPLATEDIRFilePath (const Char_t *namefile="")
 
static const Char_t * GetWORKDIRFilePath (const Char_t *namefile="")
 
static const Char_t * gitBranch ()
 Returns git branch of sources. More...
 
static const Char_t * gitCommit ()
 Returns last git commit of sources. More...
 
static void InitEnvironment ()
 
static bool is_gnuinstall ()
 
static Bool_t IsThisAPlugin (const TString &uri, TString &base)
 
static TPluginHandler * LoadPlugin (const Char_t *base, const Char_t *uri="0")
 
static Bool_t OpenContextMenu (const char *method, TObject *obj, const char *alt_method_name="")
 
static void OpenTempFile (TString &base, std::ofstream &fp)
 
static void PrintSplashScreen ()
 Prints welcome message and infos on version etc. More...
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, KVSQLite::database &dbfile, const Char_t *kvsubdir="")
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, std::ifstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0)
 
static Bool_t SearchAndOpenKVFile (const Char_t *name, std::ofstream &file, const Char_t *kvsubdir="", KVLockfile *locks=0)
 
static Bool_t SearchKVFile (const Char_t *name, TString &fullpath, const Char_t *kvsubdir="")
 
static const Char_t * WorkingDirectory ()
 

Constructor & Destructor Documentation

◆ KVGeoNavigator()

KVGeoNavigator::KVGeoNavigator ( TGeoManager *  g)

Constructor. Call with pointer to geometry.

Definition at line 176 of file KVGeoNavigator.cpp.

◆ ~KVGeoNavigator()

KVGeoNavigator::~KVGeoNavigator ( )
virtual

Destructor.

Definition at line 190 of file KVGeoNavigator.cpp.

Member Function Documentation

◆ AbsorbDetectorPaths()

void KVGeoNavigator::AbsorbDetectorPaths ( KVGeoNavigator GN)
inline

Add all contents of GN->fDetectorPaths to our list.

Remove ownership of these paths from GN - our dtor will delete them

Definition at line 208 of file KVGeoNavigator.h.

◆ AddPointToCurrentTrack()

virtual void KVGeoNavigator::AddPointToCurrentTrack ( Double_t  ,
Double_t  ,
Double_t   
)
inlinevirtual

Reimplemented in KVRangeTableGeoNavigator.

Definition at line 205 of file KVGeoNavigator.h.

◆ CurrentStructures()

const TClonesArray& KVGeoNavigator::CurrentStructures ( ) const
inline

Definition at line 201 of file KVGeoNavigator.h.

◆ DrawTracks()

void KVGeoNavigator::DrawTracks ( KVNumberList zlist = nullptr)

When using ROOT geometry, after calling PropagateEvent() to simulate detection of some particles, you can call this method to overlay the tracks of the corresponding particles on the 3D geometry of the array

If KVNumberList pointer is given, use it to limit Z of drawn tracks

Definition at line 806 of file KVGeoNavigator.cpp.

◆ ExtractDetectorNameFromPath()

void KVGeoNavigator::ExtractDetectorNameFromPath ( KVString detname)

We analyse the current path in order to construct the full (unique) name of the detector, i.e. if the current path is

/TOP_1/STRUCT_BLOCK_2/CHIO_WALL_1/DET_CHIO_2/WINDOW_1

then the default name of the detector will be BLOCK_2_CHIO_2 (see below to override this).

This method also fills the fCurrentStructures array with elements deduced from the path, e.g. if the path is

/TOP_1/STRUCT_BLOCK_2/STRUCT_QUARTET_1/DET_SI1-T1

then by default

fCurrentStructures[0] = KVGeoStrucElement(name = "BLOCK_2", type = "BLOCK", number = 2)
fCurrentStructures[1] = KVGeoStrucElement(name = "QUARTET_1", type = "QUARTET", number = 1)
TClonesArray fCurrentStructures
list of current structures deduced from path
Base class describing elements of array geometry.

and the default name of the detector will be BLOCK_2_QUARTET_1_SI1-T1

STRUCTURE & DETECTOR NAME FORMATTING

Structures

The default names for structures are taken from the node name by stripping off the STRUCT_ prefix. It is assumed that the remaining string is of the form

"[structure type]_[structure number]"

(the structure number is always taken after the last occurence of '_' in the node name). This is the name that will be used by default for the structure.

However, this format can be change by calling method

SetStructureNameFormat("[structure type]", "[format]")
void SetStructureNameFormat(const Char_t *type, const Char_t *fmt)

where format can contain any of the following tokens:

$type$ - will be replaced by the structure type name
$type%[fmt]$ - will be replaced by the structure type name using given format
$number$ - will be replaced by the structure number
$number%[fmt]$ - will be replaced by the structure number using given format

Example: to change the name of the block in the previous example to "B-02":

SetStructureNameFormat("BLOCK", "$type%.1s$-$number%02d$")

Detectors

The default base names for detectors are taken from the node name by stripping off the DET_ prefix. In order to ensure that all detectors have unique names, by default we prefix the names of the parent structures to the basename in order to generate the full name of the detector:

[struc1-name]_[struc2-name]_..._[detector-basename]

However, this format can be changed by calling method

void SetDetectorNameFormat(const Char_t *fmt)

where format can contain any of the following tokens:

$det:name$ - will be replaced by the detector basename
$struc:[type]:name$ - will be replaced by the name of the parent structure of given type
$struc:[type]:type$ - will be replaced by the type of the parent structure of given type
$struc:[type]:number$ - will be replaced by the number of the parent structure of given type

plus additional formatting information as for SetStructureNameFormat() (see above).

Example: to change the name of the SI1-T1 detector in the previous example to SI1-T1-Q1-B2:

SetDetectorNameFormat("$det:name$-Q$struc:QUARTET:number$-B$struc:BLOCK:number$");

Or if you also change the format of the structure names:

SetStructureNameFormat("BLOCK", "$type%.1s$$number$");
SetStructureNameFormat("QUARTET", "$type%.1s$$number$");
SetDetectorNameFormat("$det:name$-$struc:QUARTET:name$-$struc:BLOCK:name$");

Definition at line 579 of file KVGeoNavigator.cpp.

◆ FormatDetectorName()

void KVGeoNavigator::FormatDetectorName ( const Char_t *  basename,
KVString name 
)
private

If a format for naming detectors has been defined by a call to SetDetectorNameFormat(const Char_t *), we use it to format the name in the TString.

If no format was given we prefix the names of the parent structures to the basename in order to generate the full name of the detector:

[struc1-name]_[struc2-name]_..._[detector-basename]

If SetNameCorrespondanceList(const Char_t *) was used, we use it to translate any names resulting from this formatting to their final value.

Definition at line 82 of file KVGeoNavigator.cpp.

◆ FormatStructureName()

void KVGeoNavigator::FormatStructureName ( const Char_t *  type,
Int_t  number,
KVString name 
)
private

If a format for naming structures of given type has been defined by a call to SetStructureNameFormat(const Char_t *, const Char_t *), we use it to format the name in the TString.

If no format was given, we use by default "[type]_[number]".

If SetNameCorrespondanceList(const Char_t *) was used, we use it to translate any names resulting from this formatting to their final value.

Definition at line 26 of file KVGeoNavigator.cpp.

◆ GetCurrentDetectorNameAndVolume()

TGeoVolume * KVGeoNavigator::GetCurrentDetectorNameAndVolume ( KVString detector_name,
Bool_t &  multilayer 
)

Returns the name of the current detector (if we are inside a detector) and whether it is a multilayer or simple detector.

Returns nullptr if we are not inside a detector volume.

N.B. the returned volume corresponds to the whole detector (even if it has several layers). For a multilayer detector, GetCurrentVolume() returns the volume for the current layer.

See ExtractDetectorNameFromPath() for details on detector name formatting.

Definition at line 437 of file KVGeoNavigator.cpp.

◆ GetCurrentDetectorNode()

TGeoNode * KVGeoNavigator::GetCurrentDetectorNode ( ) const

Returns the node corresponding to the current detector volume

N.B. the returned node corresponds to the whole detector (even if it has several layers).

Definition at line 483 of file KVGeoNavigator.cpp.

◆ GetCurrentMatrix()

const TGeoHMatrix * KVGeoNavigator::GetCurrentMatrix ( ) const

Returns pointer to internal copy of current global transformation matrix.

Definition at line 418 of file KVGeoNavigator.cpp.

◆ GetCurrentNode()

TGeoNode* KVGeoNavigator::GetCurrentNode ( ) const
inline

Definition at line 167 of file KVGeoNavigator.h.

◆ GetCurrentPath()

TString KVGeoNavigator::GetCurrentPath ( ) const
inline

Definition at line 186 of file KVGeoNavigator.h.

◆ GetCurrentVolume()

TGeoVolume* KVGeoNavigator::GetCurrentVolume ( ) const
inline

Definition at line 163 of file KVGeoNavigator.h.

◆ GetDetectorFromPath()

KVDetector* KVGeoNavigator::GetDetectorFromPath ( const Char_t *  p)
inlineprivate

Fast look-up of detector from full path to physical node This can only be used AFTER a KVGeoImport of the geometry

Definition at line 90 of file KVGeoNavigator.h.

◆ GetDetectorNameFormat()

const Char_t* KVGeoNavigator::GetDetectorNameFormat ( ) const
inline

Definition at line 147 of file KVGeoNavigator.h.

◆ GetEntryPoint()

const TVector3& KVGeoNavigator::GetEntryPoint ( ) const
inline

Definition at line 176 of file KVGeoNavigator.h.

◆ GetExitPoint()

const TVector3& KVGeoNavigator::GetExitPoint ( ) const
inline

Definition at line 180 of file KVGeoNavigator.h.

◆ GetGeometry()

TGeoManager* KVGeoNavigator::GetGeometry ( ) const
inline

Definition at line 159 of file KVGeoNavigator.h.

◆ GetNameCorrespondance()

Bool_t KVGeoNavigator::GetNameCorrespondance ( const Char_t *  name,
TString &  tran 
)

IF name correspondance lists have been set with SetNameCorrespondanceList(const Char_t*), look up new name for 'name'.

If found, returns kTRUE and 'tran' is the 'translated' name, otherwise returns kFALSE and tran=name.

Definition at line 326 of file KVGeoNavigator.cpp.

◆ GetStepSize()

Double_t KVGeoNavigator::GetStepSize ( ) const
inline

Definition at line 172 of file KVGeoNavigator.h.

◆ GetTrackID()

Int_t KVGeoNavigator::GetTrackID ( ) const
inline

Definition at line 106 of file KVGeoNavigator.h.

◆ IncrementTrackID()

void KVGeoNavigator::IncrementTrackID ( )
inline

Definition at line 110 of file KVGeoNavigator.h.

◆ IsTracking()

Bool_t KVGeoNavigator::IsTracking ( ) const
inline

Definition at line 118 of file KVGeoNavigator.h.

◆ ParticleEntersNewVolume()

void KVGeoNavigator::ParticleEntersNewVolume ( KVNucleus )
virtual

User-overridable method, to be redefined in child classes.

This method is called every time that a propagated particle enters a new volume in the geometry. The user then has access to the following informations:

  • the TGeoVolume the particle is now entering (GetCurrentVolume());
  • the node in the geometry this volume occupies (GetCurrentNode());
  • the distance the particle will have to travel in this volume before leaving it (GetStepSize());
  • the position of the particle on the boundary as it enters this volume (GetEntryPoint()).
  • the position of the particle on the boundary as it leaves this volume (GetExitPoint()).

If required, propagation of the particle can be stopped at any time by calling SetStopPropagation()

Reimplemented in KVRangeTableGeoNavigator, and KVGeoImport.

Definition at line 390 of file KVGeoNavigator.cpp.

◆ PrintDetectorPaths()

void KVGeoNavigator::PrintDetectorPaths ( )
inline

Definition at line 217 of file KVGeoNavigator.h.

◆ PropagateEvent()

void KVGeoNavigator::PropagateEvent ( KVEvent TheEvent,
TVector3 *  TheOrigin = 0 
)

Propagate a set of particles through the geometry.

By default, propagates particles from (0,0,0) (world coordinates), unless a different origin is given.

Definition at line 356 of file KVGeoNavigator.cpp.

◆ PropagateParticle()

void KVGeoNavigator::PropagateParticle ( KVNucleus part,
TVector3 *  TheOrigin = 0 
)
virtual

Propagate a particle through the geometry in the direction of its momentum, until we reach the boundary of the geometry, or until fStopPropagation is set to kFALSE.

Propagation will also stop if we encounter a volume whose name begins with "DEADZONE" Define point of origin of particles

Reimplemented in KVGeoImport, and KVRangeTableGeoNavigator.

Definition at line 703 of file KVGeoNavigator.cpp.

◆ ResetTrackID()

void KVGeoNavigator::ResetTrackID ( Int_t  id = 0)
inline

Definition at line 102 of file KVGeoNavigator.h.

◆ SetDetectorNameFormat()

void KVGeoNavigator::SetDetectorNameFormat ( const Char_t *  fmt)
inline

The default base names for detectors are taken from the node name by stripping off the DET_ prefix. In order to ensure that all detectors have unique names, by default we prefix the names of the parent structures to the basename in order to generate the full name of the detector:

[struc1-name]_[struc2-name]_..._[detector-basename]

However, this format can be changed by calling method

where format can contain any of the following tokens:

$det:name$ - will be replaced by the detector basename
$struc:[type]:name$ - will be replaced by the name of the parent structure of given type
$struc:[type]:type$ - will be replaced by the type of the parent structure of given type
$struc:[type]:number$ - will be replaced by the number of the parent structure of given type

plus additional formatting information as for SetStructureNameFormat()

Definition at line 124 of file KVGeoNavigator.h.

◆ SetNameCorrespondanceList() [1/2]

void KVGeoNavigator::SetNameCorrespondanceList ( const Char_t *  listfile)

Allows to provide a list of "translations" for naming structures/detectors "listfile" must be a file in TEnv format, e.g.

SI_06_1_A1: SI_0601
SI_06_1_A2: SI_0602
SI_06_1_B1: SI_0701
SI_06_1_B2: SI_0702
SI_06_2_A1: SI_0603
SI_06_2_A2: SI_0604
SI_06_2_B1: SI_0703

The name before ':' is the name of the detector or structure as deduced from the geometry, including any formatting due to SetStructureNameFormat() or SetDetectorNameFormat().

The name after ':' is the name that will be used 'externally', e.g. by a KVMultiDetArray created from the geometry using KVGeoImport.

Several lists can be combined by calling this method several times.

"listfile" can be an absolute path name; if not, we look for it in $KVROOT/KVFiles/data, or in $HOME, or (finally) in $PWD.

Definition at line 270 of file KVGeoNavigator.cpp.

◆ SetNameCorrespondanceList() [2/2]

void KVGeoNavigator::SetNameCorrespondanceList ( const TEnv *  list)

copy TEnv of name correspondances

Definition at line 311 of file KVGeoNavigator.cpp.

◆ SetStopPropagation()

void KVGeoNavigator::SetStopPropagation ( Bool_t  stop = kTRUE)
inline

Definition at line 195 of file KVGeoNavigator.h.

◆ SetStructureNameFormat()

void KVGeoNavigator::SetStructureNameFormat ( const Char_t *  type,
const Char_t *  fmt 
)

The default names for structures are taken from the node name by stripping off the STRUCT_ prefix. It is assumed that the remaining string is of the form

"[structure type]_[structure number]"

This is the name that will be used by default for the structure.

However, this format can be change by calling this method

SetStructureNameFormat("[structure type]", "[format]")

where format can contain any of the following tokens:

$type$ - will be replaced by the structure type name
$type%[fmt]$ - will be replaced by the structure type name using given format
$number$ - will be replaced by the structure number
$number%[fmt]$ - will be replaced by the structure number using given format

This is the name that will be used by default for the structure.

Definition at line 219 of file KVGeoNavigator.cpp.

◆ SetTracking()

void KVGeoNavigator::SetTracking ( Bool_t  on = kTRUE)
inline

Definition at line 114 of file KVGeoNavigator.h.

◆ StopPropagation()

Bool_t KVGeoNavigator::StopPropagation ( ) const
inline

Definition at line 191 of file KVGeoNavigator.h.

Member Data Documentation

◆ fCurrentDetectorNode

TGeoNode* KVGeoNavigator::fCurrentDetectorNode
private

node for current detector

Definition at line 51 of file KVGeoNavigator.h.

◆ fCurrentMatrix

TGeoHMatrix KVGeoNavigator::fCurrentMatrix
private

current global transformation matrix

Definition at line 52 of file KVGeoNavigator.h.

◆ fCurrentNode

TGeoNode* KVGeoNavigator::fCurrentNode
private

current node

Definition at line 50 of file KVGeoNavigator.h.

◆ fCurrentPath

TString KVGeoNavigator::fCurrentPath
private

current full path to physical node

Definition at line 53 of file KVGeoNavigator.h.

◆ fCurrentStructures

TClonesArray KVGeoNavigator::fCurrentStructures
private

list of current structures deduced from path

Definition at line 54 of file KVGeoNavigator.h.

◆ fCurrentVolume

TGeoVolume* KVGeoNavigator::fCurrentVolume
private

current volume

Definition at line 49 of file KVGeoNavigator.h.

◆ fCurStrucNumber

Int_t KVGeoNavigator::fCurStrucNumber
private

number of current parent structures

Definition at line 55 of file KVGeoNavigator.h.

◆ fDetectorPaths

KVUniqueNameList KVGeoNavigator::fDetectorPaths
private

correspondance between physical node and detector objects

Definition at line 89 of file KVGeoNavigator.h.

◆ fDetNameFmt

KVString KVGeoNavigator::fDetNameFmt
private

user-defined format for detector names

Definition at line 65 of file KVGeoNavigator.h.

◆ fDetStrucNameCorrespList

TEnv* KVGeoNavigator::fDetStrucNameCorrespList
private

list(s) of correspondance for renaming structures/detectors

Definition at line 66 of file KVGeoNavigator.h.

◆ fEntryPoint

TVector3 KVGeoNavigator::fEntryPoint
private

position of particle on entering volume

Definition at line 58 of file KVGeoNavigator.h.

◆ fExitPoint

TVector3 KVGeoNavigator::fExitPoint
private

position of particle on exiting volume

Definition at line 59 of file KVGeoNavigator.h.

◆ fGeometry

TGeoManager* KVGeoNavigator::fGeometry
private

geometry to navigate

Definition at line 48 of file KVGeoNavigator.h.

◆ fMotherNode

TGeoNode* KVGeoNavigator::fMotherNode
private

mother node of current node

Definition at line 56 of file KVGeoNavigator.h.

◆ fStepSize

Double_t KVGeoNavigator::fStepSize
private

distance to travel in volume

Definition at line 57 of file KVGeoNavigator.h.

◆ fStopPropagation

Bool_t KVGeoNavigator::fStopPropagation
private

flag set by user when particle propagation should stop

Definition at line 60 of file KVGeoNavigator.h.

◆ fStrucNameFmt

KVNameValueList KVGeoNavigator::fStrucNameFmt
private

list of user-defined formats for structure names

Definition at line 64 of file KVGeoNavigator.h.

◆ fTrackID

Int_t KVGeoNavigator::fTrackID
private

track counter

Definition at line 61 of file KVGeoNavigator.h.

◆ fTracking

Bool_t KVGeoNavigator::fTracking
private

set to true when tracking particles

Definition at line 62 of file KVGeoNavigator.h.