'ADDITION AND CONVOLUTION' RooFit tutorial macro #207 Tools and utilities for manipulation of composite objects 
 
import ROOT
 
 
x = ROOT.RooRealVar("x", "x", 0, 10)
 
mean = ROOT.RooRealVar("mean", "mean of gaussians", 5)
sigma = ROOT.RooRealVar("sigma", "width of gaussians", 0.5)
sig = ROOT.RooGaussian("sig", "Signal component 1", x, mean, sigma)
 
a0 = ROOT.RooRealVar("a0", "a0", 0.5, 0.0, 1.0)
a1 = ROOT.RooRealVar("a1", "a1", 0.2, 0.0, 1.0)
bkg1 = ROOT.RooChebychev("bkg1", "Background 1", x, [a0, a1])
 
alpha = ROOT.RooRealVar("alpha", "alpha", -1)
bkg2 = ROOT.RooExponential("bkg2", "Background 2", x, alpha)
 
bkg1frac = ROOT.RooRealVar("bkg1frac", "fraction of component 1 in background", 0.2, 0.0, 1.0)
bkg = ROOT.RooAddPdf("bkg", "Signal", [bkg1, bkg2], [bkg1frac])
 
bkgfrac = ROOT.RooRealVar("bkgfrac", "fraction of background", 0.5, 0.0, 1.0)
model = ROOT.RooAddPdf("model", "g1+g2+a", [bkg, sig], [bkgfrac])
 
y = ROOT.RooRealVar("y", "y", -10, 10)
data = ROOT.RooDataSet("data", "data", {x, y})
 
 
 
 
 
model_obs = model.getObservables(data)
model_obs.Print("v")
 
 
model_params = model.getParameters({x})
model_params.Print("v")
 
model_params2 = model.getParameters(data)
model_params2.Print()
 
 
model_comps = model.getComponents()
model_comps.Print("v")
 
 
sigma2 = ROOT.RooRealVar("sigma2", "width of gaussians", 1)
sig2 = ROOT.RooGaussian("sig2", "Signal component 1", x, mean, sigma2)
 
sig1frac = ROOT.RooRealVar("sig1frac", "fraction of component 1 in signal", 0.8, 0.0, 1.0)
sigsum = ROOT.RooAddPdf("sigsum", "sig+sig2", [sig, sig2], [sig1frac])
 
cust = ROOT.RooCustomizer(model, "cust")
 
cust.replaceArg(sig, sigsum)
 
cust_clone = cust.build(ROOT.kTRUE)
 
cust_clone.Print("t")
 
del cust
  [#0] WARNING:InputArguments -- The parameter 'sigma' with range [-1e+30, 1e+30] of the RooGaussian 'sig' exceeds the safe range of (0, inf). Advise to limit its range.
  1) 0x6776e10 RooRealVar:: x = 5  L(0 - 10)  "x"
  1) 0x1e6b0a0 RooRealVar::       a0 = 0.5  L(0 - 1)  "a0"
  2) 0x73369a0 RooRealVar::       a1 = 0.2  L(0 - 1)  "a1"
  3) 0x3119820 RooRealVar::    alpha = -1 C  L(-INF - +INF)  "alpha"
  4) 0x7728210 RooRealVar:: bkg1frac = 0.2  L(0 - 1)  "fraction of component 1 in background"
  5) 0x7892d70 RooRealVar::  bkgfrac = 0.5  L(0 - 1)  "fraction of background"
  6) 0x66abd70 RooRealVar::     mean = 5 C  L(-INF - +INF)  "mean of gaussians"
  7) 0x37b5e80 RooRealVar::    sigma = 0.5 C  L(-INF - +INF)  "width of gaussians"
RooArgSet::parameters = (a0,a1,alpha,bkg1frac,bkgfrac,mean,sigma)
  1) 0x78753f0 RooAddPdf:: model[ bkgfrac * bkg + [%] * sig ] = 0.582695/1  "g1+g2+a"
  2) 0x7862a20 RooAddPdf::   bkg[ bkg1frac * bkg1 + [%] * bkg2 ] = 0.16539/1  "Signal"
  3) 0x76c6ee0 RooChebychev::  bkg1[ x=x coefficients=(a0,a1) ] = 0.8  "Background 1"
  4) 0x77f1e20 RooExponential::  bkg2[ x=x c=alpha ] = 0.00673795  "Background 2"
  5) 0x733a040 RooGaussian::   sig[ x=x mean=mean sigma=sigma ] = 1  "Signal component 1"
[#0] WARNING:InputArguments -- The parameter 'sigma2' with range [-1e+30, 1e+30] of the RooGaussian 'sig2' exceeds the safe range of (0, inf). Advise to limit its range.
[#1] INFO:ObjectHandling -- RooCustomizer::build(model): tree node sig will be replaced by sigsum
[#1] INFO:ObjectHandling -- RooCustomizer::build(model) Branch node RooAddPdf::model cloned: depends on a replaced parameter
[#1] INFO:ObjectHandling -- RooCustomizer::build(model) Branch node sig is already replaced
0x7e3b3f0 RooAddPdf::model_cust = 0.582695/1 [Auto,Clean] 
  0x7862a20/V- RooAddPdf::bkg = 0.16539/1 [Auto,Clean] 
    0x76c6ee0/V- RooChebychev::bkg1 = 0.8 [Auto,Dirty] 
      0x6776e10/V- RooRealVar::x = 5
      0x1e6b0a0/V- RooRealVar::a0 = 0.5
      0x73369a0/V- RooRealVar::a1 = 0.2
    0x7728210/V- RooRealVar::bkg1frac = 0.2
    0x77f1e20/V- RooExponential::bkg2 = 0.00673795 [Auto,Dirty] 
      0x6776e10/V- RooRealVar::x = 5
      0x3119820/V- RooRealVar::alpha = -1
  0x7892d70/V- RooRealVar::bkgfrac = 0.5
  0x7bf8200/V- RooAddPdf::sigsum = 1/1 [Auto,Clean] 
    0x733a040/V- RooGaussian::sig = 1 [Auto,Dirty] 
      0x6776e10/V- RooRealVar::x = 5
      0x66abd70/V- RooRealVar::mean = 5
      0x37b5e80/V- RooRealVar::sigma = 0.5
    0x7281f00/V- RooRealVar::sig1frac = 0.8
    0x7d34db0/V- RooGaussian::sig2 = 1 [Auto,Dirty] 
      0x6776e10/V- RooRealVar::x = 5
      0x66abd70/V- RooRealVar::mean = 5
      0x7dac940/V- RooRealVar::sigma2 = 1
- Date
 - February 2018 
 
- Authors
 - Clemens Lange, Wouter Verkerke (C version) 
 
Definition in file rf207_comptools.py.