46 void rs_numberCountingCombination_expected();
47 void rs_numberCountingCombination_observed();
48 void rs_numberCountingCombination_observedWithTau();
52 void rs_numberCountingCombination(
int flag=1)
55 rs_numberCountingCombination_expected();
57 rs_numberCountingCombination_observed();
59 rs_numberCountingCombination_observedWithTau();
63 void rs_numberCountingCombination_expected()
90 f.
AddModel(s,2,wspace,
"TopLevelPdf",
"masterSignal");
95 f.
AddExpData(s, b, db, 2, wspace,
"ExpectedNumberCountingData");
115 *wspace->
pdf(
"TopLevelPdf"), *poi, 0.05, nullParams);
121 cout <<
"-------------------------------------------------" << endl;
122 cout <<
"The p-value for the null is " << htr->NullPValue() << endl;
123 cout <<
"Corresponding to a significance of " << htr->Significance() << endl;
124 cout <<
"-------------------------------------------------\n\n" << endl;
138 RooArgSet* paramsOfInterest = nullParams;
139 plc.SetParameters(*paramsOfInterest);
150 lrPlot.SetMaximum(3.);
154 cout <<
"lower limit on master signal = " << lower << endl;
155 cout <<
"upper limit on master signal = " << upper << endl;
164 cout <<
"-------------------------------------------------" << endl;
165 std::cout <<
"Consider this parameter point:" << std::endl;
168 std::cout <<
"It IS in the interval." << std::endl;
170 std::cout <<
"It is NOT in the interval." << std::endl;
171 cout <<
"-------------------------------------------------\n\n" << endl;
175 cout <<
"-------------------------------------------------" << endl;
176 std::cout <<
"Consider this parameter point:" << std::endl;
179 std::cout <<
"It IS in the interval." << std::endl;
181 std::cout <<
"It is NOT in the interval." << std::endl;
182 cout <<
"-------------------------------------------------\n\n" << endl;
231 void rs_numberCountingCombination_observed()
257 f.
AddModel(s,2,wspace,
"TopLevelPdf",
"masterSignal");
262 Double_t bkgMeas[2] = {111.23,98.76};
264 f.
AddData(mainMeas, bkgMeas, dbMeas, 2, wspace,
"ObservedNumberCountingData");
284 *wspace->
pdf(
"TopLevelPdf"), *poi, 0.05, nullParams);
291 cout <<
"-------------------------------------------------" << endl;
292 cout <<
"The p-value for the null is " << htr->
NullPValue() << endl;
293 cout <<
"Corresponding to a significance of " << htr->
Significance() << endl;
294 cout <<
"-------------------------------------------------\n\n" << endl;
309 RooArgSet* paramsOfInterest = nullParams;
310 plc.SetParameters(*paramsOfInterest);
315 cout <<
"lower limit on master signal = " << lrint->
LowerLimit(*mu ) << endl;
316 cout <<
"upper limit on master signal = " << lrint->
UpperLimit(*mu ) << endl;
328 void rs_numberCountingCombination_observedWithTau()
353 f.
AddModel(s,2,wspace,
"TopLevelPdf",
"masterSignal");
358 Double_t sideband[2] = {11123.,9876.};
360 f.
AddDataWithSideband(mainMeas, sideband, tau, 2, wspace,
"ObservedNumberCountingDataWithSideband");
380 *wspace->
pdf(
"TopLevelPdf"), *poi, 0.05, nullParams);
385 cout <<
"-------------------------------------------------" << endl;
386 cout <<
"The p-value for the null is " << htr->
NullPValue() << endl;
387 cout <<
"Corresponding to a significance of " << htr->Significance() << endl;
388 cout <<
"-------------------------------------------------\n\n" << endl;
403 RooArgSet* paramsOfInterest = nullParams;
404 plc.SetParameters(*paramsOfInterest);
411 cout <<
"lower limit on master signal = " << lrint->
LowerLimit(*mu ) << endl;
412 cout <<
"upper limit on master signal = " << lrint->
UpperLimit(*mu ) << endl;
Bool_t setRealValue(const char *name, Double_t newVal=0, Bool_t verbose=kFALSE)
Set value of a RooAbsRealLValye stored in set with given name to newVal No error messages are printed...
LikelihoodInterval is a concrete implementation of the RooStats::ConfInterval interface.
HypoTestResult is a base class for results from hypothesis tests.
This class provides simple and straightforward utilities to plot a LikelihoodInterval object...
ProfileLikelihoodCalculator is a concrete implementation of CombinedCalculator (the interface class f...
A factory for building PDFs and data for a number counting combination.
Double_t LowerLimit(const RooRealVar ¶m)
return the lower bound of the interval on a given parameter
void AddExpData(Double_t *sigExp, Double_t *bkgExp, Double_t *db, Int_t nbins, RooWorkspace *ws, const char *dsName="ExpectedNumberCountingData")
Arguments are an array of expected signal, expected background, and relative background uncertainty (...
virtual Double_t Significance() const
familiar name for the Null p-value in terms of 1-sided Gaussian significance
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t tau
virtual void Print(Option_t *options=0) const
Print TNamed name and title.
virtual Bool_t IsInInterval(const RooArgSet &) const
check if given point is in the interval
RooRealVar represents a fundamental (non-derived) real valued object.
virtual void addClone(const RooAbsCollection &col, Bool_t silent=kFALSE)
Add a collection of arguments to this collection by calling addOwned() for each element in the source...
RooAbsData * data(const char *name) const
Retrieve dataset (binned or unbinned) with given name. A null pointer is returned if not found...
Double_t UpperLimit(const RooRealVar ¶m)
return the upper bound of the interval on a given parameter
RooAbsArg * first() const
virtual Double_t NullPValue() const
Return p-value for null hypothesis.
Namespace for the RooStats classes.
RooAbsPdf * pdf(const char *name) const
Retrieve p.d.f (RooAbsPdf) with given name. A null pointer is returned if not found.
static constexpr double s
RooRealVar * var(const char *name) const
Retrieve real-valued variable (RooRealVar) with given name. A null pointer is returned if not found...
virtual void SetConfidenceLevel(Double_t cl)
set the confidence level for the interval (e.g 0.682 for a 1-sigma interval)
void AddDataWithSideband(Double_t *mainMeas, Double_t *sideband, Double_t *tau, Int_t nbins, RooWorkspace *ws, const char *dsName="ExpectedNumberCountingData")
Arguments are an array of expected signal, expected background, and relative background uncertainty (...
void AddData(Double_t *mainMeas, Double_t *bkgMeas, Double_t *db, Int_t nbins, RooWorkspace *ws, const char *dsName="NumberCountingData")
Arguments are an array of results from a main measurement, a measured background, and relative backgr...
you should not use this method at all Int_t Int_t Double_t Double_t Double_t Int_t Double_t Double_t Double_t Double_t b
void AddModel(Double_t *sigExp, Int_t nchan, RooWorkspace *ws, const char *pdfName="CombinedPdf", const char *masterSignalName="masterSignal")
This method produces a PDF for N channels with uncorrelated background uncertainty.
The RooWorkspace is a persistable container for RooFit projects.