35 TH1D* backgroundHist =
new TH1D(
"background",
"The expected background",30,-4,4);
36 TH1D* signalHist =
new TH1D(
"signal",
"the expected signal",30,-4,4);
37 TH1D* dataHist =
new TH1D(
"data",
"some fake data points",30,-4,4);
42 backgroundHist->
Sumw2();
48 for (
Int_t i = 0; i < 25000; i++) {
51 backgroundHist->
Fill(bg,0.02);
52 signalHist->
Fill(sig,0.001);
54 for (
Int_t i = 0; i < 500; i++) {
58 THStack *hs =
new THStack(
"hs",
"Signal and background compared to data...");
59 hs->
Add(backgroundHist);
62 dataHist->
Draw(
"PE1,Same");
65 c1->GetFrame()->SetFillColor(21);
66 c1->GetFrame()->SetBorderSize(6);
67 c1->GetFrame()->SetBorderMode(-1);
73 cout <<
"Computing limits... " << endl;
76 cout <<
"CLs : " << myconfidence->
CLs() << endl;
77 cout <<
"CLsb : " << myconfidence->
CLsb() << endl;
78 cout <<
"CLb : " << myconfidence->
CLb() << endl;
84 cout << endl <<
"Computing limits with stat systematics... " << endl;
86 cout <<
"CLs : " << mystatconfidence->
CLs() << endl;
87 cout <<
"CLsb : " << mystatconfidence->
CLsb() << endl;
88 cout <<
"CLb : " << mystatconfidence->
CLb() << endl;
94 cout << endl <<
"Computing limits with systematics... " << endl;
107 mynewdatasource->
AddChannel(signalHist,backgroundHist,dataHist,&errors,&errorb,names);
109 cout <<
"CLs : " << mynewconfidence->
CLs() << endl;
110 cout <<
"CLsb : " << mynewconfidence->
CLsb() << endl;
111 cout <<
"CLb : " << mynewconfidence->
CLb() << endl;
120 myconfidence->
Draw();
125 delete mystatconfidence;
126 delete mynewconfidence;
127 delete mynewdatasource;
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
R__EXTERN TSystem * gSystem
virtual void SetFillColor(Color_t fcolor)
Set the fill area color.
virtual void SetMarkerColor(Color_t mcolor=1)
Set the marker color.
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
Class to compute 95% CL limits.
void Draw(const Option_t *option="") override
Display sort of a "canonical" -2lnQ plot.
Double_t GetExpectedCLs_b(Int_t sigma=0) const
Double_t GetExpectedCLb_b(Int_t sigma=0) const
Get the expected Confidence Level for the background only if there is only background.
Double_t CLsb(bool use_sMC=kFALSE) const
Get the Confidence Level for the signal plus background hypothesis.
Double_t CLb(bool use_sMC=kFALSE) const
Get the Confidence Level for the background only.
Double_t GetExpectedCLsb_b(Int_t sigma=0) const
Get the expected Confidence Level for the signal plus background hypothesis if there is only backgrou...
Double_t CLs(bool use_sMC=kFALSE) const
Get the Confidence Level defined by CLs = CLsb/CLb.
1-D histogram with a double per channel (see TH1 documentation)
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
void Draw(Option_t *option="") override
Draw this histogram with options.
virtual void Sumw2(Bool_t flag=kTRUE)
Create structure to store sum of squares of weights.
The Histogram stack class.
virtual void Add(TH1 *h, Option_t *option="")
Add a new histogram to the list.
void Draw(Option_t *chopt="") override
Draw this stack with its current attributes.
This class serves as input for the TLimit::ComputeLimit method.
virtual void AddChannel(TH1 *, TH1 *, TH1 *)
Adds a channel with signal, background and data given as input.
static TConfidenceLevel * ComputeLimit(TLimitDataSource *data, Int_t nmc=50000, bool stat=false, TRandom *generator=nullptr)
void AddLast(TObject *obj) override
Add object in the next empty slot in the array.
Collectable string class.
Random number generator class based on the maximally quidistributed combined Tausworthe generator by ...
virtual Bool_t ProcessEvents()
Process pending events (GUI, timers, sockets).