4 #include "KVGeoNavigator.h"
5 #include "KVTemplateEvent.h"
6 #include "KV3DGeoTrack.h"
7 #include "KVNucleusEvent.h"
8 #include <TGeoManager.h>
9 #include <TGeoMatrix.h>
10 #include "KVGeoStrucElement.h"
11 #include <TVirtualPad.h>
38 if (fStrucNameFmt.HasParameter(type)) {
39 KVString fmt = fStrucNameFmt.GetStringValue(type);
43 if (bit.BeginsWith(
"type")) {
44 Ssiz_t ind = bit.Index(
"%");
47 name += Form(bit.Data(), type);
50 }
else if (bit.BeginsWith(
"number")) {
51 Ssiz_t ind = bit.Index(
"%");
54 name += Form(bit.Data(), number);
61 name.Form(
"%s_%d", type, number);
63 GetNameCorrespondance(name.Data(), tmp);
104 name += Form(
"%s_", el->GetName());
115 if (bit.Contains(
":")) {
118 if (itbit ==
"det") {
120 if (itbit.BeginsWith(
"name")) {
121 Ssiz_t ind = itbit.Index(
"%");
123 itbit.Remove(0, ind);
124 name += Form(itbit.Data(), basename);
128 }
else if (itbit ==
"struc") {
133 if (el->
IsType(struc_typ))
break;
137 if (itbit.BeginsWith(
"name")) {
138 Ssiz_t ind = itbit.Index(
"%");
140 itbit.Remove(0, ind);
141 name += Form(itbit.Data(), el->GetName());
143 name += el->GetName();
144 }
else if (itbit.BeginsWith(
"type")) {
145 Ssiz_t ind = itbit.Index(
"%");
147 itbit.Remove(0, ind);
148 name += Form(itbit.Data(), el->
GetType());
151 }
else if (itbit.BeginsWith(
"number")) {
152 Ssiz_t ind = itbit.Index(
"%");
154 itbit.Remove(0, ind);
155 name += Form(itbit.Data(), el->
GetNumber());
177 : fGeometry(g), fCurrentStructures(
"KVGeoStrucElement", 50), fDetStrucNameCorrespList(nullptr),
178 fDetectorPaths(kTRUE)
299 Warning(
"SetNameCorrespondanceList",
"File %s not found", listfile);
410 AbstractMethod(
"ParticleEntersNewVolume");
452 TGeoVolume* detector_volume = 0;
453 if (volNom.BeginsWith(
"DET_")) {
461 TString mom = mother_vol->GetName();
462 if (mom.BeginsWith(
"DET_")) {
466 detector_volume = mother_vol;
473 return detector_volume;
672 while (!path.
End()) {
674 if (elem.BeginsWith(
"STRUCT_")) {
676 KVString struc_name(elem(7, elem.Length() - 7));
678 Ssiz_t last_ = struc_name.Last(
'_');
679 TString type = struc_name(0, last_);
680 TString nums = struc_name(last_ + 1, struc_name.Length() - last_ - 1);
681 Int_t number = nums.Atoi();
684 gel->SetNameTitle(name, type);
686 }
else if (elem.BeginsWith(
"DET_")) {
688 KVString basename(elem(4, elem.Length() - 4));
711 if (TheOrigin)
fGeometry->SetCurrentPoint(TheOrigin->X(), TheOrigin->Y(), TheOrigin->Z());
712 else fGeometry->SetCurrentPoint(0., 0., 0.);
717 fGeometry->SetCurrentDirection(v.x(), v.y(), v.z());
728 TGeoVolume* newVol =
fGeometry->GetCurrentVolume();
729 TGeoNode* newNod =
fGeometry->GetCurrentNode();
730 TGeoNode* newMom =
fGeometry->GetMother();
731 TGeoHMatrix* newMatx =
fGeometry->GetCurrentMatrix();
744 const Double_t* posi =
fGeometry->GetCurrentPoint();
753 const Double_t* posi =
fGeometry->GetCurrentPoint();
761 if (vn.BeginsWith(
"DEADZONE")) {
792 const Double_t* posi =
fGeometry->GetCurrentPoint();
814 TIter next_track(
fGeometry->GetListOfTracks());
815 TVirtualGeoTrack* track;
817 while ((track = (TVirtualGeoTrack*)next_track())) {
822 if (gPad) gtrack->
Draw(
"same");
823 else gtrack->
Draw(
"ogl");
825 }
else gtrack->
Draw(
"same");
Class for iterating over nuclei in events accessed through base pointer/reference.
Visualise particle trajectories through array geometry.
void Draw(Option_t *option="")
Override Draw to add a TPolyMarker3D at the end of the track.
virtual const Char_t * GetType() const
virtual Bool_t IsType(const Char_t *typ) const
virtual void SetNumber(UInt_t num)
static Bool_t SearchKVFile(const Char_t *name, TString &fullpath, const Char_t *kvsubdir="")
Abstract base class container for multi-particle events.
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
TGeoHMatrix fCurrentMatrix
current global transformation matrix
void PropagateEvent(KVEvent *, TVector3 *TheOrigin=0)
const TGeoHMatrix * GetCurrentMatrix() const
Returns pointer to internal copy of current global transformation matrix.
TClonesArray fCurrentStructures
list of current structures deduced from path
TString fCurrentPath
current full path to physical node
void FormatDetectorName(const Char_t *basename, KVString &name)
TGeoNode * fCurrentDetectorNode
node for current detector
void ExtractDetectorNameFromPath(KVString &)
KVUniqueNameList fDetectorPaths
correspondance between physical node and detector objects
TGeoNode * GetCurrentNode() const
TGeoNode * fMotherNode
mother node of current node
void SetTracking(Bool_t on=kTRUE)
KVGeoNavigator(TGeoManager *)
Constructor. Call with pointer to geometry.
KVNameValueList fStrucNameFmt
list of user-defined formats for structure names
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)
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
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
void SetStructureNameFormat(const Char_t *type, const Char_t *fmt)
TGeoVolume * GetCurrentDetectorNameAndVolume(KVString &, Bool_t &)
void DrawTracks(KVNumberList *=nullptr)
Base class describing elements of array geometry.
void SetValue(const Char_t *name, value_type value)
Description of properties and kinematics of atomic nuclei.
Int_t GetZ() const
Return the number of proton / atomic number.
Strings used to represent a set of ranges of values.
Bool_t Contains(Int_t val) const
returns kTRUE if the value 'val' is contained in the ranges defined by the number list
TVector3 GetMomentum() const
KVNameValueList * GetParameters() const
virtual void SetOwner(Bool_t enable=kTRUE)
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
void Begin(TString delim) const
KVString Next(Bool_t strip_whitespace=kFALSE) const