00001
00002
00003 void PrepareWorkspace_GaussOverFlat_withSystematics( TString fileName = "WS_GaussOverFlat_withSystematics.root" )
00004 {
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015 using namespace RooFit;
00016 using namespace RooStats;
00017
00018
00019 RooRealVar* mass = new RooRealVar("mass","mass",0,500,"GeV/c^{2}");
00020 mass->setBins(100);
00021 RooArgSet* observables = new RooArgSet(*mass,"observables");
00022
00023
00024 RooRealVar* sigSigma = new RooRealVar("sigSigma","sigma in signal PDF",0,100);
00025 RooAbsPdf* sigPdf = new RooGaussian("sigPdf","signal PDF",*mass,RooConst(200),*sigSigma);
00026 RooAbsPdf* bkgPdf = new RooPolynomial("bkgPdf","background PDF",*mass,RooFit::RooConst(0));
00027
00028
00029 RooRealVar* S = new RooRealVar("S","signal yield",1000,0,100000);
00030 RooRealVar* B = new RooRealVar("B","background yield",1000,0,100000);
00031 RooAbsPdf* model = new RooAddPdf("model","S+B PDF",RooArgList(*sigPdf,*bkgPdf),RooArgList(*S,*B));
00032
00033
00034 RooAbsPdf* modelBkg = new RooExtendPdf("modelBkg","B-only PDF",*bkgPdf,*B);
00035
00036
00037
00038 RooAbsPdf* prior_sigSigma = new RooGaussian("prior_sigSigma","prior probability on sigSigma",*sigSigma,RooConst(sigSigma->getVal()),RooConst(sigSigma->getVal()*0.10));
00039 RooAbsPdf* prior_B = new RooGaussian("prior_B","prior probability on B",*B,RooConst(B->getVal()),RooConst(B->getVal()*0.20));
00040 RooAbsPdf* priorNuisance = new RooProdPdf("priorNuisance","prior on the nuisance parameters",*prior_B,*prior_sigSigma);
00041 RooArgSet* parameters = new RooArgSet(*B,*sigSigma,"parameters");
00042
00043
00044 RooAbsPdf* priorPOI = new RooPolynomial("priorPOI","flat prior on the POI",*S,RooFit::RooConst(0));
00045 RooArgSet* POI = new RooArgSet(*S,"POI");
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056 RooAbsData* data = (RooDataHist*) model->generateBinned(*observables,Name("data"),ExpectedData());
00057
00058
00059
00060
00061
00062
00063
00064 RooWorkspace myWS("myWS");
00065 myWS.import(*data,Rename("data"));
00066 myWS.import(*model,RecycleConflictNodes());
00067 myWS.import(*modelBkg,RecycleConflictNodes());
00068 myWS.import(*priorPOI,RecycleConflictNodes());
00069 myWS.import(*priorNuisance,RecycleConflictNodes());
00070 myWS.defineSet("observables",*observables,kTRUE);
00071 myWS.defineSet("parameters",*parameters,kTRUE);
00072 myWS.defineSet("POI",*POI,kTRUE);
00073
00074
00075 TFile file(fileName,"RECREATE");
00076 file.cd();
00077 myWS.Write();
00078 file.Write();
00079 file.Close();
00080
00081 std::cout << "\nRooFit model initialized and stored in " << fileName << std::endl;
00082 }