KaliVeda
Toolkit for HIC analysis
KVINDRATelescope Class Reference

Detailed Description

Base class for telescopes in INDRA array.

Definition at line 18 of file KVINDRATelescope.h.

#include <KVINDRATelescope.h>

Inheritance diagram for KVINDRATelescope:

Public Member Functions

 KVINDRATelescope ()
 Default constructor. More...
 
virtual ~KVINDRATelescope ()
 Destructor. More...
 
Int_t Compare (const TObject *obj) const
 
virtual const Char_t * GetArrayName ()
 
KVGroupGetGroup () const
 
const Char_t * GetName () const
 
KVRingGetRing () const
 
Int_t GetRingNumber () const
 
Bool_t IsSortable () const
 
- Public Member Functions inherited from KVTelescope
 KVTelescope ()
 
virtual ~ KVTelescope ()
 
void Add (KVBase *element)
 
virtual void AddToGeometry ()
 Construct and position a TGeoVolume shape to represent this telescope in the current geometry. More...
 
virtual void DetectParticle (KVNucleus *kvp, KVNameValueList *nvl=0)
 
Float_t GetDepth () const
 get depth of entire telescope in mm (sum of depths of detectors) More...
 
Float_t GetDepth (Int_t ndet) const
 get depth of detector ndet(=1,2,...) in mm More...
 
Double_t GetDepthInCM (Int_t ndet) const
 
KVDetectorGetDetector (Int_t n) const
 
Int_t GetDetectorRank (KVDetector *kvd)
 returns position (1=front, 2=next, etc.) detector in the telescope structure More...
 
virtual TGeoVolume * GetGeoVolume ()
 Create and return TGeoVolume representing detectors in this telescope. More...
 
Int_t GetSize () const
 
Double_t GetTotalLengthInCM () const
 
void ResetDetectors ()
 Reset Energy losses to be ready for the next event. More...
 
virtual void SetAzimuthalAngle (Double_t ph)
 override KVPosition methods to apply to all detectors More...
 
virtual void SetAzimuthalMinMax (Double_t min, Double_t max)
 
virtual void SetAzimuthalWidth (Double_t aw)
 
void SetDepth (UInt_t ndet, Float_t depth)
 set the depth of detector number ndet(=1,2,...) in mm. More...
 
virtual void SetPolarAngle (Double_t th)
 
virtual void SetPolarMinMax (Double_t min, Double_t max)
 
virtual void SetPolarWidth (Double_t pw)
 
- Public Member Functions inherited from KVGeoStrucElement
 KVGeoStrucElement ()
 Default constructor. More...
 
 KVGeoStrucElement (const Char_t *name, const Char_t *type="")
 Create a geometry structure element with given name and type. More...
 
virtual ~KVGeoStrucElement ()
 Destructor. More...
 
void Clear (Option_t *opt="")
 Empty lists of detectors, daughter structures, and parent structures. More...
 
void ClearDetectors (const Char_t *type="")
 
void ClearStructures (const Char_t *type="")
 
virtual Bool_t Contains (KVBase *name) const
 
virtual Bool_t Fired (Option_t *opt="any") const
 
KVDetectorGetDetector (const Char_t *name) const
 Return detector in this structure with given name. More...
 
KVDetectorGetDetectorAny (const Char_t *name)
 
KVDetectorGetDetectorByType (const Char_t *type) const
 Return detector in this structure with given type. More...
 
KVSeqCollectionGetDetectorNameList (const Char_t *name) const
 
KVSeqCollectionGetDetectors ()
 
const KVSeqCollectionGetDetectors () const
 
KVSeqCollectionGetDetectorTypeList (const Char_t *type) const
 
const KVSeqCollectionGetParents () const
 
KVGeoStrucElementGetParentStructure (const Char_t *type, const Char_t *name="") const
 
KVGeoStrucElementGetStructure (const Char_t *name) const
 
KVGeoStrucElementGetStructure (const Char_t *type, const Char_t *name) const
 Get structure with type and name. More...
 
KVGeoStrucElementGetStructure (const Char_t *type, Int_t num) const
 Get structure with type and number. More...
 
const KVSeqCollectionGetStructures () const
 
KVSeqCollectionGetStructureTypeList (const Char_t *type) const
 
bool OwnsDaughters () const
 
bool OwnsDetectors () const
 
void Print (Option_t *option="") const
 
virtual void Remove (KVBase *)
 
void SetOwnsDaughters (Bool_t yes=kTRUE)
 
void SetOwnsDetectors (Bool_t yes=kTRUE)
 
void Sort (Bool_t order=kSortAscending)
 
void SortDetectors (Bool_t order=kSortAscending)
 
void SortStructures (Bool_t order=kSortAscending)
 
- 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 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...
 
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 KVPosition
 KVPosition ()
 
 KVPosition (Double_t thmin, Double_t thmax, Double_t phmin, Double_t phmax, Double_t dist=0.0)
 
virtual ~KVPosition ()
 
Double_t GetAzimuthalWidth (Double_t phmin=-1., Double_t phimax=-1.) const
 
void GetCornerCoordinates (TVector3 *, Double_t=0)
 
void GetCornerCoordinatesInOwnFrame (TVector3 *, Double_t=0)
 
virtual Double_t GetCosTheta () const
 
virtual TVector3 GetDirection ()
 
virtual Double_t GetDistance (void) const
 
virtual TGeoHMatrix * GetMatrix () const
 
virtual Double_t GetMisalignmentAngle () const
 
virtual Double_t GetPhi () const
 
Double_t GetPhiMax () const
 
Double_t GetPhiMin () const
 
virtual void GetRandomAngles (Double_t &th, Double_t &ph, Option_t *t="isotropic")
 
virtual TVector3 GetRandomDirection (Option_t *t="isotropic")
 
TRotation GetRandomIsotropicRotation ()
 
virtual TVector3 GetRandomPointOnSurface () const
 
virtual TGeoBBox * GetShape () const
 
virtual Double_t GetSinTheta () const
 
virtual Double_t GetSolidAngle (void) const
 
virtual Double_t GetSurfaceArea (int npoints=100000) const
 
virtual TVector3 GetSurfaceCentre () const
 
virtual TVector3 GetSurfaceNormal () const
 
virtual Double_t GetTheta () const
 
Double_t GetThetaMax () const
 
Double_t GetThetaMin () const
 
virtual TVector3 GetVolumeCentre () const
 
void GetWidthsFromDimension (Double_t lin_dim)
 
void init ()
 default initialiser More...
 
Bool_t IsAlignedWith (KVPosition *pos)
 kTRUE if one of the two solid angle elements is completely contained within the other. More...
 
Bool_t IsAzimuthallyWiderThan (KVPosition *pos)
 
Bool_t IsInPhiRange (const Double_t phi)
 
Bool_t IsInPolarRange (const Double_t theta)
 kTRUE if given angle theta is within the polar range of this solid angle element More...
 
Bool_t IsOverlappingWith (KVPosition *pos)
 kTRUE if there is at least partial overlap between two solid angle elements More...
 
Bool_t IsSmallerThan (KVPosition *pos)
 kTRUE if "this" is entirely contained within "pos" More...
 
Bool_t ROOTGeo () const
 Returns kTRUE if ROOT geometry is used, kFALSE if not. More...
 
void SetDistance (Double_t d)
 
virtual void SetMatrix (const TGeoHMatrix *)
 
void SetPhi (Double_t p)
 
void SetPhiMinMax (Double_t min, Double_t max)
 
virtual void SetShape (TGeoBBox *)
 
void SetTheta (Double_t t)
 

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

◆ KVINDRATelescope()

KVINDRATelescope::KVINDRATelescope ( )

Default constructor.

Definition at line 13 of file KVINDRATelescope.cpp.

◆ ~KVINDRATelescope()

KVINDRATelescope::~KVINDRATelescope ( )
virtual

Destructor.

Definition at line 23 of file KVINDRATelescope.cpp.

Member Function Documentation

◆ Compare()

Int_t KVINDRATelescope::Compare ( const TObject *  obj) const

telescopes are sorted (i) according to layer number if they are in different layers (ii) according to lower edge polar angle if they belong to the same layer (iii) according to telescope number if they belong to the same ring

Definition at line 110 of file KVINDRATelescope.cpp.

◆ GetArrayName()

const Char_t * KVINDRATelescope::GetArrayName ( )
virtual

Name of telescope given in the form Det1_Det2_..._Ring-numberTelescope-number where Det1 etc. are the ACTIVE detector layers of the telescope The detectors are signified by their TYPE names i.e. KVDetector::GetType

Definition at line 54 of file KVINDRATelescope.cpp.

◆ GetGroup()

KVGroup * KVINDRATelescope::GetGroup ( ) const

Definition at line 96 of file KVINDRATelescope.cpp.

◆ GetName()

const Char_t * KVINDRATelescope::GetName ( ) const

Name of telescope given in the form Det1_Det2_..._Ring-numberTelescope-number where Det1 etc. are the ACTIVE detector layers of the telescope The detectors are signified by their TYPE names i.e. KVDetector::GetType

Just a wrapper for GetArrayName to allow polymorphism

Definition at line 37 of file KVINDRATelescope.cpp.

◆ GetRing()

KVRing * KVINDRATelescope::GetRing ( ) const

Definition at line 87 of file KVINDRATelescope.cpp.

◆ GetRingNumber()

Int_t KVINDRATelescope::GetRingNumber ( void  ) const

Definition at line 78 of file KVINDRATelescope.cpp.

◆ IsSortable()

Bool_t KVINDRATelescope::IsSortable ( ) const
inline

Definition at line 29 of file KVINDRATelescope.h.