KaliVeda
Toolkit for HIC analysis
KVTGID Class Referenceabstract

Detailed Description

Abstract base class for particle identfication using functionals developed by L. Tassan-Got (IPN Orsay)

These functionals are defined in the KVTGIDFunctions namespace, and the functional used by each KVTGID object is defined by giving its name to the constructor. These objects are persistent, i.e. can be retrieved from a ROOT file and used for identification.

GetIdentification() method performs an identification. Status code can be retrieved afterwards using GetStatus();

A KVIDGrid identification grid can be generated from the functional in order to visualise the corresponding identification lines. (MakeIDGrid)

The following methods must be defined by child-classes:

SetIdent() -- determine how to set the identification for each line in the grid
AddLine() -- define the type of IDLine added to the grid
NewGrid() -- define the type of IDGrid to generate
virtual KVIDLine * AddLine(KVIDGrid *)=0
virtual void SetIdent(KVIDLine *, Double_t ID)=0

Definition at line 44 of file KVTGID.h.

#include <KVTGID.h>

Inheritance diagram for KVTGID:

Public Types

enum  { kStatus_OK , kStatus_NotBetween_IDMin_IDMax }
 status codes for GetIdentification More...
 

Public Member Functions

 KVTGID ()
 Default ctor. More...
 
 KVTGID (const Char_t *name, const Char_t *function, Double_t xmin, Double_t xmax, Int_t npar, Int_t par_x, Int_t par_y)
 
 KVTGID (const KVTGID &)
 copy constructor More...
 
virtual ~ KVTGID ()
 
void AddIDTelescope (KVBase *tel)
 
virtual void AddLineToGrid (KVIDGrid *g, Int_t ID, Int_t npoints, Double_t xmin, Double_t xmax, Bool_t log_scale=kFALSE)
 
void ClearIDTelescopes ()
 
Int_t Compare (const TObject *obj) const
 
virtual void Copy (TObject &tgid) const
 Copy this KVTGID function into the KVTGID object referenced by tgid. More...
 
Double_t GetAlpha () const
 
Double_t GetBeta () const
 
Double_t GetDistanceToLine (Double_t x, Double_t y, Int_t id, Double_t *params=0)
 
Double_t GetEta () const
 
Int_t GetFunctionalType () const
 
const Char_t * GetFunctionName () const
 
Double_t GetG () const
 
virtual Double_t GetIdentification (Double_t ID_min, Double_t ID_max, Double_t &ID_quality, Double_t *par=0)
 
Double_t GetIDmax () const
 
Double_t GetIDmin () const
 
const KVStringGetIDTelescopes () const
 
Double_t GetLambda () const
 
Int_t GetLightEnergyDependence () const
 
Int_t GetMassFormula () const
 
Double_t GetMu () const
 
Double_t GetNu () const
 
Double_t GetPdx () const
 
Double_t GetPdy () const
 
virtual Int_t GetStatus () const
 
virtual const Char_t * GetStatusString () const
 Returns explanatory message for value of GetStatus() More...
 
const KVNumberListGetValidRuns () const
 
const Char_t * GetVarX () const
 
const Char_t * GetVarY () const
 
Double_t GetXi () const
 
Int_t GetZorA () const
 
Bool_t IsValidForRun (Int_t run) const
 
Bool_t IsValidForTelescope (KVBase *tel) const
 
virtual void Print (Option_t *option="") const
 Print info on functional and grid. More...
 
void SetAlpha (Double_t val)
 
void SetBeta (Double_t val)
 
void SetEta (Double_t val)
 
void SetG (Double_t val)
 
void SetIDmax (Double_t x)
 
void SetIDmin (Double_t x)
 
void SetIDTelescopes (const TCollection *)
 
void SetLambda (Double_t val)
 
void SetLTGParameterNames ()
 
void SetLTGParameters (Double_t *par)
 
void SetLTGParameters (Float_t *par)
 
void SetMassformula (Int_t val)
 
void SetMu (Double_t val)
 
void SetNu (Double_t val)
 
void SetPdx (Double_t val)
 
void SetPdy (Double_t val)
 
void SetValidRuns (const KVNumberList &r)
 
void SetVarX (const Char_t *x)
 
void SetVarY (const Char_t *x)
 
void SetXi (Double_t val)
 
void WriteToAsciiFile (std::ofstream &) const
 Write parameters of LTG fit in file. More...
 

Static Public Member Functions

static Int_t GetNumberOfLTGParameters (Int_t type, Int_t light)
 
static KVTGIDMakeTGID (const Char_t *name, Int_t type, Int_t light, Int_t ZorA, Int_t mass)
 
static KVTGIDReadFromAsciiFile (const Char_t *name, std::ifstream &)
 

Private Member Functions

virtual KVIDLineAddLine (KVIDGrid *)=0
 
void init ()
 
virtual void SetIdent (KVIDLine *, Double_t ID)=0
 
void SetStringTelescopes (const Char_t *s)
 

Private Attributes

Int_t fAlpha
 
Int_t fBeta
 
Int_t fEta
 
Int_t fG
 
Double_t fID_max
 maximum ID fitted with functional More...
 
Double_t fID_min
 minimum ID fitted with functional More...
 
Int_t fLambda
 indices of parameters More...
 
Int_t fLight
 with (1) or without (0) CsI light-energy dependence More...
 
Int_t fMassFormula
 mass formula used to calculate A from Z (if Z identification used) More...
 
Int_t fMu
 
Int_t fNu
 
Int_t fPdx
 
Int_t fPdy
 
KVNumberList fRuns
 list of runs for which fit is valid More...
 
Int_t fStatus
 transient member, holds status code of last call to GetIdentification More...
 
KVString fTelescopes
 list of telescopes for which fit is valid More...
 
TString fTGIDFunctionName
 name of KVTGIDFunctions:: namespace function used for identification More...
 
Int_t fType
 type of functional (=0 standard, =1 extended) More...
 
TString fVarX
 quantity used for X coordinates More...
 
TString fVarY
 quantity used for Y coordinates More...
 
Int_t fXi
 
Int_t fZorA
 used for Z (1) or A (0) identification More...
 

Member Enumeration Documentation

◆ anonymous enum

anonymous enum

status codes for GetIdentification

Enumerator
kStatus_OK 
kStatus_NotBetween_IDMin_IDMax 

Definition at line 99 of file KVTGID.h.

Constructor & Destructor Documentation

◆ KVTGID() [1/3]

KVTGID::KVTGID ( )

Default ctor.

Definition at line 61 of file KVTGID.cpp.

◆ KVTGID() [2/3]

KVTGID::KVTGID ( const KVTGID obj)

copy constructor

Definition at line 127 of file KVTGID.cpp.

◆ KVTGID() [3/3]

KVTGID::KVTGID ( const Char_t *  name,
const Char_t *  function,
Double_t  xmin,
Double_t  xmax,
Int_t  npar,
Int_t  par_x,
Int_t  par_y 
)

Create TF1 named "name" using "function", range xmin->xmax and number of parameters npar.

The given function name must correspond to one of the functions defined in the KVTGIDFunctions namespace (without the "KVTGIDFunctions::" scope, i.e. function="tassangot_Z" is a valid argument for this constructor). The resulting object can be written to and read back from a ROOT file and the function pointer will be reinitialised automatically when the object is read back from the file.

par_x and par_y are the indices of the parameters of the functional which correspond to the 'X' and 'Y' coordinates of the identification map, respectively.

NOTE: the function pointer passed to the TF1 constructor is just a dummy to make sure that the right constructor is called, and that the TF1 is set up correctly. The actual function used is set using the name given as argument 'function'.

Definition at line 88 of file KVTGID.cpp.

◆ ~ KVTGID()

virtual KVTGID::~ KVTGID ( )
inlinevirtual

Definition at line 114 of file KVTGID.h.

Member Function Documentation

◆ AddIDTelescope()

void KVTGID::AddIDTelescope ( KVBase tel)
inline

Adds tel to list of ID telescopes for which this fit is valid

Definition at line 284 of file KVTGID.h.

◆ AddLine()

virtual KVIDLine* KVTGID::AddLine ( KVIDGrid )
privatepure virtual

Implemented in KVTGIDZA, and KVTGIDZ.

◆ AddLineToGrid()

void KVTGID::AddLineToGrid ( KVIDGrid g,
Int_t  ID,
Int_t  npoints,
Double_t  xmin,
Double_t  xmax,
Bool_t  log_scale = kFALSE 
)
virtual

Add a line to the grid 'g' for identification label 'ID' with 'npoints' points calculated between X-coordinates xmin and xmax. Points are omitted if the resulting value of the functional is not a number (TMath::IsNan = kTRUE).

If log_scale=kTRUE (default is kFALSE), more points are used at the beginning of the line than at the end, with a logarithmic dependence. add new line to grid

Reimplemented in KVTGIDZA.

Definition at line 241 of file KVTGID.cpp.

◆ ClearIDTelescopes()

void KVTGID::ClearIDTelescopes ( )
inline

Definition at line 280 of file KVTGID.h.

◆ Compare()

Int_t KVTGID::Compare ( const TObject *  obj) const

Used to sort list of KVTGID in KVTGIDManager ID obj with smallest IDmax will be first in sorted list

Definition at line 318 of file KVTGID.cpp.

◆ Copy()

void KVTGID::Copy ( TObject &  tgid) const
virtual

Copy this KVTGID function into the KVTGID object referenced by tgid.

Definition at line 139 of file KVTGID.cpp.

◆ GetAlpha()

Double_t KVTGID::GetAlpha ( ) const
inline

Definition at line 200 of file KVTGID.h.

◆ GetBeta()

Double_t KVTGID::GetBeta ( ) const
inline

Definition at line 208 of file KVTGID.h.

◆ GetDistanceToLine()

Double_t KVTGID::GetDistanceToLine ( Double_t  x,
Double_t  y,
Int_t  id,
Double_t *  params = 0 
)

Given a point (x,y) (which could, for example, be a point in a KVIDGrid line which we want to fit) we give the (vertical) distance to the functional identification line 'id'. If the point is below the line the distance is positive, if the point is above the line it is negative. If the parameter array 'params' is not given, we use the current values of the parameters.

Definition at line 364 of file KVTGID.cpp.

◆ GetEta()

Double_t KVTGID::GetEta ( ) const
inline

Definition at line 232 of file KVTGID.h.

◆ GetFunctionalType()

Int_t KVTGID::GetFunctionalType ( ) const
inline

Definition at line 85 of file KVTGID.h.

◆ GetFunctionName()

const Char_t* KVTGID::GetFunctionName ( ) const
inline

Definition at line 104 of file KVTGID.h.

◆ GetG()

Double_t KVTGID::GetG ( ) const
inline

Definition at line 176 of file KVTGID.h.

◆ GetIdentification()

Double_t KVTGID::GetIdentification ( Double_t  ID_min,
Double_t  ID_max,
Double_t &  ID_quality,
Double_t *  par = 0 
)
virtual

Use the functional with the current parameter values in order to perform an identification. The value returned is the estimated identification value. If the identification is not possible, -1 is returned (ID_quality=-1 also).

For status code use GetStatus().

ID_min and ID_max are the lower & upper limits for the identification. The functional must change sign between these two limits in order for the identification to be possible. ID_quality is the (absolute) value of the functional corresponding to the estimated identification: it is the distance from the identified point to the nearest identification line. Ideally it should be zero or as small as possible.

Optional argument "par" allows to replace the current parameters.

Definition at line 188 of file KVTGID.cpp.

◆ GetIDmax()

Double_t KVTGID::GetIDmax ( ) const
inline

Definition at line 121 of file KVTGID.h.

◆ GetIDmin()

Double_t KVTGID::GetIDmin ( ) const
inline

Definition at line 129 of file KVTGID.h.

◆ GetIDTelescopes()

const KVString& KVTGID::GetIDTelescopes ( ) const
inline

Definition at line 296 of file KVTGID.h.

◆ GetLambda()

Double_t KVTGID::GetLambda ( ) const
inline

Definition at line 160 of file KVTGID.h.

◆ GetLightEnergyDependence()

Int_t KVTGID::GetLightEnergyDependence ( ) const
inline

Definition at line 93 of file KVTGID.h.

◆ GetMassFormula()

Int_t KVTGID::GetMassFormula ( ) const
inline

Definition at line 240 of file KVTGID.h.

◆ GetMu()

Double_t KVTGID::GetMu ( ) const
inline

Definition at line 168 of file KVTGID.h.

◆ GetNu()

Double_t KVTGID::GetNu ( ) const
inline

Definition at line 216 of file KVTGID.h.

◆ GetNumberOfLTGParameters()

Int_t KVTGID::GetNumberOfLTGParameters ( Int_t  type,
Int_t  light 
)
static

Static function returning number of parameters used by Tassan-Got functional. Depends on type of functional (type) and whether non-linear light response is calculated or not (light). According to the (type, light) combination the numbers and orders of parameters are : type=0 light=0 5 parameters: lambda, mu, g, pdx, pdy type=0 light<>0 6 parameters: lambda, mu, g, pdx, pdy, eta type<>0 light=0 9 parameters: lambda, alpha, beta, mu, nu, xi, g, pdx, pdy type<>0 light<>0 10 parameters: lambda, alpha, beta, mu, nu, xi, g, pdx, pdy, eta}

Definition at line 700 of file KVTGID.cpp.

◆ GetPdx()

Double_t KVTGID::GetPdx ( ) const
inline

Definition at line 184 of file KVTGID.h.

◆ GetPdy()

Double_t KVTGID::GetPdy ( ) const
inline

Definition at line 192 of file KVTGID.h.

◆ GetStatus()

virtual Int_t KVTGID::GetStatus ( void  ) const
inlinevirtual

Definition at line 145 of file KVTGID.h.

◆ GetStatusString()

const Char_t * KVTGID::GetStatusString ( ) const
virtual

Returns explanatory message for value of GetStatus()

Definition at line 341 of file KVTGID.cpp.

◆ GetValidRuns()

const KVNumberList& KVTGID::GetValidRuns ( ) const
inline

Definition at line 253 of file KVTGID.h.

◆ GetVarX()

const Char_t* KVTGID::GetVarX ( ) const
inline

Definition at line 267 of file KVTGID.h.

◆ GetVarY()

const Char_t* KVTGID::GetVarY ( ) const
inline

Definition at line 275 of file KVTGID.h.

◆ GetXi()

Double_t KVTGID::GetXi ( ) const
inline

Definition at line 224 of file KVTGID.h.

◆ GetZorA()

Int_t KVTGID::GetZorA ( ) const
inline

Definition at line 89 of file KVTGID.h.

◆ init()

void KVTGID::init ( void  )
private

Default intitialisations We remove this object from gROOT->GetListOfFunctions() to stop the TF1 constructors from deleting previous KVTGID's with the same name

Definition at line 29 of file KVTGID.cpp.

◆ IsValidForRun()

Bool_t KVTGID::IsValidForRun ( Int_t  run) const
inline

Returns kTRUE if 'run' is contained in list of runs for which fit is valid, fRuns. If fRuns is empty, returns kTRUE for ALL runs.

Definition at line 257 of file KVTGID.h.

◆ IsValidForTelescope()

Bool_t KVTGID::IsValidForTelescope ( KVBase tel) const
inline

return kTRUE if fit is good for this telescope

Definition at line 290 of file KVTGID.h.

◆ MakeTGID()

KVTGID * KVTGID::MakeTGID ( const Char_t *  name,
Int_t  type,
Int_t  light,
Int_t  ZorA,
Int_t  mass 
)
static

Static function used to create TGID objects

type --—> type of functional

  • type : =0->basic functional <>0->extended functional
  • * For the basic formula :
  • yy = ((g*E)**(mu+1)+lambda**(mu+1)*Z**2*A**mu)**(1/(mu+1))-g*E + pdy
  • * For the extended formula :
  • yy = ((g*E)**(mu+nu+1)+(lambda*Z**alpha*A**beta)**(mu+nu+1)+
  • xi*A**mu*(g*E)**nu)**(1/(mu+mu+1))-g*E + pdy

light --—> treatment of CsI total light output

  • light : =0->no non-linear light response <>0->non-linear light response included
  • * If ih=0 no non-linear light response : E=xx-pdx
  • * If ih<>0 non-linear light response included :
  • E = sqrt(h**2+2*rho*h*(1+log(1+h/rho)))
  • rho=eta*Z**2*A and h=xx-pdx

ZorA --—> functional used to find Z or A

  • ZorA : =0->A <>0->Z

Definition at line 429 of file KVTGID.cpp.

◆ Print()

void KVTGID::Print ( Option_t *  option = "") const
virtual

Print info on functional and grid.

Definition at line 300 of file KVTGID.cpp.

◆ ReadFromAsciiFile()

KVTGID * KVTGID::ReadFromAsciiFile ( const Char_t *  name,
std::ifstream &   
)
static

Read parameters of LTG fit in file (which must have been written with current version of KVTGID::WriteToAsciiFile)

Definition at line 813 of file KVTGID.cpp.

◆ SetAlpha()

void KVTGID::SetAlpha ( Double_t  val)
inline

Definition at line 196 of file KVTGID.h.

◆ SetBeta()

void KVTGID::SetBeta ( Double_t  val)
inline

Definition at line 204 of file KVTGID.h.

◆ SetEta()

void KVTGID::SetEta ( Double_t  val)
inline

Definition at line 228 of file KVTGID.h.

◆ SetG()

void KVTGID::SetG ( Double_t  val)
inline

Definition at line 172 of file KVTGID.h.

◆ SetIdent()

virtual void KVTGID::SetIdent ( KVIDLine ,
Double_t  ID 
)
privatepure virtual

Implemented in KVTGIDZA, and KVTGIDZ.

◆ SetIDmax()

void KVTGID::SetIDmax ( Double_t  x)
inline

Definition at line 117 of file KVTGID.h.

◆ SetIDmin()

void KVTGID::SetIDmin ( Double_t  x)
inline

Definition at line 125 of file KVTGID.h.

◆ SetIDTelescopes()

void KVTGID::SetIDTelescopes ( const TCollection *  list)

set list of ID telescopes for which fit is valid. any previous list is deleted.

Definition at line 743 of file KVTGID.cpp.

◆ SetLambda()

void KVTGID::SetLambda ( Double_t  val)
inline

Definition at line 156 of file KVTGID.h.

◆ SetLTGParameterNames()

void KVTGID::SetLTGParameterNames ( )

Definition at line 723 of file KVTGID.cpp.

◆ SetLTGParameters() [1/2]

void KVTGID::SetLTGParameters ( Double_t *  par)

'par' is an array containing the LTG functional parameters, whose number and order depends on fType & fLight:

fType=0, fLight=0: Double_t par[5];

par[0] = lambda par[1] = mu par[2] = g par[3] = pdx par[4] = pdy

fType=0, fLight<>0: Double_t par[6];

par[0] = lambda par[1] = mu par[2] = g par[3] = pdx par[4] = pdy par[5] = eta

fType<>0, fLight=0: Double_t par[9];

par[0] = lambda par[1] = alpha par[2] = beta par[3] = mu par[4] = nu par[5] = xi par[6] = g par[7] = pdx par[8] = pdy

fType<>0, fLight<>0: Double_t par[10];

par[0] = lambda par[1] = alpha par[2] = beta par[3] = mu par[4] = nu par[5] = xi par[6] = g par[7] = pdx par[8] = pdy par[9] = eta

Definition at line 527 of file KVTGID.cpp.

◆ SetLTGParameters() [2/2]

void KVTGID::SetLTGParameters ( Float_t *  par)

'par' is an array containing the LTG functional parameters, whose number and order depends on fType & fLight:

fType=0, fLight=0: Double_t par[5];

par[0] = lambda par[1] = mu par[2] = g par[3] = pdx par[4] = pdy

fType=0, fLight<>0: Double_t par[6];

par[0] = lambda par[1] = mu par[2] = g par[3] = pdx par[4] = pdy par[5] = eta

fType<>0, fLight=0: Double_t par[9];

par[0] = lambda par[1] = alpha par[2] = beta par[3] = mu par[4] = nu par[5] = xi par[6] = g par[7] = pdx par[8] = pdy

fType<>0, fLight<>0: Double_t par[10];

par[0] = lambda par[1] = alpha par[2] = beta par[3] = mu par[4] = nu par[5] = xi par[6] = g par[7] = pdx par[8] = pdy par[9] = eta

Definition at line 630 of file KVTGID.cpp.

◆ SetMassformula()

void KVTGID::SetMassformula ( Int_t  val)
inline

Definition at line 236 of file KVTGID.h.

◆ SetMu()

void KVTGID::SetMu ( Double_t  val)
inline

Definition at line 164 of file KVTGID.h.

◆ SetNu()

void KVTGID::SetNu ( Double_t  val)
inline

Definition at line 212 of file KVTGID.h.

◆ SetPdx()

void KVTGID::SetPdx ( Double_t  val)
inline

Definition at line 180 of file KVTGID.h.

◆ SetPdy()

void KVTGID::SetPdy ( Double_t  val)
inline

Definition at line 188 of file KVTGID.h.

◆ SetStringTelescopes()

void KVTGID::SetStringTelescopes ( const Char_t *  s)
inlineprivate

Set directly the contents of fTelescopes

Definition at line 77 of file KVTGID.h.

◆ SetValidRuns()

void KVTGID::SetValidRuns ( const KVNumberList r)
inline

Definition at line 249 of file KVTGID.h.

◆ SetVarX()

void KVTGID::SetVarX ( const Char_t *  x)
inline

Definition at line 263 of file KVTGID.h.

◆ SetVarY()

void KVTGID::SetVarY ( const Char_t *  x)
inline

Definition at line 271 of file KVTGID.h.

◆ SetXi()

void KVTGID::SetXi ( Double_t  val)
inline

Definition at line 220 of file KVTGID.h.

◆ WriteToAsciiFile()

void KVTGID::WriteToAsciiFile ( std::ofstream &  ) const

Write parameters of LTG fit in file.

Definition at line 758 of file KVTGID.cpp.

Member Data Documentation

◆ fAlpha

Int_t KVTGID::fAlpha
private

Definition at line 59 of file KVTGID.h.

◆ fBeta

Int_t KVTGID::fBeta
private

Definition at line 60 of file KVTGID.h.

◆ fEta

Int_t KVTGID::fEta
private

Definition at line 63 of file KVTGID.h.

◆ fG

Int_t KVTGID::fG
private

Definition at line 56 of file KVTGID.h.

◆ fID_max

Double_t KVTGID::fID_max
private

maximum ID fitted with functional

Definition at line 49 of file KVTGID.h.

◆ fID_min

Double_t KVTGID::fID_min
private

minimum ID fitted with functional

Definition at line 48 of file KVTGID.h.

◆ fLambda

Int_t KVTGID::fLambda
private

indices of parameters

Definition at line 54 of file KVTGID.h.

◆ fLight

Int_t KVTGID::fLight
private

with (1) or without (0) CsI light-energy dependence

Definition at line 65 of file KVTGID.h.

◆ fMassFormula

Int_t KVTGID::fMassFormula
private

mass formula used to calculate A from Z (if Z identification used)

Definition at line 67 of file KVTGID.h.

◆ fMu

Int_t KVTGID::fMu
private

Definition at line 55 of file KVTGID.h.

◆ fNu

Int_t KVTGID::fNu
private

Definition at line 61 of file KVTGID.h.

◆ fPdx

Int_t KVTGID::fPdx
private

Definition at line 57 of file KVTGID.h.

◆ fPdy

Int_t KVTGID::fPdy
private

Definition at line 58 of file KVTGID.h.

◆ fRuns

KVNumberList KVTGID::fRuns
private

list of runs for which fit is valid

Definition at line 69 of file KVTGID.h.

◆ fStatus

Int_t KVTGID::fStatus
private

transient member, holds status code of last call to GetIdentification

Definition at line 50 of file KVTGID.h.

◆ fTelescopes

KVString KVTGID::fTelescopes
private

list of telescopes for which fit is valid

Definition at line 72 of file KVTGID.h.

◆ fTGIDFunctionName

TString KVTGID::fTGIDFunctionName
private

name of KVTGIDFunctions:: namespace function used for identification

Definition at line 52 of file KVTGID.h.

◆ fType

Int_t KVTGID::fType
private

type of functional (=0 standard, =1 extended)

Definition at line 64 of file KVTGID.h.

◆ fVarX

TString KVTGID::fVarX
private

quantity used for X coordinates

Definition at line 70 of file KVTGID.h.

◆ fVarY

TString KVTGID::fVarY
private

quantity used for Y coordinates

Definition at line 71 of file KVTGID.h.

◆ fXi

Int_t KVTGID::fXi
private

Definition at line 62 of file KVTGID.h.

◆ fZorA

Int_t KVTGID::fZorA
private

used for Z (1) or A (0) identification

Definition at line 66 of file KVTGID.h.