Logo ROOT   6.07/09
Reference Guide
Deconvolution.C
Go to the documentation of this file.
1 /// \file
2 /// \ingroup tutorial_spectrum
3 /// \notebook
4 /// Example to illustrate deconvolution function (class TSpectrum).
5 ///
6 /// \macro_image
7 /// \macro_code
8 ///
9 /// \authors Miroslav Morhac, Olivier Couet
10 
11 void Deconvolution() {
12  Int_t i;
13  const Int_t nbins = 256;
14  Double_t xmin = 0;
16  Double_t source[nbins];
17  Double_t response[nbins];
18  gROOT->ForceStyle();
19 
20  TString dir = gROOT->GetTutorialsDir();
21  TString file = dir+"/spectrum/TSpectrum.root";
22  TFile *f = new TFile(file.Data());
23  TH1F *h = (TH1F*) f->Get("decon1");
24  h->SetTitle("Deconvolution");
25  TH1F *d = (TH1F*) f->Get("decon_response");
26 
27  for (i = 0; i < nbins; i++) source[i]=h->GetBinContent(i + 1);
28  for (i = 0; i < nbins; i++) response[i]=d->GetBinContent(i + 1);
29 
30  h->SetMaximum(30000);
31  h->Draw("L");
32  TSpectrum *s = new TSpectrum();
33  s->Deconvolution(source,response,256,1000,1,1);
34 
35  for (i = 0; i < nbins; i++) d->SetBinContent(i + 1,source[i]);
36  d->SetLineColor(kRed);
37  d->Draw("SAME L");
38 }
float xmin
Definition: THbookFile.cxx:93
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
Definition: TH1.cxx:4640
Definition: Rtypes.h:61
TH1 * h
Definition: legend2.C:5
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format...
Definition: TFile.h:50
virtual TObject * Get(const char *namecycle)
Return pointer to object identified by namecycle.
#define gROOT
Definition: TROOT.h:364
Basic string class.
Definition: TString.h:137
tomato 1-D histogram with a float per channel (see TH1 documentation)}
Definition: TH1.h:575
int Int_t
Definition: RtypesCore.h:41
int nbins[3]
const char * Data() const
Definition: TString.h:349
virtual void SetLineColor(Color_t lcolor)
Set the line color.
Definition: TAttLine.h:46
virtual void Draw(Option_t *option="")
Draw this histogram with options.
Definition: TH1.cxx:2853
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
Definition: TH1.cxx:8280
const char * Deconvolution(Double_t *source, const Double_t *response, Int_t ssize, Int_t numberIterations, Int_t numberRepetitions, Double_t boost)
One-dimensional deconvolution function.
Definition: TSpectrum.cxx:1858
float xmax
Definition: THbookFile.cxx:93
double f(double x)
double Double_t
Definition: RtypesCore.h:55
Advanced Spectra Processing.
Definition: TSpectrum.h:20
Definition: file.py:1