ROOT logo
AliRoot » STEER » AOD » AliAODMCParticle

class AliAODMCParticle: public AliVParticle

     Realisation of AliVParticle for MC Particles
     Basically a stripped down AliMCParicle / TParticle
     with minimum information on MC tracks
     Author: Christian Klein-Bösing, CERN

Function Members (Methods)

public:
AliAODMCParticle()
AliAODMCParticle(const AliAODMCParticle& mcPart)
AliAODMCParticle(const AliMCParticle* part, Int_t label = 0, Int_t flag = 0)
virtual~AliAODMCParticle()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
virtual Short_tCharge() const
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tAliVParticle::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 Double_tE() const
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual Double_tEta() 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 Double_tGetCalcMass() const
virtual Int_tGetDaughter(Int_t i) const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual Int_tGetFirstDaughter() const
virtual UInt_tGetFlag() const
virtual Short_tGetGeneratorIndex() const
virtual const char*TObject::GetIconName() const
virtual Int_tGetLabel() const
virtual Int_tGetLastDaughter() const
UInt_tGetMCProcessCode()
virtual Int_tGetMother() const
virtual const char*TObject::GetName() const
virtual Int_tGetNDaughters() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual Int_tGetPdgCode() const
virtual UInt_tGetStatus() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
Bool_tAliVParticle::Global2LocalMomentum(Double_t* p, Short_t charge, Double_t& alpha) const
Bool_tAliVParticle::Global2LocalPosition(Double_t* r, Double_t alpha) 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
Bool_tIsPhysicalPrimary() const
virtual Bool_tIsPrimary() const
Bool_tIsSecondaryFromMaterial() const
Bool_tIsSecondaryFromWeakDecay() const
virtual Bool_tAliVParticle::IsSortable() const
Bool_tTObject::IsZombie() const
virtual Int_tLabel() const
Bool_tAliVParticle::Local2GlobalMomentum(Double_t* p, Double_t alpha) const
Bool_tAliVParticle::Local2GlobalPosition(Double_t* r, Double_t alpha) const
virtual voidTObject::ls(Option_t* option = "") const
virtual Double_tM() const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
voidTObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const
virtual Double_tOneOverPt() 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)
AliAODMCParticle&operator=(const AliAODMCParticle& mcPart)
virtual Double_tP() const
virtual voidTObject::Paint(Option_t* option = "")
virtual Int_tPdgCode() const
virtual Double_tPhi() const
virtual const Double_t*PID() const
virtual voidTObject::Pop()
virtual voidPrint(Option_t* opt = "") const
virtual Double_tPt() const
virtual Double_tPx() const
virtual Bool_tPxPyPz(Double_t* p) const
virtual Double_tPy() const
virtual Double_tPz() 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 voidSetDaughter(Int_t i, Int_t id)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
virtual voidSetFlag(UInt_t flag)
virtual voidSetGeneratorIndex(Short_t i)
voidSetMCProcessCode(UInt_t mcProcess)
virtual voidSetMother(Int_t im)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetPhysicalPrimary(Bool_t b = kTRUE)
voidSetPrimary(Bool_t b = kTRUE)
voidSetSecondaryFromMaterial(Bool_t b = kTRUE)
voidSetSecondaryFromWeakDecay(Bool_t b = kTRUE)
voidSetStatus(Int_t status)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
static const char*StdBranchName()
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
virtual Double_tT() const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual Double_tTheta() 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
virtual Double_tXv() const
virtual Bool_tXvYvZv(Double_t* x) const
virtual Double_tY() const
virtual Double_tYv() const
virtual Double_tZv() const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()

Data Members

public:
enum { kPrimary
kPhysicalPrim
kSecondaryFromWeakDecay
kSecondaryFromMaterial
};
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
private:
Int_tfDaughter[2]Indices of the daughter particles
Double32_tfEEnergy
UInt_tfFlagFlag for indication of primary etc, Status code in the upper 16 bits 17-32, MC process id (AKA UniqueID) in bins 16-9)
Short_tfGeneratorIndex! Index of generator in cocktail
Int_tfLabelLabel of the original MCParticle
Int_tfMotherIndex of the mother particles
Int_tfPdgCodePDG code of the particle
Double32_tfPxx component of momentum
Double32_tfPyy component of momentum
Double32_tfPzz component of momentum
Double32_tfVt[0.,0.,12] t of production vertex
Double32_tfVx[0.,0.,12] x of production vertex
Double32_tfVy[0.,0.,12] y of production vertex
Double32_tfVz[0.,0.,12] z of production vertex
static TStringfgkStdBranchNameStandard branch name

Class Charts

Inheritance Chart:
TObject
AliVParticle
AliAODMCParticle

Function documentation

AliAODMCParticle()
 Default Constructor
AliAODMCParticle(const AliMCParticle* part, Int_t label = 0, Int_t flag = 0)
 Constructor
AliAODMCParticle(const AliAODMCParticle& mcPart)
 Copy constructor
AliAODMCParticle& operator=(const AliAODMCParticle& mcPart)
 assignment operator

Double_t M() const
 return the mass

Short_t Charge() const
 return tha charge

void Print(Option_t* opt = "") const
 Print particle information
Double_t Px() const
{return fPx;}
Double_t Py() const
{return fPy;}
Double_t Pz() const
{return fPz;}
Double_t Pt() const
{return TMath::Sqrt(fPx*fPx+fPy*fPy);}
Double_t P() const
{return TMath::Sqrt(fPx*fPx+fPy*fPy+fPz*fPz); }
Double_t OneOverPt() const
{return 1. / Pt();}
Bool_t PxPyPz(Double_t* p) const
{ p[0] = fPx; p[1] = fPy; p[2] = fPz; return kTRUE; }
Double_t Phi() const
{return TMath::Pi()+TMath::ATan2(-fPy,-fPx); }
Double_t Theta() const
{return (fPz==0)?TMath::PiOver2():TMath::ACos(fPz/P()); }
Double_t Xv() const
{return fVx;}
Double_t Yv() const
{return fVy;}
Double_t Zv() const
{return fVz;}
Bool_t XvYvZv(Double_t* x) const
{ x[0] = fVx; x[1] = fVy; x[2] = fVz; return kTRUE; }
Double_t T() const
{return fVt;}
Double_t E() const
{return fE;}
Double_t Eta() const
Double_t Y() const
Int_t Label() const
{return fLabel;}
Double_t GetCalcMass() const
virtual ~AliAODMCParticle()
{}
Int_t GetLabel() const
{return Label();}
const Double_t * PID() const
 PID
{return 0;}
void SetDaughter(Int_t i, Int_t id)
{if(i<2)fDaughter[i] = id;}
Int_t GetDaughter(Int_t i) const
{if(i<2)return fDaughter[i];else return -1;}
Int_t GetNDaughters() const
{ return fDaughter[1]>0 ? fDaughter[1]-fDaughter[0]+1 : (fDaughter[0]>0 ? 1:0 ) ;}
void SetMother(Int_t im)
{fMother = im;}
Int_t GetMother() const
{return fMother;}
Int_t GetFirstDaughter() const
{return fDaughter[0];}
Int_t GetLastDaughter() const
{return fDaughter[1];}
Int_t GetPdgCode() const
{ return fPdgCode;}
Int_t PdgCode() const
{ return GetPdgCode();}
void SetGeneratorIndex(Short_t i)
Short_t GetGeneratorIndex() const
{return fGeneratorIndex;}
void SetFlag(UInt_t flag)
{fFlag = flag;}
UInt_t GetFlag() const
{return fFlag;}
void SetStatus(Int_t status)
 for the status we use the upper 16 bits/2 bytes of the flag word
UInt_t GetStatus() const
 bit shift by 16
void SetPrimary(Bool_t b = kTRUE)
 Bitwise operations
Bool_t IsPrimary() const
{return ((fFlag&kPrimary)==kPrimary);}
void SetPhysicalPrimary(Bool_t b = kTRUE)
Bool_t IsPhysicalPrimary() const
void SetSecondaryFromWeakDecay(Bool_t b = kTRUE)
Bool_t IsSecondaryFromWeakDecay() const
void SetSecondaryFromMaterial(Bool_t b = kTRUE)
Bool_t IsSecondaryFromMaterial() const
void SetMCProcessCode(UInt_t mcProcess)
UInt_t GetMCProcessCode()
const char* StdBranchName()
{return fgkStdBranchName.Data();}