ROOT logo
//////////////////////////////////////////////////////////////////////////
//
// 'MULTIDIMENSIONAL MODELS' RooFit tutorial macro #306
// 
// Complete example with use of conditional p.d.f. with per-event errors
//
//
//
// 07/2008 - Wouter Verkerke 
// 
/////////////////////////////////////////////////////////////////////////

#ifndef __CINT__
#include "RooGlobalFunc.h"
#endif
#include "RooRealVar.h"
#include "RooDataSet.h"
#include "RooGaussian.h"
#include "RooConstVar.h"
#include "RooGaussModel.h"
#include "RooDecay.h"
#include "RooLandau.h"
#include "RooPlot.h"
#include "TCanvas.h"
#include "TAxis.h"
#include "TH2D.h"
using namespace RooFit ;



void rf306_condpereventerrors()
{
  // B - p h y s i c s   p d f   w i t h   p e r - e v e n t  G a u s s i a n   r e s o l u t i o n
  // ----------------------------------------------------------------------------------------------

  // Observables
  RooRealVar dt("dt","dt",-10,10) ;
  RooRealVar dterr("dterr","per-event error on dt",0.01,10) ;

  // Build a gaussian resolution model scaled by the per-event error = gauss(dt,bias,sigma*dterr)
  RooRealVar bias("bias","bias",0,-10,10) ;
  RooRealVar sigma("sigma","per-event error scale factor",1,0.1,10) ;
  RooGaussModel gm("gm1","gauss model scaled bt per-event error",dt,bias,sigma,dterr) ;

  // Construct decay(dt) (x) gauss1(dt|dterr)
  RooRealVar tau("tau","tau",1.548) ;
  RooDecay decay_gm("decay_gm","decay",dt,tau,gm,RooDecay::DoubleSided) ;



  // C o n s t r u c t   f a k e   ' e x t e r n a l '   d a t a    w i t h   p e r - e v e n t   e r r o r
  // ------------------------------------------------------------------------------------------------------

  // Use landau p.d.f to get somewhat realistic distribution with long tail
  RooLandau pdfDtErr("pdfDtErr","pdfDtErr",dterr,RooConst(1),RooConst(0.25)) ;
  RooDataSet* expDataDterr = pdfDtErr.generate(dterr,10000) ;



  // S a m p l e   d a t a   f r o m   c o n d i t i o n a l   d e c a y _ g m ( d t | d t e r r )
  // ---------------------------------------------------------------------------------------------

  // Specify external dataset with dterr values to use decay_dm as conditional p.d.f.
  RooDataSet* data = decay_gm.generate(dt,ProtoData(*expDataDterr)) ;

  

  // F i t   c o n d i t i o n a l   d e c a y _ d m ( d t | d t e r r )
  // ---------------------------------------------------------------------

  // Specify dterr as conditional observable
  decay_gm.fitTo(*data,ConditionalObservables(dterr)) ;


  
  // P l o t   c o n d i t i o n a l   d e c a y _ d m ( d t | d t e r r )
  // ---------------------------------------------------------------------


  // Make two-dimensional plot of conditional p.d.f in (dt,dterr)
  TH1* hh_decay = decay_gm.createHistogram("hh_decay",dt,Binning(50),YVar(dterr,Binning(50))) ;
  hh_decay->SetLineColor(kBlue) ;


  // Plot decay_gm(dt|dterr) at various values of dterr
  RooPlot* frame = dt.frame(Title("Slices of decay(dt|dterr) at various dterr")) ;
  for (Int_t ibin=0 ; ibin<100 ; ibin+=20) {
    dterr.setBin(ibin) ;
    decay_gm.plotOn(frame,Normalization(5.)) ;
  }


  // Make projection of data an dt
  RooPlot* frame2 = dt.frame(Title("Projection of decay(dt|dterr) on dt")) ;
  data->plotOn(frame2) ;

  // Make projection of decay(dt|dterr) on dt. 
  //
  // Instead of integrating out dterr, make a weighted average of curves
  // at values dterr_i as given in the external dataset. 
  // (The kTRUE argument bins the data before projection to speed up the process)
  decay_gm.plotOn(frame2,ProjWData(*expDataDterr,kTRUE)) ;



  // Draw all frames on canvas
  TCanvas* c = new TCanvas("rf306_condpereventerrors","rf306_condperventerrors",1200, 400);
  c->Divide(3) ;
  c->cd(1) ; gPad->SetLeftMargin(0.20) ; hh_decay->GetZaxis()->SetTitleOffset(2.5) ; hh_decay->Draw("surf") ;
  c->cd(2) ; gPad->SetLeftMargin(0.15) ; frame->GetYaxis()->SetTitleOffset(1.6) ; frame->Draw() ;
  c->cd(3) ; gPad->SetLeftMargin(0.15) ; frame2->GetYaxis()->SetTitleOffset(1.6) ; frame2->Draw() ;


}

 rf306_condpereventerrors.C:1
 rf306_condpereventerrors.C:2
 rf306_condpereventerrors.C:3
 rf306_condpereventerrors.C:4
 rf306_condpereventerrors.C:5
 rf306_condpereventerrors.C:6
 rf306_condpereventerrors.C:7
 rf306_condpereventerrors.C:8
 rf306_condpereventerrors.C:9
 rf306_condpereventerrors.C:10
 rf306_condpereventerrors.C:11
 rf306_condpereventerrors.C:12
 rf306_condpereventerrors.C:13
 rf306_condpereventerrors.C:14
 rf306_condpereventerrors.C:15
 rf306_condpereventerrors.C:16
 rf306_condpereventerrors.C:17
 rf306_condpereventerrors.C:18
 rf306_condpereventerrors.C:19
 rf306_condpereventerrors.C:20
 rf306_condpereventerrors.C:21
 rf306_condpereventerrors.C:22
 rf306_condpereventerrors.C:23
 rf306_condpereventerrors.C:24
 rf306_condpereventerrors.C:25
 rf306_condpereventerrors.C:26
 rf306_condpereventerrors.C:27
 rf306_condpereventerrors.C:28
 rf306_condpereventerrors.C:29
 rf306_condpereventerrors.C:30
 rf306_condpereventerrors.C:31
 rf306_condpereventerrors.C:32
 rf306_condpereventerrors.C:33
 rf306_condpereventerrors.C:34
 rf306_condpereventerrors.C:35
 rf306_condpereventerrors.C:36
 rf306_condpereventerrors.C:37
 rf306_condpereventerrors.C:38
 rf306_condpereventerrors.C:39
 rf306_condpereventerrors.C:40
 rf306_condpereventerrors.C:41
 rf306_condpereventerrors.C:42
 rf306_condpereventerrors.C:43
 rf306_condpereventerrors.C:44
 rf306_condpereventerrors.C:45
 rf306_condpereventerrors.C:46
 rf306_condpereventerrors.C:47
 rf306_condpereventerrors.C:48
 rf306_condpereventerrors.C:49
 rf306_condpereventerrors.C:50
 rf306_condpereventerrors.C:51
 rf306_condpereventerrors.C:52
 rf306_condpereventerrors.C:53
 rf306_condpereventerrors.C:54
 rf306_condpereventerrors.C:55
 rf306_condpereventerrors.C:56
 rf306_condpereventerrors.C:57
 rf306_condpereventerrors.C:58
 rf306_condpereventerrors.C:59
 rf306_condpereventerrors.C:60
 rf306_condpereventerrors.C:61
 rf306_condpereventerrors.C:62
 rf306_condpereventerrors.C:63
 rf306_condpereventerrors.C:64
 rf306_condpereventerrors.C:65
 rf306_condpereventerrors.C:66
 rf306_condpereventerrors.C:67
 rf306_condpereventerrors.C:68
 rf306_condpereventerrors.C:69
 rf306_condpereventerrors.C:70
 rf306_condpereventerrors.C:71
 rf306_condpereventerrors.C:72
 rf306_condpereventerrors.C:73
 rf306_condpereventerrors.C:74
 rf306_condpereventerrors.C:75
 rf306_condpereventerrors.C:76
 rf306_condpereventerrors.C:77
 rf306_condpereventerrors.C:78
 rf306_condpereventerrors.C:79
 rf306_condpereventerrors.C:80
 rf306_condpereventerrors.C:81
 rf306_condpereventerrors.C:82
 rf306_condpereventerrors.C:83
 rf306_condpereventerrors.C:84
 rf306_condpereventerrors.C:85
 rf306_condpereventerrors.C:86
 rf306_condpereventerrors.C:87
 rf306_condpereventerrors.C:88
 rf306_condpereventerrors.C:89
 rf306_condpereventerrors.C:90
 rf306_condpereventerrors.C:91
 rf306_condpereventerrors.C:92
 rf306_condpereventerrors.C:93
 rf306_condpereventerrors.C:94
 rf306_condpereventerrors.C:95
 rf306_condpereventerrors.C:96
 rf306_condpereventerrors.C:97
 rf306_condpereventerrors.C:98
 rf306_condpereventerrors.C:99
 rf306_condpereventerrors.C:100
 rf306_condpereventerrors.C:101
 rf306_condpereventerrors.C:102
 rf306_condpereventerrors.C:103
 rf306_condpereventerrors.C:104
 rf306_condpereventerrors.C:105
 rf306_condpereventerrors.C:106
 rf306_condpereventerrors.C:107
 rf306_condpereventerrors.C:108
 rf306_condpereventerrors.C:109
 rf306_condpereventerrors.C:110
 rf306_condpereventerrors.C:111
 rf306_condpereventerrors.C:112
 rf306_condpereventerrors.C:113
 rf306_condpereventerrors.C:114
 rf306_condpereventerrors.C:115
 rf306_condpereventerrors.C:116