Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
rf710_roopoly.py File Reference

Namespaces

namespace  rf710_roopoly
 

Detailed Description

View in nbviewer Open in SWAN Taylor expansion of RooFit functions using the taylorExpand function

␛[1mRooFit v3.60 -- Developed by Wouter Verkerke and David Kirkby␛[0m
Copyright (C) 2000-2013 NIKHEF, University of California & Stanford University
All rights reserved, please read http://roofit.sourceforge.net/license.txt
import ROOT
# Create functions
# -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
x = ROOT.RooRealVar("x", "x", 0.0, -3, 10)
# RooPolyFunc polynomial
# -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
# x ^ 4 - 5x ^ 3 + 5x ^ 2 + 5x - 6
# -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
f = ROOT.RooPolyFunc("f", "f", ROOT.RooArgList(x))
f.addTerm(+1, x, 4)
f.addTerm(-5, x, 3)
f.addTerm(+5, x, 2)
f.addTerm(+5, x, 1)
f.addTerm(-6, x, 0)
f = ROOT.RooFormulaVar("f", "f", "pow(@0,4) -5 * pow(@0,3) +5 * pow(@0,2) + 5 * pow(@0,1) - 6", ROOT.RooArgList(x))
# taylor expand around x0 = 0
# -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -
x0 = 2.0
taylor_o1 = ROOT.RooPolyFunc.taylorExpand("taylorfunc_o1", "taylor expansion order 1", f, ROOT.RooArgSet(x), x0, 1)
taylor_o2 = ROOT.RooPolyFunc.taylorExpand("taylorfunc_o2", "taylor expansion order 2", f, ROOT.RooArgSet(x), x0, 2)
frame = x.frame(Title="x^{4} - 5x^{3} + 5x^{2} + 5x - 6")
c = ROOT.TCanvas("c", "c", 400, 400)
f.plotOn(frame, Name="f")
taylor_o1.plotOn(frame, Name="taylor_o1", LineColor=ROOT.kRed, LineStyle=ROOT.kDashed)
taylor_o2.plotOn(frame, Name="taylor_o2", LineColor=ROOT.kRed - 9, LineStyle=ROOT.kDotted)
c.cd()
frame.SetMinimum(-8.0)
frame.SetMaximum(+8.0)
frame.SetYTitle("function value")
frame.Draw()
legend = ROOT.TLegend(0.53, 0.73, 0.86, 0.87)
legend.SetFillColor(ROOT.kWhite)
legend.SetLineColor(ROOT.kWhite)
legend.SetTextSize(0.02)
legend.AddEntry("taylor_o1", "Taylor expansion upto first order", "L")
legend.AddEntry("taylor_o2", "Taylor expansion upto second order", "L")
legend.AddEntry("f", "Polynomial of fourth order", "L")
legend.Draw()
c.Draw()
c.SaveAs("rf710_roopoly.png")
Date
November 2021
Authors
Rahul Balasubramanian

Definition in file rf710_roopoly.py.