KaliVeda
Toolkit for HIC analysis
KVGroupReconstructor Class Reference

Detailed Description

Base class for particle reconstruction in one group of a detector array.

KVGroupReconstructor is the basic working unit of event reconstruction. A KVEventReconstructor will use many KVGroupReconstructor objects in order to reconstruct an event from data detected by the array (let us recall that a group of detectors is the largest part of any array which can be treated independently of all other detectors).

Daughter classes of KVGroupReconstructor can be specialised for event reconstruction in specific arrays (or even specific parts of specific arrays).

See also
KVEventReconstructor, KVGroup, KVMultiDetArray

Definition at line 30 of file KVGroupReconstructor.h.

#include <KVGroupReconstructor.h>

Inheritance diagram for KVGroupReconstructor:

Classes

struct  particle_to_add_from_coherency_analysis
 informations required to add a particle to the event which is revealed by an inconsistency between the different identifications for an existing particle More...
 

Public Member Functions

 KVGroupReconstructor ()
 Default constructor. More...
 
virtual ~KVGroupReconstructor ()
 Destructor. More...
 
void AnalyseParticles ()
 
void Calibrate ()
 Calculate and set energies of all identified but uncalibrated particles in event. More...
 
virtual void CalibrateParticle (KVReconstructedNucleus *)
 
KVReconstructedEventGetEventFragment () const
 
KVGroupGetGroup () const
 
int GetNFiredDets () const
 
Int_t GetNIdentifiedInGroup ()
 
Int_t GetNUnidentifiedInGroup ()
 
virtual void Identify ()
 
void Process ()
 
void Reconstruct ()
 
virtual void SetGroup (KVGroup *g)
 
void SetReconEventClass (TClass *c)
 Instantiate event fragment object. More...
 
- 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)
 

Static Public Member Functions

static KVGroupReconstructorFactory (const TString &plugin="")
 
static void SetDoCalibration (bool on=kTRUE)
 
static void SetDoIdentification (bool on=kTRUE)
 
- 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 ()
 

Private Member Functions

virtual void AddCoherencyParticles ()
 
virtual void CalibrateCoherencyParticle (KVReconstructedNucleus *)
 
TString GetPartSeedCond () const
 
Double_t GetTargetEnergyLossCorrection (KVReconstructedNucleus *ion)
 
virtual void IdentifyParticle (KVReconstructedNucleus &)
 
virtual void PostReconstructionProcessing ()
 
void ReconstructParticle (KVReconstructedNucleus *part, const KVGeoDNTrajectory *traj, const KVGeoDetectorNode *node)
 
virtual KVReconstructedNucleusReconstructTrajectory (const KVGeoDNTrajectory *traj, const KVGeoDetectorNode *node)
 
void SetCalibrationStatus (KVReconstructedNucleus &PART, UShort_t code)
 
void TreatStatusStopFirstStage (KVReconstructedNucleus &)
 

Private Attributes

std::vector< particle_to_add_from_coherency_analysiscoherency_particles
 
KVGroupfGroup
 the group where we are reconstructing More...
 
KVReconstructedEventfGrpEvent
 event containing particles reconstructed in this group More...
 
TString fPartSeedCond
 condition for seeding reconstructed particles More...
 
std::unordered_map< std::string, KVIdentificationResult * > id_by_type
 identification results by type for current particle More...
 
KVIDTelescopeidentifying_telescope
 telescope which identified current particle More...
 
int nfireddets
 number of fired detectors in group for current event More...
 
KVIdentificationResult partID
 identification to be applied to current particle More...
 

Static Private Attributes

static bool fDoCalibration = kTRUE
 
static bool fDoIdentification = kTRUE
 

Additional Inherited Members

- Public Types inherited from KVBase
enum  EKaliVedaBits { kIsKaliVedaObject = BIT(23) }
 

Constructor & Destructor Documentation

◆ KVGroupReconstructor()

KVGroupReconstructor::KVGroupReconstructor ( )

Default constructor.

Definition at line 18 of file KVGroupReconstructor.cpp.

◆ ~KVGroupReconstructor()

KVGroupReconstructor::~KVGroupReconstructor ( )
virtual

Destructor.

Definition at line 31 of file KVGroupReconstructor.cpp.

Member Function Documentation

◆ AddCoherencyParticles()

virtual void KVGroupReconstructor::AddCoherencyParticles ( )
inlineprivatevirtual

Reimplemented in KVFAZIAGroupReconstructor.

Definition at line 79 of file KVGroupReconstructor.h.

◆ AnalyseParticles()

void KVGroupReconstructor::AnalyseParticles ( )

Analyse and set status of reconstructed particles in group, to decide whether they can be identified and further treated straight away.

If there is more than one reconstructed particle in the group on different trajectories which have a detector in common, then it may be necessary to identify one of the particles before the others in order to try to subtract its contribution from the common detector and allow the identification of the other particles.

Definition at line 274 of file KVGroupReconstructor.cpp.

◆ Calibrate()

void KVGroupReconstructor::Calibrate ( )

Calculate and set energies of all identified but uncalibrated particles in event.

Definition at line 539 of file KVGroupReconstructor.cpp.

◆ CalibrateCoherencyParticle()

virtual void KVGroupReconstructor::CalibrateCoherencyParticle ( KVReconstructedNucleus )
inlineprivatevirtual

Reimplemented in KVFAZIAGroupReconstructor, and KVINDRAGroupReconstructor.

Definition at line 48 of file KVGroupReconstructor.h.

◆ CalibrateParticle()

virtual void KVGroupReconstructor::CalibrateParticle ( KVReconstructedNucleus )
inlinevirtual

Reimplemented in KVINDRAGroupReconstructor, and KVFAZIAGroupReconstructor.

Definition at line 107 of file KVGroupReconstructor.h.

◆ Factory()

KVGroupReconstructor * KVGroupReconstructor::Factory ( const TString &  plugin = "")
static

Create a new object of a class derived from KVGroupReconstructor defined by a plugin

If plugin="" this is just a new KVGroupReconstructor instance

Definition at line 73 of file KVGroupReconstructor.cpp.

◆ GetEventFragment()

KVReconstructedEvent* KVGroupReconstructor::GetEventFragment ( ) const
inline

Definition at line 91 of file KVGroupReconstructor.h.

◆ GetGroup()

KVGroup* KVGroupReconstructor::GetGroup ( ) const
inline

Definition at line 96 of file KVGroupReconstructor.h.

◆ GetNFiredDets()

int KVGroupReconstructor::GetNFiredDets ( ) const
inline

Definition at line 86 of file KVGroupReconstructor.h.

◆ GetNIdentifiedInGroup()

Int_t KVGroupReconstructor::GetNIdentifiedInGroup ( )
inline

number of identified particles reconstructed in group

Definition at line 113 of file KVGroupReconstructor.h.

◆ GetNUnidentifiedInGroup()

Int_t KVGroupReconstructor::GetNUnidentifiedInGroup ( )
inline

number of unidentified particles reconstructed in group

Definition at line 125 of file KVGroupReconstructor.h.

◆ GetPartSeedCond()

TString KVGroupReconstructor::GetPartSeedCond ( ) const
inlineprivate

Definition at line 60 of file KVGroupReconstructor.h.

◆ GetTargetEnergyLossCorrection()

Double_t KVGroupReconstructor::GetTargetEnergyLossCorrection ( KVReconstructedNucleus ion)
private

Calculate the energy loss in the current target of the multidetector for the reconstructed charged particle 'ion', assuming that the current energy and momentum of this particle correspond to its state on leaving the target.

WARNING: for this correction to work, the target must be in the right 'state':

gMultiDetArray->GetTarget()->SetIncoming(kFALSE); gMultiDetArray->GetTarget()->SetOutgoing(kTRUE);

(see KVTarget::GetParticleEIncFromERes).

The returned value is the energy lost in the target in MeV. The energy/momentum of 'ion' are not affected.

Definition at line 571 of file KVGroupReconstructor.cpp.

◆ Identify()

void KVGroupReconstructor::Identify ( )
virtual

Identify all particles reconstructed so far in this group which may be identified independently of all other particles in the group according to the 1st order coherency analysis (see AnalyseParticles() ). This is done by calling the method IdentifyParticle() for each particle in turn.

Particles stopping in the first member of a telescope will have their Z estimated from the energy loss in the detector (if calibrated): in this case the Z is a minimum value.

Reimplemented in KVINDRAGroupReconstructor.

Definition at line 506 of file KVGroupReconstructor.cpp.

◆ IdentifyParticle()

void KVGroupReconstructor::IdentifyParticle ( KVReconstructedNucleus PART)
privatevirtual

Try to identify this nucleus by calling the KVIDTelescope::Identify() method of each identification telescope on its reconstruction trajectory, starting with the telescope where the particle stopped (i.e. containing its stopping detector), in order.

Only identifications which have been correctly initialised for the current run are used, i.e. those for which KVIDTelescope::IsReadyForID() returns kTRUE.

Note that all identifications along the trajectory are tried, even those far in front of the detector where the particle stopped. The results of all identifications (KVIdentificationResult) are stored with the particle (they can be retrieved later using KVReconstructedNucleus::GetIdentificationResult() ). They are later used for consistency checks ("coherency") between the identifications in the different stages.

The first successful identification obtained in this way, if one exists, for a KVIDTelescope which includes the detector where the particle stopped is then attributed to the particle (see KVReconstructedNucleus::SetIdentification()).

Reimplemented in KVINDRAGroupReconstructor, and KVFAZIAGroupReconstructor.

Definition at line 380 of file KVGroupReconstructor.cpp.

◆ PostReconstructionProcessing()

void KVGroupReconstructor::PostReconstructionProcessing ( )
privatevirtual

This method will be called after reconstruction and first-order coherency analysis of all particles in the group (if there are any reconstructed particles). By default it does nothing.

Reimplemented in KVFAZIAGroupReconstructor.

Definition at line 175 of file KVGroupReconstructor.cpp.

◆ Process()

void KVGroupReconstructor::Process ( )

Perform full reconstruction of particles detected in group.

This will call in order Reconstruct(), Identify(), Calibrate() and AddCoherencyParticles()

  • identification can be inhibited (for all groups) by calling KVGroupReconstructor::SetDoIdentification(false);
  • calibration can be inhibited (for all groups) by calling KVGroupReconstructor::SetDoCalibration(false);

Definition at line 97 of file KVGroupReconstructor.cpp.

◆ Reconstruct()

void KVGroupReconstructor::Reconstruct ( )

Reconstruct the particles in the group from hit trajectories

We work our way along each trajectory, starting from the furthest detector from the target, and start reconstruction of a new detected particle depending on decision made in ReconstructTrajectory() for each detector we try (normally just the first fired detector we find).

The reconstruction is then handled by ReconstructParticle().

Definition at line 130 of file KVGroupReconstructor.cpp.

◆ ReconstructParticle()

void KVGroupReconstructor::ReconstructParticle ( KVReconstructedNucleus part,
const KVGeoDNTrajectory traj,
const KVGeoDetectorNode node 
)
private

Reconstruction of a detected nucleus from the successive energy losses measured in a series of detectors/telescopes along a given trajectory.

The particle is associated with a reconstruction trajectory which starts from the detector in which the particle stopped and leads up through the detection layers towards the target. These can be accessed in later analysis using the two methods

See also
KVReconNucTrajectory

Definition at line 235 of file KVGroupReconstructor.cpp.

◆ ReconstructTrajectory()

KVReconstructedNucleus * KVGroupReconstructor::ReconstructTrajectory ( const KVGeoDNTrajectory traj,
const KVGeoDetectorNode node 
)
privatevirtual
Parameters
trajtrajectory currently being scanned
nodecurrent detector on trajectory to test
Returns
pointer to a new reconstructed particle added to this group's event; nullptr if nothing is to be done

The condition which must be fulfilled for us to begin the reconstruction of a new particle starting from a fired detector on the trajectory is either:

  • the trajectory is the only one which passes through this detector; or
  • the detector directly in front of this one on this trajectory also fired.

Reimplemented in KVINDRAGroupReconstructor, and KVINDRAEtalonGroupReconstructor.

Definition at line 194 of file KVGroupReconstructor.cpp.

◆ SetCalibrationStatus()

void KVGroupReconstructor::SetCalibrationStatus ( KVReconstructedNucleus PART,
UShort_t  code 
)
inlineprivate

Set status of particle to 'IsCalibrated' and give the quality code corresponding to the calibration

Definition at line 52 of file KVGroupReconstructor.h.

◆ SetDoCalibration()

static void KVGroupReconstructor::SetDoCalibration ( bool  on = kTRUE)
inlinestatic

Enable/Disable calibration step in KVGroupReconstructor::Process

Definition at line 135 of file KVGroupReconstructor.h.

◆ SetDoIdentification()

static void KVGroupReconstructor::SetDoIdentification ( bool  on = kTRUE)
inlinestatic

Enable/Disable identification step in KVGroupReconstructor::Process

Definition at line 130 of file KVGroupReconstructor.h.

◆ SetGroup()

void KVGroupReconstructor::SetGroup ( KVGroup g)
virtual

Set the group to be reconstructed

Set condition for seeding reconstructed particles

Reimplemented in KVINDRAGroupReconstructor, and KVFAZIAGroupReconstructor.

Definition at line 45 of file KVGroupReconstructor.cpp.

◆ SetReconEventClass()

void KVGroupReconstructor::SetReconEventClass ( TClass *  c)

Instantiate event fragment object.

Definition at line 59 of file KVGroupReconstructor.cpp.

◆ TreatStatusStopFirstStage()

void KVGroupReconstructor::TreatStatusStopFirstStage ( KVReconstructedNucleus d)
private

particles stopped in first member of a telescope estimation of Z (minimum) from energy loss (if detector is calibrated)

Definition at line 476 of file KVGroupReconstructor.cpp.

Member Data Documentation

◆ coherency_particles

std::vector<particle_to_add_from_coherency_analysis> KVGroupReconstructor::coherency_particles
private

Definition at line 78 of file KVGroupReconstructor.h.

◆ fDoCalibration

bool KVGroupReconstructor::fDoCalibration = kTRUE
staticprivate

Definition at line 33 of file KVGroupReconstructor.h.

◆ fDoIdentification

bool KVGroupReconstructor::fDoIdentification = kTRUE
staticprivate

Definition at line 32 of file KVGroupReconstructor.h.

◆ fGroup

KVGroup* KVGroupReconstructor::fGroup
private

the group where we are reconstructing

Definition at line 35 of file KVGroupReconstructor.h.

◆ fGrpEvent

KVReconstructedEvent* KVGroupReconstructor::fGrpEvent
private

event containing particles reconstructed in this group

Definition at line 36 of file KVGroupReconstructor.h.

◆ fPartSeedCond

TString KVGroupReconstructor::fPartSeedCond
private

condition for seeding reconstructed particles

Definition at line 37 of file KVGroupReconstructor.h.

◆ id_by_type

std::unordered_map<std::string, KVIdentificationResult*> KVGroupReconstructor::id_by_type
private

identification results by type for current particle

Definition at line 42 of file KVGroupReconstructor.h.

◆ identifying_telescope

KVIDTelescope* KVGroupReconstructor::identifying_telescope
private

telescope which identified current particle

Definition at line 41 of file KVGroupReconstructor.h.

◆ nfireddets

int KVGroupReconstructor::nfireddets
mutableprivate

number of fired detectors in group for current event

Definition at line 39 of file KVGroupReconstructor.h.

◆ partID

KVIdentificationResult KVGroupReconstructor::partID
private

identification to be applied to current particle

Definition at line 40 of file KVGroupReconstructor.h.