ROOT logo
AliRoot » PWG » FLOW » BASE » AliFlowVector

class AliFlowVector: public TVector2

 AliFlowVector:                                                    *
 Class to hold the flow vector and multiplicity for flow analysis. *
 Author: A. Bilandzic (anteb@nikhef.nl)                            *
 extended: M.Krzewicki (mikolaj.krzewicki@cern.ch)                 *

Function Members (Methods)

public:
AliFlowVector()
AliFlowVector(const AliFlowVector& aVector)
AliFlowVector(const TVector2& p, Double_t m, Int_t h = 2, Int_t poiType = 0, Int_t s = 1)
AliFlowVector(Double_t* y, Double_t m = 1, Int_t h = 2, Int_t poiType = 0, Int_t s = -1)
AliFlowVector(Double_t x, Double_t y, Double_t m = 1, Int_t h = 2, Int_t poiType = 0, Int_t s = -1)
virtual~AliFlowVector()
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 voidClear(Option_t* option = "")
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
Double_tTVector2::DeltaPhi(const TVector2& v) const
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
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
Int_tGetHarmonic() const
virtual const char*TObject::GetIconName() const
Double_tGetMult() 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_tGetPOItype() const
Int_tGetSubeventNumber() 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_tIsFolder() 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
Double_tTVector2::Mod() const
Double_tTVector2::Mod2() const
TVector2TVector2::Norm(const TVector2& v) 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)
const AliFlowVectoroperator*(Double_t w) const
AliFlowVector&operator*=(Double_t w)
const AliFlowVectoroperator+(const AliFlowVector& a) const
AliFlowVector&operator+=(const AliFlowVector& aVector)
const AliFlowVectoroperator-(const AliFlowVector& a) const
AliFlowVector&operator-=(const AliFlowVector& aVector)
const AliFlowVectoroperator/(Double_t w) const
AliFlowVector&operator/=(Double_t w)
AliFlowVector&operator=(const AliFlowVector& aVector)
TVector2TVector2::Ort() const
virtual voidTObject::Paint(Option_t* option = "")
Double_tTVector2::Phi() const
static Double_tTVector2::Phi_0_2pi(Double_t x)
static Double_tTVector2::Phi_mpi_pi(Double_t x)
virtual voidTObject::Pop()
virtual voidTVector2::Print(Option_t* option = "") const
TVector2TVector2::Proj(const TVector2& v) const
Double_tTVector2::Px() const
Double_tTVector2::Py() const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
TVector2TVector2::Rotate(Double_t phi) const
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(basic_ostream<char,char_traits<char> >& out, Option_t* option = "")
voidTVector2::Set(const TVector2& v)
voidTVector2::Set(Double_t x0, Double_t y0)
voidTVector2::Set(float x0, float y0)
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)
voidSetHarmonic(Int_t h)
voidSetMagPhi(Double_t size, Double_t angle, Double_t mult = 1)
voidSetMult(Double_t mult)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetPOItype(Int_t t)
voidSetSubeventNumber(Int_t n)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
Int_tSubtractTrackWithDaughters(const AliFlowTrackSimple* track, Double_t extraWeight = 1.)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
TVector2TVector2::Unit() 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
Double_tTVector2::X() const
Double_tTVector2::Y() const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()

Data Members

protected:
Double_tTVector2::fXcomponents of the vector
Double_tTVector2::fY
private:
Int_tfHarmonicharmonic for which the vector is constructed
Double_tfMultmultiplicity = sum of weights = w_1 + w_2 + ... + w_n
Int_tfPOItypewhich tracks are used to construct? RP=0, POIn=n,...
Int_tfSubeventNumberfor which subevent is this vector constructed? (-1 for no subevent in particular)

Class Charts

Inheritance Chart:
TVector2
AliFlowVector

Function documentation

AliFlowVector()
 default constructor
AliFlowVector(const AliFlowVector& aVector)
 copy constructor
AliFlowVector(Double_t* y, Double_t m = 1, Int_t h = 2, Int_t poiType = 0, Int_t s = -1)
 Analogue of TVector2 constructor. Sets (x,y) and multiplicity 1.
AliFlowVector(const TVector2& p, Double_t m, Int_t h = 2, Int_t poiType = 0, Int_t s = 1)
 custom constructor, Sets vector and multiplicity
AliFlowVector(Double_t x, Double_t y, Double_t m = 1, Int_t h = 2, Int_t poiType = 0, Int_t s = -1)
 custom constructor analogue of TVector2 constructor
~AliFlowVector()
 default destructor
void SetMagPhi(Double_t size, Double_t angle, Double_t mult = 1)
 Analogue to SetMagPhi for a TVector2 but here including a sum of weights
AliFlowVector& operator=(const AliFlowVector& aVector)
 assignement operator
AliFlowVector& operator+=(const AliFlowVector& aVector)
 addition operator
AliFlowVector& operator-=(const AliFlowVector& aVector)
 subtraction operator
AliFlowVector& operator*=(Double_t w)
 multiply by a weight operator
void Clear(Option_t* option = "")
clear
Int_t SubtractTrackWithDaughters(const AliFlowTrackSimple* track, Double_t extraWeight = 1.)
subtract a track and all its daughters, only if tagged with flowTag and in specified
subevent (-1 for no subevent selection)
to only subtract if it was actually used in the construction of the vector)
TODO: maybe make recursive if it ever becomes needed
for complicated decay topologies
AliFlowVector& operator/=(Double_t w)
{ (*this)*=(1.0/w); return *this;}
const AliFlowVector operator+(const AliFlowVector& a) const
{ AliFlowVector v(*this); return v+=a; }
const AliFlowVector operator-(const AliFlowVector& a) const
{ AliFlowVector v(*this); return v-=a; }
const AliFlowVector operator*(Double_t w) const
{ AliFlowVector v(*this); return v*=w; }
const AliFlowVector operator/(Double_t w) const
{ AliFlowVector v(*this); return v/=w; }
Bool_t IsFolder() const
{return kTRUE;}
void SetMult(Double_t mult)
{fMult = mult;}
Double_t GetMult() const
{return fMult;}
void SetHarmonic(Int_t h)
{fHarmonic = h;}
Int_t GetHarmonic() const
{return fHarmonic;}
void SetPOItype(Int_t t)
Int_t GetPOItype() const
{return fPOItype;}
void SetSubeventNumber(Int_t n)
Int_t GetSubeventNumber() const
{return fSubeventNumber;}