Logo ROOT  
Reference Guide
 
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
Loading...
Searching...
No Matches
kdTreeBinning.C
Go to the documentation of this file.
1/// \file
2/// \ingroup tutorial_math
3/// \notebook
4/// kdTreeBinning tutorial: bin the data in cells of equal content using a kd-tree
5///
6/// Using TKDTree wrapper class as a data binning structure
7/// Plot the 2D data using the TH2Poly class
8///
9/// \macro_image
10/// \macro_output
11/// \macro_code
12///
13/// \author Bartolomeu Rabacal
14
15#include <cmath>
16
17#include "TKDTreeBinning.h"
18#include "TH2D.h"
19#include "TH2Poly.h"
20#include "TStyle.h"
21#include "TGraph2D.h"
22#include "TRandom3.h"
23#include "TCanvas.h"
24#include <iostream>
25
26void kdTreeBinning() {
27
28 // -----------------------------------------------------------------------------------------------
29 // Create random sample with regular binning plotting
30
31 const UInt_t DATASZ = 10000;
32 const UInt_t DATADIM = 2;
33 const UInt_t NBINS = 50;
34
36
37 double mu[2] = {0,2};
38 double sig[2] = {2,3};
39 TRandom3 r;
40 r.SetSeed(1);
41 for (UInt_t i = 0; i < DATADIM; ++i)
42 for (UInt_t j = 0; j < DATASZ; ++j)
43 smp[DATASZ * i + j] = r.Gaus(mu[i], sig[i]);
44
45 UInt_t h1bins = (UInt_t) sqrt(NBINS);
46
47 TH2D* h1 = new TH2D("h1BinTest", "Regular binning", h1bins, -5., 5., h1bins, -5., 5.);
48 for (UInt_t j = 0; j < DATASZ; ++j)
49 h1->Fill(smp[j], smp[DATASZ + j]);
50
51
52 // ---------------------------------------------------------------------------------------------
53 // Create KDTreeBinning object with TH2Poly plotting
54
56
57 UInt_t nbins = kdBins->GetNBins();
58 UInt_t dim = kdBins->GetDim();
59
60 const Double_t* binsMinEdges = kdBins->GetBinsMinEdges();
61 const Double_t* binsMaxEdges = kdBins->GetBinsMaxEdges();
62
63 TH2Poly* h2pol = new TH2Poly("h2PolyBinTest", "KDTree binning", kdBins->GetDataMin(0), kdBins->GetDataMax(0), kdBins->GetDataMin(1), kdBins->GetDataMax(1));
64
65 for (UInt_t i = 0; i < nbins; ++i) {
66 UInt_t edgeDim = i * dim;
68 }
69
70 for (UInt_t i = 1; i <= kdBins->GetNBins(); ++i)
71 h2pol->SetBinContent(i, kdBins->GetBinDensity(i - 1));
72
73 std::cout << "Bin with minimum density: " << kdBins->GetBinMinDensity() << std::endl;
74 std::cout << "Bin with maximum density: " << kdBins->GetBinMaxDensity() << std::endl;
75
76 TCanvas* c1 = new TCanvas("glc1", "TH2Poly from a kdTree",0,0,600,800);
77 c1->Divide(1,3);
78 c1->cd(1);
79 h1->Draw("lego");
80
81 c1->cd(2);
82 h2pol->Draw("COLZ L");
83 c1->Update();
84
85 //-------------------------------------------------
86 // Draw an equivalent plot showing the data points
87
88
89 std::vector<Double_t> z = std::vector<Double_t>(DATASZ, 0.);
90 for (UInt_t i = 0; i < DATASZ; ++i)
91 z[i] = (Double_t) h2pol->GetBinContent(h2pol->FindBin(smp[i], smp[DATASZ + i]));
92
93 TGraph2D *g = new TGraph2D(DATASZ, smp, &smp[DATASZ], &z[0]);
94 g->SetMarkerStyle(20);
95
96 c1->cd(3);
97 g->Draw("pcol");
98 c1->Update();
99
100 // ---------------------------------------------------------
101 // make a new TH2Poly where bins are ordered by the density
102
103 TH2Poly* h2polrebin = new TH2Poly("h2PolyBinTest", "KDTree binning", kdBins->GetDataMin(0), kdBins->GetDataMax(0), kdBins->GetDataMin(1), kdBins->GetDataMax(1));
104 h2polrebin->SetFloat();
105
106 //---------------------------------
107 // Sort the bins by their density
108
109 kdBins->SortBinsByDensity();
110
111 for (UInt_t i = 0; i < kdBins->GetNBins(); ++i) {
112 const Double_t* binMinEdges = kdBins->GetBinMinEdges(i);
113 const Double_t* binMaxEdges = kdBins->GetBinMaxEdges(i);
115 }
116
117 for (UInt_t i = 1; i <= kdBins->GetNBins(); ++i){
118 h2polrebin->SetBinContent(i, kdBins->GetBinDensity(i - 1));}
119
120 std::cout << "Bin with minimum density: " << kdBins->GetBinMinDensity() << std::endl;
121 std::cout << "Bin with maximum density: " << kdBins->GetBinMaxDensity() << std::endl;
122
123 // now make a vector with bin number vs position
124 for (UInt_t i = 0; i < DATASZ; ++i)
125 z[i] = (Double_t) h2polrebin->FindBin(smp[i], smp[DATASZ + i]);
126
127 TGraph2D *g2 = new TGraph2D(DATASZ, smp, &smp[DATASZ], &z[0]);
128 g2->SetMarkerStyle(20);
129
130
131 // plot new TH2Poly (ordered one) and TGraph2D
132 // The new TH2Poly has to be same as old one and the TGraph2D should be similar to
133 // the previous one. It is now made using as z value the bin number
134
135 TCanvas* c4 = new TCanvas("glc4", "TH2Poly from a kdTree (Ordered)",50,50,800,800);
136
137 c4->Divide(2,2);
138 c4->cd(1);
139 h2polrebin->Draw("COLZ L"); // draw as scatter plot
140
141 c4->cd(2);
142 g2->Draw("pcol");
143
144 c4->Update();
145
146 // make also the 1D binned histograms
147
148 TKDTreeBinning* kdX = new TKDTreeBinning(DATASZ, 1, &smp[0], 20);
150
151
152 kdX->SortOneDimBinEdges();
153 kdY->SortOneDimBinEdges();
154
155 TH1* hX=new TH1F("hX", "X projection", kdX->GetNBins(), kdX->GetOneDimBinEdges());
156 for(int i=0; i<kdX->GetNBins(); ++i){
157 hX->SetBinContent(i+1, kdX->GetBinDensity(i));
158 }
159
160 TH1* hY=new TH1F("hY", "Y Projection", kdY->GetNBins(), kdY->GetOneDimBinEdges());
161 for(int i=0; i<kdY->GetNBins(); ++i){
162 hY->SetBinContent(i+1, kdY->GetBinDensity(i));
163 }
164
165 c4->cd(3);
166 hX->Draw();
167 c4->cd(4);
168 hY->Draw();
169}
#define g(i)
Definition RSha256.hxx:105
unsigned int UInt_t
Definition RtypesCore.h:46
double Double_t
Definition RtypesCore.h:59
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
The Canvas class.
Definition TCanvas.h:23
Graphics object made of three arrays X, Y and Z with the same number of points each.
Definition TGraph2D.h:41
1-D histogram with a float per channel (see TH1 documentation)
Definition TH1.h:622
TH1 is the base class of all histogram classes in ROOT.
Definition TH1.h:59
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
Definition TH1.cxx:3344
void Draw(Option_t *option="") override
Draw this histogram with options.
Definition TH1.cxx:3066
2-D histogram with a double per channel (see TH1 documentation)
Definition TH2.h:357
2D Histogram with Polygonal Bins
Definition TH2Poly.h:66
<- TKDTreeBinning - A class providing multidimensional binning ->
Random number generator class based on M.
Definition TRandom3.h:27
return c1
Definition legend1.C:41
TH1F * h1
Definition legend1.C:5