'Bayesian Calculator' RooStats tutorial macro #701
This tutorial shows an example of using the BayesianCalculator class
Processing /mnt/build/workspace/root-makedoc-v612/rootspi/rdoc/src/v6-12-00-patches/tutorials/roostats/rs701_BayesianCalculator.C...
[1mRooFit v3.60 -- Developed by Wouter Verkerke and David Kirkby[0m
Copyright (C) 2000-2013 NIKHEF, University of California & Stanford University
All rights reserved, please read http://roofit.sourceforge.net/license.txt
[#1] INFO:ObjectHandling -- RooWorkspace::exportToCint(w) INFO: references to all objects in this workspace will be created in CINT in 'namespace w'
Bayesian Result using a Flat prior
0.9% CL central interval: [ 0.50606 - 6.89326 ] or 0.95% CL limits
Bayesian Result using a 1/sqrt(s) prior
0.9% CL central interval: [ 0.0746294 - 5.85425 ] or 0.95% CL limits
void rs701_BayesianCalculator(bool useBkg = true, double confLevel = 0.90)
{
w->
factory(
"SUM::pdf(s[0.001,15]*Uniform(x[0,1]),b[1,0,2]*Uniform(x))");
w->
factory(
"Gaussian::prior_b(b,1,1)");
w->
factory(
"PROD::model(pdf,prior_b)");
if (useBkg) nuisPar = &nuisanceParameters;
double size = 1.-confLevel;
std::cout << "\nBayesian Result using a Flat prior " << std::endl;
bcalc.SetTestSize(size);
double cl = bcalc.ConfidenceLevel();
std::cout << cl <<
"% CL central interval: [ " << interval->
LowerLimit() <<
" - " << interval->
UpperLimit()
<< " ] or "
<< cl+(1.-cl)/2 << "% CL limits\n";
RooPlot * plot = bcalc.GetPosteriorPlot();
std::cout << "\nBayesian Result using a 1/sqrt(s) prior " << std::endl;
bcalc2.SetTestSize(size);
std::cout << cl <<
"% CL central interval: [ " << interval2->
LowerLimit() <<
" - " << interval2->
UpperLimit()
<< " ] or "
<< cl+(1.-cl)/2 << "% CL limits\n";
RooPlot * plot2 = bcalc2.GetPosteriorPlot();
}
- Author
- Gregory Schott
Definition in file rs701_BayesianCalculator.C.