![]() |
KaliVeda
Toolkit for HIC analysis
|
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>
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) |
KVMultiDetArray * | GetArray () const |
Double_t | GetMinKECutOff () const |
KVTarget * | GetTarget () const |
Bool_t | IncludeTargetEnergyLoss () const |
void | SetArray (KVMultiDetArray *a) |
void | SetIncludeTargetEnergyLoss (Bool_t y=kTRUE) |
void | SetMinKECutOff (Double_t cutoff) |
![]() | |
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) |
Private Attributes | |
KVMultiDetArray * | fArray |
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 | |
![]() | |
enum | EKaliVedaBits { kIsKaliVedaObject = BIT(23) } |
![]() | |
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 () |
|
inline |
Definition at line 28 of file KVDetectionSimulator.h.
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.
|
inlinevirtual |
Definition at line 30 of file KVDetectionSimulator.h.
|
inline |
Reset any detectors/groups hit by previous detection
Definition at line 65 of file KVDetectionSimulator.h.
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 :
Reset detectors in array hit by any previous events
Definition at line 64 of file KVDetectionSimulator.cpp.
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.
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.
|
inline |
Definition at line 36 of file KVDetectionSimulator.h.
|
inline |
Definition at line 52 of file KVDetectionSimulator.h.
|
inline |
Definition at line 40 of file KVDetectionSimulator.h.
|
inline |
Definition at line 48 of file KVDetectionSimulator.h.
|
inline |
Definition at line 32 of file KVDetectionSimulator.h.
|
inline |
Definition at line 44 of file KVDetectionSimulator.h.
|
inline |
Definition at line 56 of file KVDetectionSimulator.h.
|
private |
array used for detection
Definition at line 23 of file KVDetectionSimulator.h.
|
private |
whether to include energy loss in target, if defined
Definition at line 25 of file KVDetectionSimulator.h.
|
private |
used to reset hit detectors in between events
Definition at line 24 of file KVDetectionSimulator.h.