125void OneSidedFrequentistUpperLimitWithBands(
const char *infile =
"",
const char *workspaceName =
"combined",
126 const char *modelConfigName =
"ModelConfig",
127 const char *dataName =
"obsData")
130 double confidenceLevel = 0.95;
131 int nPointsToScan = 12;
137 const char *filename =
"";
138 if (!strcmp(infile,
"")) {
139 filename =
"results/example_combined_GaussExample_model.root";
140 bool fileExist = !
gSystem->AccessPathName(filename);
144 cout <<
"will run standard hist2workspace example" << endl;
145 gROOT->ProcessLine(
".! prepareHistFactory .");
146 gROOT->ProcessLine(
".! hist2workspace config/example.xml");
147 cout <<
"\n\n---------------------" << endl;
148 cout <<
"Done creating example input" << endl;
149 cout <<
"---------------------\n\n" << endl;
160 cout <<
"StandardRooStatsDemoMacro: Input file " << filename <<
" is not found" << endl;
170 cout <<
"workspace not found" << endl;
183 cout <<
"data or ModelConfig was not found" << endl;
203 fc.SetConfidenceLevel(confidenceLevel);
204 fc.AdditionalNToysFactor(
207 fc.SetNBins(nPointsToScan);
208 fc.CreateConfBelt(
true);
231 if (data->numEntries() == 1)
232 fc.FluctuateNumDataEntries(
false);
234 cout <<
"Not sure what to do about this model" << endl;
238 cout <<
"will use global observables for unconditional ensemble" << endl;
248 cout <<
"\n95% interval on " << firstPOI->
GetName() <<
" is : [" << interval->
LowerLimit(*firstPOI) <<
", "
249 << interval->
UpperLimit(*firstPOI) <<
"] " << endl;
253 double observedUL = interval->
UpperLimit(*firstPOI);
254 firstPOI->
setVal(observedUL);
255 double obsTSatObsUL = fc.GetTestStatSampler()->EvaluateTestStatistic(*data, tmpPOI);
262 TH1F *histOfThresholds =
275 histOfThresholds->
Fill(poiVal, arMax);
281 histOfThresholds->
Draw();
296 w->saveSnapshot(
"paramsToGenerateData", *poiAndNuisance);
298 cout <<
"\nWill use these parameter points to generate pseudo data for bkg only" << endl;
299 paramsToGenerateData->
Print(
"v");
306 double CLbinclusive = 0;
309 TH1F *histOfUL =
new TH1F(
"histOfUL",
"", 100, 0, firstPOI->
getMax());
312 for (
int imc = 0; imc < nToyMC; ++imc) {
316 w->loadSnapshot(
"paramsToGenerateData");
319 std::unique_ptr<RooDataSet> toyData;
322 if (data->numEntries() == 1)
325 cout <<
"Not sure what to do about this model" << endl;
340 allVars->assign(*values);
345 auto const& catName =
tt.first;
352 std::unique_ptr<RooDataSet> tmp{pdftmp->
generate(*globtmp, 1)};
355 globtmp->assign(*tmp->get(0));
367 firstPOI->
setVal(observedUL);
368 double toyTSatObsUL = fc.GetTestStatSampler()->EvaluateTestStatistic(*toyData, tmpPOI);
371 if (obsTSatObsUL < toyTSatObsUL)
372 CLb += (1.) / nToyMC;
373 if (obsTSatObsUL <= toyTSatObsUL)
374 CLbinclusive += (1.) / nToyMC;
383 double thisTS = fc.GetTestStatSampler()->EvaluateTestStatistic(*toyData, tmpPOI);
388 if (thisTS <= arMax) {
389 thisUL = firstPOI->
getVal();
425 histOfUL->
Fill(thisUL);
431 c1->SaveAs(
"one-sided_upper_limit_output.pdf");
449 double band2sigDown, band1sigDown, bandMedian, band1sigUp, band2sigUp;
450 for (
int i = 1; i <= cumulative->
GetNbinsX(); ++i) {
462 cout <<
"-2 sigma band " << band2sigDown << endl;
463 cout <<
"-1 sigma band " << band1sigDown <<
" [Power Constraint)]" << endl;
464 cout <<
"median of band " << bandMedian << endl;
465 cout <<
"+1 sigma band " << band1sigUp << endl;
466 cout <<
"+2 sigma band " << band2sigUp << endl;
469 cout <<
"\nobserved 95% upper-limit " << interval->
UpperLimit(*firstPOI) << endl;
470 cout <<
"CLb strict [P(toy>obs|0)] for observed 95% upper-limit " << CLb << endl;
471 cout <<
"CLb inclusive [P(toy>=obs|0)] for observed 95% upper-limit " << CLbinclusive << endl;
int Int_t
Signed integer 4 bytes (int).
double Double_t
Double 8 bytes.
RooFit::OwningPtr< RooArgSet > getObservables(const RooArgSet &set, bool valueOnly=true) const
Given a set of possible observables, return the observables that this PDF depends on.
RooFit::OwningPtr< RooArgSet > getVariables(bool stripDisconnected=true) const
Return RooArgSet with all variables (tree leaf nodes of expression tree).
double getRealValue(const char *name, double defVal=0.0, bool verbose=false) const
Get value of a RooAbsReal stored in set with given name.
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
RooAbsArg * first() const
void Print(Option_t *options=nullptr) const override
This method must be overridden when a class wants to print itself.
Abstract base class for binned and unbinned datasets.
virtual Int_t numEntries() const
Return number of entries in dataset, i.e., count unweighted entries.
Abstract interface for all probability density functions.
bool canBeExtended() const
If true, PDF can provide extended likelihood term.
RooFit::OwningPtr< RooAbsReal > createNLL(RooAbsData &data, CmdArgs_t const &... cmdArgs)
Construct representation of -log(L) of PDF with given dataset.
RooFit::OwningPtr< RooDataSet > generate(const RooArgSet &whatVars, Int_t nEvents, const RooCmdArg &arg1, const RooCmdArg &arg2={}, const RooCmdArg &arg3={}, const RooCmdArg &arg4={}, const RooCmdArg &arg5={})
See RooAbsPdf::generate(const RooArgSet&,const RooCmdArg&,const RooCmdArg&,const RooCmdArg&,...
virtual double getMax(const char *name=nullptr) const
Get maximum of currently defined range.
virtual double getMin(const char *name=nullptr) const
Get minimum of currently defined range.
double getVal(const RooArgSet *normalisationSet=nullptr) const
Evaluate object.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
RooArgSet * snapshot(bool deepCopy=true) const
Use RooAbsCollection::snapshot(), but return as RooArgSet.
TObject * clone(const char *newname=nullptr) const override
Container class to hold unbinned data.
const RooArgSet * get(Int_t index) const override
Return RooArgSet with coordinates of event 'index'.
Variable that can be changed from the outside.
void setVal(double value) override
Set value of variable to 'value'.
Facilitates simultaneous fitting of multiple PDFs to subsets of a given dataset.
RooAbsPdf * getPdf(RooStringView catName) const
Return the p.d.f associated with the given index category name.
const RooAbsCategoryLValue & indexCat() const
ConfidenceBelt is a concrete implementation of the ConfInterval interface.
double GetAcceptanceRegionMax(RooArgSet &, double cl=-1., double leftside=-1.)
The FeldmanCousins class (like the Feldman-Cousins technique) is essentially a specific configuration...
const RooArgSet * GetGlobalObservables() const
get RooArgSet for global observables (return nullptr if not existing)
const RooArgSet * GetParametersOfInterest() const
get RooArgSet containing the parameter of interest (return nullptr if not existing)
const RooArgSet * GetNuisanceParameters() const
get RooArgSet containing the nuisance parameters (return nullptr if not existing)
const RooArgSet * GetObservables() const
get RooArgSet for observables (return nullptr if not existing)
RooAbsPdf * GetPdf() const
get model PDF (return nullptr if pdf has not been specified or does not exist)
PointSetInterval is a concrete implementation of the ConfInterval interface.
double UpperLimit(RooRealVar ¶m)
return upper limit on a given parameter
double LowerLimit(RooRealVar ¶m)
return lower limit on a given parameter
ProfileLikelihoodTestStat is an implementation of the TestStatistic interface that calculates the pro...
void SetOneSided(bool flag=true)
ToyMCSampler is an implementation of the TestStatSampler interface.
virtual TestStatistic * GetTestStatistic(unsigned int i) const
void SetGlobalObservables(const RooArgSet &o) override
specify the conditional observables
Persistable container for RooFit projects.
TObject * Get(const char *namecycle) override
Return pointer to object identified by namecycle.
A file, usually with extension .root, that stores data and code in the form of serialized objects in ...
static TFile * Open(const char *name, Option_t *option="", const char *ftitle="", Int_t compress=ROOT::RCompressionSetting::EDefaults::kUseCompiledDefault, Int_t netopt=0)
Create / open a file.
1-D histogram with a float per channel (see TH1 documentation)
virtual Double_t GetBinCenter(Int_t bin) const
Return bin center for 1D histogram.
virtual Int_t GetNbinsX() const
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
virtual void SetContent(const Double_t *content)
Replace bin contents by the contents of array content.
void Draw(Option_t *option="") override
Draw this histogram with options.
virtual void SetMinimum(Double_t minimum=-1111)
virtual Double_t * GetIntegral()
Return a pointer to the array of bins integral.
TObject * Clone(const char *newname="") const override
Make a complete copy of the underlying object.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
const char * GetName() const override
Returns name of object.
double nll(double pdf, double weight, int binnedL, int doBinOffset)
The namespace RooFit contains mostly switches that change the behaviour of functions of PDFs (or othe...
RooStats::ModelConfig ModelConfig
Namespace for the RooStats classes.
double SignificanceToPValue(double Z)
returns p-value corresponding to a 1-sided significance