KaliVeda
Toolkit for HIC analysis
KVReconstructedEvent Class Reference

Detailed Description

Event containing KVReconstructedNucleus nuclei reconstructed from hits in detectors.

A KVReconstructedEvent is the result of applying reconstruction procedures to data from either experiments or filtered simulations in order to deduce the KVReconstructedNucleus nuclei produced in a reaction and detected by an array.

See also
KVReconstructedNucleus, Nuclei & Events
Examples
KVEvent_iterator_example.C.

Definition at line 43 of file KVReconstructedEvent.h.

#include <KVReconstructedEvent.h>

Inheritance diagram for KVReconstructedEvent:

Public Member Functions

 KVReconstructedEvent (Int_t mult=50)
 
virtual ~ KVReconstructedEvent ()
 
virtual Bool_t AnalyseDetectors (TList *kvtl)
 
virtual void CalibrateEvent ()
 
virtual const Char_t * GetPartSeedCond () const
 
Bool_t HasMeanAngles ()
 
Bool_t HasRandomAngles ()
 
virtual void IdentifyEvent ()
 
void init ()
 default initialisations More...
 
void ls (Option_t *option="") const
 
void MergeEventFragments (TCollection *, Option_t *opt="")
 
virtual void Print (Option_t *option="") const
 
virtual void SecondaryIdentCalib ()
 
virtual void SetPartSeedCond (const Char_t *cond)
 
void UseMeanAngles ()
 
void UseRandomAngles ()
 
- Public Member Functions inherited from KVTemplateEvent< KVReconstructedNucleus >
 KVTemplateEvent (Int_t mult=50)
 internal iterator used by GetNextParticle() More...
 
KVReconstructedNucleusAddParticle ()
 
Iterator begin () const
 
void ChangeDefaultFrame (const Char_t *newdef, const Char_t *defname="")
 
void ChangeFrame (const KVFrameTransform &ft, const KVString &name="")
 
EventIterator ConditionalIterator (const KVTemplateParticleCondition< KVReconstructedNucleus > &c)
 
void DefineGroup (const Char_t *groupname, const Char_t *from="")
 
void DefineGroup (const Char_t *groupname, KVTemplateParticleCondition< KVReconstructedNucleus > *cond, const Char_t *from="")
 
Iterator end () const
 
void FillHisto (TH1 *h, const Char_t *Nucleus_method, const Char_t *method_prototype, const Char_t *args, Option_t *opt="")
 
void FillHisto (TH1 *h, const Char_t *Nucleus_method, Option_t *opt="")
 
std::enable_if< std::is_base_of< KVNucleus, U >::value >::type FillIntegerList (KVIntegerList *IL, Option_t *opt)
 
std::enable_if< std::is_base_of< KVNucleus, U >::value, Double_t >::type get_channel_qvalue () const
 
std::enable_if< !std::is_base_of< KVNucleus, U >::value, Double_t >::type get_channel_qvalue () const
 
std::enable_if< std::is_base_of< KVNucleus, U >::value, KVString >::type get_partition_name ()
 
std::enable_if< !std::is_base_of< KVNucleus, U >::value, KVString >::type get_partition_name ()
 
Double_t GetChannelQValue () const
 
std::enable_if< std::is_base_of< KVNucleus, U >::value, Double_t >::type GetGSChannelQValue () const
 
std::enable_if< std::is_base_of< KVNucleus, U >::value >::type GetGSMasses (std::vector< Double_t > &mass)
 
void GetMasses (std::vector< Double_t > &mass)
 
virtual Int_t GetMult (Option_t *opt="") const
 
void GetMultiplicities (Int_t mult[], const TString &species, Option_t *opt="")
 
Int_t GetMultiplicity (Int_t Z, Int_t A=0, Option_t *opt="")
 
KVReconstructedNucleusGetNextParticle (Option_t *opt="") const
 
Iterator GetNextParticleIterator (Option_t *opt) const
 
KVReconstructedNucleusGetParticle (const Char_t *group_name) const
 
KVReconstructedNucleusGetParticle (Int_t npart) const
 
KVReconstructedNucleusGetParticleWithName (const Char_t *name) const
 
KVString GetPartitionName ()
 
Double_t GetSum (const Char_t *Nucleus_method, const Char_t *method_prototype, const Char_t *args, Option_t *opt="")
 
Double_t GetSum (const Char_t *Nucleus_method, Option_t *opt="")
 
void ResetEnergies ()
 
void ResetGetNextParticle () const
 
void SetFrame (const Char_t *frame, const KVFrameTransform &ft)
 
void SetFrame (const Char_t *newframe, const Char_t *oldframe, const KVFrameTransform &ft)
 
void SetFrameName (const KVString &name)
 
void UpdateAllFrames ()
 
- Public Member Functions inherited from KVEvent
 KVEvent (const TClass *particle_class, Int_t mult=50)
 
virtual ~KVEvent ()
 
KVNucleusAddNucleus ()
 
void Clear (Option_t *opt="")
 
void Copy (TObject &obj) const
 
void CustomStreamer ()
 
const Char_t * GetFrameName () const
 
KVNucleusGetNextNucleus (Option_t *opt="") const
 
KVNucleusGetNucleus (Int_t npart) const
 
KVNameValueListGetParameters () const
 
const TClonesArray * GetParticleArray () const
 
void ResetGetNextNucleus () const
 
template<typename ValType >
void SetParameter (const Char_t *name, ValType value) 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 ()
 
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)
 

Private Attributes

Bool_t fMeanAngles
 kTRUE if particle momenta calculated using mean angles of detectors (default: randomised angles) More...
 
TString fPartSeedCond
 condition used in AnalyseTelescopes for seeding new reconstructed particle More...
 

Additional Inherited Members

- Public Types inherited from KVBase
enum  EKaliVedaBits { kIsKaliVedaObject = BIT(23) }
 
- Static Public Member Functions inherited from KVEvent
static KVEventFactory (const char *plugin)
 
template<typename T >
static void MakeEventBranch (TTree *tree, const TString &branchname, T &event, Int_t bufsize=10000000)
 
- 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

◆ KVReconstructedEvent()

KVReconstructedEvent::KVReconstructedEvent ( Int_t  mult = 50)

Definition at line 50 of file KVReconstructedEvent.cpp.

◆ ~ KVReconstructedEvent()

virtual KVReconstructedEvent::~ KVReconstructedEvent ( )
inlinevirtual

Definition at line 52 of file KVReconstructedEvent.h.

Member Function Documentation

◆ AnalyseDetectors()

Bool_t KVReconstructedEvent::AnalyseDetectors ( TList *  kvtl)
virtual

Loop over detectors in list if any detector has fired, start construction of new detected particle More precisely: If detector has fired, making sure fired detector hasn't already been used to reconstruct a particle, then we create and fill a new detected particle. In order to avoid creating spurious particles when reading data, by default we ask that ALL coder values be non-zero here i.e. data and time-marker. This can be changed by calling SetPartSeedCond("any"): in this case, particles will be reconstructed starting from detectors with at least 1 fired parameter.

Definition at line 124 of file KVReconstructedEvent.cpp.

◆ CalibrateEvent()

void KVReconstructedEvent::CalibrateEvent ( )
virtual

Calculate and set energies of all identified particles in event.

This will call the KVReconstructedNucleus::Calibrate() method of each uncalibrated particle (those for which KVReconstructedNucleus::IsCalibrated() returns kFALSE).

In order to make sure that target energy loss corrections are correctly calculated, we first set the state of the target in the current multidetector

Definition at line 276 of file KVReconstructedEvent.cpp.

◆ GetPartSeedCond()

virtual const Char_t* KVReconstructedEvent::GetPartSeedCond ( ) const
inlinevirtual

Definition at line 55 of file KVReconstructedEvent.h.

◆ HasMeanAngles()

Bool_t KVReconstructedEvent::HasMeanAngles ( )
inline

Definition at line 77 of file KVReconstructedEvent.h.

◆ HasRandomAngles()

Bool_t KVReconstructedEvent::HasRandomAngles ( )
inline

Definition at line 81 of file KVReconstructedEvent.h.

◆ IdentifyEvent()

void KVReconstructedEvent::IdentifyEvent ( )
virtual

All particles which have not been previously identified (IsIdentified=kFALSE), and which may be identified independently of all other particles in their group according to the 1st order coherency analysis (KVReconstructedNucleus::GetStatus=0), will be identified. Particles stopping in first member of a telescope (KVReconstructedNucleus::GetStatus=3) will have their Z estimated from the energy loss in the detector (if calibrated).

Definition at line 231 of file KVReconstructedEvent.cpp.

◆ init()

void KVReconstructedEvent::init ( void  )

default initialisations

Definition at line 39 of file KVReconstructedEvent.cpp.

◆ ls()

void KVReconstructedEvent::ls ( Option_t *  option = "") const
virtual

Print out compact listing of all particles in event.

Parameters
[in]optionif given, will be used as argument to GetNextParticleIterator() to limit particles shown to those which correspond to the given criteria. This also affects the displayed event multiplicity.

Reimplemented from KVTemplateEvent< KVReconstructedNucleus >.

Definition at line 202 of file KVReconstructedEvent.cpp.

◆ MergeEventFragments()

void KVReconstructedEvent::MergeEventFragments ( TCollection *  events,
Option_t *  opt = "" 
)
virtual

Merge all events in the list into one event (this one) First we clear this event, then we fill it with copies of each particle in each event in the list. If option "opt" is given, it is given as argument to each call to KVEvent::Clear() - this option is then passed on to the Clear() method of each particle in each event. NOTE: the events in the list will be empty and useless after this!

This method overrides the one defined in KVEvent. As KVReconstructedNucleus objects are referenced by the detectors used in their reconstruction, we also have to update the references in the detectors otherwise they will still reference the particles in the events in the list, which will no longer be valid after this operation.

Reimplemented from KVEvent.

Definition at line 321 of file KVReconstructedEvent.cpp.

◆ Print()

void KVReconstructedEvent::Print ( Option_t *  option = "") const
virtual

Print out detailed information on each particle in the event.

Parameters
[in]optionif given, will be used as argument to GetNextParticleIterator() to limit particles shown to those which correspond to the given criteria. This also affects the displayed event multiplicity.

Reimplemented from KVTemplateEvent< KVReconstructedNucleus >.

Reimplemented in KVINDRAReconEvent.

Definition at line 169 of file KVReconstructedEvent.cpp.

◆ SecondaryIdentCalib()

virtual void KVReconstructedEvent::SecondaryIdentCalib ( )
inlinevirtual

Perform identifications and calibrations of particles not included in first round (methods IdentifyEvent() and CalibrateEvent()).

Definition at line 86 of file KVReconstructedEvent.h.

◆ SetPartSeedCond()

virtual void KVReconstructedEvent::SetPartSeedCond ( const Char_t *  cond)
inlinevirtual

Definition at line 59 of file KVReconstructedEvent.h.

◆ UseMeanAngles()

void KVReconstructedEvent::UseMeanAngles ( )
inline

Definition at line 69 of file KVReconstructedEvent.h.

◆ UseRandomAngles()

void KVReconstructedEvent::UseRandomAngles ( )
inline

Definition at line 73 of file KVReconstructedEvent.h.

Member Data Documentation

◆ fMeanAngles

Bool_t KVReconstructedEvent::fMeanAngles
private

kTRUE if particle momenta calculated using mean angles of detectors (default: randomised angles)

Definition at line 45 of file KVReconstructedEvent.h.

◆ fPartSeedCond

TString KVReconstructedEvent::fPartSeedCond
private

condition used in AnalyseTelescopes for seeding new reconstructed particle

Definition at line 46 of file KVReconstructedEvent.h.