#include "TProofProgressDialog.h"
#include "TProofProgressLog.h"
#include "TEnv.h"
#include "TError.h"
#include "TGLabel.h"
#include "TGButton.h"
#include "TGTextBuffer.h"
#include "TGTextEntry.h"
#include "TGProgressBar.h"
#include "TProof.h"
#include "TSystem.h"
#include "TTimer.h"
#include "TGraph.h"
#include "TNtuple.h"
#include "TCanvas.h"
#include "TColor.h"
#include "TLine.h"
#include "TPaveText.h"
#ifdef PPD_SRV_NEWER
#undef PPD_SRV_NEWER
#endif
#define PPD_SRV_NEWER(v) (fProof->GetRemoteProtocol() > v)
Bool_t TProofProgressDialog::fgKeepDefault = kTRUE;
Bool_t TProofProgressDialog::fgLogQueryDefault = kFALSE;
TString TProofProgressDialog::fgTextQueryDefault = "last";
ClassImp(TProofProgressDialog)
TProofProgressDialog::TProofProgressDialog(TProof *proof,
const char *selector,
Int_t files,
Long64_t first,
Long64_t entries)
{
fProof = proof;
fFiles = files;
fFirst = first;
fEntries = entries;
fPrevProcessed = 0;
fPrevTotal = 0;
fLogWindow = 0;
fStatus = kRunning;
fKeep = fgKeepDefault;
fLogQuery = fgLogQueryDefault;
fRatePoints = 0;
fRateGraph = 0;
fAvgRate = 0.;
fAvgMBRate = 0.;
if (PPD_SRV_NEWER(11))
fRatePoints = new TNtuple("RateNtuple","Rate progress info","tm:evr:mbr");
const TGWindow *main = gClient->GetRoot();
fDialog = new TGTransientFrame(main, main, 10, 10);
fDialog->Connect("CloseWindow()", "TProofProgressDialog", this, "DoClose()");
fDialog->DontCallClose();
char buf[256];
sprintf(buf, "Executing on PROOF cluster \"%s\" with %d parallel workers:",
fProof ? fProof->GetMaster() : "<dummy>",
fProof ? fProof->GetParallel() : 0);
fTitleLab = new TGLabel(fDialog, buf),
fDialog->AddFrame(fTitleLab,
new TGLayoutHints(kLHintsNormal, 10, 10, 20, 0));
sprintf(buf,"Selector: %s", selector);
fSelector = new TGLabel(fDialog, buf);
fDialog->AddFrame(fSelector,
new TGLayoutHints(kLHintsNormal, 10, 10, 5, 0));
sprintf(buf, "%d files, number of events %lld, starting event %lld",
fFiles, fEntries, fFirst);
fFilesEvents = new TGLabel(fDialog, buf);
fDialog->AddFrame(fFilesEvents, new TGLayoutHints(kLHintsNormal, 10, 10, 5, 0));
fBar = new TGHProgressBar(fDialog, TGProgressBar::kFancy, 450);
fBar->SetBarColor("green");
fDialog->AddFrame(fBar, new TGLayoutHints(kLHintsTop | kLHintsLeft |
kLHintsExpandX, 10, 10, 20, 20));
if (PPD_SRV_NEWER(11)) {
TGHorizontalFrame *hf0 = new TGHorizontalFrame(fDialog, 0, 0);
TGCompositeFrame *cf0 = new TGCompositeFrame(hf0, 110, 0, kFixedWidth);
cf0->AddFrame(new TGLabel(cf0, "Initialization time:"));
hf0->AddFrame(cf0);
fInit = new TGLabel(hf0, "- secs");
hf0->AddFrame(fInit, new TGLayoutHints(kLHintsNormal, 10, 10, 0, 0));
fDialog->AddFrame(hf0, new TGLayoutHints(kLHintsNormal, 10, 10, 5, 0));
}
TGHorizontalFrame *hf1 = new TGHorizontalFrame(fDialog, 0, 0);
TGCompositeFrame *cf1 = new TGCompositeFrame(hf1, 110, 0, kFixedWidth);
fProcessed = new TGLabel(cf1, "Estimated time left:");
cf1->AddFrame(fProcessed);
hf1->AddFrame(cf1);
fTotal= new TGLabel(hf1, "- sec (- events of - processed)");
hf1->AddFrame(fTotal, new TGLayoutHints(kLHintsNormal, 10, 10, 0, 0));
fDialog->AddFrame(hf1, new TGLayoutHints(kLHintsNormal, 10, 10, 5, 0));
TGHorizontalFrame *hf2 = new TGHorizontalFrame(fDialog, 0, 0);
TGCompositeFrame *cf2 = new TGCompositeFrame(hf2, 110, 0, kFixedWidth);
cf2->AddFrame(new TGLabel(cf2, "Processing rate:"));
hf2->AddFrame(cf2);
fRate = new TGLabel(hf2, "- events/sec");
hf2->AddFrame(fRate, new TGLayoutHints(kLHintsNormal, 10, 10, 0, 0));
fDialog->AddFrame(hf2, new TGLayoutHints(kLHintsNormal, 10, 10, 5, 0));
fKeepToggle = new TGCheckButton(fDialog,
new TGHotString("Close dialog when processing is complete"));
if (!fKeep) fKeepToggle->SetState(kButtonDown);
fKeepToggle->Connect("Toggled(Bool_t)",
"TProofProgressDialog", this, "DoKeep(Bool_t)");
fDialog->AddFrame(fKeepToggle, new TGLayoutHints(kLHintsNormal, 10, 10, 20, 0));
TGHorizontalFrame *hflog = new TGHorizontalFrame(fDialog, 200, 20, kFixedWidth);
fLogQueryToggle = new TGCheckButton(hflog,
new TGHotString("Show only logs from query"));
if (!fLogQuery) fLogQueryToggle->SetState(kButtonUp);
fLogQueryToggle->Connect("Toggled(Bool_t)",
"TProofProgressDialog", this, "DoSetLogQuery(Bool_t)");
hflog->AddFrame(fLogQueryToggle,
new TGLayoutHints(kLHintsCenterY | kLHintsLeft, 0, 0, 0, 0));
fTextQuery = new TGTextBuffer();
fTextQuery->AddText(0, fgTextQueryDefault);
fEntry = new TGTextEntry(hflog, fTextQuery);
if (fLogQuery)
fEntry->SetToolTipText("Enter the query number ('last' for the last query)",50);
fEntry->SetEnabled(fLogQuery);
hflog->AddFrame(fEntry, new TGLayoutHints(kLHintsCenterY |
kLHintsExpandX, 2, 0, 0, 0));
fDialog->AddFrame(hflog, new TGLayoutHints(kLHintsNormal, 10, 10, 5, 0));
TGHorizontalFrame *hf3 = new TGHorizontalFrame(fDialog, 60, 20, kFixedWidth);
UInt_t nb = 0, width = 0, height = 0;
fStop = new TGTextButton(hf3, "&Stop");
fStop->SetToolTipText("Stop processing, Terminate() will be executed");
fStop->Connect("Clicked()", "TProofProgressDialog", this, "DoStop()");
hf3->AddFrame(fStop, new TGLayoutHints(kLHintsCenterY | kLHintsExpandX, 7, 7, 0, 0));
height = TMath::Max(height, fStop->GetDefaultHeight());
width = TMath::Max(width, fStop->GetDefaultWidth()); ++nb;
fAbort = new TGTextButton(hf3, "&Cancel");
fAbort->SetToolTipText("Cancel processing, Terminate() will NOT be executed");
fAbort->Connect("Clicked()", "TProofProgressDialog", this, "DoAbort()");
hf3->AddFrame(fAbort, new TGLayoutHints(kLHintsCenterY | kLHintsExpandX, 7, 7, 0, 0));
height = TMath::Max(height, fAbort->GetDefaultHeight());
width = TMath::Max(width, fAbort->GetDefaultWidth()); ++nb;
fClose = new TGTextButton(hf3, "&Close");
fClose->SetToolTipText("Close this dialog");
fClose->SetState(kButtonDisabled);
fClose->Connect("Clicked()", "TProofProgressDialog", this, "DoClose()");
hf3->AddFrame(fClose, new TGLayoutHints(kLHintsCenterY | kLHintsExpandX, 7, 7, 0, 0));
height = TMath::Max(height, fClose->GetDefaultHeight());
width = TMath::Max(width, fClose->GetDefaultWidth()); ++nb;
fLog = new TGTextButton(hf3, "&Show Logs");
fLog->SetToolTipText("Show query log messages");
fLog->Connect("Clicked()", "TProofProgressDialog", this, "DoLog()");
hf3->AddFrame(fLog, new TGLayoutHints(kLHintsCenterY | kLHintsExpandX, 7, 7, 0, 0));
height = TMath::Max(height, fLog->GetDefaultHeight());
width = TMath::Max(width, fLog->GetDefaultWidth()); ++nb;
if (PPD_SRV_NEWER(11)) {
fRatePlot = new TGTextButton(hf3, "&Rate plot");
fRatePlot->SetToolTipText("Show processing rate vs time");
fRatePlot->SetState(kButtonDisabled);
fRatePlot->Connect("Clicked()", "TProofProgressDialog", this, "DoPlotRateGraph()");
hf3->AddFrame(fRatePlot, new TGLayoutHints(kLHintsCenterY | kLHintsExpandX, 7, 7, 0, 0));
height = TMath::Max(height, fRatePlot->GetDefaultHeight());
width = TMath::Max(width, fRatePlot->GetDefaultWidth()); ++nb;
}
fDialog->AddFrame(hf3, new TGLayoutHints(kLHintsBottom | kLHintsCenterX, 10, 10, 20, 10));
hf3->Resize((width + 40) * nb, height);
if (fProof) {
fProof->Connect("Progress(Long64_t,Long64_t)", "TProofProgressDialog",
this, "Progress(Long64_t,Long64_t)");
fProof->Connect("Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)",
"TProofProgressDialog", this,
"Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)");
fProof->Connect("StopProcess(Bool_t)", "TProofProgressDialog", this,
"IndicateStop(Bool_t)");
fProof->Connect("ResetProgressDialog(const char*,Int_t,Long64_t,Long64_t)",
"TProofProgressDialog", this,
"ResetProgressDialog(const char*,Int_t,Long64_t,Long64_t)");
fProof->Connect("CloseProgressDialog()", "TProofProgressDialog", this, "DoClose()");
}
fDialog->SetWindowName(Form("PROOF Query Progress: %s",
(fProof ? fProof->GetMaster() : "<dummy>")));
fDialog->MapSubwindows();
width = fDialog->GetDefaultWidth();
height = fDialog->GetDefaultHeight();
fDialog->Resize(width, height);
Window_t wdum;
int ax, ay;
Int_t mw = ((TGFrame *) main)->GetWidth();
Int_t mh = ((TGFrame *) main)->GetHeight();
gVirtualX->TranslateCoordinates(main->GetId(), main->GetId(),
(mw - width), (mh - height) >> 1, ax, ay, wdum);
fDialog->Move(ax-5, ay - mh/4);
fDialog->SetWMPosition(ax-5, ay - mh/4);
fDialog->SetWMSize(width, height);
fDialog->SetWMSizeHints(width, height, width, height, 0, 0);
fDialog->SetMWMHints(kMWMDecorAll | kMWMDecorResizeH | kMWMDecorMaximize |
kMWMDecorMinimize | kMWMDecorMenu,
kMWMFuncAll | kMWMFuncResize | kMWMFuncMaximize |
kMWMFuncMinimize,
kMWMInputModeless);
fDialog->MapWindow();
fStartTime = gSystem->Now();
}
void TProofProgressDialog::ResetProgressDialog(const char *selec,
Int_t files, Long64_t first,
Long64_t entries)
{
char buf[512];
sprintf(buf, "Executing on PROOF cluster \"%s\" with %d parallel workers:",
fProof ? fProof->GetMaster() : "<dummy>",
fProof ? fProof->GetParallel() : 0);
fTitleLab->SetText(buf);
fFiles = files;
fFirst = first;
fEntries = entries;
fPrevProcessed = 0;
fPrevTotal = 0;
fStatus = kRunning;
sprintf(buf,"Selector: %s", selec);
fSelector->SetText(buf);
sprintf(buf, "%d files, number of events %lld, starting event %lld",
fFiles, fEntries, fFirst);
fFilesEvents->SetText(buf);
fBar->SetBarColor("green");
fBar->Reset();
fStop->SetState(kButtonUp);
fAbort->SetState(kButtonUp);
fClose->SetState(kButtonDisabled);
if (fProof) {
fProof->Connect("Progress(Long64_t,Long64_t)", "TProofProgressDialog",
this, "Progress(Long64_t,Long64_t)");
fProof->Connect("Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)",
"TProofProgressDialog", this,
"Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)");
fProof->Connect("StopProcess(Bool_t)", "TProofProgressDialog", this,
"IndicateStop(Bool_t)");
}
fStartTime = gSystem->Now();
if (PPD_SRV_NEWER(11))
fRatePoints->Reset();
SafeDelete(fRateGraph);
fAvgRate = 0.;
fAvgMBRate = 0.;
}
void TProofProgressDialog::Progress(Long64_t total, Long64_t processed)
{
char buf[256];
static const char *cproc[] = { "running", "done",
"STOPPED", "ABORTED", "***EVENTS SKIPPED***"};
sprintf(buf, "Executing on PROOF cluster \"%s\" with %d parallel workers:",
fProof ? fProof->GetMaster() : "<dummy>",
fProof ? fProof->GetParallel() : 0);
fTitleLab->SetText(buf);
if (total < 0)
total = fPrevTotal;
else
fPrevTotal = total;
if (fPrevProcessed == processed)
return;
Long64_t evproc = (processed >= 0) ? processed : fPrevProcessed;
if (fEntries != total) {
fEntries = total;
sprintf(buf, "%d files, number of events %lld, starting event %lld",
fFiles, fEntries, fFirst);
fFilesEvents->SetText(buf);
}
Float_t pos = Float_t(Double_t(evproc * 100)/Double_t(total));
fBar->SetPosition(pos);
fEndTime = gSystem->Now();
TTime tdiff = fEndTime - fStartTime;
Float_t eta = 0;
if (evproc > 0)
eta = ((Float_t)((Long_t)tdiff)*total/Float_t(evproc) - Long_t(tdiff))/1000.;
if (processed >= 0 && processed >= total) {
fProcessed->SetText("Processed:");
sprintf(buf, "%lld events in %.1f sec", total, Long_t(tdiff)/1000.);
fTotal->SetText(buf);
if (fProof) {
fProof->Disconnect("Progress(Long64_t,Long64_t)", this,
"Progress(Long64_t,Long64_t)");
fProof->Disconnect("StopProcess(Bool_t)", this,
"IndicateStop(Bool_t)");
}
fStop->SetState(kButtonDisabled);
fAbort->SetState(kButtonDisabled);
fClose->SetState(kButtonUp);
if (!fKeep)
DoClose();
} else {
Bool_t incomplete = (processed < 0 &&
(fPrevProcessed < total || fPrevProcessed == 0))
? kTRUE : kFALSE;
if (incomplete) {
fStatus = kIncomplete;
fBar->SetBarColor("magenta");
}
if (fStatus > kDone) {
sprintf(buf, "%.1f sec (%lld events of %lld processed) - %s",
eta, evproc, total, cproc[fStatus]);
} else {
sprintf(buf, "%.1f sec (%lld events of %lld processed)",
eta, evproc, total);
}
fTotal->SetText(buf);
sprintf(buf, "%.1f events/sec", Float_t(evproc)/Long_t(tdiff)*1000.);
fRate->SetText(buf);
if (processed < 0) {
fStop->SetState(kButtonDisabled);
fAbort->SetState(kButtonDisabled);
fClose->SetState(kButtonUp);
}
}
fPrevProcessed = evproc;
fDialog->Layout();
}
void TProofProgressDialog::Progress(Long64_t total, Long64_t processed,
Long64_t bytesread,
Float_t initTime, Float_t procTime,
Float_t evtrti, Float_t mbrti)
{
char buf[256];
static const char *cproc[] = { "running", "done",
"STOPPED", "ABORTED", "***EVENTS SKIPPED***"};
sprintf(buf, "Executing on PROOF cluster \"%s\" with %d parallel workers:",
fProof ? fProof->GetMaster() : "<dummy>",
fProof ? fProof->GetParallel() : 0);
fTitleLab->SetText(buf);
if (initTime >= 0.) {
sprintf(buf, "%.1f secs", initTime);
fInit->SetText(buf);
fDialog->Layout();
}
Bool_t over = kFALSE;
if (total < 0) {
total = fPrevTotal;
over = kTRUE;
} else {
fPrevTotal = total;
}
if (fPrevProcessed == processed)
return;
Long64_t evproc = (processed >= 0) ? processed : fPrevProcessed;
Float_t mbsproc = bytesread / TMath::Power(2.,20.);
if (fEntries != total) {
fEntries = total;
sprintf(buf, "%d files, number of events %lld, starting event %lld",
fFiles, fEntries, fFirst);
fFilesEvents->SetText(buf);
}
Float_t pos = Float_t(Double_t(evproc * 100)/Double_t(total));
fBar->SetPosition(pos);
Float_t eta = 0;
if (evproc > 0 && procTime > 0.)
eta = (Float_t) (total - evproc) / (Double_t)evproc * procTime;
if (procTime > 0.) {
fAvgRate = Float_t(evproc) / procTime;
fAvgMBRate = mbsproc / procTime;
}
if (over || (processed >= 0 && processed >= total)) {
fProcessed->SetText("Processed:");
sprintf(buf, "%lld events (%.2f MBs) in %.1f sec", total, mbsproc, procTime);
fTotal->SetText(buf);
sprintf(buf, "%.1f evts/sec (%.1f MBs/sec)", fAvgRate, fAvgMBRate);
fRate->SetText(buf);
if (evtrti > 0.) {
fRatePoints->Fill(procTime, evtrti, mbrti);
fRatePlot->SetState(kButtonUp);
}
if (fProof) {
fProof->Disconnect("Progress(Long64_t,Long64_t)", this,
"Progress(Long64_t,Long64_t)");
fProof->Disconnect("Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)",
this,
"Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)");
fProof->Disconnect("StopProcess(Bool_t)", this,
"IndicateStop(Bool_t)");
}
fStop->SetState(kButtonDisabled);
fAbort->SetState(kButtonDisabled);
fClose->SetState(kButtonUp);
if (!fKeep)
DoClose();
} else {
Bool_t incomplete = (processed < 0 &&
(fPrevProcessed < total || fPrevProcessed == 0))
? kTRUE : kFALSE;
if (incomplete) {
fStatus = kIncomplete;
fBar->SetBarColor("magenta");
}
if (fStatus > kDone) {
sprintf(buf, "%.1f sec (processed %lld events out of %lld - %.2f MBs of data) - %s",
eta, evproc, total, mbsproc, cproc[fStatus]);
} else {
sprintf(buf, "%.1f sec (processed %lld events out of %lld - %.2f MBs of data)",
eta, evproc, total, mbsproc);
}
fTotal->SetText(buf);
if (evtrti > 0.) {
sprintf(buf, "%.1f evts/sec (%.1f MBs/sec) - avg: %.1f evts/sec (%.1f MBs/sec)",
evtrti, mbrti, fAvgRate, fAvgMBRate);
fRatePoints->Fill(procTime, evtrti, mbrti);
fRatePlot->SetState(kButtonUp);
} else {
sprintf(buf, "avg: %.1f evts/sec (%.1f MBs/sec)", fAvgRate, fAvgMBRate);
}
fRate->SetText(buf);
if (processed < 0) {
fStop->SetState(kButtonDisabled);
fAbort->SetState(kButtonDisabled);
fClose->SetState(kButtonUp);
}
}
fPrevProcessed = evproc;
fDialog->Layout();
}
TProofProgressDialog::~TProofProgressDialog()
{
if (fProof) {
fProof->Disconnect("Progress(Long64_t,Long64_t)", this,
"Progress(Long64_t,Long64_t)");
fProof->Disconnect("Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)",
this,
"Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)");
fProof->Disconnect("StopProcess(Bool_t)", this,
"IndicateStop(Bool_t)");
fProof->Disconnect("LogMessage(const char*,Bool_t)", this,
"LogMessage(const char*,Bool_t)");
fProof->Disconnect("ResetProgressDialog(const char*,Int_t,Long64_t,Long64_t)",
this,
"ResetProgressDialog(const char*,Int_t,Long64_t,Long64_t)");
fProof->Disconnect("CloseProgressDialog()", this, "CloseProgressDialog()");
fProof->ResetProgressDialogStatus();
if (!fProof->IsValid())
SafeDelete(fProof);
}
if (fLogWindow)
delete fLogWindow;
fDialog->Cleanup();
delete fDialog;
}
void TProofProgressDialog::CloseWindow()
{
delete this;
}
void TProofProgressDialog::IndicateStop(Bool_t aborted)
{
if (aborted == kTRUE)
fBar->SetBarColor("red");
else
fBar->SetBarColor("yellow");
if (fProof) {
fProof->Disconnect("Progress(Long64_t,Long64_t)", this,
"Progress(Long64_t,Long64_t)");
fProof->Disconnect("Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)",
this,
"Progress(Long64_t,Long64_t,Long64_t,Float_t,Float_t,Float_t,Float_t)");
fProof->Disconnect("StopProcess(Bool_t)", this,
"IndicateStop(Bool_t)");
fStop->SetState(kButtonDisabled);
fAbort->SetState(kButtonDisabled);
}
fClose->SetState(kButtonUp);
if (!fKeep)
DoClose();
}
void TProofProgressDialog::LogMessage(const char *msg, Bool_t all)
{
if (fLogWindow) {
if (all) {
fLogWindow->LoadBuffer(msg);
} else {
fLogWindow->AddBuffer(msg);
}
}
}
void TProofProgressDialog::DoClose()
{
fClose->SetState(kButtonDisabled);
TTimer::SingleShot(50, "TProofProgressDialog", this, "CloseWindow()");
}
void TProofProgressDialog::DoLog()
{
if (fProof) {
if (!fLogWindow) {
fLogWindow = new TProofProgressLog(this);
} else {
fLogWindow->Clear();
}
fProof->Connect("LogMessage(const char*,Bool_t)", "TProofProgressDialog",
this, "LogMessage(const char*,Bool_t)");
if (!fLogQuery) {
fProof->LogMessage(0, kTRUE);
} else {
Int_t qry = -2;
TString qs = fTextQuery->GetString();
if (qs != "last" && qs.IsDigit())
qry = qs.Atoi();
Bool_t logonly = fProof->SendingLogToWindow();
fProof->SendLogToWindow(kTRUE);
fProof->ShowLog(qry);
fProof->SendLogToWindow(logonly);
}
}
}
void TProofProgressDialog::DoKeep(Bool_t)
{
fKeep = !fKeep;
fgKeepDefault = fKeep;
}
void TProofProgressDialog::DoSetLogQuery(Bool_t)
{
fLogQuery = !fLogQuery;
fEntry->SetEnabled(fLogQuery);
if (fLogQuery)
fEntry->SetToolTipText("Enter the query number ('last' for the last query)",50);
else
fEntry->SetToolTipText(0);
fgLogQueryDefault = fLogQuery;
}
void TProofProgressDialog::DoStop()
{
Long_t timeout = gEnv->GetValue("Proof.ShutdownTimeout", 60) / 2;
timeout = (timeout > 10) ? timeout : 10;
fProof->StopProcess(kFALSE, timeout);
fStatus = kStopped;
fStop->SetState(kButtonDisabled);
fAbort->SetState(kButtonDisabled);
fClose->SetState(kButtonUp);
}
void TProofProgressDialog::DoAbort()
{
fProof->StopProcess(kTRUE);
fStatus = kAborted;
fStop->SetState(kButtonDisabled);
fAbort->SetState(kButtonDisabled);
fClose->SetState(kButtonUp);
}
void TProofProgressDialog::DoPlotRateGraph()
{
if (!fRatePoints || fRatePoints->GetEntries() <= 0) {
Info("DoPlotRateGraph","list is empty!");
return;
}
TCanvas *c1 = new TCanvas("c1","Rate vs Time",200,10,700,500);
c1->SetFillColor(42);
c1->SetGrid();
Int_t np = (Int_t)fRatePoints->GetEntries();
Double_t ymx = -1.;
SafeDelete(fRateGraph);
fRateGraph = new TGraph(np);
Float_t *nar = fRatePoints->GetArgs();
Int_t ii = 0;
for ( ; ii < np; ++ii) {
fRatePoints->GetEntry(ii);
fRateGraph->SetPoint(ii, (Double_t) nar[0], (Double_t) nar[1]);
ymx = (nar[1] > ymx) ? nar[1] : ymx;
}
fRateGraph->SetMinimum(0.);
fRateGraph->SetMaximum(ymx*1.1);
fRateGraph->SetLineColor(2);
fRateGraph->SetLineWidth(4);
fRateGraph->SetMarkerColor(4);
fRateGraph->SetMarkerStyle(21);
fRateGraph->SetTitle("Processing rate (evts/sec)");
fRateGraph->GetXaxis()->SetTitle("elapsed time (sec)");
fRateGraph->Draw("ALP");
TLine *line = new TLine(fRateGraph->GetXaxis()->GetXmin(),fAvgRate,
fRateGraph->GetXaxis()->GetXmax(),fAvgRate);
Int_t ci;
ci = TColor::GetColor("#008200");
line->SetLineColor(ci);
line->SetLineWidth(2);
line->Draw("P");
Double_t xax0 = fRateGraph->GetXaxis()->GetXmin();
Double_t xax1 = fRateGraph->GetXaxis()->GetXmax();
Double_t yax0 = 0.;
Double_t yax1 = ymx*1.1;
Double_t x0 = xax0 + 0.05 * (xax1 - xax0);
Double_t x1 = xax0 + 0.40 * (xax1 - xax0);
Double_t y0 = yax0 + 0.08 * (yax1 - yax0);
Double_t y1 = yax0 + 0.16 * (yax1 - yax0);
TPaveText *pt = new TPaveText(x0, y0, x1, y1, "br");
pt->SetFillColor(19);
pt->AddText(Form("Global average: %.2f evts/sec", fAvgRate));
pt->Draw();
c1->Modified();
}
ROOT page - Class index - Class Hierarchy - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.