Logo ROOT   6.30.04
Reference Guide
 All Namespaces Files Pages
Background_width.C
Go to the documentation of this file.
1 /// \file
2 /// \ingroup tutorial_spectrum
3 /// \notebook
4 /// Example to illustrate the influence of the clipping window width on the
5 /// estimated background.
6 ///
7 /// \macro_image
8 /// \macro_code
9 ///
10 /// \authors Miroslav Morhac, Olivier Couet
11 
12 void Background_width() {
13  Int_t i;
14  const Int_t nbins = 1024;
15  Double_t xmin = 0;
16  Double_t xmax = nbins;
17  Double_t source[nbins];
18  gROOT->ForceStyle();
19 
20  TString dir = gROOT->GetTutorialDir();
21  TString file = dir+"/spectrum/TSpectrum.root";
22  TFile *f = new TFile(file.Data());
23  TH1F *back = (TH1F*) f->Get("back1");
24  TH1F *d1 = new TH1F("d1","",nbins,xmin,xmax);
25  TH1F *d2 = new TH1F("d2","",nbins,xmin,xmax);
26  TH1F *d3 = new TH1F("d3","",nbins,xmin,xmax);
27 
28  back->GetXaxis()->SetRange(1,nbins);
29  back->SetTitle("Influence of clipping window width on the estimated background");
30  back->Draw("L");
31 
32  TSpectrum *s = new TSpectrum();
33 
34  for (i = 0; i < nbins; i++) source[i]=back->GetBinContent(i + 1);
35  s->Background(source,nbins,4,TSpectrum::kBackDecreasingWindow,
36  TSpectrum::kBackOrder2,kFALSE,
37  TSpectrum::kBackSmoothing3,kFALSE);
38  for (i = 0; i < nbins; i++) d1->SetBinContent(i + 1,source[i]);
39  d1->SetLineColor(kRed);
40  d1->Draw("SAME L");
41 
42  for (i = 0; i < nbins; i++) source[i]=back->GetBinContent(i + 1);
43  s->Background(source,nbins,6,TSpectrum::kBackDecreasingWindow,
44  TSpectrum::kBackOrder2,kFALSE,
45  TSpectrum::kBackSmoothing3,kFALSE);
46  for (i = 0; i < nbins; i++) d2->SetBinContent(i + 1,source[i]);
47  d2->SetLineColor(kOrange);
48  d2->Draw("SAME L");
49 
50  for (i = 0; i < nbins; i++) source[i]=back->GetBinContent(i + 1);
51  s->Background(source,nbins,8,TSpectrum::kBackDecreasingWindow,
52  TSpectrum::kBackOrder2,kFALSE,
53  TSpectrum::kBackSmoothing3,kFALSE);
54  for (i = 0; i < nbins; i++) d3->SetBinContent(i + 1,source[i]);
55  d3->SetLineColor(kGreen);
56  d3->Draw("SAME L");
57 }