ROOT » PROOF » PROOFBENCH » TProofPerfAnalysis

class TProofPerfAnalysis: public TNamed


TProofPerfAnalysis

Set of tools to analyse the performance tree


Function Members (Methods)

public:
virtual~TProofPerfAnalysis()
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
voidEventDist()
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
voidFileDist(Bool_t writedet = kFALSE)
voidFileProcPlot(const char* fn, const char* out = 0)
voidFileRatePlot(const char* fns = 0)
virtual voidTNamed::FillBuffer(char*& buffer)
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
voidGetAverages(Double_t& evtmax, Double_t& mbmax, Double_t& evt, Double_t& mb) const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
Double_tGetEvtRateAvg() const
Double_tGetEvtRateAvgMax() const
virtual const char*TObject::GetIconName() const
Double_tGetMBRateAvg() const
Double_tGetMBRateAvgMax() 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_tIsValid() const
Bool_tTObject::IsZombie() const
voidLatencyPlot(const char* wrks = 0)
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
voidTObject::operator delete(void* ptr)
voidTObject::operator delete(void* ptr, void* vp)
voidTObject::operator delete[](void* ptr)
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)
TProofPerfAnalysis&operator=(const TProofPerfAnalysis&)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTNamed::Print(Option_t* option = "") const
voidPrintFileInfo(Int_t showlast = 10, const char* opt = "", const char* out = 0)
voidPrintFileInfo(const char* fn, const char* opt = "P", const char* out = 0)
voidPrintWrkInfo(Int_t showlast = 10)
voidPrintWrkInfo(const char* wrk)
voidRatePlot(const char* wrks = 0)
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(ostream& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
voidSetDebug(Int_t d = 0)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
static voidSetgDebug(Bool_t on = kTRUE)
virtual voidTNamed::SetName(const char* name)MENU
virtual voidTNamed::SetNameTitle(const char* name, const char* title)
static voidTObject::SetObjectStat(Bool_t stat)
Int_tSetSaveResult(const char* file = "results.root", Option_t* mode = "RECREATE")
virtual voidTNamed::SetTitle(const char* title = "")MENU
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector& insp) const
virtual Int_tTNamed::Sizeof() const
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
voidSummary(Option_t* opt = "", const char* out = "")
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
TProofPerfAnalysis(const TProofPerfAnalysis&)
TProofPerfAnalysis(TTree* tree, const char* title = "")
TProofPerfAnalysis(const char* perffile, const char* title = "", const char* treename = "PROOF_PerfStats")
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
voidWorkerActivity()
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
Bool_tWrkInfoOK() const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()
private:
Int_tCompareOrd(const char* ord1, const char* ord2)
voidDoDraw(TObject* o, Option_t* opt = "", const char* name = 0)
voidFillFileDist(TH1F* hf, TH1F* hb, TH2F* hx, Bool_t wdet = kFALSE)
voidFillFileDistOneSrv(TH1F* hx, Bool_t wdet = kFALSE)
voidFillFileInfo(Bool_t force = kFALSE)
voidFillWrkInfo(Bool_t force = kFALSE)
TStringGetCanvasTitle(const char* t)
voidGetWrkFileList(TList* wl, TList* sl)
voidLoadTree(TDirectory* dir)

Data Members

public:
static TObject::(anonymous)TObject::kBitMask
static TObject::EStatusBitsTObject::kCanDelete
static TObject::EStatusBitsTObject::kCannotPick
static TObject::EStatusBitsTObject::kHasUUID
static TObject::EStatusBitsTObject::kInvalidObject
static TObject::(anonymous)TObject::kIsOnHeap
static TObject::EStatusBitsTObject::kIsReferenced
static TObject::EStatusBitsTObject::kMustCleanup
static TObject::EStatusBitsTObject::kNoContextMenu
static TObject::(anonymous)TObject::kNotDeleted
static TObject::EStatusBitsTObject::kObjInCanvas
static TObject::(anonymous)TObject::kOverwrite
static TObject::(anonymous)TObject::kSingleKey
static TObject::(anonymous)TObject::kWriteDelete
static TObject::(anonymous)TObject::kZombie
protected:
TStringTNamed::fNameobject identifier
TStringTNamed::fTitleobject title
private:
Int_tfDebugLocal verbosity level
TStringfDirNameThe name of the subdir with the perfomance tree
TH1F*fEventsEvent distribution per worker
TH1F*fEvtRateEvent processing rate vs query time
Double_tfEvtRateAvgAverage event processing rate
Double_tfEvtRateAvgMaxMax running event processing rate
Double_tfEvtRateMaxMax event processing rate per packet
TH1F*fEvtRateRunEvent processing rate running avg vs query time
TFile*fFileThe open performance file
TStringfFileResultFile where to save basics of a run when requested
TSortedListfFilesInfoSorted list of files info
Float_tfInitTimeEnd of initialization time for this query
Double_tfLatencyMaxMax retrieval latency per packet
TH1F*fMBRateByte processing rate vs query time
Double_tfMBRateAvgAverage MB processing rate
Double_tfMBRateAvgMaxMax running MB processing rate
Double_tfMBRateMaxMax MB processing rate per packet
TH1F*fMBRateRunByte processing rate running avg vs query time
Float_tfMaxTimeMax time for this query (slowest worker)
Float_tfMergeTimeBegin of merging time for this query
TH1F*fPacketsPacket distribution per worker
Bool_tfSaveResultWhether to save the results of a run
TTree*fTreeThe performance tree
TStringfTreeNameThe name of the performance tree
TSortedListfWrksInfoSorted list of workers info
static Bool_tfgDebugGlobal verbosity on/off

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

TProofPerfAnalysis(const char* perffile, const char* title = "", const char* treename = "PROOF_PerfStats")
 Constructor: open the file and attach to the tree
TProofPerfAnalysis(TTree* tree, const char* title = "")
 Constructor: open the file and attach to the tree
~TProofPerfAnalysis()
 Destructor: detach the tree and close the file
TString GetCanvasTitle(const char* t)
 If defined, add '- <this title>' to the canvas title 't'
void LoadTree(TDirectory* dir)
 Load tree fTreeName from directory 'dir'. If not found, look for the
 first TTree in the directory (and sub-directories) with the name containing
 fTreeName.
 The tree pointer is saved in fTree.
void FileDist(Bool_t writedet = kFALSE)
 Analyse the file distribution. If writedet, underling details are
 written out to a text file.
void GetWrkFileList(TList* wl, TList* sl)
 Fill file info
Int_t CompareOrd(const char* ord1, const char* ord2)
 Return -1 if ord1 comes before ord2, 0 i they are equal,
 1 if ord1 comes after ord2
void FillFileDist(TH1F* hf, TH1F* hb, TH2F* hx, Bool_t wdet = kFALSE)
 Fill file info
void FillFileDistOneSrv(TH1F* hx, Bool_t wdet = kFALSE)
 Fill file info when there is only one file server
void WorkerActivity()
 Measure the worker activity
void PrintWrkInfo(Int_t showlast = 10)
 Print information for all or the slowest showlast workers.
 Use showlast < 0 to print all
void PrintWrkInfo(const char* wrk)
 Print information for worker 'wn' (ordinal) or on the machine whose
 ordinal or fqdn matches 'wn'. Multiple specifications separated by ','
 or ' ' are supported, as well as wildcards '*', e.g. '0.2*,lxb10* lxf2323.doma.in"
void PrintFileInfo(Int_t showlast = 10, const char* opt = "", const char* out = 0)
 Print information for all or the slowest showlast workers.
 Use showlast < 0 to print all
void PrintFileInfo(const char* fn, const char* opt = "P", const char* out = 0)
 Print information for file 'fn' (path including directory) or server 'fn'.
 Multiple specifications separated by ','
 or ' ' are supported, as well as wildcards '*', e.g. 'pippo.root, h4mu*,lxb10*"
void FillWrkInfo(Bool_t force = kFALSE)
 Fill basic worker info; if 'force' rescan the TTree even already done
void Summary(Option_t* opt = "", const char* out = "")
 Print summary of query. Use opt = 'S' for compact version.
 Output to 'out' or to screen.
void FillFileInfo(Bool_t force = kFALSE)
 Fill basic worker info; if 'force' rescan the TTree even already done
void SetDebug(Int_t d = 0)
 Static setter for the verbosity level
void DoDraw(TObject* o, Option_t* opt = "", const char* name = 0)
 Draw object 'o' with options 'opt'
 Save it with 'name' if in saving mode (see SetSaveResult)
Int_t SetSaveResult(const char* file = "results.root", Option_t* mode = "RECREATE")
 Set save result mode and validate 'file' according to 'mode'.
 Return 0 on success, -1 if any problem with the file is encountered
 (save result mode is not enabled in such a case).
 If 'file' is null saving is disabled.
void SetgDebug(Bool_t on = kTRUE)
 Static setter for the verbosity level
void EventDist()
 Display event and packet distribution
void RatePlot(const char* wrks = 0)
 Show event processing or MB processing rate plot vs time
void LatencyPlot(const char* wrks = 0)
 Show event processing or MB processing rate plot vs time
 Create the histograms
void FileProcPlot(const char* fn, const char* out = 0)
 Show event processing or MB processing rate plot vs time
void FileRatePlot(const char* fns = 0)
 Show MB processing rate plot per file vs time
TProofPerfAnalysis(const char* perffile, const char* title = "", const char* treename = "PROOF_PerfStats")
Bool_t IsValid() const
{ return (fFile && fTree) ? kTRUE : kFALSE; }
Bool_t WrkInfoOK() const
{ return (fWrksInfo.GetSize() > 0) ? kTRUE : kFALSE; }
Double_t GetEvtRateAvgMax() const
{ return fEvtRateAvgMax; }
Double_t GetMBRateAvgMax() const
{ return fMBRateAvgMax; }
Double_t GetEvtRateAvg() const
{ return fEvtRateAvg; }
Double_t GetMBRateAvg() const
{ return fMBRateAvg; }
void GetAverages(Double_t& evtmax, Double_t& mbmax, Double_t& evt, Double_t& mb) const
{ evtmax = fEvtRateAvgMax; mbmax = fMBRateAvgMax; evt = fEvtRateAvg; mb = fMBRateAvg; return; }