ROOT logo
AliRoot » MUON » AliMUONPreClusterFinderV3

class AliMUONPreClusterFinderV3: public AliMUONVClusterFinder

 \class AliMUONPreClusterFinderV3

 Implementation of AliMUONVClusterFinder

 This version uses a 2 steps approach :

 we first clusterize each cathode independently to form proto-preclusters,
 and then we try to "merge" proto-preclusters from the two cathodes
 when thoses proto-preclusters overlap, thus ending up with preclusters
 spanning the two cathodes.

 This implementation, on the contrary to PreClusterFinder or PreClusterFinderV2
 should not depend on the order of the input digits.

 \author Laurent Aphecetche

Function Members (Methods)

public:
AliMUONPreClusterFinderV3()
virtual~AliMUONPreClusterFinderV3()
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
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
virtual Bool_tNeedSegmentation() const
virtual AliMUONCluster*NextCluster()
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)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual Bool_tPrepare(Int_t detElemId, TObjArray** pads, const AliMpArea& area, const AliMpVSegmentation** seg)
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 voidAliMUONVClusterFinder::SetChargeHints(Double_t, Double_t)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
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 Bool_tUsePad(const AliMUONPad& pad)
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

private:
TClonesArray*fClusters!< the clusters we've found (owner)
Int_tfDetElemId!< which DE we're considering
TIterator*fIterator!< iterator on fClusters
TObjArray**fPads!< the pads corresponding to the digits (not owner)
TClonesArray*fPreClusters[2]!< the preclusters per cathode (owner)
const AliMpVSegmentation**fkSegmentations!< segmentations (not owner)

Class Charts

Inheritance Chart:
TObject
AliMUONVClusterFinder
AliMUONPreClusterFinderV3

Function documentation

AliMUONPreClusterFinderV3()
 ctor
~AliMUONPreClusterFinderV3()
 dtor
UsePad(const AliMUONPad& pad)
 Add a pad to the list of pads to be considered
Prepare(Int_t detElemId, TObjArray** pads, const AliMpArea& area, const AliMpVSegmentation** seg)
 Prepare for clustering, by giving access to segmentations and digit lists
DumpPreClusters() const
 Dump preclusters
AddPreCluster(AliMUONCluster& cluster, AliMUONCluster* preCluster)
 Add a pad to a cluster
AddPad(AliMUONCluster& cluster, AliMUONPad* pad)
 Add a pad to a cluster
NextCluster()
 Returns the next cluster
MakeClusters()
 Associate (proto)preclusters to form (pre)clusters
MakeCathodePreClusters(Int_t cathode)
 Build (proto)preclusters from digits on a given cathode
AliMUONPreClusterFinderV3()
Bool_t NeedSegmentation() const
{ return kTRUE; }
AliMUONPreClusterFinderV3& operator=(const AliMUONPreClusterFinderV3& rhs)
 Not implemented