KaliVeda  1.12/06
Heavy-Ion Analysis Toolkit
List of all members | Public Member Functions | Private Member Functions | Private Attributes | List of all members
KVINDRAReconEvent Class Reference

Event reconstructed from energy losses in INDRA multidetector.

By default this contains a TClonesArray of KVINDRAReconNuc objects.

Random vs. mean angles

By default reconstructed particles have randomised angles within the aperture of the detector where they were stopped. To use the mean angles of the detectors, call UseMeanAngles().

"OK" & not "OK" particles

The "OK" status of particles is defined by setting acceptable identification and calibration codes using AcceptIDCodes and AcceptECodes. The comparison of each particle's codes with the "acceptable" codes then determines whether KVParticle::IsOK() is set or not.

Trigger Information

Use EventTrigger() to access the KVINDRATriggerInfo object which stores the values of Selecteur registers STAT_EVE, R_DEC and CONFIG for this event

Definition at line 56 of file KVINDRAReconEvent.h.

Public Member Functions

 KVINDRAReconEvent (Int_t mult=50, const char *classname="KVINDRAReconNuc")
 
virtual ~ KVINDRAReconEvent ()
 
KVINDRAReconNucAddParticle ()
 Wrapper for KVEvent::GetNextParticle casting result to KVINDRAReconNuc*. More...
 
void ChangeFragmentMasses (UChar_t mass_formula)
 
Bool_t CheckCodes (KVINDRACodeMask &code)
 
KVINDRAReconNucGetNextParticle (Option_t *opt="")
 
KVINDRAReconNucGetParticle (Int_t npart) const
 
void IdentifyEvent ()
 
void init ()
 default initialisations More...
 
virtual void Print (Option_t *option="") const
 
void SecondaryAnalyseGroup (KVGroup *grp)
 
virtual void SecondaryIdentCalib ()
 
- Public Member Functions inherited from KVReconstructedEvent
 KVReconstructedEvent (Int_t mult=50, const char *classname="KVReconstructedNucleus")
 
virtual ~ KVReconstructedEvent ()
 
KVReconstructedNucleusAddParticle ()
 
virtual Bool_t AnalyseDetectors (TList *kvtl)
 
virtual void CalibrateEvent ()
 
KVReconstructedNucleusGetNextParticle (Option_t *opt="")
 
KVReconstructedNucleusGetParticle (const Char_t *group_name) const
 
KVReconstructedNucleusGetParticle (Int_t npart) const
 
KVReconstructedNucleusGetParticleWithName (const Char_t *name) const
 
virtual const Char_tGetPartSeedCond () const
 
Bool_t HasMeanAngles ()
 
Bool_t HasRandomAngles ()
 
void init ()
 default initialisations More...
 
void ls (Option_t *="") const
 compact listing of reconstructed event More...
 
void MergeEventFragments (TCollection *, Option_t *opt="")
 
virtual void SetPartSeedCond (const Char_t *cond)
 
void UseMeanAngles ()
 
void UseRandomAngles ()
 
- Public Member Functions inherited from KVEvent
 KVEvent (Int_t mult=50, const char *classname="KVNucleus")
 
virtual ~ KVEvent ()
 
KVNucleusAddParticle ()
 
Iterator begin () const
 
void ChangeDefaultFrame (const Char_t *, const Char_t *defname="")
 
void ChangeFrame (const KVFrameTransform &, const KVString &="")
 
virtual void Clear (Option_t *opt="")
 
virtual void Copy (TObject &obj) const
 Copy this to obj. More...
 
void CustomStreamer ()
 
void DefineGroup (const Char_t *groupname, const Char_t *from="")
 
void DefineGroup (const Char_t *groupname, KVParticleCondition *cond, const Char_t *from="")
 
Iterator end () const
 
void FillHisto (TH1 *h, const Char_t *KVNucleus_method, const Char_t *method_prototype, const Char_t *args, Option_t *opt="")
 
void FillHisto (TH1 *h, const Char_t *KVNucleus_method, Option_t *opt="")
 
virtual void FillIntegerList (KVIntegerList *, Option_t *opt)
 
Double_t GetChannelQValue () const
 
const Char_tGetFrameName () const
 
Double_t GetGSChannelQValue () const
 
virtual void GetGSMasses (std::vector< Double_t > &)
 Fill vector with ground state mass of each nucleus of event (in MeV). More...
 
virtual void GetMasses (std::vector< Double_t > &)
 Fill vector with mass of each nucleus of event (in MeV) [note: this is the mass including any excitation energy, not ground state]. More...
 
Int_t GetMinimumOKMultiplicity () const
 
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="")
 
KVNucleusGetNextParticle (Option_t *opt="") const
 
Iterator GetNextParticleIterator (Option_t *opt) const
 
KVNameValueListGetParameters () const
 
KVNucleusGetParticle (const Char_t *group_name) const
 Find first particle in event belonging to group with name "group_name". More...
 
KVNucleusGetParticle (Int_t npart) const
 
KVNucleusGetParticleWithName (const Char_t *name) const
 
const Char_tGetPartitionName ()
 
Double_t GetSum (const Char_t *KVNucleus_method, const Char_t *method_prototype, const Char_t *args, Option_t *opt="")
 
Double_t GetSum (const Char_t *KVNucleus_method, Option_t *opt="")
 
virtual Bool_t IsOK ()
 
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 &)
 
void SetMinimumOKMultiplicity (Int_t)
 
template<typename ValType >
void SetParameter (const Char_t *name, ValType value) const
 
void UpdateAllFrames ()
 
- 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_tGetLabel () const
 
UInt_t GetNumber () const
 
UInt_t GetNumberOfObjects () const
 
virtual TObjectGetObject () const
 
const Char_tGetType () 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)
 
- Public Member Functions inherited from TNamed
 TNamed ()
 
 TNamed (const char *name, const char *title)
 
 TNamed (const TNamed &named)
 
 TNamed (const TString &name, const TString &title)
 
virtual ~TNamed ()
 
virtual TObjectClone (const char *newname="") const
 
virtual Int_t Compare (const TObject *obj) const
 
virtual void FillBuffer (char *&buffer)
 
virtual const char * GetName () const
 
virtual const char * GetTitle () const
 
virtual ULong_t Hash () const
 
virtual Bool_t IsSortable () const
 
TNamedoperator= (const TNamed &rhs)
 
virtual void SetName (const char *name)
 
virtual void SetNameTitle (const char *name, const char *title)
 
virtual void SetTitle (const char *title="")
 
virtual Int_t Sizeof () const
 
- Public Member Functions inherited from TObject
 TObject ()
 
 TObject (const TObject &object)
 
virtual ~TObject ()
 
void AbstractMethod (const char *method) const
 
virtual void AppendPad (Option_t *option="")
 
virtual void Browse (TBrowser *b)
 
ULong_t CheckedHash ()
 
virtual const char * ClassName () const
 
virtual void Delete (Option_t *option="")
 
virtual Int_t DistancetoPrimitive (Int_t px, Int_t py)
 
virtual void Draw (Option_t *option="")
 
virtual void DrawClass () const
 
virtual TObjectDrawClone (Option_t *option="") const
 
virtual void Dump () const
 
virtual void Error (const char *method, const char *msgfmt,...) const
 
virtual void Execute (const char *method, const char *params, Int_t *error=0)
 
virtual void Execute (TMethod *method, TObjArray *params, Int_t *error=0)
 
virtual void ExecuteEvent (Int_t event, Int_t px, Int_t py)
 
virtual void Fatal (const char *method, const char *msgfmt,...) const
 
virtual TObjectFindObject (const char *name) const
 
virtual TObjectFindObject (const TObject *obj) const
 
virtual Option_tGetDrawOption () const
 
virtual const char * GetIconName () const
 
virtual char * GetObjectInfo (Int_t px, Int_t py) const
 
virtual Option_tGetOption () const
 
virtual UInt_t GetUniqueID () const
 
virtual Bool_t HandleTimer (TTimer *timer)
 
Bool_t HasInconsistentHash () const
 
virtual void Info (const char *method, const char *msgfmt,...) const
 
virtual Bool_t InheritsFrom (const char *classname) const
 
virtual Bool_t InheritsFrom (const TClass *cl) const
 
virtual void Inspect () const
 
void InvertBit (UInt_t f)
 
virtual Bool_t IsEqual (const TObject *obj) const
 
virtual Bool_t IsFolder () const
 
R__ALWAYS_INLINE Bool_t IsOnHeap () const
 
R__ALWAYS_INLINE Bool_t IsZombie () const
 
void MayNotUse (const char *method) const
 
virtual Bool_t Notify ()
 
void Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const
 
void operator delete (void *ptr)
 
void operator delete[] (void *ptr)
 
voidoperator new (size_t sz)
 
voidoperator new (size_t sz, void *vp)
 
voidoperator new[] (size_t sz)
 
voidoperator new[] (size_t sz, void *vp)
 
TObjectoperator= (const TObject &rhs)
 
virtual void Paint (Option_t *option="")
 
virtual void Pop ()
 
virtual Int_t Read (const char *name)
 
virtual void RecursiveRemove (TObject *obj)
 
void ResetBit (UInt_t f)
 
virtual void SaveAs (const char *filename="", Option_t *option="") const
 
virtual void SavePrimitive (std::ostream &out, Option_t *option="")
 
void SetBit (UInt_t f)
 
void SetBit (UInt_t f, Bool_t set)
 
virtual void SetDrawOption (Option_t *option="")
 
virtual void SetUniqueID (UInt_t uid)
 
virtual void SysError (const char *method, const char *msgfmt,...) const
 
R__ALWAYS_INLINE Bool_t TestBit (UInt_t f) const
 
Int_t TestBits (UInt_t f) const
 
virtual void UseCurrentStyle ()
 
virtual void Warning (const char *method, const char *msgfmt,...) const
 
virtual Int_t Write (const char *name=0, Int_t option=0, Int_t bufsize=0)
 
virtual Int_t Write (const char *name=0, Int_t option=0, Int_t bufsize=0) const
 

Private Member Functions

KVINDRACodeMaskGetCodeMask ()
 

Private Attributes

KVINDRACodeMaskfCodeMask
 VEDA codes accepted for "good" particles (IsOK) More...
 
KVUniqueNameListfHitGroups
 non-persistent pointer to list of hit groups used in SecondaryIdentAndCalib() More...
 

Additional Inherited Members

- Public Types inherited from KVBase
enum  EKaliVedaBits { kIsKaliVedaObject = BIT(23) }
 
- Public Types inherited from TObject
enum  EDeprecatedStatusBits
 
enum  EStatusBits
 
- Static Public Member Functions inherited from KVEvent
static KVEventFactory (const char *)
 Create and return pointer to new event of class given by plugin. More...
 
template<typename T >
static void MakeEventBranch (TTree *tree, const TString &branchname, const TString &classname, 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_tFindFile (const Char_t *search, TString &wfil)
 
static const Char_tGetBINDIRFilePath (const Char_t *namefile="")
 
static const Char_tGetDATABASEFilePath ()
 
static const Char_tGetDATADIRFilePath (const Char_t *namefile="")
 
static Bool_t GetDataSetEnv (const Char_t *dataset, const Char_t *type, Bool_t defval)
 
static const Char_tGetDataSetEnv (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_tGetETCDIRFilePath (const Char_t *namefile="")
 
static const Char_tGetExampleFilePath (const Char_t *library, const Char_t *namefile)
 Return full path to example file for given library (="KVMultiDet", "BackTrack", etc.) More...
 
static const Char_tGetINCDIRFilePath (const Char_t *namefile="")
 
static const Char_tGetKVBuildDate ()
 Returns KaliVeda build date. More...
 
static const Char_tGetKVBuildDir ()
 Returns top-level directory used for build. More...
 
static const Char_tGetKVBuildTime ()
 Returns KaliVeda build date. More...
 
static const Char_tGetKVBuildType ()
 Returns KaliVeda build type (cmake build: Release, Debug, RelWithDebInfo, ...) More...
 
static const Char_tGetKVBuildUser ()
 Returns username of person who performed build. More...
 
static const Char_tGetKVSourceDir ()
 Returns top-level directory of source tree used for build. More...
 
static const Char_tGetKVVersion ()
 Returns KaliVeda version string. More...
 
static const Char_tGetLIBDIRFilePath (const Char_t *namefile="")
 
static const Char_tGetListOfPlugins (const Char_t *base)
 
static const Char_tGetListOfPluginURIs (const Char_t *base)
 
static const Char_tGetPluginURI (const Char_t *base, const Char_t *plugin)
 
static void GetTempFileName (TString &base)
 
static const Char_tGetTEMPLATEDIRFilePath (const Char_t *namefile="")
 
static const Char_tGetWORKDIRFilePath (const Char_t *namefile="")
 
static const Char_tgitBranch ()
 Returns git branch of sources. More...
 
static const Char_tgitCommit ()
 Returns last git commit of sources. More...
 
static void InitEnvironment ()
 
static bool is_gnuinstall ()
 
static Bool_t IsThisAPlugin (const TString &uri, TString &base)
 
static TPluginHandlerLoadPlugin (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, 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_tWorkingDirectory ()
 
- Static Public Member Functions inherited from TObject
static Longptr_t GetDtorOnly ()
 
static Bool_t GetObjectStat ()
 
static void SetDtorOnly (void *obj)
 
static void SetObjectStat (Bool_t stat)
 
- Public Attributes inherited from TObject
 kBitMask
 
 kCanDelete
 
 kCannotPick
 
 kHasUUID
 
 kInconsistent
 
 kInvalidObject
 
 kIsOnHeap
 
 kIsReferenced
 
 kMustCleanup
 
 kNoContextMenu
 
 kNotDeleted
 
 kObjInCanvas
 
 kOverwrite
 
 kSingleKey
 
 kWriteDelete
 
 kZombie
 
- Protected Member Functions inherited from TObject
virtual void DoError (int level, const char *location, const char *fmt, va_list va) const
 
void MakeZombie ()
 
- Protected Attributes inherited from KVEvent
Iterator fIter
 internal iterator used by GetNextParticle() More...
 
KVNameValueList fParameters
 general-purpose list of parameters More...
 
TClonesArrayfParticles
 array of particles in event More...
 
- Protected Attributes inherited from KVBase
TString fLabel
 label for the object More...
 
- Protected Attributes inherited from TNamed
TString fName
 
TString fTitle
 
- Protected Attributes inherited from TObject
 kOnlyPrepStep
 

#include <KVINDRAReconEvent.h>

Inheritance diagram for KVINDRAReconEvent:
Inheritance graph
[legend]

Constructor & Destructor Documentation

◆ KVINDRAReconEvent()

KVINDRAReconEvent::KVINDRAReconEvent ( Int_t  mult = 50,
const char *  classname = "KVINDRAReconNuc" 
)

Definition at line 56 of file KVINDRAReconEvent.cpp.

◆ ~ KVINDRAReconEvent()

virtual KVINDRAReconEvent::~ KVINDRAReconEvent ( )
virtual

Member Function Documentation

◆ AddParticle()

KVINDRAReconNuc * KVINDRAReconEvent::AddParticle ( )

Wrapper for KVEvent::GetNextParticle casting result to KVINDRAReconNuc*.

Definition at line 100 of file KVINDRAReconEvent.cpp.

◆ ChangeFragmentMasses()

void KVINDRAReconEvent::ChangeFragmentMasses ( UChar_t  mass_formula)

Changes the mass formula used to calculate A from Z for all nuclei in event For the values of mass_formula, see KVNucleus::GetAFromZ

The fragment energy is modified in proportion to its mass, this is due to the contribution from the CsI light-energy calibration:

E -> E + E_CsI*( newA/oldA - 1 )

From an original lunch by Remi Bougault.

Only particles with 'acceptable' ID & E codes stopping in (or passing through) a CsI detector are affected; particles whose mass was measured (i.e. having KVReconstructedNucleus::IsAMeasured()==kTRUE) are not affected by the change of mass formula.

Definition at line 186 of file KVINDRAReconEvent.cpp.

◆ CheckCodes()

Bool_t KVINDRAReconEvent::CheckCodes ( KVINDRACodeMask code)
inline

returns kTRUE if "code" is compatible with event's code mask if no code mask set for event, returns kTRUE in all cases

Definition at line 83 of file KVINDRAReconEvent.h.

◆ GetCodeMask()

KVINDRACodeMask* KVINDRAReconEvent::GetCodeMask ( )
inlineprivate

Definition at line 60 of file KVINDRAReconEvent.h.

◆ GetNextParticle()

KVINDRAReconNuc * KVINDRAReconEvent::GetNextParticle ( Option_t opt = "")

Use this method to iterate over the list of particles in the event.

If opt="ok" only the particles whose ID codes and E codes correspond to those set using AcceptIDCodes and AcceptECodes will be returned, in the order in which they appear in the event.

After the last particle in the event GetNextParticle() returns a null pointer and resets itself ready for a new iteration over the particle list. Therefore, to loop over all particles in an event, use a structure like:

KVINDRAReconNuc* p; while( (p = GetNextParticle() ){ ... your code here ... }

Definition at line 148 of file KVINDRAReconEvent.cpp.

◆ GetParticle()

KVINDRAReconNuc * KVINDRAReconEvent::GetParticle ( Int_t  npart) const

Access to event member with index npart (1<=npart<=fMult)

Definition at line 84 of file KVINDRAReconEvent.cpp.

◆ IdentifyEvent()

void KVINDRAReconEvent::IdentifyEvent ( )
virtual

Performs event identification (see KVReconstructedEvent::IdentifyEvent), and then particles stopping in first member of a telescope (GetStatus() == KVReconstructedNucleus::kStatusStopFirstStage) are labelled with VEDA ID code kIDCode5 (Zmin)

When CsI identification gives a gamma, we unset the 'analysed' state of all detectors in front of the CsI and reanalyse the group in order to reconstruct and identify charged particles stopping in them.

Unidentified particles receive the general ID code for non-identified particles (kIDCode14)

Reimplemented from KVReconstructedEvent.

Definition at line 238 of file KVINDRAReconEvent.cpp.

◆ init()

void KVINDRAReconEvent::init ( void  )

default initialisations

Definition at line 44 of file KVINDRAReconEvent.cpp.

◆ Print()

void KVINDRAReconEvent::Print ( Option_t option = "") const
virtual

Print out list of particles in the event. If option="ok" only particles with IsOK=kTRUE are included.

Reimplemented from KVReconstructedEvent.

Definition at line 114 of file KVINDRAReconEvent.cpp.

◆ SecondaryAnalyseGroup()

void KVINDRAReconEvent::SecondaryAnalyseGroup ( KVGroup grp)

Definition at line 366 of file KVINDRAReconEvent.cpp.

◆ SecondaryIdentCalib()

void KVINDRAReconEvent::SecondaryIdentCalib ( )
virtual

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

Here we treat particles with GetStatus()==KVReconstructedNucleus::kStatusOKafterSub after subtracting the energy losses of all previously calibrated particles in group from the measured energy losses in the detectors they crossed.

Reimplemented from KVReconstructedEvent.

Definition at line 329 of file KVINDRAReconEvent.cpp.

Member Data Documentation

◆ fCodeMask

KVINDRACodeMask* KVINDRAReconEvent::fCodeMask
private

VEDA codes accepted for "good" particles (IsOK)

Definition at line 59 of file KVINDRAReconEvent.h.

◆ fHitGroups

KVUniqueNameList* KVINDRAReconEvent::fHitGroups
private

non-persistent pointer to list of hit groups used in SecondaryIdentAndCalib()

Definition at line 66 of file KVINDRAReconEvent.h.


The documentation for this class was generated from the following files: