ROOT logo

From $ROOTSYS/tutorials/math/exampleTKDE.C

// Example of using the TKDE class (kernel density estimator)
// Author: Lorenzo Moneta, Bartolomeu Rabacal (Dec 2010)

#include "TH1.h"
#include "TF1.h"
#include "TKDE.h"
#include "TCanvas.h"
//#include "TStopwatch.h"
#include "TRandom.h"
#ifndef __CINT__
#include "Math/DistFunc.h"
#endif
#include "TLegend.h"

// test TKDE




void exampleTKDE(int n = 1000) { 

 // generate some gaussian points


   int nbin = 100;
   double xmin = 0;
   double xmax = 10;

   TH1D * h1 = new TH1D("h1","h1",nbin,xmin,xmax);

   // generate some points with bi- gaussian distribution

   std::vector<double> data(n);
   for (int i = 0; i < n; ++i) {
      if (i < 0.4*n) { 
         data[i] = gRandom->Gaus(2,1);
         h1->Fill(data[i]);
      }
      else { 
         data[i] = gRandom->Gaus(7,1.5);
         h1->Fill(data[i]);
      }
   }

   // scale histogram
   h1->Scale(1./h1->Integral(),"width" );
   h1->SetStats(false);
   h1->SetTitle("Bi-Gaussian");
   h1->Draw();

   // drawn true normalized density 
   TF1 * f1 = new TF1("f1","0.4*ROOT::Math::normal_pdf(x,1,2)+0.6*ROOT::Math::normal_pdf(x,1.5,7)",xmin,xmax);
   f1->SetLineColor(kGreen+2);
   f1->Draw("SAME");


   ///////////////////////////////////////////////////////////////////////////

   // create TKDE class
   double rho = 1.0; //default value
   TKDE * kde = new TKDE(n, &data[0], xmin,xmax, "", rho);
   //kde->Draw("ConfidenceInterval@0.95 Same");
   kde->Draw("SAME");

   // KDE options
   // int nbinKDE = 0;
   // TKDE::EBinning bin;
   // TKDE::EIteration iter;
   // TKDE::EMirror mirror;
   // if (nbinKDE> 0) kde->SetNBins(nbinKDE);
   // if (iter != TKDE::kAdaptive) kde->SetIteration(iter);
   // if (mirror != TKDE::kNoMirror) kde->SetMirror(mirror);


   //alternative way instead of using kde->Draw()
   // TF1 * const hk = kde->GetFunction(1000);
   // hk->SetLineColor(kBlue);
   // hk->Draw("same");
   
   // TF1 * fl = kde->GetLowerFunction(0.684);
   // TF1 * fu = kde->GetUpperFunction(0.684);
   // fl->Draw("SAME");
   // fl->SetLineColor(kBlue-5);
   // fu->SetLineColor(kBlue-5);
   // fu->Draw("SAME");


   TLegend * legend = new TLegend(0.6,0.7,0.9,0.95);
   legend->AddEntry(f1,"True function");
   legend->AddEntry(kde->GetDrawnFunction(),"TKDE");
   legend->AddEntry(kde->GetDrawnLowerFunction(),"TKDE - #sigma");
   legend->AddEntry(kde->GetDrawnUpperFunction(),"TKDE + #sigma");
   legend->Draw();
   return;

   gPad->Update();


}

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