![]() |
KaliVeda
Toolkit for HIC analysis
|
Reconstruct particles in INDRA groups.
Created by KVClassFactory on Wed Feb 21 13:42:47 2018 Author: John Frankland,,,
Definition at line 17 of file KVINDRAGroupReconstructor.h.
#include <KVINDRAGroupReconstructor.h>
Public Member Functions | |
KVINDRAGroupReconstructor () | |
virtual | ~KVINDRAGroupReconstructor () |
void | CalibrateParticle (KVReconstructedNucleus *PART) |
virtual void | DoCalibration (KVReconstructedNucleus *) |
virtual bool | DoCoherencyAnalysis (KVReconstructedNucleus &)=0 |
void | Identify () |
void | IdentifyParticle (KVReconstructedNucleus &PART) |
KVReconstructedNucleus * | ReconstructTrajectory (const KVGeoDNTrajectory *traj, const KVGeoDetectorNode *node) |
void | SetGroup (KVGroup *g) |
![]() | |
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... | |
KVReconstructedEvent * | GetEventFragment () const |
KVGroup * | GetGroup () const |
int | GetNFiredDets () const |
Int_t | GetNIdentifiedInGroup () |
Int_t | GetNUnidentifiedInGroup () |
void | Process () |
void | Reconstruct () |
void | SetReconEventClass (TClass *c) |
Instantiate event fragment object. More... | |
![]() | |
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 Member Functions | |
Bool_t | CalculateChIoDEFromResidualEnergy (KVReconstructedNucleus *n, Double_t ERES) |
void | CalibrateCoherencyParticle (KVReconstructedNucleus *) |
void | CheckCsIEnergy (KVReconstructedNucleus *n) |
double | DoBeryllium8Calibration (KVReconstructedNucleus *n) |
KVDetector * | GetCsI (KVReconstructedNucleus *n) |
void | SetBadCalibrationStatus (KVReconstructedNucleus *n) |
void | SetNoCalibrationStatus (KVReconstructedNucleus *n) |
Private Attributes | |
Double_t | fEChIo |
Double_t | fECsI |
Double_t | fESi |
bool | print_part |
debug More... | |
KVDetector * | theChio |
the ChIo of the group More... | |
Static Private Attributes | |
static TString | CSI_ID_TYPE = "CSI" |
Friends | |
class | KVINDRA |
Additional Inherited Members | |
![]() | |
enum | EKaliVedaBits { kIsKaliVedaObject = BIT(23) } |
![]() | |
static KVGroupReconstructor * | Factory (const TString &plugin="") |
static void | SetDoCalibration (bool on=kTRUE) |
static void | SetDoIdentification (bool on=kTRUE) |
![]() | |
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 53 of file KVINDRAGroupReconstructor.h.
|
inlinevirtual |
Definition at line 54 of file KVINDRAGroupReconstructor.h.
|
private |
calculate fEChIo from residual energy
returns kFALSE if it doesn't work, and sets particle bad calibration status
returns kTRUE if it works, and sets calib status to SOME_ENERGY_LOSSES_CALCULATED
Definition at line 255 of file KVINDRAGroupReconstructor.cpp.
|
inlineprivatevirtual |
Reimplemented from KVGroupReconstructor.
Definition at line 50 of file KVINDRAGroupReconstructor.h.
|
virtual |
Calculate and set the energy of a (previously identified) reconstructed particle
This is only possible for correctly identified particles. We exclude IDCODE9 particles (Zmin in CsI-RL)
Reimplemented from KVGroupReconstructor.
Definition at line 284 of file KVINDRAGroupReconstructor.cpp.
|
private |
Check calculated CsI energy loss of particle:
Definition at line 360 of file KVINDRAGroupReconstructor.cpp.
|
private |
Beryllium-8 = 2 alpha particles of same energy We halve the total light output of the CsI to calculate the energy of 1 alpha Then multiply resulting energy by 2 Note: fECsI is -ve, because energy is calculated not measured
Definition at line 329 of file KVINDRAGroupReconstructor.cpp.
|
inlinevirtual |
Reimplemented in KVINDRAForwardGroupReconstructor, KVINDRAEtalonGroupReconstructor, and KVINDRABackwardGroupReconstructor.
Definition at line 70 of file KVINDRAGroupReconstructor.h.
|
pure virtual |
Implemented in KVINDRAForwardGroupReconstructor, KVINDRAEtalonGroupReconstructor, and KVINDRABackwardGroupReconstructor.
|
inlineprivate |
Definition at line 42 of file KVINDRAGroupReconstructor.h.
|
virtual |
Reimplemented from KVGroupReconstructor.
Definition at line 91 of file KVINDRAGroupReconstructor.cpp.
|
virtual |
INDRA-specific particle identification. Here we attribute the Veda6-style general identification codes depending on the result of KVReconstructedNucleus::Identify and the subcodes from the different identification algorithms: If the particle's mass A was NOT measured, we make sure that it is calculated from the measured Z using the mass formula defined by default
IDENTIFIED PARTICLES Identified particles with ID code = 2 with subcodes 4 & 5 (masse hors limite superieure/inferieure) are relabelled with kIDCode10 (identification entre les lignes CsI)
UNIDENTIFIED PARTICLES Unidentified particles receive the general ID code for non-identified particles (kIDCode14) EXCEPT if their identification in CsI gave subcodes 6 or 7 (Zmin) then they are relabelled "Identified" with IDcode = 9 (ident. incomplete dans CsI ou Phoswich (Z.min)) Their "identifying" telescope is set to the CsI ID telescope
Reimplemented from KVGroupReconstructor.
Definition at line 139 of file KVINDRAGroupReconstructor.cpp.
|
virtual |
traj | trajectory currently being scanned |
node | current detector on trajectory to test |
Specialised particle reconstruction for INDRA data.
If the fired detector in question is a CsI we check, if identification is available, whether this corresponds to a 'gamma'. If so we count it (event parameter "INDRA_GAMMA_MULT") and add the name of the detector to the parameter "INDRA_GAMMA_DETS" but do not begin the reconstruction of a particle. This allows to continue along the trajectory and directly reconstruct any charged particle which may stop in the Si detector in coincidence with a 'gamma' in the CsI.
Reimplemented from KVGroupReconstructor.
Definition at line 29 of file KVINDRAGroupReconstructor.cpp.
|
inlineprivate |
Definition at line 27 of file KVINDRAGroupReconstructor.h.
|
inlinevirtual |
Reimplemented from KVGroupReconstructor.
Definition at line 56 of file KVINDRAGroupReconstructor.h.
|
inlineprivate |
Definition at line 33 of file KVINDRAGroupReconstructor.h.
|
friend |
Definition at line 19 of file KVINDRAGroupReconstructor.h.
|
staticprivate |
Definition at line 25 of file KVINDRAGroupReconstructor.h.
|
private |
Definition at line 23 of file KVINDRAGroupReconstructor.h.
|
private |
Definition at line 23 of file KVINDRAGroupReconstructor.h.
|
private |
Definition at line 23 of file KVINDRAGroupReconstructor.h.
|
private |
debug
Definition at line 24 of file KVINDRAGroupReconstructor.h.
|
private |
the ChIo of the group
Definition at line 22 of file KVINDRAGroupReconstructor.h.