ROOT logo
AliRoot » PWGLF » SPECTRA » NUCLEI » B2 » AliLnID

class AliLnID: public TObject

Function Members (Methods)

public:
AliLnID()
AliLnID(const AliLnID& other)
virtual~AliLnID()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) const
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
Int_tGetBayesPID(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta) const
Double_tGetBetaExpectedSigma(Double_t p, Double_t mass) const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
Bool_tGetITSlikelihood(Double_t p, Double_t dEdx, Int_t nPoints, Double_t* r) const
Bool_tGetITSmatch(Int_t pid, Double_t p, Double_t dEdx, Int_t nPoints, Double_t nSigma = 3.) const
Int_tGetITSpid(Int_t partCode, Double_t pITS, Double_t dEdx, Double_t nPoints, Double_t nSigma = 3) const
Int_tGetITSTPCpid(Int_t partCode, Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t nSigmaITS, Double_t pTPC, Double_t dEdxTPC, Double_t nPointsTPC, Double_t nSigmaTPC) const
Int_tGetMaxLikelihoodPID(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta) const
virtual const char*TObject::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
Int_tGetPID(const TParticle* p) const
Int_tGetPID(const AliAODMCParticle* p) const
Int_tGetPID(Int_t pdgCode) const
Int_tGetPID(Int_t partCode, Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta, Double_t nSigITS = 3, Double_t nSigTPC = 3, Double_t nSigTOF = 3) const
Int_tGetPidProcedure() const
virtual const char*TObject::GetTitle() const
Bool_tGetTOFlikelihood(Double_t p, Double_t beta, Double_t* r) const
Bool_tGetTOFmatch(Int_t pid, Double_t pTOF, Double_t beta, Double_t nSigma = 3.) const
Bool_tGetTPClikelihood(Double_t p, Double_t dEdx, Int_t nPoints, Double_t* r) const
Bool_tGetTPCmatch(Int_t pid, Double_t pTPC, Double_t dEdx, Double_t nPoints, Double_t nSigma = 3.) const
Int_tGetTPCpid(Int_t partCode, Double_t pTPC, Double_t dEdx, Double_t nPoints, Double_t nSigma = 3) const
Int_tGetTPCTOFpid(Int_t partCode, Double_t pTPC, Double_t dEdx, Double_t nPoints, Double_t nSigmaTPC, Double_t pTOF, Double_t beta, Double_t nSigmaTOF) const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tIsITSTOFmismatch(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTOF, Double_t beta, Double_t nSigma = 5.) const
Bool_tIsITSTPCmismatch(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t nSigma = 5.) const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tIsTPCTOFmismatch(Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta, Double_t nSigma = 5.) const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
voidTObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
AliLnID&operator=(const AliLnID& other)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(basic_ostream<char,char_traits<char> >& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
voidSetITSBetheBlochParams(const Double_t* param, Double_t res = 0.13)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetPidProcedure(Int_t proc)
voidSetPriorProbabilities(const Double_t* prob)
voidSetPriorProbabilities(Double_t e, Double_t mu, Double_t pi, Double_t k, Double_t p, Double_t d, Double_t t, Double_t he3, Double_t alpha)
voidSetTPCBetheBlochParams(const Double_t* param, Double_t mip = 1., Double_t res = 0.06)
voidSetTPCBetheBlochParams(Double_t c0, Double_t c1, Double_t c2, Double_t c3, Double_t c4, Double_t mip = 1., Double_t res = 0.06)
voidSetTPCChargeCorrection(Double_t zexp)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()
private:
Double_tBeta(Double_t p, Double_t m) const
Int_tGetIndexOfMaxValue(const Double_t* w) const
Bool_tGetLikelihood(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta, Double_t* r) const

Data Members

public:
enum { kSPECIES
kBayes
kMaxLikelihood
kITS
kTPC
kITSTPC
kTPCTOF
};
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
private:
AliITSPIDResponse*fITSpidITS likelihood
Int_tfPidProcedurePID procedure code
Double_tfPrior[9]prior probabilities
Double_tfRangenumber of sigmas to the expected values
AliPID::EParticleTypefSpecies[9]particle species known by the pid
AliTPCPIDResponse*fTPCpidTPC likelihood
Double_tfZexpTPC BB charge dependence

Class Charts

Inheritance Chart:
TObject
AliLnID

Function documentation

AliLnID()
 Default constructor

AliLnID(const AliLnID& other)
 Copy constructor

AliLnID& operator=(const AliLnID& other)
 Assignment operator

void SetPriorProbabilities(Double_t e, Double_t mu, Double_t pi, Double_t k, Double_t p, Double_t d, Double_t t, Double_t he3, Double_t alpha)
 Set prior probabilities

void SetPriorProbabilities(const Double_t* prob)
 Set prior probabilities

void SetITSBetheBlochParams(const Double_t* param, Double_t res = 0.13)
 Set ALEPH Bethe Bloch parameters for ITS

void SetTPCBetheBlochParams(const Double_t* param, Double_t mip = 1., Double_t res = 0.06)
 Set ALEPH Bethe Bloch parameters for TPC

void SetTPCBetheBlochParams(Double_t c0, Double_t c1, Double_t c2, Double_t c3, Double_t c4, Double_t mip = 1., Double_t res = 0.06)
 Set ALEPH Bethe Bloch parameters for TPC

~AliLnID()
 Default destructor

Int_t GetPID(const TParticle* p) const
 Montecarlo PID

Int_t GetPID(const AliAODMCParticle* p) const
 Montecarlo PID

Int_t GetPID(Int_t pdgCode) const
 Montecarlo PID

Int_t GetPID(Int_t partCode, Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta, Double_t nSigITS = 3, Double_t nSigTPC = 3, Double_t nSigTOF = 3) const
 PID according to the selected procedure

Int_t GetITSpid(Int_t partCode, Double_t pITS, Double_t dEdx, Double_t nPoints, Double_t nSigma = 3) const
 Check if particle with the given pid code is within
 +/- nSigma around the expected dEdx in the ITS

Int_t GetTPCpid(Int_t partCode, Double_t pTPC, Double_t dEdx, Double_t nPoints, Double_t nSigma = 3) const
 Check if particle with the given pid code is within
 +/- nSigma around the expected dEdx in the TPC

Int_t GetTPCTOFpid(Int_t partCode, Double_t pTPC, Double_t dEdx, Double_t nPoints, Double_t nSigmaTPC, Double_t pTOF, Double_t beta, Double_t nSigmaTOF) const
 Check if particle with the given pid code is within
 +/- nSigmaTPC around the expected dEdx in the TPC
 AND +/- nSigmaTOF around the expected beta in the TOF (when available)

Int_t GetITSTPCpid(Int_t partCode, Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t nSigmaITS, Double_t pTPC, Double_t dEdxTPC, Double_t nPointsTPC, Double_t nSigmaTPC) const
 Check if particle with the given pid code is within
 +/- nSigmaITS around the expected dEdx in the ITS
 AND +/- nSigmaTPC around the expected dEdx in the TPC

Int_t GetIndexOfMaxValue(const Double_t* w) const
 Index with maximum value in the array of size kSPECIES

Bool_t GetLikelihood(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta, Double_t* r) const
 Fill r array with the combined likelihood for ITS, TPC and TOF when possible
 return 1 if success

Int_t GetMaxLikelihoodPID(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta) const
 Maximum likelihood principle

Int_t GetBayesPID(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta) const
 Bayesian inference

Bool_t GetITSlikelihood(Double_t p, Double_t dEdx, Int_t nPoints, Double_t* r) const
 Probability of dEdx in the ITS for each particle species.
 Adapted from STEER/ESD/AliESDpid.cxx
 (truncated mean method)

Bool_t GetTPClikelihood(Double_t p, Double_t dEdx, Int_t nPoints, Double_t* r) const
 Probability of dEdx for each particle species in the TPC.
 Adapted from STEER/ESD/AliESDpid.cxx

Bool_t GetTOFlikelihood(Double_t p, Double_t beta, Double_t* r) const
 Probability of beta for each particle species

Double_t Beta(Double_t p, Double_t m) const
 Expected beta for mass hypothesis m

Double_t GetBetaExpectedSigma(Double_t p, Double_t mass) const
 Expected sigma for the given mass hypothesis

Bool_t GetITSmatch(Int_t pid, Double_t p, Double_t dEdx, Int_t nPoints, Double_t nSigma = 3.) const
 Check if the signal is less than nSigma from the expected ITS dEdx

Bool_t GetTPCmatch(Int_t pid, Double_t pTPC, Double_t dEdx, Double_t nPoints, Double_t nSigma = 3.) const
 Check if the signal is less than nSigma from the expected TPC dEdx

Bool_t GetTOFmatch(Int_t pid, Double_t pTOF, Double_t beta, Double_t nSigma = 3.) const
 Check if the signal is less than nSigma from the expected velocity

Bool_t IsITSTPCmismatch(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t nSigma = 5.) const
 Check track TPC mismatch with ITS

Bool_t IsITSTOFmismatch(Double_t pITS, Double_t dEdxITS, Int_t nPointsITS, Double_t pTOF, Double_t beta, Double_t nSigma = 5.) const
 Check track TOF mismatch with ITS

Bool_t IsTPCTOFmismatch(Double_t pTPC, Double_t dEdxTPC, Int_t nPointsTPC, Double_t pTOF, Double_t beta, Double_t nSigma = 5.) const
 Check track TOF mismatch with TPC

Int_t GetPidProcedure() const
{ return fPidProcedure; }
void SetPidProcedure(Int_t proc)
{ fPidProcedure = proc; }
void SetTPCChargeCorrection(Double_t zexp)
{ fZexp = zexp; }