22x = ROOT.RooRealVar(
"x",
"x", -10, 10)
23y = ROOT.RooRealVar(
"y",
"y", -10, 10)
26ax = ROOT.RooRealVar(
"ax",
"ay", 0.6, 0, 1)
27bx = ROOT.RooRealVar(
"bx",
"by", 5)
28cx = ROOT.RooRealVar(
"cx",
"cy", -1, -10, 10)
30ay = ROOT.RooRealVar(
"ay",
"ay", 0.2, 0, 1)
31by = ROOT.RooRealVar(
"by",
"by", 5)
32cy = ROOT.RooRealVar(
"cy",
"cy", -1, -10, 10)
34effFunc = ROOT.RooFormulaVar(
35 "effFunc",
"((1-ax)+ax*cos((x-cx)/bx))*((1-ay)+ay*cos((y-cy)/by))", [ax, bx, cx, x, ay, by, cy, y]
39cut = ROOT.RooCategory(
"cut",
"cutr", {
"accept": 1,
"reject": 0})
45effPdf = ROOT.RooEfficiency(
"effPdf",
"effPdf", effFunc, cut,
"accept")
52shapePdfX = ROOT.RooPolynomial(
"shapePdfX",
"shapePdfX", x, [0
if flat
else -0.095])
53shapePdfY = ROOT.RooPolynomial(
"shapePdfY",
"shapePdfY", y, [0
if flat
else +0.095])
54shapePdf = ROOT.RooProdPdf(
"shapePdf",
"shapePdf", [shapePdfX, shapePdfY])
55model = ROOT.RooProdPdf(
"model",
"model", {shapePdf}, Conditional=({effPdf}, {cut}))
58data = model.generate({x, y, cut}, 10000)
64effPdf.fitTo(data, ConditionalObservables={x, y})
70hh_data_all = ROOT.RooAbsData.createHistogram(data,
"hh_data_all", x, Binning=(8), YVar=dict(var=y, Binning=8))
71hh_data_sel = ROOT.RooAbsData.createHistogram(
72 data,
"hh_data_sel", x, Binning=8, YVar=dict(var=y, Binning=8), Cut=
"cut==cut::accept"
74hh_eff = effFunc.createHistogram(
"hh_eff", x, Binning=50, YVar=dict(var=y, Binning=50))
77hh_data_all.SetMinimum(0)
78hh_data_sel.SetMinimum(0)
80hh_eff.SetLineColor(ROOT.kBlue)
83ca = ROOT.TCanvas(
"rf702_efficiency_2D",
"rf702_efficiency_2D", 1200, 400)
86ROOT.gPad.SetLeftMargin(0.15)
87hh_data_all.GetZaxis().SetTitleOffset(1.8)
88hh_data_all.Draw(
"lego")
90ROOT.gPad.SetLeftMargin(0.15)
91hh_data_sel.GetZaxis().SetTitleOffset(1.8)
92hh_data_sel.Draw(
"lego")
94ROOT.gPad.SetLeftMargin(0.15)
95hh_eff.GetZaxis().SetTitleOffset(1.8)
98ca.SaveAs(
"rf702_efficiency_2D.png")