26x = ROOT.RooRealVar(
"x",
"x", -15, 15)
27a1 = ROOT.RooRealVar(
"a1",
"a1", -0.5, -10.0, 20.0)
28a2 = ROOT.RooRealVar(
"a2",
"a2", 0.2, -10.0, 20.0)
29a3 = ROOT.RooRealVar(
"a3",
"a3", 0.01)
30pdf = ROOT.RooPolynomial(
"pol3",
"c + a1 * x + a2 * x*x + 0.01 * x*x*x", x, [a1, a2, a3])
33data = pdf.generate(x, 10000)
40data.plotOn(frame, Name=
"data")
44ROOT.RooMsgService.instance().getStream(0).removeTopic(ROOT.RooFit.Plotting)
45ROOT.RooMsgService.instance().getStream(1).removeTopic(ROOT.RooFit.Plotting)
58fitWithoutRecovery = pdf.fitTo(
61 RecoverFromUndefinedRegions=0.0,
66pdf.plotOn(frame, LineColor=
"r", Name=
"noRecovery")
73print(
"\n\n\n-------------- Starting second fit ---------------\n\n")
80fitWithRecovery = pdf.fitTo(
83 RecoverFromUndefinedRegions=1.0,
89pdf.plotOn(frame, LineColor=
"b", Name=
"recovery")
96fitWithoutRecovery.Print()
98 "Without recovery, the fitter encountered {}".format(fitWithoutRecovery.numInvalidNLL())
99 +
" invalid function values. The parameters are unchanged.\n"
102fitWithRecovery.Print()
104 "With recovery, the fitter encountered {}".format(fitWithoutRecovery.numInvalidNLL())
105 +
" invalid function values, but the parameters are fitted.\n"
108legend = ROOT.TLegend(0.5, 0.7, 0.9, 0.9)
109legend.SetBorderSize(0)
110legend.SetFillStyle(0)
111legend.AddEntry(frame.findObject(
"data"),
"Data",
"P")
112legend.AddEntry(frame.findObject(
"noRecovery"),
"Without recovery (cannot be plotted)",
"L")
113legend.AddEntry(frame.findObject(
"recovery"),
"With recovery",
"L")
118c.SaveAs(
"rf612_recoverFromInvalidParameters.png")