KaliVeda
1.13/01
Heavy-Ion Analysis Toolkit
|
Import detector array described by ROOT geometry and set up corresponding KVMultiDetArray object.
To use:
1.) All detector volumes & nodes must have names which begin with DET_
2.) They must be made of materials which are known by the range table fRangeTable.
3.) For multi-layer detectors, the active layer volume/node must have a name beginning with ACTIVE_
4.) The "thickness" of the detector or any layer inside a multilayer detector will be taken as the size of the volume's shape along its Z-axis (so make sure that you define your detector volumes in this way).
5.) It is assumed that the natural length units of the geometry are centimetres.
6.) The name of the KVDetector object created and added to the array will be taken from the unique full path of the node corresponding to the geometrical positioning of the detector, see KVGeoNavigator::ExtractDetectorNameFromPath()
A structure element is any association of detectors which may occur several times in a geometry in different places, with the same internal structure.
The detectors in the wall may all be represented by a single volume (if they are identical) called DET_SI, for example, which is placed N times in N different positions on nodes called, by default, DET_SI_1, DET_SI_2, etc.
Once you have defined the wall volume, call it STRUCT_SIWALL (or whatever you want: only the STRUCT_ part is mandatory). Now you can place the same wall structure in different positions of your geometry on nodes called STRUCT_SIWALL_1, STRUCT_SIWALL_2, etc.
This will give a full path to the node of DET_SI_1 in SIWALL_2 like this:
which will be interpreted by KVGeoNavigator::ExtractDetectorNameFromPath() as a detector with unique name: SIWALL_2_SI_1 (the STRUCT_ and DET_ parts are stripped off).
Definition at line 67 of file KVGeoImport.h.
Public Member Functions | |
KVGeoImport (TGeoManager *, KVIonRangeTable *, KVMultiDetArray *, Bool_t create=kTRUE) | |
virtual | ~KVGeoImport () |
Destructor. More... | |
void | AddAcceptedDetectorName (const char *name) |
void | ImportGeometry (Double_t dTheta=0.1, Double_t dPhi=1.0, Double_t ThetaMin=0.0, Double_t PhiMin=0.0, Double_t ThetaMax=180.0, Double_t PhiMax=360.0) |
virtual void | ParticleEntersNewVolume (KVNucleus *) |
All detectors crossed by the particle's trajectory are added to the multidetector. More... | |
void | PropagateParticle (KVNucleus *, TVector3 *TheOrigin=nullptr) |
void | SetDetectorPlugin (const TString &name) |
void | SetLastDetector (KVDetector *) |
void | SetOrigin (double x, double y, double z) |
Public Member Functions inherited from KVGeoNavigator | |
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 |
void | PrintDetectorPaths () |
void | PropagateEvent (KVEvent *, 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 () |
KVBase & | operator= (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) |
Public Member Functions inherited from TNamed | |
TNamed () | |
TNamed (const char *name, const char *title) | |
TNamed (const TNamed &named) | |
TNamed (const TString &name, const TString &title) | |
virtual | ~TNamed () |
virtual TObject * | Clone (const char *newname="") const |
virtual Int_t | Compare (const TObject *obj) const |
virtual void | FillBuffer (char *&buffer) |
virtual const char * | GetName () const |
virtual const char * | GetTitle () const |
virtual ULong_t | Hash () const |
virtual Bool_t | IsSortable () const |
virtual void | ls (Option_t *option="") const |
TNamed & | operator= (const TNamed &rhs) |
virtual void | SetName (const char *name) |
virtual void | SetNameTitle (const char *name, const char *title) |
virtual void | SetTitle (const char *title="") |
virtual Int_t | Sizeof () const |
Public Member Functions inherited from TObject | |
TObject () | |
TObject (const TObject &object) | |
virtual | ~TObject () |
void | AbstractMethod (const char *method) const |
virtual void | AppendPad (Option_t *option="") |
virtual void | Browse (TBrowser *b) |
ULong_t | CheckedHash () |
virtual const char * | ClassName () const |
virtual void | Delete (Option_t *option="") |
virtual Int_t | DistancetoPrimitive (Int_t px, Int_t py) |
virtual void | Draw (Option_t *option="") |
virtual void | DrawClass () const |
virtual TObject * | DrawClone (Option_t *option="") const |
virtual void | Dump () const |
virtual void | Error (const char *method, const char *msgfmt,...) const |
virtual void | Execute (const char *method, const char *params, Int_t *error=0) |
virtual void | Execute (TMethod *method, TObjArray *params, Int_t *error=0) |
virtual void | ExecuteEvent (Int_t event, Int_t px, Int_t py) |
virtual void | Fatal (const char *method, const char *msgfmt,...) const |
virtual TObject * | FindObject (const char *name) const |
virtual TObject * | FindObject (const TObject *obj) const |
virtual Option_t * | GetDrawOption () const |
virtual const char * | GetIconName () const |
virtual char * | GetObjectInfo (Int_t px, Int_t py) const |
virtual Option_t * | GetOption () const |
virtual UInt_t | GetUniqueID () const |
virtual Bool_t | HandleTimer (TTimer *timer) |
Bool_t | HasInconsistentHash () const |
virtual void | Info (const char *method, const char *msgfmt,...) const |
virtual Bool_t | InheritsFrom (const char *classname) const |
virtual Bool_t | InheritsFrom (const TClass *cl) const |
virtual void | Inspect () const |
void | InvertBit (UInt_t f) |
virtual Bool_t | IsEqual (const TObject *obj) const |
virtual Bool_t | IsFolder () const |
R__ALWAYS_INLINE Bool_t | IsOnHeap () const |
R__ALWAYS_INLINE Bool_t | IsZombie () const |
void | MayNotUse (const char *method) const |
virtual Bool_t | Notify () |
void | Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const |
void | operator delete (void *ptr) |
void | operator delete[] (void *ptr) |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, void *vp) |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, void *vp) |
TObject & | operator= (const TObject &rhs) |
virtual void | Paint (Option_t *option="") |
virtual void | Pop () |
virtual Int_t | Read (const char *name) |
virtual void | RecursiveRemove (TObject *obj) |
void | ResetBit (UInt_t f) |
virtual void | SaveAs (const char *filename="", Option_t *option="") const |
virtual void | SavePrimitive (std::ostream &out, Option_t *option="") |
void | SetBit (UInt_t f) |
void | SetBit (UInt_t f, Bool_t set) |
virtual void | SetDrawOption (Option_t *option="") |
virtual void | SetUniqueID (UInt_t uid) |
virtual void | SysError (const char *method, const char *msgfmt,...) const |
R__ALWAYS_INLINE Bool_t | TestBit (UInt_t f) const |
Int_t | TestBits (UInt_t f) const |
virtual void | UseCurrentStyle () |
virtual void | Warning (const char *method, const char *msgfmt,...) const |
virtual Int_t | Write (const char *name=0, Int_t option=0, Int_t bufsize=0) |
virtual Int_t | Write (const char *name=0, Int_t option=0, Int_t bufsize=0) const |
Private Member Functions | |
void | AddLayer (KVDetector *, TGeoVolume *) |
KVDetector * | BuildDetector (TString det_name, TGeoVolume *det_vol) |
KVDetector * | GetCurrentDetector () |
Additional Inherited Members | |
Public Types inherited from KVBase | |
enum | EKaliVedaBits { kIsKaliVedaObject = BIT(23) } |
Public Types inherited from TObject | |
enum | EDeprecatedStatusBits |
enum | EStatusBits |
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 () |
Static Public Member Functions inherited from TObject | |
static Longptr_t | GetDtorOnly () |
static Bool_t | GetObjectStat () |
static void | SetDtorOnly (void *obj) |
static void | SetObjectStat (Bool_t stat) |
Public Attributes inherited from TObject | |
kBitMask | |
kCanDelete | |
kCannotPick | |
kHasUUID | |
kInconsistent | |
kInvalidObject | |
kIsOnHeap | |
kIsReferenced | |
kMustCleanup | |
kNoContextMenu | |
kNotDeleted | |
kObjInCanvas | |
kOverwrite | |
kSingleKey | |
kWriteDelete | |
kZombie | |
Protected Member Functions inherited from KVGeoNavigator | |
void | FormatDetectorName (const Char_t *basename, KVString &name) |
void | FormatStructureName (const Char_t *type, Int_t number, KVString &name) |
KVDetector * | GetDetectorFromPath (const Char_t *p) |
Protected Member Functions inherited from TObject | |
virtual void | DoError (int level, const char *location, const char *fmt, va_list va) const |
void | MakeZombie () |
Protected Attributes inherited from KVGeoNavigator | |
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... | |
KVNameValueList | fStrucNameFmt |
list of user-defined formats for structure names More... | |
Protected Attributes inherited from KVBase | |
TString | fLabel |
label for the object More... | |
Protected Attributes inherited from TNamed | |
TString | fName |
TString | fTitle |
Protected Attributes inherited from TObject | |
kOnlyPrepStep | |
#include <KVGeoImport.h>
KVGeoImport::KVGeoImport | ( | TGeoManager * | g, |
KVIonRangeTable * | r, | ||
KVMultiDetArray * | m, | ||
Bool_t | create = kTRUE |
||
) |
Import geometry described by TGeoManager into KVMultiDetArray object
if create=kFALSE, we do not create any detectors etc., but just set up the required links between the geometry and the existing array detectors
We change the colours of volumes depending on their material
Definition at line 29 of file KVGeoImport.cpp.
|
virtual |
Destructor.
Definition at line 65 of file KVGeoImport.cpp.
void KVGeoImport::AddAcceptedDetectorName | ( | const char * | name | ) |
Add to list of acceptable detector names when scanning geometry Each detector volume name will be tested; if it doesn't contain any of the (partial) detector names in the list, it will be ignored
Definition at line 218 of file KVGeoImport.cpp.
|
private |
Add an absorber layer to the detector.
Volumes representing 'active' layers in detectors must have names which begin with ACTIVE_.
Definition at line 438 of file KVGeoImport.cpp.
|
private |
Create a KVDetector with given name for the given volume
Definition at line 378 of file KVGeoImport.cpp.
|
private |
Returns pointer to KVDetector corresponding to current location in geometry. Detector is created and added to array if needed. We also set up any geometry structure elements (from nodes beginning with "STRUCT_") Any detector volume with a name not recognised by comparison with the list fAcceptedDetectorNames (if defined) will be ignored.
Definition at line 237 of file KVGeoImport.cpp.
void KVGeoImport::ImportGeometry | ( | Double_t | dTheta = 0.1 , |
Double_t | dPhi = 1.0 , |
||
Double_t | ThetaMin = 0.0 , |
||
Double_t | PhiMin = 0.0 , |
||
Double_t | ThetaMax = 180.0 , |
||
Double_t | PhiMax = 360.0 |
||
) |
Scan the geometry in order to find all detectors and detector alignments. This is done by sending out "particles" from (0,0,0) or (x,y,z) (if SetOrigin(x,y,z) was called) in all directions between (ThetaMin,ThetaMax) - with respect to Z-axis - and (PhiMin,PhiMax) - cylindrical angle in the (X,Y)-plane, over a grid of step dTheta in Theta and dPhi in Phi.
Definition at line 99 of file KVGeoImport.cpp.
All detectors crossed by the particle's trajectory are added to the multidetector.
Reimplemented from KVGeoNavigator.
Definition at line 76 of file KVGeoImport.cpp.
Override KVGeoNavigator method We build the list of all trajectories through the array
Reimplemented from KVGeoNavigator.
Definition at line 186 of file KVGeoImport.cpp.
Definition at line 94 of file KVGeoImport.h.
void KVGeoImport::SetLastDetector | ( | KVDetector * | d | ) |
Definition at line 175 of file KVGeoImport.cpp.
Call this method if needed before calling ImportGeometry in order to shoot particles from an arbitrary point (x,y,z) instead of (0,0,0). This can be useful if the detector array is "misaligned" so that its telescopes are not pointing towards the theoretical origin (i.e. target position).
Definition at line 100 of file KVGeoImport.h.
|
private |
Definition at line 79 of file KVGeoImport.h.
|
private |
Definition at line 68 of file KVGeoImport.h.
|
private |
Definition at line 80 of file KVGeoImport.h.
|
private |
Definition at line 71 of file KVGeoImport.h.
|
private |
Definition at line 73 of file KVGeoImport.h.
|
private |
Definition at line 72 of file KVGeoImport.h.
|
private |
Definition at line 70 of file KVGeoImport.h.
|
private |
Definition at line 74 of file KVGeoImport.h.
|
private |
Definition at line 69 of file KVGeoImport.h.