KaliVeda
Toolkit for HIC analysis
KVDetectionSimulator Class Reference

Detailed Description

Simulate detection of particles or events in a detector array.

Created by KVClassFactory on Sat Oct 10 09:37:42 2015 Author: John Frankland,,,

Definition at line 20 of file KVDetectionSimulator.h.

#include <KVDetectionSimulator.h>

Inheritance diagram for KVDetectionSimulator:

Public Member Functions

 KVDetectionSimulator ()
 
 KVDetectionSimulator (KVMultiDetArray *a, Double_t cut_off=1.e-3)
 
virtual ~KVDetectionSimulator ()
 
void ClearHitGroups ()
 
void DetectEvent (KVEvent *event, const Char_t *detection_frame="")
 
KVNameValueList DetectParticle (KVNucleus *)
 
KVNameValueList DetectParticleIn (const Char_t *detname, KVNucleus *kvp)
 
KVMultiDetArrayGetArray () const
 
Double_t GetMinKECutOff () const
 
KVTargetGetTarget () const
 
Bool_t IncludeTargetEnergyLoss () const
 
void SetArray (KVMultiDetArray *a)
 
void SetIncludeTargetEnergyLoss (Bool_t y=kTRUE)
 
void SetMinKECutOff (Double_t cutoff)
 
- 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 Attributes

KVMultiDetArrayfArray
 array used for detection More...
 
Bool_t fCalcTargELoss
 whether to include energy loss in target, if defined More...
 
KVDetectorEvent fHitGroups
 used to reset hit detectors in between events 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

◆ KVDetectionSimulator() [1/2]

KVDetectionSimulator::KVDetectionSimulator ( )
inline

Definition at line 28 of file KVDetectionSimulator.h.

◆ KVDetectionSimulator() [2/2]

KVDetectionSimulator::KVDetectionSimulator ( KVMultiDetArray a,
Double_t  e_cut_off = 1.e-3 
)

Initialise a detection simulator The detector array is put into simulation mode, and the minimum cut-off energy for propagation of particles is set

Definition at line 15 of file KVDetectionSimulator.cpp.

◆ ~KVDetectionSimulator()

virtual KVDetectionSimulator::~KVDetectionSimulator ( )
inlinevirtual

Definition at line 30 of file KVDetectionSimulator.h.

Member Function Documentation

◆ ClearHitGroups()

void KVDetectionSimulator::ClearHitGroups ( )
inline

Reset any detectors/groups hit by previous detection

Definition at line 65 of file KVDetectionSimulator.h.

◆ DetectEvent()

void KVDetectionSimulator::DetectEvent ( KVEvent event,
const Char_t *  detection_frame = "" 
)

Simulate detection of event by multidetector array.

optional argument detection_frame(="" by default) can be used to give name of inertial reference frame (defined for all particles of 'event') to be used. e.g. if the simulated event's default reference frame is the centre of mass frame, before calling this method you should create the 'laboratory' or 'detector' frame with KVEvent::SetFrame(...), and then give the name of the 'LAB' or 'DET' frame as 3rd argument here.

For each particle in the event we calculate first its energy loss in the target (if the target has been defined, see KVMultiDetArray::SetTarget). By default these energy losses are calculated from a point half-way along the beam-direction through the target (taking into account the orientation of the target), if you want random depths for each event call GetTarget()->SetRandomized() before using DetectEvent().

If the particle escapes the target then we look for the group in the array that it will hit. If there is one, then the detection of this particle by the different members of the group is simulated.

The detectors concerned have their fEloss members set to the energy lost by the particle when it crosses them.

Give tags to the simulated particles via KVNucleus::AddGroup() method Two general tags :

  • DETECTED : cross at least one active layer of one detector
  • UNDETECTED : go through dead zone or stopped in target We add also different sub group :
  • For UNDETECTED particles : "DEAD ZONE", "STOPPED IN TARGET" and "THRESHOLD", the last one concerned particle go through the first detection stage of the multidetector array but stopped in an absorber (ie an inactive layer)
  • For DETECTED particles : "PUNCH THROUGH" corrresponds to particle which cross all the materials in front of it (high energy particle punh through), or which miss some detectors due to a non perfect overlap between defined telescope, "INCOMPLETE" corresponds to particles which stopped in the first detection stage of the multidetector in a detector which can not give alone a clear identification,

Reset detectors in array hit by any previous events

Definition at line 64 of file KVDetectionSimulator.cpp.

◆ DetectParticle()

KVNameValueList KVDetectionSimulator::DetectParticle ( KVNucleus part)

Simulate detection of a single particle

Propagate particle through the array, calculating its energy losses in all absorbers, and setting the energy loss members of the active detectors on the way.

Returns a list containing the name and energy loss of each detector hit in array (list is empty if none i.e. particle in beam pipe or dead zone of the multidetector)

Definition at line 197 of file KVDetectionSimulator.cpp.

◆ DetectParticleIn()

KVNameValueList KVDetectionSimulator::DetectParticleIn ( const Char_t *  detname,
KVNucleus kvp 
)

Given the name of a detector, simulate detection of a given particle by the complete corresponding group. The particle's theta and phi are set at random within the limits of detector entrance window

Returns a list containing the name and energy loss of each detector hit in array

Definition at line 261 of file KVDetectionSimulator.cpp.

◆ GetArray()

KVMultiDetArray* KVDetectionSimulator::GetArray ( ) const
inline

Definition at line 36 of file KVDetectionSimulator.h.

◆ GetMinKECutOff()

Double_t KVDetectionSimulator::GetMinKECutOff ( ) const
inline

Definition at line 52 of file KVDetectionSimulator.h.

◆ GetTarget()

KVTarget* KVDetectionSimulator::GetTarget ( ) const
inline

Definition at line 40 of file KVDetectionSimulator.h.

◆ IncludeTargetEnergyLoss()

Bool_t KVDetectionSimulator::IncludeTargetEnergyLoss ( ) const
inline

Definition at line 48 of file KVDetectionSimulator.h.

◆ SetArray()

void KVDetectionSimulator::SetArray ( KVMultiDetArray a)
inline

Definition at line 32 of file KVDetectionSimulator.h.

◆ SetIncludeTargetEnergyLoss()

void KVDetectionSimulator::SetIncludeTargetEnergyLoss ( Bool_t  y = kTRUE)
inline

Definition at line 44 of file KVDetectionSimulator.h.

◆ SetMinKECutOff()

void KVDetectionSimulator::SetMinKECutOff ( Double_t  cutoff)
inline

Definition at line 56 of file KVDetectionSimulator.h.

Member Data Documentation

◆ fArray

KVMultiDetArray* KVDetectionSimulator::fArray
private

array used for detection

Definition at line 23 of file KVDetectionSimulator.h.

◆ fCalcTargELoss

Bool_t KVDetectionSimulator::fCalcTargELoss
private

whether to include energy loss in target, if defined

Definition at line 25 of file KVDetectionSimulator.h.

◆ fHitGroups

KVDetectorEvent KVDetectionSimulator::fHitGroups
private

used to reset hit detectors in between events

Definition at line 24 of file KVDetectionSimulator.h.