Steering class for PROOF benchmarks.
Definition at line 37 of file TProofBench.h.
Public Member Functions | |
TProofBench (const char *url, const char *outfile="<default>", const char *proofopt=0) | |
Constructor: check PROOF and load selectors PAR. | |
~TProofBench () override | |
Destructor. | |
void | CloseOutFile () |
Close output file. | |
Int_t | CopyDataSet (const char *dset, const char *dsetdst, const char *destdir) |
Copy the files of dataset 'dset' to 'destdir' and create a new dataset named 'dsetdst' decribing them. | |
Bool_t | GetDebug () |
const char * | GetOutFileName () const |
TClass * | IsA () const override |
Int_t | MakeDataSet (const char *dset=0, Long64_t nevt=-1, const char *fnroot="event", Bool_t regenerate=kFALSE) |
Create the largest dataset for the run. | |
Int_t | OpenOutFile (Bool_t wrt=kFALSE, Bool_t verbose=kTRUE) |
Set the otuput file Return 0 on success, -1 on error. | |
Int_t | ReleaseCache (const char *dset) |
Release memory cache for dataset 'dset' Return 0 on success, -1 on error. | |
Int_t | RemoveDataSet (const char *dset) |
Physically remove the dataset 'dset', i.e. | |
Int_t | RunCPU (Long64_t nevents=-1, Int_t start=-1, Int_t stop=-1, Int_t step=-1) |
Perform the CPU run Return 0 on success, -1 on error. | |
Int_t | RunCPUx (Long64_t nevents=-1, Int_t start=-1, Int_t stop=-1) |
Perform the CPU run scanning over the number of workers per node Return 0 on success, -1 on error. | |
Int_t | RunDataSet (const char *dset="BenchDataSet", Int_t start=1, Int_t stop=-1, Int_t step=1) |
Perform a test using dataset 'dset' Return 0 on success, -1 on error Open the file for the results. | |
Int_t | RunDataSetx (const char *dset="BenchDataSet", Int_t start=1, Int_t stop=-1) |
Perform a test using dataset 'dset' scanning over the number of workers per node. | |
void | SetCPUPar (const char *par) |
void | SetCPUSel (const char *sel) |
void | SetDataGenPar (const char *par) |
void | SetDataGenSel (const char *sel) |
void | SetDataPar (const char *par) |
void | SetDataSel (const char *sel) |
void | SetDebug (Bool_t debug=kTRUE) |
void | SetHistType (TPBHistType *histtype) |
void | SetNFilesWrk (Int_t nf=0) |
void | SetNHist (Int_t nh) |
void | SetNTries (Int_t nt) |
Int_t | SetOutFile (const char *outfile, Bool_t verbose=kTRUE) |
Set the output file Return 0 on success, -1 on error. | |
void | SetProofDS (TProof *p) |
Set the PROOF instance to be used for dataset operations, like releasing cache ... Use SetProofDS(0) to reset and using the default PROOF. | |
void | SetReadType (TPBReadType *readtype) |
void | SetReleaseCache (Bool_t on=kTRUE) |
void | SetSelOption (const char *opt) |
void | Streamer (TBuffer &) override |
Stream an object of class TObject. | |
void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) |
Public Member Functions inherited from TObject | |
TObject () | |
TObject constructor. | |
TObject (const TObject &object) | |
TObject copy ctor. | |
virtual | ~TObject () |
TObject destructor. | |
void | AbstractMethod (const char *method) const |
Use this method to implement an "abstract" method that you don't want to leave purely abstract. | |
virtual void | AppendPad (Option_t *option="") |
Append graphics object to current pad. | |
virtual void | Browse (TBrowser *b) |
Browse object. May be overridden for another default action. | |
ULong_t | CheckedHash () |
Check and record whether this class has a consistent Hash/RecursiveRemove setup (*) and then return the regular Hash value for this object. | |
virtual const char * | ClassName () const |
Returns name of class to which the object belongs. | |
virtual void | Clear (Option_t *="") |
virtual TObject * | Clone (const char *newname="") const |
Make a clone of an object using the Streamer facility. | |
virtual Int_t | Compare (const TObject *obj) const |
Compare abstract method. | |
virtual void | Copy (TObject &object) const |
Copy this to obj. | |
virtual void | Delete (Option_t *option="") |
Delete this object. | |
virtual Int_t | DistancetoPrimitive (Int_t px, Int_t py) |
Computes distance from point (px,py) to the object. | |
virtual void | Draw (Option_t *option="") |
Default Draw method for all objects. | |
virtual void | DrawClass () const |
Draw class inheritance tree of the class to which this object belongs. | |
virtual TObject * | DrawClone (Option_t *option="") const |
Draw a clone of this object in the current selected pad with: gROOT->SetSelectedPad(c1) . | |
virtual void | Dump () const |
Dump contents of object on stdout. | |
virtual void | Error (const char *method, const char *msgfmt,...) const |
Issue error message. | |
virtual void | Execute (const char *method, const char *params, Int_t *error=nullptr) |
Execute method on this object with the given parameter string, e.g. | |
virtual void | Execute (TMethod *method, TObjArray *params, Int_t *error=nullptr) |
Execute method on this object with parameters stored in the TObjArray. | |
virtual void | ExecuteEvent (Int_t event, Int_t px, Int_t py) |
Execute action corresponding to an event at (px,py). | |
virtual void | Fatal (const char *method, const char *msgfmt,...) const |
Issue fatal error message. | |
virtual TObject * | FindObject (const char *name) const |
Must be redefined in derived classes. | |
virtual TObject * | FindObject (const TObject *obj) const |
Must be redefined in derived classes. | |
virtual Option_t * | GetDrawOption () const |
Get option used by the graphics system to draw this object. | |
virtual const char * | GetIconName () const |
Returns mime type name of object. | |
virtual const char * | GetName () const |
Returns name of object. | |
virtual char * | GetObjectInfo (Int_t px, Int_t py) const |
Returns string containing info about the object at position (px,py). | |
virtual Option_t * | GetOption () const |
virtual const char * | GetTitle () const |
Returns title of object. | |
virtual UInt_t | GetUniqueID () const |
Return the unique object id. | |
virtual Bool_t | HandleTimer (TTimer *timer) |
Execute action in response of a timer timing out. | |
virtual ULong_t | Hash () const |
Return hash value for this object. | |
Bool_t | HasInconsistentHash () const |
Return true is the type of this object is known to have an inconsistent setup for Hash and RecursiveRemove (i.e. | |
virtual void | Info (const char *method, const char *msgfmt,...) const |
Issue info message. | |
virtual Bool_t | InheritsFrom (const char *classname) const |
Returns kTRUE if object inherits from class "classname". | |
virtual Bool_t | InheritsFrom (const TClass *cl) const |
Returns kTRUE if object inherits from TClass cl. | |
virtual void | Inspect () const |
Dump contents of this object in a graphics canvas. | |
void | InvertBit (UInt_t f) |
Bool_t | IsDestructed () const |
IsDestructed. | |
virtual Bool_t | IsEqual (const TObject *obj) const |
Default equal comparison (objects are equal if they have the same address in memory). | |
virtual Bool_t | IsFolder () const |
Returns kTRUE in case object contains browsable objects (like containers or lists of other objects). | |
R__ALWAYS_INLINE Bool_t | IsOnHeap () const |
virtual Bool_t | IsSortable () const |
R__ALWAYS_INLINE Bool_t | IsZombie () const |
virtual void | ls (Option_t *option="") const |
The ls function lists the contents of a class on stdout. | |
void | MayNotUse (const char *method) const |
Use this method to signal that a method (defined in a base class) may not be called in a derived class (in principle against good design since a child class should not provide less functionality than its parent, however, sometimes it is necessary). | |
virtual Bool_t | Notify () |
This method must be overridden to handle object notification (the base implementation is no-op). | |
void | Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const |
Use this method to declare a method obsolete. | |
void | operator delete (void *ptr) |
Operator delete. | |
void | operator delete (void *ptr, void *vp) |
Only called by placement new when throwing an exception. | |
void | operator delete[] (void *ptr) |
Operator delete []. | |
void | operator delete[] (void *ptr, void *vp) |
Only called by placement new[] when throwing an exception. | |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, void *vp) |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, void *vp) |
TObject & | operator= (const TObject &rhs) |
TObject assignment operator. | |
virtual void | Paint (Option_t *option="") |
This method must be overridden if a class wants to paint itself. | |
virtual void | Pop () |
Pop on object drawn in a pad to the top of the display list. | |
virtual void | Print (Option_t *option="") const |
This method must be overridden when a class wants to print itself. | |
virtual Int_t | Read (const char *name) |
Read contents of object with specified name from the current directory. | |
virtual void | RecursiveRemove (TObject *obj) |
Recursively remove this object from a list. | |
void | ResetBit (UInt_t f) |
virtual void | SaveAs (const char *filename="", Option_t *option="") const |
Save this object in the file specified by filename. | |
virtual void | SavePrimitive (std::ostream &out, Option_t *option="") |
Save a primitive as a C++ statement(s) on output stream "out". | |
void | SetBit (UInt_t f) |
void | SetBit (UInt_t f, Bool_t set) |
Set or unset the user status bits as specified in f. | |
virtual void | SetDrawOption (Option_t *option="") |
Set drawing option for object. | |
virtual void | SetUniqueID (UInt_t uid) |
Set the unique object id. | |
void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) |
virtual void | SysError (const char *method, const char *msgfmt,...) const |
Issue system error message. | |
R__ALWAYS_INLINE Bool_t | TestBit (UInt_t f) const |
Int_t | TestBits (UInt_t f) const |
virtual void | UseCurrentStyle () |
Set current style settings in this object This function is called when either TCanvas::UseCurrentStyle or TROOT::ForceStyle have been invoked. | |
virtual void | Warning (const char *method, const char *msgfmt,...) const |
Issue warning message. | |
virtual Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) |
Write this object to the current directory. | |
virtual Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) const |
Write this object to the current directory. | |
Static Public Member Functions | |
static TClass * | Class () |
static const char * | Class_Name () |
static constexpr Version_t | Class_Version () |
static const char * | DeclFileName () |
static void | DrawCPU (const char *outfile, const char *opt="std:", Bool_t verbose=kFALSE, Int_t dofit=0, Int_t n0=-1, Int_t n1=-1) |
Draw the CPU speedup plot. | |
static void | DrawDataSet (const char *outfile, const char *opt="std:", const char *type="mbs", Bool_t verbose=kFALSE, Int_t dofit=0, Int_t n0=-1, Int_t n1=-1) |
Draw the CPU speedup plot. | |
static void | DrawEfficiency (const char *outfile, const char *opt="", Bool_t verbose=kFALSE) |
Draw the efficiency plot. | |
static TList * | GetGraphs () |
static void | GetPerfSpecs (const char *path=".", Int_t degfit=1) |
Get performance specs. | |
Static Public Member Functions inherited from TObject | |
static TClass * | Class () |
static const char * | Class_Name () |
static constexpr Version_t | Class_Version () |
static const char * | DeclFileName () |
static Longptr_t | GetDtorOnly () |
Return destructor only flag. | |
static Bool_t | GetObjectStat () |
Get status of object stat flag. | |
static void | SetDtorOnly (void *obj) |
Set destructor only flag. | |
static void | SetObjectStat (Bool_t stat) |
Turn on/off tracking of objects in the TObjectTable. | |
Static Protected Member Functions | |
static void | AssertFittingFun (Double_t mi, Double_t mx) |
Make sure that the fitting functions are defined. | |
static TGraphErrors * | GetGraph (TDirectory *d, const char *pfn, Int_t &nb, Double_t &xmi, Double_t &xmx, Double_t &ymi, Double_t &ymx, Int_t &kmx, TProfile *&pf) |
Get from TDirectory 'd' the TProfile named 'pfn' and create the graph. | |
Static Protected Attributes | |
static TF1 * | fgFio = 0 |
static TF1 * | fgFioV = 0 |
static TF1 * | fgFp1 = 0 |
static TF1 * | fgFp1n = 0 |
static TF1 * | fgFp2 = 0 |
static TF1 * | fgFp2n = 0 |
static TF1 * | fgFp3 = 0 |
static TF1 * | fgFp3n = 0 |
static TList * | fgGraphs = new TList |
Private Attributes | |
Bool_t | fUnlinkOutfile |
Additional Inherited Members | |
Public Types inherited from TObject | |
enum | { kIsOnHeap = 0x01000000 , kNotDeleted = 0x02000000 , kZombie = 0x04000000 , kInconsistent = 0x08000000 , kBitMask = 0x00ffffff } |
enum | { kSingleKey = (1ULL << ( 0 )) , kOverwrite = (1ULL << ( 1 )) , kWriteDelete = (1ULL << ( 2 )) } |
enum | EDeprecatedStatusBits { kObjInCanvas = (1ULL << ( 3 )) } |
enum | EStatusBits { kCanDelete = (1ULL << ( 0 )) , kMustCleanup = (1ULL << ( 3 )) , kIsReferenced = (1ULL << ( 4 )) , kHasUUID = (1ULL << ( 5 )) , kCannotPick = (1ULL << ( 6 )) , kNoContextMenu = (1ULL << ( 8 )) , kInvalidObject = (1ULL << ( 13 )) } |
Protected Types inherited from TObject | |
enum | { kOnlyPrepStep = (1ULL << ( 3 )) } |
Protected Member Functions inherited from TObject | |
virtual void | DoError (int level, const char *location, const char *fmt, va_list va) const |
Interface to ErrorHandler (protected). | |
void | MakeZombie () |
#include <TProofBench.h>
TProofBench::TProofBench | ( | const char * | url, |
const char * | outfile = "<default>" , |
||
const char * | proofopt = 0 |
||
) |
Constructor: check PROOF and load selectors PAR.
Definition at line 184 of file TProofBench.cxx.
|
override |
Destructor.
Definition at line 247 of file TProofBench.cxx.
Make sure that the fitting functions are defined.
Definition at line 696 of file TProofBench.cxx.
|
static |
|
inlinestaticconstexpr |
Definition at line 143 of file TProofBench.h.
void TProofBench::CloseOutFile | ( | ) |
Close output file.
Definition at line 326 of file TProofBench.cxx.
Int_t TProofBench::CopyDataSet | ( | const char * | dset, |
const char * | dsetdst, | ||
const char * | destdir | ||
) |
Copy the files of dataset 'dset' to 'destdir' and create a new dataset named 'dsetdst' decribing them.
Return 0 on success, -1 on error
Definition at line 1518 of file TProofBench.cxx.
|
inlinestatic |
Definition at line 143 of file TProofBench.h.
|
static |
Draw the CPU speedup plot.
opt = 'typewhat', e.g. 'std:max:' type = 'std:' draw standard evt/s plot 'stdx:' draw standard evt/s plot, 1 worker per node 'norm:' draw normalized plot 'normx:' draw normalized plot, 1 worker per node what = 'max:' draw max rate 'avg:' draw average rate 'all:' draw max and average rate on same plot (default) dofit = 0 no fit 1 fit with the relevant '1st degree related' function 2 fit with the relevant '2nd degree related' function 3 fit with varying rcpu function n0 = for dofit == 3, number of real cores n1 = for dofit == 3, number of total cores (real + hyperthreaded)
Definition at line 408 of file TProofBench.cxx.
|
static |
Draw the CPU speedup plot.
opt = 'typewhat', e.g. 'std:max:' type = 'std:' draw standard plot 'stdx:' draw standard plot, 1 worker per node 'norm:' draw normalized plot 'normx:' draw normalized plot, 1 worker per node what = 'max:' draw max rate 'avg:' draw average rate 'all:' draw max and average rate on same plot (default) type = 'mbs' MB/s scaling plots (default) 'evts' Event/s scaling plots dofit = 0 no fit 1 fit with default 3 parameter saturated I/O formula 2 fit with 4 parameter saturated I/O formula (varying Rcpu) n0 = for dofit == 2, number of real cores n1 = for dofit == 2, number of total cores (real + hyperthreaded)
Definition at line 978 of file TProofBench.cxx.
|
static |
Draw the efficiency plot.
opt = 'cpu' or 'data' (default the first found)
Definition at line 1189 of file TProofBench.cxx.
|
inline |
Definition at line 132 of file TProofBench.h.
|
staticprotected |
Get from TDirectory 'd' the TProfile named 'pfn' and create the graph.
Return also the max y in mx.
Definition at line 638 of file TProofBench.cxx.
|
inlinestatic |
Definition at line 141 of file TProofBench.h.
|
inline |
Definition at line 112 of file TProofBench.h.
|
static |
Get performance specs.
Check file 'path', or files in directory 'path' (default current directory). The degree of the polynomial used for the fit is 'degfit' (default 1).
Definition at line 760 of file TProofBench.cxx.
|
inlineoverridevirtual |
Reimplemented from TObject.
Definition at line 143 of file TProofBench.h.
Int_t TProofBench::MakeDataSet | ( | const char * | dset = 0 , |
Long64_t | nevt = -1 , |
||
const char * | fnroot = "event" , |
||
Bool_t | regenerate = kFALSE |
||
) |
Create the largest dataset for the run.
Defaults for dataset name, filename root are "BenchDataSet", "event" respectively. These can be changed via dset and fnroot, respectively. The string 'fnroot' defines the location of the files, interpreted as an URL. Examples: fnroot files 'event' <datadir>
/event_<ord>
_<#>
.root '/mss/event' /mss/event_<ord>
_<#>
.root 'root://srv//mss/event?remote=1' root://srv//mss/event_<ord>
_<#>
?remote=1.root Default selector is TSelEventGen. Use SetDataGenSel and SetDataGenPar to change it and to pass the list of PARs defining the alternative selector. The argument 'nevt' controls the number of events per file (-1 for the default, which is 30000). Return 0 on success, -1 on error
Definition at line 1343 of file TProofBench.cxx.
Set the otuput file Return 0 on success, -1 on error.
Definition at line 261 of file TProofBench.cxx.
Int_t TProofBench::ReleaseCache | ( | const char * | dset | ) |
Release memory cache for dataset 'dset' Return 0 on success, -1 on error.
Definition at line 1303 of file TProofBench.cxx.
Int_t TProofBench::RemoveDataSet | ( | const char * | dset | ) |
Physically remove the dataset 'dset', i.e.
remove the dataset and the files it describes Return 0 on success, -1 on error
Definition at line 1315 of file TProofBench.cxx.
Int_t TProofBench::RunCPU | ( | Long64_t | nevents = -1 , |
Int_t | start = -1 , |
||
Int_t | stop = -1 , |
||
Int_t | step = -1 |
||
) |
Perform the CPU run Return 0 on success, -1 on error.
Definition at line 336 of file TProofBench.cxx.
Perform the CPU run scanning over the number of workers per node Return 0 on success, -1 on error.
Definition at line 365 of file TProofBench.cxx.
Int_t TProofBench::RunDataSet | ( | const char * | dset = "BenchDataSet" , |
Int_t | start = 1 , |
||
Int_t | stop = -1 , |
||
Int_t | step = 1 |
||
) |
Perform a test using dataset 'dset' Return 0 on success, -1 on error Open the file for the results.
Definition at line 897 of file TProofBench.cxx.
Int_t TProofBench::RunDataSetx | ( | const char * | dset = "BenchDataSet" , |
Int_t | start = 1 , |
||
Int_t | stop = -1 |
||
) |
Perform a test using dataset 'dset' scanning over the number of workers per node.
Return 0 on success, -1 on error Open the file for the results
Definition at line 932 of file TProofBench.cxx.
|
inline |
Definition at line 121 of file TProofBench.h.
|
inline |
Definition at line 120 of file TProofBench.h.
|
inline |
Definition at line 125 of file TProofBench.h.
|
inline |
Definition at line 124 of file TProofBench.h.
|
inline |
Definition at line 123 of file TProofBench.h.
|
inline |
Definition at line 122 of file TProofBench.h.
Definition at line 130 of file TProofBench.h.
|
inline |
Definition at line 115 of file TProofBench.h.
|
inline |
Definition at line 113 of file TProofBench.h.
|
inline |
Definition at line 116 of file TProofBench.h.
|
inline |
Definition at line 114 of file TProofBench.h.
Set the output file Return 0 on success, -1 on error.
Definition at line 295 of file TProofBench.cxx.
void TProofBench::SetProofDS | ( | TProof * | p | ) |
Set the PROOF instance to be used for dataset operations, like releasing cache ... Use SetProofDS(0) to reset and using the default PROOF.
Definition at line 1590 of file TProofBench.cxx.
|
inline |
Definition at line 117 of file TProofBench.h.
Definition at line 118 of file TProofBench.h.
|
inline |
Definition at line 126 of file TProofBench.h.
|
overridevirtual |
|
inline |
Definition at line 143 of file TProofBench.h.
|
protected |
Definition at line 58 of file TProofBench.h.
|
protected |
Definition at line 57 of file TProofBench.h.
|
protected |
Definition at line 62 of file TProofBench.h.
|
protected |
Definition at line 61 of file TProofBench.h.
|
protected |
Definition at line 60 of file TProofBench.h.
|
protected |
Definition at line 59 of file TProofBench.h.
|
protected |
Definition at line 52 of file TProofBench.h.
|
protected |
Definition at line 69 of file TProofBench.h.
|
protected |
Definition at line 71 of file TProofBench.h.
|
protected |
Definition at line 67 of file TProofBench.h.
|
staticprotected |
Definition at line 84 of file TProofBench.h.
|
staticprotected |
Definition at line 85 of file TProofBench.h.
|
staticprotected |
Definition at line 77 of file TProofBench.h.
|
staticprotected |
Definition at line 78 of file TProofBench.h.
|
staticprotected |
Definition at line 79 of file TProofBench.h.
|
staticprotected |
Definition at line 80 of file TProofBench.h.
|
staticprotected |
Definition at line 81 of file TProofBench.h.
|
staticprotected |
Definition at line 82 of file TProofBench.h.
Definition at line 87 of file TProofBench.h.
|
protected |
Definition at line 49 of file TProofBench.h.
|
protected |
Definition at line 53 of file TProofBench.h.
|
protected |
Definition at line 50 of file TProofBench.h.
|
protected |
Definition at line 48 of file TProofBench.h.
|
protected |
Definition at line 54 of file TProofBench.h.
|
protected |
Definition at line 46 of file TProofBench.h.
|
protected |
Definition at line 47 of file TProofBench.h.
|
protected |
Definition at line 44 of file TProofBench.h.
|
protected |
Definition at line 45 of file TProofBench.h.
|
protected |
Definition at line 51 of file TProofBench.h.
|
protected |
Definition at line 55 of file TProofBench.h.
|
protected |
Definition at line 65 of file TProofBench.h.
|
protected |
Definition at line 66 of file TProofBench.h.
|
protected |
Definition at line 63 of file TProofBench.h.
|
private |
Definition at line 40 of file TProofBench.h.