import ROOT
x = ROOT.RooRealVar("x", "x", -20, 20)
mean = ROOT.RooRealVar("mean", "mean of g1 and g2", 0)
sigma_g1 = ROOT.RooRealVar("sigma_g1", "width of g1", 3)
g1 = ROOT.RooGaussian("g1", "g1", x, mean, sigma_g1)
sigma_g2 = ROOT.RooRealVar("sigma_g2", "width of g2", 4, 3.0, 6.0)
g2 = ROOT.RooGaussian("g2", "g2", x, mean, sigma_g2)
frac = ROOT.RooRealVar("frac", "frac", 0.5, 0.0, 1.0)
model = ROOT.RooAddPdf("model", "model", [g1, g2], [frac])
data = model.generate({x}, 1000)
nll = model.createNLL(data)
m = ROOT.RooMinimizer(nll)
m.setVerbose(True)
m.migrad()
model.getParameters({x}).
Print(
"s")
m.setVerbose(False)
m.hesse()
sigma_g2.Print()
m.minos({sigma_g2})
sigma_g2.Print()
r = m.save()
frame = m.contour(frac, sigma_g2, 1, 2, 3)
frame.SetTitle("Contour plot")
r.Print("v")
mean.setVal(0.3)
m.migrad()
m.hesse()
frac.Print()
sigma_g2.setConstant(True)
m.migrad()
m.hesse()
frac.Print()
c = ROOT.TCanvas("rf601_intminuit", "rf601_intminuit", 600, 600)
ROOT.gPad.SetLeftMargin(0.15)
frame.GetYaxis().SetTitleOffset(1.4)
frame.Draw()
c.SaveAs("rf601_intminuit.png")
void Print(std::ostream &os, const OptionType &opt)