ROOT  6.07/01
Reference Guide
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
hsumTimer.C
Go to the documentation of this file.
1 /// \file
2 /// \ingroup tutorial_hist
3 /// Demo of Timers.
4 ///
5 /// Simple example illustrating how to use the C++ interpreter
6 /// to fill histograms in a loop and show the graphics results
7 /// This program is a variant of the tutorial "hsum".
8 /// It illustrates the use of Timers.
9 ///
10 /// \macro_image
11 /// \macro_code
12 ///
13 /// \author Rene Brun
14 
15 Float_t ratio;
17 TCanvas *c1;
18 
19 void hsumUpdate()
20 {
21 // called when Timer times out
22  if (slider) slider->SetRange(0, ::ratio);
23  c1->Modified();
24  c1->Update();
25 }
26 
27 void hsumTimer(Int_t nfill=100000)
28 {
29  c1 = new TCanvas("c1","The HSUM example",200,10,600,400);
30  c1->SetGrid();
31 
32 
33 // Create some histograms.
34  total = new TH1F("total","This is the total distribution",100,-4,4);
35  main = new TH1F("main","Main contributor",100,-4,4);
36  s1 = new TH1F("s1","This is the first signal",100,-4,4);
37  s2 = new TH1F("s2","This is the second signal",100,-4,4);
38  total->Sumw2(); // store the sum of squares of weights
39  total->SetMarkerStyle(21);
40  total->SetMarkerSize(0.7);
41  main->SetFillColor(16);
42  s1->SetFillColor(42);
43  s2->SetFillColor(46);
44  total->SetMaximum(nfill/20.);
45  total->Draw("e1p");
46  main->Draw("same");
47  s1->Draw("same");
48  s2->Draw("same");
49  c1->Update();slider = new TSlider("slider",
50  "test",4.2,0,4.6,0.8*total->GetMaximum(),38);
51  slider->SetFillColor(46);
52 
53 // Create a TTimer (hsumUpdate called every 300 msec)
54  TTimer timer("hsumUpdate()",300);
55  timer.TurnOn();
56 
57  // Fill histograms randomly
58  Float_t xs1, xs2, xmain;
59  gRandom->SetSeed();
60  for (Int_t i=0; i<nfill; i++) {
61  ::ratio = Float_t(i)/Float_t(nfill);
62  if (gSystem->ProcessEvents()) break;
63  xmain = gRandom->Gaus(-1,1.5);
64  xs1 = gRandom->Gaus(-0.5,0.5);
65  xs2 = gRandom->Landau(1,0.15);
66  main->Fill(xmain);
67  s1->Fill(xs1,0.3);
68  s2->Fill(xs2,0.2);
69  total->Fill(xmain);
70  total->Fill(xs1,0.3);
71  total->Fill(xs2,0.2);
72  }
73  timer.TurnOff();
74  hsumUpdate();
75 }
76 
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
Definition: TH1.cxx:3159
virtual Bool_t ProcessEvents()
Process pending events (GUI, timers, sockets).
Definition: TSystem.cxx:420
tuple slider
Definition: hsum.py:65
virtual void SetMaximum(Double_t maximum=-1111)
Definition: TH1.h:394
float Float_t
Definition: RtypesCore.h:53
virtual Double_t Gaus(Double_t mean=0, Double_t sigma=1)
Samples a random number from the standard Normal (Gaussian) Distribution with the given mean and sigm...
Definition: TRandom.cxx:235
TCanvas * c1
Definition: legend1.C:2
virtual void SetRange(Double_t xmin=0, Double_t xmax=1)
Set Slider range in [0,1].
Definition: TSlider.cxx:204
1-D histogram with a float per channel (see TH1 documentation)}
Definition: TH1.h:570
int Int_t
Definition: RtypesCore.h:41
virtual void Draw(Option_t *option="")
Default Draw method for all objects.
Definition: TObject.cxx:254
virtual void SetSeed(UInt_t seed=0)
Set the random generator seed.
Definition: TRandom.cxx:568
tuple xs2
Definition: hsum.py:47
A specialized TPad including a TSliderBox object.
Definition: TSlider.h:31
TSocket * s1
Definition: hserv2.C:36
TStopwatch timer
Definition: pirndm.C:37
virtual void SetGrid(Int_t valuex=1, Int_t valuey=1)
Definition: TPad.h:326
tuple xmain
Definition: hsum.py:45
R__EXTERN TSystem * gSystem
Definition: TSystem.h:545
virtual void Draw(Option_t *option="")
Draw this histogram with options.
Definition: TH1.cxx:2878
tuple main
Definition: hsum.py:20
virtual void SetFillColor(Color_t fcolor)
Definition: TAttFill.h:50
Handles synchronous and a-synchronous timer events.
Definition: TTimer.h:57
virtual void SetMarkerStyle(Style_t mstyle=1)
Definition: TAttMarker.h:53
R__EXTERN TRandom * gRandom
Definition: TRandom.h:62
virtual void SetMarkerSize(Size_t msize=1)
Definition: TAttMarker.h:54
TH1F * total
Definition: threadsh2.C:15
The Canvas class.
Definition: TCanvas.h:48
TH1F * s2
Definition: threadsh2.C:15
virtual void Sumw2(Bool_t flag=kTRUE)
Create structure to store sum of squares of weights.
Definition: TH1.cxx:8350
tuple xs1
Definition: hsum.py:46
virtual void Update()
Update canvas pad buffers.
Definition: TCanvas.cxx:2179
virtual Double_t GetMaximum(Double_t maxval=FLT_MAX) const
Return maximum value smaller than maxval of bins in the range, unless the value has been overridden b...
Definition: TH1.cxx:7921
virtual Double_t Landau(Double_t mean=0, Double_t sigma=1)
Generate a random number following a Landau distribution with location parameter mu and scale paramet...
Definition: TRandom.cxx:340
void Modified(Bool_t flag=1)
Definition: TPad.h:407