KaliVeda
Toolkit for HIC analysis
KVIDGCsI Class Reference

Detailed Description

Identification grids for CsI R-L (fast-slow) matrices.

The identification procedure is supposed to be identical to that of the FORTRAN algorithm IdnCsOr developed by Laurent Tassan-Got and used by the INDRA collaboration since 1993.

The status codes returned by GetQualityCode() are the same as IdnCsOr, with the addition of kICODE10 for identification of gammas:

KVIDGCsI::kICODE1 Z ok, mais les masses superieures a A sont possibles
KVIDGCsI::kICODE2 Z ok, mais les masses inferieures a A sont possibles
KVIDGCsI::kICODE3 Z ok, mais les masses superieures ou inferieures a A sont possibles
KVIDGCsI::kICODE4 Z ok, masse hors limite superieure ou egale a A
KVIDGCsI::kICODE5 Z ok, masse hors limite inferieure ou egale a A
KVIDGCsI::kICODE6 au-dessus de la ligne fragment, Z est alors un Zmin
KVIDGCsI::kICODE7 a gauche de la ligne fragment, Z est alors un Zmin et le plus probable
KVIDGCsI::kICODE8 Z indetermine ou (x,y) hors limites
KVIDGCsI::kICODE9 pas de lignes pour ce module

Definition at line 42 of file KVIDGCsI.h.

#include <KVIDGCsI.h>

Inheritance diagram for KVIDGCsI:

Public Member Functions

 KVIDGCsI ()
 Default constructor. More...
 
 KVIDGCsI (const KVIDGCsI &)
 Copy constructor. More...
 
virtual ~ KVIDGCsI ()
 
virtual TClass * DefaultIDLineClass ()
 
KVIDLineGetGammaLine () const
 
KVIDLineGetIMFLine () const
 
KVIDZALineGetZALine (Int_t z, Int_t a, Int_t &) const
 
KVIDZALineGetZLine (Int_t z, Int_t &) const
 
virtual void Identify (Double_t x, Double_t y, KVIdentificationResult *) const
 
void IdentZA (Double_t x, Double_t y, Int_t &Z, Double_t &A)
 
virtual void Initialize ()
 
virtual Bool_t IsIdentifiable (Double_t x, Double_t y, TString *=nullptr) const
 
- Public Member Functions inherited from KVIDZAGrid
 KVIDZAGrid ()
 default ctor. More...
 
 KVIDZAGrid (const KVIDZAGrid &)
 Copy constructor. More...
 
virtual ~ KVIDZAGrid ()
 
virtual void CalculateLineWidths ()
 
virtual void Copy (TObject &) const
 Copy this to 'obj'. More...
 
void DrawLinesWithWidth ()
 
KVIDLineGetClosestLine () const
 
Double_t GetDistanceClosestLine () const
 
UChar_t GetIndexClosest () const
 
Int_t GetQualityCode () const
 
Int_t GetZmax () const
 
KVIDZALineGetZmaxLine () const
 
virtual void IdentZ (Double_t x, Double_t y, Double_t &Z)
 
KVIDGraphMakeSubsetGraph (Int_t Zmin, Int_t Zmax, const Char_t *="")
 virtual void MakeEDeltaEZGrid(Int_t Zmin, Int_t Zmax, Int_t npoints=20, Double_t gamma = 2);//*MENU* More...
 
KVIDGraphMakeSubsetGraph (TList *, TClass *=0)
 
void ReCheckQuality (Int_t &Z, Double_t &A)
 
void RemoveLine (Int_t Z, Int_t A=-1)
 Remove and destroy identifier. More...
 
void RemoveZLines (const Char_t *ZList)
 Remove and destroy identifiers. More...
 
void SetManualWidth (Double_t manual_width=.3, Double_t manual_width_scaling=0.05)
 
void SetVarXVarY (const char *VarX, const char *VarY)
 
- Public Member Functions inherited from KVIDGrid
 KVIDGrid ()
 Default constructor. More...
 
virtual ~ KVIDGrid ()
 
virtual TClass * DefaultOKLineClass ()
 
KVIDLineFindNearestEmbracingIDLine (Double_t x, Double_t y, const Char_t *position, const Char_t *axis, Int_t &idx, Int_t &idx_min, Int_t &idx_max, Double_t &dist, Double_t &dist_min, Double_t &dist_max) const
 
KVIDLineFindNearestIDLineFast (Double_t x, Double_t y, const Char_t *position, Int_t &idx, Int_t &idx_min, Int_t &idx_max, Double_t &dist, Double_t &dist_min, Double_t &dist_max) const
 
KVIDLineFindNextEmbracingLine (Int_t &index, Int_t inc_index, Double_t x, Double_t y, const Char_t *axis) const
 
Int_t GetIDLinesEmbracingPoint (const Char_t *direction, Double_t x, Double_t y) const
 
KVIDLineNewLine (const Char_t *idline_class="")
 
- Public Member Functions inherited from KVIDGraph
 KVIDGraph ()
 
 KVIDGraph (const KVIDGraph &)
 Copy constructor. More...
 
virtual ~KVIDGraph ()
 
virtual Bool_t AcceptIDForTest (const KVIdentificationResult &idr)
 
void Add (TString, KVIDentifier *)
 
KVIDentifierAdd (TString, TString)
 
virtual void AddCut (KVIDentifier *cut)
 
virtual void AddIdentifier (KVIDentifier *id)
 
void AddIDTelescope (KVBase *t)
 
void AddIDTelescopes (const TList *)
 Associate this graph with all ID telescopes in list. More...
 
virtual void AddInfo (KVIDentifier *info)
 
void AddParameter (char *Name, char *Value)
 
virtual Int_t CheckVersion (Int_t version)
 
virtual void Clear (Option_t *opt="")
 
void ClearListOfTelescopes ()
 
void ClearPad (TVirtualPad *)
 
virtual void Delete (Option_t *option="")
 
void Draw (Option_t *opt="")
 
virtual void DrawAndAdd (const Char_t *type="ID", const Char_t *classname="KVIDentifier")
 
virtual void DrawClass () const
 
virtual TObject * DrawClone (Option_t *option="") const
 
virtual void DrawPanel ()
 
virtual void Dump () const
 
virtual Bool_t ExistVersion (Int_t version)
 
void ExtendBeginningAllIdentLines (Double_t, Option_t *="")
 
void ExtendEndAllIdentLines (Double_t, Option_t *="")
 
void FindAxisLimits ()
 Calculate X/Y min/max of all objects in graph. More...
 
virtual TFitResultPtr Fit (const char *formula, Option_t *option="", Option_t *goption="", Axis_t xmin=0, Axis_t xmax=0)
 
virtual TFitResultPtr Fit (TF1 *f1, Option_t *option="", Option_t *goption="", Axis_t xmin=0, Axis_t xmax=0)
 
virtual void FitPanel ()
 virtual void SetTitle(const char *title="") {TGraph::SetTitle(title);}; More...
 
KVIDentifierGetCut (const Char_t *name) const
 
KVListGetCuts ()
 
const KVListGetCuts () const
 
KVIDentifierGetIdentifier (const Char_t *name) const
 
KVIDentifierGetIdentifier (Int_t Z, Int_t A) const
 
KVIDentifierGetIdentifierAt (Int_t index) const
 
KVListGetIdentifiers ()
 
const KVListGetIdentifiers () const
 
const Char_t * GetIDTelescopeLabel () const
 
const TList * GetIDTelescopes () const
 
KVIDentifierGetInfo (const Char_t *name) const
 
KVListGetInfos ()
 
const KVListGetInfos () const
 
KVIDGraphGetLastSavedVersion () const
 
Int_t GetMassFormula () const
 
const Char_t * GetName () const
 
const Char_t * GetNamesOfIDTelescopes () const
 
Int_t GetNumberOfCuts () const
 
Int_t GetNumberOfIdentifiers () const
 
Int_t GetNumberOfInfos () const
 
TVirtualPad * GetPad () const
 
KVNameValueListGetParameters ()
 
const KVNameValueListGetParameters () const
 
TString GetPattern (void)
 
const Char_t * GetRunList () const
 
const KVNumberListGetRuns () const
 
Axis_t GetXmax () const
 
Axis_t GetXmin () const
 
Double_t GetXScaleFactor ()
 
Axis_t GetYmax () const
 
Axis_t GetYmin () const
 
Double_t GetYScaleFactor ()
 
Bool_t HandlesIDTelescope (KVBase *t) const
 
virtual Bool_t HasMassIDCapability () const
 
void Increment (Float_t x)
 
virtual Int_t InsertPoint ()
 
virtual void Inspect () const
 
TVirtualPad * IsDrawn () const
 
Bool_t IsSorted () const
 
void Modified ()
 
void Print (Option_t *opt="") const
 Print out all objects in graph. More...
 
void ReadAsciiFile (const Char_t *filename)
 
virtual void ReadAsciiFile_WP (Int_t version=-1)
 lecture des grilles avec version suivant un modele de fichier More...
 
virtual void ReadFromAsciiFile (std::ifstream &gridfile)
 
void RemoveCut (KVIDentifier *)
 Remove and destroy cut. More...
 
void RemoveIdentifier (KVIDentifier *)
 Remove and destroy identifier. More...
 
void RemoveIDTelescope (KVBase *t)
 
void RemoveInfo (KVIDentifier *)
 Remove and destroy cut. More...
 
virtual Int_t RemovePoint ()
 
virtual Int_t RemovePoint (Int_t i)
 
void ResetDraw ()
 
void ResetPad ()
 
void RevertToLastSavedVersion ()
 
virtual void SaveAs (const char *filename="", Option_t *option="") const
 
void Scale (TF1 *sx, TF1 *sy)
 
virtual void SetDrawOption (Option_t *option="")
 
virtual void SetEditable (Bool_t editable=kTRUE)
 
virtual void SetFillAttributes ()
 
virtual void SetInfos (Double_t, Double_t, KVIdentificationResult *) const
 loop over KVIDGraph::fInfoZones to set flags in KVIdentificationResult More...
 
virtual void SetLineAttributes ()
 
void SetLineColor (Color_t lcolor)
 
void SetLineStyle (Style_t lstyle)
 
void SetLineWidth (Width_t lwidth)
 
virtual void SetMarkerAttributes ()
 
void SetMassFormula (Int_t)
 
virtual void SetMassIDCapability (Bool_t yes=kTRUE)
 
virtual void SetMaximum (Double_t maximum=-1111)
 
virtual void SetMinimum (Double_t minimum=-1111)
 
virtual void SetName (const char *name)
 
virtual void SetOnlyZId (Bool_t yes=kTRUE)
 
void SetPattern (TString pattern)
 
void SetRunList (const char *runlist)
 
void SetRuns (const KVNumberList &nl)
 Set list of runs for which grid is valid. More...
 
virtual void SetVarX (const char *v)
 
virtual void SetVarY (const char *v)
 
void SetXScaleFactor (Double_t=0)
 
void SetXVariable (const char *v)
 void SetIDTelescopes();// MENU={Hierarchy="Set.../ID Telescopes"} More...
 
void SetYScaleFactor (Double_t=0)
 
void SetYVariable (const char *v)
 
void SortIdentifiers ()
 
virtual void TestIdentification (TH2F *data, KVHashList &histos, KVNameValueList &histo_names)
 
void UnDraw ()
 
void UpdateLastSavedVersion ()
 update last saved version. mkae copy of current state of graph. More...
 
void WriteAsciiFile (const Char_t *filename)
 Open, write and close ascii file containing this grid. More...
 
virtual void WriteAsciiFile_WP (Int_t version=-1)
 
virtual void WriteToAsciiFile (std::ofstream &gridfile)
 

Private Member Functions

virtual void BackwardsCompatibilityFix ()
 
KVIDLineGetNearestIDLine (Double_t x, Double_t y, const Char_t *position, Int_t &idx_min, Int_t &idx_max)
 

Private Attributes

KVIDLineGammaLine
 
KVIDLineIMFLine
 

Additional Inherited Members

- Public Types inherited from KVIDZAGrid
enum  {
  kICODE0 , kICODE1 , kICODE2 , kICODE3 ,
  kICODE4 , kICODE5 , kICODE6 , kICODE7 ,
  kICODE8 , kICODE9 , kICODE10
}
 
- Static Public Member Functions inherited from KVIDGraph
static KVIDGraphAddGraphs (KVIDGraph *g1, Int_t id1_min, Int_t id1_max, KVIDGraph *g2, Int_t id2_min, Int_t id2_max)
 
static Bool_t GetAutoAdd ()
 
static KVIDGraphMakeIDGraph (const Char_t *)
 
static void SetAutoAdd (Bool_t yes=kTRUE)
 

Constructor & Destructor Documentation

◆ KVIDGCsI() [1/2]

KVIDGCsI::KVIDGCsI ( )

Default constructor.

Definition at line 12 of file KVIDGCsI.cpp.

◆ KVIDGCsI() [2/2]

KVIDGCsI::KVIDGCsI ( const KVIDGCsI grid)

Copy constructor.

Definition at line 24 of file KVIDGCsI.cpp.

◆ ~ KVIDGCsI()

virtual KVIDGCsI::~ KVIDGCsI ( )
virtual

Member Function Documentation

◆ BackwardsCompatibilityFix()

void KVIDGCsI::BackwardsCompatibilityFix ( )
privatevirtual

Called after reading a grid from an ascii file. Tries to convert information written by an old version of the class:

PARAMETER> Ring min=... -—> <PARAMETER> IDTelescopes=... PARAMETER> Ring max=... PARAMETER> Mod min=... PARAMETER> Mod max=...

This will fail. The fix is no longer supported. Such files should no longer exist.

Reimplemented from KVIDGraph.

Definition at line 673 of file KVIDGCsI.cpp.

◆ DefaultIDLineClass()

virtual TClass* KVIDGCsI::DefaultIDLineClass ( )
inlinevirtual

Reimplemented from KVIDZAGrid.

Definition at line 79 of file KVIDGCsI.h.

◆ GetGammaLine()

KVIDLine* KVIDGCsI::GetGammaLine ( ) const
inline

Definition at line 59 of file KVIDGCsI.h.

◆ GetIMFLine()

KVIDLine* KVIDGCsI::GetIMFLine ( ) const
inline

Definition at line 63 of file KVIDGCsI.h.

◆ GetNearestIDLine()

KVIDLine* KVIDGCsI::GetNearestIDLine ( Double_t  x,
Double_t  y,
const Char_t *  position,
Int_t &  idx_min,
Int_t &  idx_max 
)
private

◆ GetZALine()

KVIDZALine * KVIDGCsI::GetZALine ( Int_t  z,
Int_t  a,
Int_t &  index 
) const
virtual

Returns ID line corresponding to nucleus (Z,A) and its index in fIDLines. This is done by looping over all the lines in the list, not as in base class KVIDZAGrid, because of the 8Be line being in between 6He and 6Li.

Reimplemented from KVIDZAGrid.

Definition at line 216 of file KVIDGCsI.cpp.

◆ GetZLine()

KVIDZALine * KVIDGCsI::GetZLine ( Int_t  z,
Int_t &  index 
) const
virtual

Returns first ID line in sorted list for which GetZ() returns 'z'. index=index of line found in fIDLines list (-1 if not found). This is done by looping over all the lines in the list, not by dichotomy as in base class KVIDZAGrid, because of the 8Be line being in between 6He and 6Li.

Reimplemented from KVIDZAGrid.

Definition at line 188 of file KVIDGCsI.cpp.

◆ Identify()

void KVIDGCsI::Identify ( Double_t  x,
Double_t  y,
KVIdentificationResult idr 
) const
virtual

Set Z and A of nucleus based on position in R-L grid The identification of gammas (kICODE10) and charged particles is performed

Note

for isotopically identified particles, the integer A (KVNucleus::GetA) is the mass assigned to the closest line [unless the closest line is the IMF line, in which case we use the closest identifier line], whereas the floating-point A (KVReconstructedNucleus::GetRealA) is calculated by interpolation. the integer A is not necessarily = nint(floating-point A): for example, if no 5He line is drawn in the grid (which is usually the case), there will be no isotopically-identified particle with GetA()=5, although there may be particles with GetRealA() between 4.5 and 5.5

Reimplemented from KVIDZAGrid.

Definition at line 105 of file KVIDGCsI.cpp.

◆ IdentZA()

void KVIDGCsI::IdentZA ( Double_t  x,
Double_t  y,
Int_t &  Z,
Double_t &  A 
)
virtual

Finds Z, A and 'real A' for point (x,y) once closest lines to point have been found. Double_t A = mass calculated by interpolation This is a line-for-line copy of the latter part of IdnCsOr, even the same variable names and comments have been used (as much as possible).

Reimplemented from KVIDZAGrid.

Definition at line 245 of file KVIDGCsI.cpp.

◆ Initialize()

void KVIDGCsI::Initialize ( void  )
virtual

General initialisation method for CsI R-L identification grid. This method MUST be called once before using the grid for identifications. The ID lines are sorted. The natural line widths of all ID lines are calculated. The line with the largest Z (Zmax line) is found. IMF & Gamma line pointers are initialised if grid has already been used for identification, IMF_line will be in identifiers list.

Reimplemented from KVIDZAGrid.

Definition at line 630 of file KVIDGCsI.cpp.

◆ IsIdentifiable()

Bool_t KVIDGCsI::IsIdentifiable ( Double_t  x,
Double_t  y,
TString *  reject = nullptr 
) const
virtual

Performs rejection of gammas - returns kTRUE if point above gamma line (note - position w.r.t. IMF line is not considered) Returns kFALSE for points below gamma line i.e. for gammas ;-) If no gamma line defined, returns kTRUE for all points

Reimplemented from KVIDGraph.

Definition at line 56 of file KVIDGCsI.cpp.

Member Data Documentation

◆ GammaLine

KVIDLine* KVIDGCsI::GammaLine
private

Definition at line 45 of file KVIDGCsI.h.

◆ IMFLine

KVIDLine* KVIDGCsI::IMFLine
private

Definition at line 44 of file KVIDGCsI.h.