ROOT logo
AliRoot » CORRFW » AliCFParticleGenCuts

class AliCFParticleGenCuts: public AliCFCutBase

          ----   CORRECTION FRAMEWORK   ----
 class AliCFParticleGenCuts implementation
 Using this class a user may define selections relative to
 MC particle (AliMCParticle) using generation-level information.

 author : R. Vernet (renaud.vernet@cern.ch)

Function Members (Methods)

public:
AliCFParticleGenCuts()
AliCFParticleGenCuts(const AliCFParticleGenCuts& c)
AliCFParticleGenCuts(const Char_t* name, const Char_t* title)
virtual~AliCFParticleGenCuts()
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 voidTNamed::Clear(Option_t* option = "")
virtual TObject*TNamed::Clone(const char* newname = "") const
virtual Int_tTNamed::Compare(const TObject* obj) const
virtual voidTNamed::Copy(TObject& named) 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 voidTNamed::FillBuffer(char*& buffer)
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 UInt_tAliAnalysisCuts::GetFilterMask() const
virtual const char*TObject::GetIconName() const
virtual const char*TNamed::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual TList*AliAnalysisCuts::GetOutput()
virtual UInt_tAliVCuts::GetSelectionMask(const TObject*)
virtual TObject*AliAnalysisCuts::GetStatistics(Option_t*) const
virtual const char*TNamed::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTNamed::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 voidAliAnalysisCuts::Init()
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
static Bool_tIsA(AliMCParticle* mcPart, Int_t pdg, Bool_t abs = kFALSE)
static Bool_tIsA(AliAODMCParticle* mcPart, Int_t pdg, Bool_t abs = kFALSE)
static Bool_tIsCharged(AliVParticle* mcPart)
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
Bool_tIsPrimary(AliMCParticle* mcPart)
Bool_tIsPrimary(AliAODMCParticle* mcPart)
Bool_tIsPrimaryCharged(AliVParticle* mcPart)
virtual Bool_tAliCFCutBase::IsQAOn() const
virtual Bool_tIsSelected(TObject* obj)
virtual Bool_tIsSelected(TList*)
virtual Bool_tTNamed::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTNamed::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Long64_tAliAnalysisCuts::Merge(TCollection*)
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)
AliCFParticleGenCuts&operator=(const AliCFParticleGenCuts& c)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTNamed::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 = "")
virtual UInt_tAliAnalysisCuts::Selected() const
voidSetAODMC(Bool_t flag)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
voidSetDecayChannel(TDecayChannel* dc)
voidSetDecayLengthRange(Double32_t rmin, Double32_t rmax)
voidSetDecayRxyRange(Double32_t rmin, Double32_t rmax)
voidSetDecayVtxRangeX(Double32_t xmin, Double32_t xmax)
voidSetDecayVtxRangeY(Double32_t ymin, Double32_t ymax)
voidSetDecayVtxRangeZ(Double32_t zmin, Double32_t zmax)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
virtual voidAliAnalysisCuts::SetFilterMask(UInt_t mask)
virtual voidSetMCEventInfo(const TObject* mcEvent)
virtual voidTNamed::SetName(const char* name)MENU
virtual voidTNamed::SetNameTitle(const char* name, const char* title)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetProdVtxRange2D(Bool_t b = kFALSE)
voidSetProdVtxRangeX(Double32_t xmin, Double32_t xmax)
voidSetProdVtxRangeY(Double32_t ymin, Double32_t ymax)
voidSetProdVtxRangeZ(Double32_t zmin, Double32_t zmax)
virtual voidAliCFCutBase::SetQAOn(TList* list)
virtual voidAliCFCutBase::SetRecEventInfo(const TObject*)
voidSetRequireIsCharged()
voidSetRequireIsNeutral()
voidSetRequireIsPrimary()
voidSetRequireIsSecondary()
voidSetRequirePdgCode(Int_t pdg, Bool_t useAbsolute = kFALSE)
virtual voidAliAnalysisCuts::SetSelected(Bool_t dec)
virtual voidTNamed::SetTitle(const char* title = "")MENU
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual Int_tTNamed::Sizeof() const
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:
virtual voidAddQAHistograms(TList* qaList)
voidDefineHistograms()
voidFillHistograms(TObject* obj, Bool_t afterCuts)
voidSelectionBitMap(AliMCParticle* obj)
voidSelectionBitMap(AliAODMCParticle* obj)

Data Members

public:
enum { kCutCharge
kCutPrimSec
kCutPDGCode
kCutProdVtxXMin
kCutProdVtxXMax
kCutProdVtxYMin
kCutProdVtxYMax
kCutProdVtxZMin
kCutProdVtxZMax
kCutDecVtxXMin
kCutDecVtxXMax
kCutDecVtxYMin
kCutDecVtxYMax
kCutDecVtxZMin
kCutDecVtxZMax
kCutDecLgthMin
kCutDecLgthMax
kCutDecRxyMin
kCutDecRxyMax
kCutDecayChannel
kNCuts
kNStepQA
};
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
protected:
Bool_tAliCFCutBase::fIsQAOnqa checking on/off
TStringTNamed::fNameobject identifier
TStringTNamed::fTitleobject title
private:
TBits*fBitmapstores single selection decisions
TArrayF*fCutValuesarray of cut values
TDecayChannel*fDecayChanneldecay channel : if fRequireAbsolutePdg, the antiparticle channel will be checked as well
Double32_tfDecayLengthMaxmax decay length (absolute)
Double32_tfDecayLengthMinmin decay length (absolute)
Double32_tfDecayRxyMaxmax decay length in transverse plane wrt (0,0,0)
Double32_tfDecayRxyMinmin decay length in transverse plane wrt (0,0,0)
Double32_tfDecayVtxXMaxmax X of particle decay vertex
Double32_tfDecayVtxXMinmin X of particle decay vertex
Double32_tfDecayVtxYMaxmax Y of particle decay vertex
Double32_tfDecayVtxYMinmin Y of particle decay vertex
Double32_tfDecayVtxZMaxmax Z of particle decay vertex
Double32_tfDecayVtxZMinmin Z of particle decay vertex
Bool_tfIsAODMCflag for standard MC or MC from AOD tree
AliVEvent*fMCInfopointer to the MC event information
Int_tfPdgCodeparticle PDG code
Bool_tfProdVtxRange2Dcut an ellipse in xy plane
Double32_tfProdVtxXMaxmax X of particle production vertex
Double32_tfProdVtxXMinmin X of particle production vertex
Double32_tfProdVtxYMaxmax Y of particle production vertex
Double32_tfProdVtxYMinmin Y of particle production vertex
Double32_tfProdVtxZMaxmax Z of particle production vertex
Double32_tfProdVtxZMinmin Z of particle production vertex
Bool_tfRequireAbsolutePdguse the PDG code absolute value, used also for the decay channel
Bool_tfRequireIsChargedrequire charged particle
Bool_tfRequireIsNeutralrequire neutral particle
Bool_tfRequireIsPrimaryrequire primary particle
Bool_tfRequireIsSecondaryrequire secondary particle
Bool_tfRequirePdgCoderequire check of the PDG code
TH2F*fhCutCorrelationHistogram: 2d statistics plot
TH1F*fhCutStatisticsHistogram: statistics of what cuts the tracks did not survive
TH2F*fhProdVtxXY[2]Histogram: production vertex in tranzverse plane
TH1F*fhQA[20][2]QA Histograms

Class Charts

Inheritance Chart:
TNamed
AliVCuts
AliAnalysisCuts
AliCFCutBase
AliCFParticleGenCuts

Function documentation

AliCFParticleGenCuts()
ctor

AliCFParticleGenCuts(const Char_t* name, const Char_t* title)
ctor

AliCFParticleGenCuts(const AliCFParticleGenCuts& c)
copy ctor

AliCFParticleGenCuts& operator=(const AliCFParticleGenCuts& c)
 Assignment operator

Bool_t IsSelected(TObject* obj)
 check if selections on 'obj' are passed
 'obj' must be an AliMCParticle

void SelectionBitMap(AliMCParticle* obj)
 test if the track passes the single cuts
 and store the information in a bitmap

void SelectionBitMap(AliAODMCParticle* obj)
 test if the track passes the single cuts
 and store the information in a bitmap

void FillHistograms(TObject* obj, Bool_t afterCuts)
 fill the QA histograms

void AddQAHistograms(TList* qaList)
 saves the histograms in a TList

void DefineHistograms()
 histograms for cut variables, cut statistics and cut correlations

Bool_t IsCharged(AliVParticle* mcPart)
check if particle is charged.

Bool_t IsPrimary(AliMCParticle* mcPart)
check if particle is primary (standard definition)

Bool_t IsPrimary(AliAODMCParticle* mcPart)
check if particle is primary (standard definition)

Bool_t IsPrimaryCharged(AliVParticle* mcPart)
check if a charged particle is primary (standard definition)

Bool_t IsA(AliMCParticle* mcPart, Int_t pdg, Bool_t abs = kFALSE)
Check on the pdg code of the MC particle. if abs=kTRUE then check on the
absolute value.

Bool_t IsA(AliAODMCParticle* mcPart, Int_t pdg, Bool_t abs = kFALSE)
Check on the pdg code of the MC particle. if abs=kTRUE then check on the
absolute value.

void SetMCEventInfo(const TObject* mcEvent)
 Sets pointer to MC event information (AliMCEvent)

virtual ~AliCFParticleGenCuts()
{ }
Bool_t IsSelected(TObject* obj)
void SetAODMC(Bool_t flag)
{fIsAODMC=flag;}
Bool_t IsA(AliMCParticle* mcPart, Int_t pdg, Bool_t abs = kFALSE)
void SetRequireIsCharged()
void SetRequireIsNeutral()
void SetRequireIsPrimary()
void SetRequireIsSecondary()
void SetRequirePdgCode(Int_t pdg, Bool_t useAbsolute = kFALSE)
void SetProdVtxRangeX(Double32_t xmin, Double32_t xmax)
{fProdVtxXMin =xmin; fProdVtxXMax =xmax;}
void SetProdVtxRangeY(Double32_t ymin, Double32_t ymax)
{fProdVtxYMin =ymin; fProdVtxYMax =ymax;}
void SetProdVtxRangeZ(Double32_t zmin, Double32_t zmax)
{fProdVtxZMin =zmin; fProdVtxZMax =zmax;}
void SetProdVtxRange2D(Bool_t b = kFALSE)
void SetDecayVtxRangeX(Double32_t xmin, Double32_t xmax)
void SetDecayVtxRangeY(Double32_t ymin, Double32_t ymax)
void SetDecayVtxRangeZ(Double32_t zmin, Double32_t zmax)
void SetDecayLengthRange(Double32_t rmin, Double32_t rmax)
void SetDecayRxyRange(Double32_t rmin, Double32_t rmax)
{fDecayRxyMin =rmin; fDecayRxyMax =rmax;}
void SetDecayChannel(TDecayChannel* dc)
{fDecayChannel = dc ;}