I’m beginner in ROOT. I have a gamma ray spectrum which needs to be deconvoluted, for this purpose I try to use TSpectrum class with its example .x Deconvolution.C (taken from this website root.cern.ch/root/html/TSpectrum.html). However, I receive an error message “Error in TFile::TFile: file spectra\TSpectrum.root does not exist”. My question is, doesn’t my root version 6.04.00 include TSpectrum class? What should I do?
void Deconvolution() {
Int_t i;
const Int_t nbins = 256;
Double_t xmin = 0;
Double_t xmax = nbins;
Double_t source[nbins];
Double_t response[nbins];
gROOT->ForceStyle();
TString dir = gROOT->GetTutorialsDir();
TString file = dir+"/spectrum/TSpectrum.root";
TFile *f = new TFile(file.Data());
TH1F *h = (TH1F*) f->Get("decon1");
h->SetTitle("Deconvolution");
TH1F *d = (TH1F*) f->Get("decon_response");
for (i = 0; i < nbins; i++) source[i]=h->GetBinContent(i + 1);
for (i = 0; i < nbins; i++) response[i]=d->GetBinContent(i + 1);
h->SetMaximum(30000);
h->Draw("L");
TSpectrum *s = new TSpectrum();
s->Deconvolution(source,response,256,1000,1,1);
for (i = 0; i < nbins; i++) d->SetBinContent(i + 1,source[i]);
d->SetLineColor(kRed);
d->Draw("SAME L");
}
I have this error:
Error in <TFile::TFile>: file /home/darkside/Vlad_Programs/root/tutorials/spectrum/TSpectrum.root does not exist
Error: illegal pointer to class object h 0x0 163 unfolding.cpp:14:
*** Interpreter error recovered ***