KaliVeda
Toolkit for HIC analysis
KVGeoNavigator.h
1 
4 #ifndef __KVGEONAVIGATOR_H
5 #define __KVGEONAVIGATOR_H
6 
7 #include "KVBase.h"
8 #include "TVector3.h"
9 #include "TClonesArray.h"
10 #include "KVDetector.h"
11 #include <KVNameValueList.h>
12 #include <TGeoMatrix.h>
13 class KVNucleus;
14 class TGeoManager;
15 class TGeoVolume;
16 class TGeoNode;
17 class TEnv;
18 
46 class KVGeoNavigator : public KVBase {
47 private:
63 protected:
67  void FormatStructureName(const Char_t* type, Int_t number, KVString& name);
68  void FormatDetectorName(const Char_t* basename, KVString& name);
69 
70 public:
75  class KVGeoDetectorPath : public TNamed {
76  KVDetector* fDetector;
77  public:
78  KVGeoDetectorPath() : TNamed(), fDetector(nullptr) {}
79  KVGeoDetectorPath(const Char_t* path, KVDetector* det) :
80  TNamed(path, ""), fDetector(det) {}
81  KVDetector* GetDetector() const
82  {
83  return fDetector;
84  }
85  ClassDef(KVGeoDetectorPath, 1) //Link physical path to node in geometry with detector
86  };
87 protected:
89  KVDetector* GetDetectorFromPath(const TString& p)
90  {
94  return (KVDetector*)(gdp ? gdp->GetDetector() : nullptr);
95  }
96  Int_t GetSubDetectorFromPathAndNodeName(KVDetector* det, const TString& p, const TString& n)
97  {
101 
102  if (p.Contains(Form("DET_%s/SUBDET_", det->GetName())) && n.BeginsWith("SUBDET_")) {
103  TString sub(n);
104  sub.Remove(0, 7);
105  return sub.Atoi();
106  }
107  return -1;
108  }
109 
110 public:
112  virtual ~KVGeoNavigator();
113 
114  void ResetTrackID(Int_t id = 0)
115  {
116  fTrackID = id;
117  }
119  {
120  return fTrackID;
121  }
123  {
124  ++fTrackID;
125  }
126  void SetTracking(Bool_t on = kTRUE)
127  {
128  fTracking = on;
129  }
131  {
132  return fTracking;
133  }
134 
135  void SetStructureNameFormat(const Char_t* type, const Char_t* fmt);
136  void SetDetectorNameFormat(const Char_t* fmt)
137  {
157  fDetNameFmt = fmt;
158  }
160  {
161  return fDetNameFmt.Data();
162  }
163  void SetNameCorrespondanceList(const Char_t*);
164  void SetNameCorrespondanceList(const TEnv*);
166 
167  void PropagateEvent(KVEvent*, TVector3* TheOrigin = 0);
168  virtual void PropagateParticle(KVNucleus*, TVector3* TheOrigin = 0);
169  virtual void ParticleEntersNewVolume(KVNucleus*);
170 
172  {
173  return fGeometry;
174  }
176  {
177  return fCurrentVolume;
178  }
180  {
181  return fCurrentNode;
182  }
183  const TGeoHMatrix* GetCurrentMatrix() const;
185  {
186  return fStepSize;
187  }
188  const TVector3& GetEntryPoint() const
189  {
190  return fEntryPoint;
191  }
192  const TVector3& GetExitPoint() const
193  {
194  return fExitPoint;
195  }
199  {
200  return fCurrentPath;
201  }
202 
204  {
205  return fStopPropagation;
206  }
207  void SetStopPropagation(Bool_t stop = kTRUE)
208  {
209  fStopPropagation = stop;
210  }
211 
214  {
215  return fCurrentStructures;
216  }
218  void DrawTracks(KVNumberList* = nullptr);
219 
221  {
225 
228  }
230  {
231  TIter it(&fDetectorPaths);
232  KVGeoDetectorPath* gdp;
233  while ((gdp = (KVGeoDetectorPath*)it())) {
234  std::cout << gdp->GetDetector()->GetName() << " : " << gdp->GetName() << std::endl;
235  }
236  }
237 
238  ClassDef(KVGeoNavigator, 0) //Propagate particles of an event through a TGeo geometry
239 };
240 
241 #endif
int Int_t
bool Bool_t
char Char_t
constexpr Bool_t kFALSE
double Double_t
#define ClassDef(name, id)
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize id
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void on
char * Form(const char *fmt,...)
Base class for KaliVeda framework.
Definition: KVBase.h:139
Abstract base class container for multi-particle events.
Definition: KVEvent.h:67
Link physical path to node in geometry with detector.
KVDetector * GetDetector() const
KVGeoDetectorPath(const Char_t *path, KVDetector *det)
Base class for propagation of particles through array geometry.
virtual void AddPointToCurrentTrack(Double_t, Double_t, Double_t)
void FormatStructureName(const Char_t *type, Int_t number, KVString &name)
Bool_t IsTracking() const
const Char_t * GetDetectorNameFormat() const
TGeoHMatrix fCurrentMatrix
current global transformation matrix
void SetDetectorNameFormat(const Char_t *fmt)
void PropagateEvent(KVEvent *, TVector3 *TheOrigin=0)
const TGeoHMatrix * GetCurrentMatrix() const
Returns pointer to internal copy of current global transformation matrix.
void AbsorbDetectorPaths(KVGeoNavigator *GN)
TClonesArray fCurrentStructures
list of current structures deduced from path
Int_t GetTrackID() const
TString fCurrentPath
current full path to physical node
void FormatDetectorName(const Char_t *basename, KVString &name)
void IncrementTrackID()
TGeoNode * fCurrentDetectorNode
node for current detector
void ExtractDetectorNameFromPath(KVString &)
KVUniqueNameList fDetectorPaths
correspondance between physical node and detector objects
void PrintDetectorPaths()
TGeoNode * GetCurrentNode() const
TGeoNode * fMotherNode
mother node of current node
void SetTracking(Bool_t on=kTRUE)
KVGeoNavigator(TGeoManager *)
Constructor. Call with pointer to geometry.
Double_t GetStepSize() const
KVNameValueList fStrucNameFmt
list of user-defined formats for structure names
KVDetector * GetDetectorFromPath(const TString &p)
const TClonesArray & CurrentStructures() const
void SetNameCorrespondanceList(const Char_t *)
TVector3 fExitPoint
position of particle on exiting volume
TEnv * fDetStrucNameCorrespList
list(s) of correspondance for renaming structures/detectors
void SetStopPropagation(Bool_t stop=kTRUE)
virtual void PropagateParticle(KVNucleus *, TVector3 *TheOrigin=0)
Int_t fTrackID
track counter
TGeoVolume * GetCurrentDetectorNameAndVolume(KVString &, Bool_t &, Bool_t &segmented)
Bool_t fTracking
set to true when tracking particles
TGeoNode * GetCurrentDetectorNode() const
virtual void ParticleEntersNewVolume(KVNucleus *)
TString GetCurrentPath() const
TGeoVolume * GetCurrentVolume() const
Bool_t GetNameCorrespondance(const Char_t *, TString &)
Double_t fStepSize
distance to travel in volume
TGeoManager * fGeometry
geometry to navigate
Bool_t StopPropagation() const
TGeoNode * fCurrentNode
current node
Int_t GetSubDetectorFromPathAndNodeName(KVDetector *det, const TString &p, const TString &n)
virtual ~KVGeoNavigator()
Destructor.
TVector3 fEntryPoint
position of particle on entering volume
KVString fDetNameFmt
user-defined format for detector names
Int_t fCurStrucNumber
number of current parent structures
void ResetTrackID(Int_t id=0)
TGeoVolume * fCurrentVolume
current volume
const TVector3 & GetExitPoint() const
void SetStructureNameFormat(const Char_t *type, const Char_t *fmt)
const TVector3 & GetEntryPoint() const
TGeoManager * GetGeometry() const
void DrawTracks(KVNumberList *=nullptr)
Bool_t fStopPropagation
flag set by user when particle propagation should stop
Handles lists of named parameters with different types, a list of KVNamedParameter objects.
Description of properties and kinematics of atomic nuclei.
Definition: KVNucleus.h:123
Strings used to represent a set of ranges of values.
Definition: KVNumberList.h:85
TObject * FindObject(const char *name) const override
void SetOwner(Bool_t enable=kTRUE) override
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
Definition: KVString.h:73
Optimised list in which named objects can only be placed once.
virtual void AddAll(const TCollection *col)
const char * GetName() const override
Int_t Atoi() const
const char * Data() const
TString & Remove(EStripType s, char c)
const Int_t n