KaliVeda
Toolkit for HIC analysis
KVDataPatch_E789_FAZIABadCsICalibFragments Class Reference

Detailed Description

Correct mistaken use of Z=2 CsI calib for all fragments in FAZIA.

In data written with v.1.12/05, the FAZIA CsI calibration for Z=2 was mistakenly extended to use for all fragments stopping in a CsI detector as well. This leads to an underestimation of energies of fragment (by up to 50%). This patch corrects the CsI energy, laboratory total energy, and centre-of-mass kinematics of these fragments.

Any particle to which this patch is applied will have a parameter

DATAPATCH.E789_FAZIABadCsICalibFragments.APPLIED = true
Author
eindra
Date
Thu Apr 21 09:41:40 2022

Definition at line 28 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

#include <KVDataPatch_E789_FAZIABadCsICalibFragments.h>

Inheritance diagram for KVDataPatch_E789_FAZIABadCsICalibFragments:

Public Member Functions

 KVDataPatch_E789_FAZIABadCsICalibFragments ()
 
void ApplyToEvent (KVReconstructedEvent *)
 
void ApplyToParticle (KVReconstructedNucleus *rnuc)
 
bool correct_ecsi (KVReconstructedNucleus *rnuc)
 
Bool_t IsEventPatch ()
 
Bool_t IsParticlePatch ()
 
Bool_t IsRequired (TString dataset, TString datatype, Int_t, TString dataseries, Int_t datareleasenumber, const TList *)
 
void PrintPatchInfo () const
 
- Public Member Functions inherited from KVDataPatch
 KVDataPatch ()
 
 KVDataPatch (const Char_t *name, const Char_t *title="")
 
void Print (Option_t *="") const
 Print infos on patch. 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...
 
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)
 

Additional Inherited Members

- Public Types inherited from KVBase
enum  EKaliVedaBits { kIsKaliVedaObject = BIT(23) }
 
- 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

◆ KVDataPatch_E789_FAZIABadCsICalibFragments()

KVDataPatch_E789_FAZIABadCsICalibFragments::KVDataPatch_E789_FAZIABadCsICalibFragments ( )
inline

Default constructor

Definition at line 30 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

Member Function Documentation

◆ ApplyToEvent()

void KVDataPatch_E789_FAZIABadCsICalibFragments::ApplyToEvent ( KVReconstructedEvent )
inlinevirtual

Implements KVDataPatch.

Definition at line 51 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

◆ ApplyToParticle()

void KVDataPatch_E789_FAZIABadCsICalibFragments::ApplyToParticle ( KVReconstructedNucleus rnuc)
inlinevirtual

Implements KVDataPatch.

Definition at line 52 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

◆ correct_ecsi()

bool KVDataPatch_E789_FAZIABadCsICalibFragments::correct_ecsi ( KVReconstructedNucleus rnuc)
inline

if nucleus stopped in FAZIA csi & has Z>2 with a CsI energy taken from calibration (FAZIA.ECSI>0), replace CsI energy with energy deduced from measured energy in SI1 & SI2 (if & only if both detectors are working & calibrated, and if there is no suspicion of pile-up in SI1 (for SI2-CSI identification) or in SI1/SI2 (for CSI identification)): in this case we must have FAZIA.ESI1>0 and FAZIA.ESI2>0.

return true if correction is performed

calculate CsI energy from total energy loss ESI1+ESI2 in a silicon detector with effective thickness equal to the sum of SI1 & SI2 thicknesses

set new energy in lab frame

update kinematics in other frames (e.g. "CM" frame automatically defined for analysis)

Definition at line 61 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

◆ IsEventPatch()

Bool_t KVDataPatch_E789_FAZIABadCsICalibFragments::IsEventPatch ( )
inlinevirtual

Implements KVDataPatch.

Definition at line 43 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

◆ IsParticlePatch()

Bool_t KVDataPatch_E789_FAZIABadCsICalibFragments::IsParticlePatch ( )
inlinevirtual

Implements KVDataPatch.

Definition at line 47 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

◆ IsRequired()

Bool_t KVDataPatch_E789_FAZIABadCsICalibFragments::IsRequired ( TString  dataset,
TString  datatype,
Int_t  ,
TString  dataseries,
Int_t  datareleasenumber,
const TList *   
)
inlinevirtual

Implements KVDataPatch.

Definition at line 37 of file KVDataPatch_E789_FAZIABadCsICalibFragments.h.

◆ PrintPatchInfo()

void KVDataPatch_E789_FAZIABadCsICalibFragments::PrintPatchInfo ( ) const
virtual

Implements KVDataPatch.

Definition at line 8 of file KVDataPatch_E789_FAZIABadCsICalibFragments.cpp.