ROOT logo
AliRoot » PWGLF » FORWARD » ANALYSIS2 » AliFMDHistCollector

class AliFMDHistCollector: public TNamed

Function Members (Methods)

public:
AliFMDHistCollector()
AliFMDHistCollector(const char* title)
AliFMDHistCollector(const AliFMDHistCollector& o)
virtual~AliFMDHistCollector()
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 Bool_tCollect(const AliForwardUtil::Histos& hists, AliForwardUtil::Histos& sums, UShort_t vtxBin, TH2D& out, Double_t cent = -1.0, Bool_t eta2phi = false, Bool_t add = true)
virtual Int_tTNamed::Compare(const TObject* obj) const
virtual voidTNamed::Copy(TObject& named) const
virtual voidCreateOutputObjects(TList* dir)
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 const char*TObject::GetIconName() const
AliFMDHistCollector::MergeMethodGetMergeMethod() 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 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 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_tTNamed::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTNamed::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) 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)
AliFMDHistCollector&operator=(const AliFMDHistCollector&)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidPrint(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)
voidSetCorrectionCut(Float_t cut = 0.5)
voidSetDebug(Int_t dbg = 1)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
voidSetFiducialMethod(AliFMDHistCollector::FiducialMethod m)
voidSetFMDRingsToSkip(UShort_t mask)
voidSetMakeBGHitMaps(Bool_t use)
voidSetMakeCentralitySums(Bool_t use)
voidSetMergeMethod(AliFMDHistCollector::MergeMethod m)
virtual voidTNamed::SetName(const char* name)MENU
virtual voidTNamed::SetNameTitle(const char* name, const char* title)
voidSetNCutBins(UInt_t n = 2)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTNamed::SetTitle(const char* title = "")MENU
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidSetupForData(const TAxis& vtxAxis, const TAxis& etaAxis)
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:
static Bool_tCheckCorrection(AliFMDHistCollector::FiducialMethod m, Double_t cut, const TH2D* bg, Int_t ie, Int_t ip)
static Bool_tCheckSkip(UShort_t d, Char_t r, UShort_t skips)
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
static voidGetDetRing(Int_t idx, UShort_t& d, Char_t& r)
static Int_tGetIdx(UShort_t d, Char_t r)
AliFMDHistCollector::VtxBin*GetVtxBin(Int_t ivtx)
const AliFMDHistCollector::VtxBin*GetVtxBin(Int_t ivtx) const
voidTObject::MakeZombie()
static voidMergeBins(AliFMDHistCollector::MergeMethod m, Double_t c, Double_t e, Double_t oc, Double_t oe, Double_t& rc, Double_t& re)

Data Members

public:
enum MergeMethod { kStraightMean
kStraightMeanNoZero
kWeightedMean
kLeastError
kSum
kPreferInner
kPreferOuter
};
enum FiducialMethod { kByCut
kDistance
};
enum FMDRingBits { kFMD1I
kFMD1
kFMD2I
kFMD2O
kFMD2
kFMD3I
kFMD3O
kFMD3
};
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
protected:
Bool_tfBgAndHitMapsMake hit/bg maps or not
TList*fByCentBy centrality sums
Float_tfCorrectionCutCut-off on secondary corrections
TH2D*fCoverageSum per ring (on y-axis)
Int_tfDebugDebug level
Bool_tfDoByCentWhether to do by centrality sum
AliFMDHistCollector::FiducialMethodfFiducialMethodFidicual method
TList*fListOutput list
AliFMDHistCollector::MergeMethodfMergeMethodMerge methiod for overlapping bins
Int_tfNCutBinsNumber of additional bins to cut away
TStringTNamed::fNameobject identifier
UShort_tfSkipFMDRingsFMD rings to ignore
TH1D*fSkippedSkipped rings
TH2D*fSumRingsSum per ring (on y-axis)
TStringTNamed::fTitleobject title
TObjArray*fVtxList! Per-vertex list

Class Charts

Inheritance Chart:
TNamed
AliFMDHistCollector

Function documentation

AliFMDHistCollector()
AliFMDHistCollector(const char* title)
AliFMDHistCollector(const AliFMDHistCollector& o)
~AliFMDHistCollector()
operator=(const AliFMDHistCollector& )
 Assignement operator

 Parameters:
    o Object to assign from

 Return:
    Reference to this object

SetupForData(const TAxis& vtxAxis, const TAxis& etaAxis)
 Intialise

 Parameters:
    vtxAxis  Vertex axis

CheckCorrection(AliFMDHistCollector::FiducialMethod m, Double_t cut, const TH2D* bg, Int_t ie, Int_t ip)
 Check if we should include the bin in the data range

 Parameters:
    bg Secondary map histogram
    ie Eta bin
    ip Phi bin

 Return:
    True if to be used

CreateOutputObjects(TList* dir)
 Output diagnostic histograms to directory

 Parameters:
    dir List to write in

CheckSkip(UShort_t d, Char_t r, UShort_t skips)
GetIdx(UShort_t d, Char_t r)
 Get the ring index from detector number and ring identifier

 Parameters:
    d Detector
    r Ring identifier

 Return:
    ring index or -1 in case of problems

GetDetRing(Int_t idx, UShort_t& d, Char_t& r)
 Get the detector and ring from the ring index

 Parameters:
    idx Ring index
    d   On return, the detector or 0 in case of errors
    r   On return, the ring id or '0' in case of errors

GetVtxBin(Int_t ivtx)
 Parameters:
    vtxBin   Vertex bin (1 based)
GetVtxBin(Int_t ivtx) const
 Parameters:
    vtxBin   Vertex bin (1 based)
MergeBins(AliFMDHistCollector::MergeMethod m, Double_t c, Double_t e, Double_t oc, Double_t oe, Double_t& rc, Double_t& re)
 Merge bins accoring to set method

 Parameters:
    c   Current content
    e   Current error
    oc  Old content
    oe  Old error
    rc  On return, the new content
    re  On return, tne new error

Collect(const AliForwardUtil::Histos& hists, AliForwardUtil::Histos& sums, UShort_t vtxBin, TH2D& out, Double_t cent = -1.0, Bool_t eta2phi = false, Bool_t add = true)
 Do the calculations

 Parameters:
    hists    Cache of histograms
    vtxBin   Vertex bin (1 based)
    out      Output histogram

 Return:
    true on successs

Print(Option_t* option = "") const
 Print information

 Parameters:
    option Not used

void SetMergeMethod(AliFMDHistCollector::MergeMethod m)
   * Set the merge method
   *
   * @param m Method

{ fMergeMethod = m; }
MergeMethod GetMergeMethod() const
   * Set the method for finding the fidicual area of the secondary maps
   *
   * @param m Method

{ return fMergeMethod; }
void SetFiducialMethod(AliFMDHistCollector::FiducialMethod m)
   * Set the number of extra bins (beyond the secondary map border)
   * to cut away.
   *
   * @param n Number of bins

void SetNCutBins(UInt_t n = 2)
   * Set the correction cut, that is, when bins in the secondary
   * correction maps have a value lower than this cut, they are
   * considered uncertain and not used
   *
   * @param cut Cut-off

{ fNCutBins = n; }
void SetCorrectionCut(Float_t cut = 0.5)
   * Set FMD rings to skip. Argument should be
   * kFirstRingToSkip|kSecondRingToSkip...
   *
   * @param mask bit pattern

{ fCorrectionCut = cut; }
void SetFMDRingsToSkip(UShort_t mask)
   * Set whether to make bg maps or not
   *
   * @param use make them

{ fSkipFMDRings = mask; }
void SetMakeBGHitMaps(Bool_t use)
   * Set whether to make by-centrality sums for each ring
   *
   * @param use If true, make by-centrality sums

{ fBgAndHitMaps = use; }
void SetMakeCentralitySums(Bool_t use)
   * Set the debug level. The higher the value the more output
   *
   * @param dbg Debug level

{ fDoByCent = use; }
void SetDebug(Int_t dbg = 1)
   * Print information
   *
   * @param option Not used

{ fDebug = dbg; }