ROOT logo
AliRoot » PWGCF » FEMTOSCOPY » UNICOR » AliUnicorPair

class AliUnicorPair: public TObject

 particle (track) pair
 Allows to calculate the kinematic pair variables typically used in
 two-particle correlation analyses.

Function Members (Methods)

public:
AliUnicorPair()
AliUnicorPair(const AliUnicorPair&)
virtual~AliUnicorPair()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
voidCalcLAB()
voidCalcLcmsCM()
voidCalcPairCM()
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)
doubleDPhi() const
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
doubleDTheta() const
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
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() 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
virtual const char*TObject::GetTitle() 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_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
doubleMinv() 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)
AliUnicorPair&operator=(const AliUnicorPair&)
virtual voidTObject::Paint(Option_t* option = "")
doublePhi() const
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
doublePt() const
doubleQCM() const
doubleQCMlong() const
doubleQCMout() const
doubleQCMpar() const
doubleQCMper() const
doubleQCMPhi() const
doubleQCMPhiOut() const
doubleQCMside() const
doubleQCMTheta() const
doubleQinv2() const
doubleRapidity() 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 = "")
voidSet0(double m, double p, double theta, double phi)
voidSet1(double m, double p, double theta, double phi)
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)
voidSetMXYZ0(double m, double px, double py, double pz)
voidSetMXYZ1(double m, double px, double py, double pz)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
voidSwap()
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()

Data Members

protected:
TVector3fBetaLAB pair velocity
TVector3fBetatLAB pair velocity transverse
TVector3fBetazLAB pair velocity along z
TLorentzVectorfBufdummy buffer for swapping
TLorentzVectorfCMpCM total four-momentum
TLorentzVectorfCMqCM four-momentum difference
TLorentzVectorfPLAB total four-momentum
TLorentzVectorfP0LAB four-momentum of track 0
TLorentzVectorfP1LAB four-momentum of track 1
TLorentzVectorfQLAB four-momentum difference
TVector3fUbetaLAB pair velocity direction
TVector3fUbetatLAB pair velocity transverse direction
TVector3fUbetazLAB pair velocity along z direction (hm)

Class Charts

Inheritance Chart:
TObject
AliUnicorPair

Function documentation

AliUnicorPair()
{}
virtual ~AliUnicorPair()
{}
void Set0(double m, double p, double theta, double phi)
{fP0.SetXYZM(0,0,p,m); fP0.SetTheta(theta); fP0.SetPhi(phi);}
void Set1(double m, double p, double theta, double phi)
{fP1.SetXYZM(0,0,p,m); fP1.SetTheta(theta); fP1.SetPhi(phi);}
void SetMXYZ0(double m, double px, double py, double pz)
{fP0.SetXYZM(px,py,pz,m);}
void SetMXYZ1(double m, double px, double py, double pz)
{fP1.SetXYZM(px,py,pz,m);}
void CalcLAB()
double Rapidity() const
{return fP.Rapidity();}
double Pt() const
{return fP.Pt();}
double Phi() const
{return fP.Phi();}
double DTheta() const
{return fP1.Theta()-fP0.Theta();}
double DPhi() const
{return TVector2::Phi_mpi_pi(fP1.Phi()-fP0.Phi());}
void CalcPairCM()
{fCMp.Boost(-fBeta); fCMq.Boost(-fBeta);}
void CalcLcmsCM()
{fCMp.Boost(-fBetaz); fCMq.Boost(-fBetaz);}
void Swap()
double Minv() const
{return fP.M();}
double Qinv2() const
{return -fQ.M2();}
double QCM() const
{return fCMq.Vect().Mag();}
double QCMpar() const
{return fCMq.Vect()*fUbeta;}
double QCMper() const
{return sqrt(fabs(QCM()*QCM()-QCMpar()*QCMpar()));}
double QCMout() const
{return +fCMq.Vect().X()*fUbetat.X()+fCMq.Vect().Y()*fUbetat.Y();}
double QCMside() const
{return -fCMq.Vect().X()*fUbetat.Y()+fCMq.Vect().Y()*fUbetat.X();}
double QCMlong() const
{return fCMq.Vect().Z();}
double QCMTheta() const
{return fCMq.Theta();}
double QCMPhi() const
{return fCMq.Phi();}
double QCMPhiOut() const
{return atan2(QCMside(),QCMout());}