Logo ROOT  
Reference Guide
variables.cxx
Go to the documentation of this file.
1#include "TMVA/variables.h"
2
3
4// this macro plots the distributions of the different input variables
5// used in TMVA (e.g. running TMVAnalysis.C). Signal and Background are overlayed.
6
7// input: - Input file (result from TMVA),
8// - normal/decorrelated/PCA
9// - use of TMVA plotting TStyle
10void TMVA::variables(TString dataset, TString fin, TString dirName , TString title ,
11 Bool_t isRegression, Bool_t useTMVAStyle )
12{
13 TString outfname = dirName;
14 outfname.ToLower(); outfname.ReplaceAll( "input", "" );
15
16 // set style and remove existing canvas'
17 TMVAGlob::Initialize( useTMVAStyle );
18
19 // obtain shorter histogram title
20 TString htitle = title;
21 htitle.ReplaceAll("variables ","variable");
22 htitle.ReplaceAll("and target(s)","");
23 htitle.ReplaceAll("(training sample)","");
24
25 // checks if file with name "fin" is already open, and if not opens one
27
28 TDirectory* dir = (TDirectory*)file->GetDirectory(dataset.Data())->Get(dirName );
29 if (dir==0) {
30 cout << "No information about " << title << " available in directory " << dirName << " of file " << fin << endl;
31 return;
32 }
33 dir->cd();
34
35 // how many plots are in the directory?
38
39 // define Canvas layout here!
40 // default setting
41 Int_t xPad; // no of plots in x
42 Int_t yPad; // no of plots in y
43 Int_t width; // size of canvas
44 Int_t height;
45 switch (noPlots) {
46 case 1:
47 xPad = 1; yPad = 1; width = 550; height = 0.90*width; break;
48 case 2:
49 xPad = 2; yPad = 1; width = 600; height = 0.50*width; break;
50 case 3:
51 xPad = 3; yPad = 1; width = 900; height = 0.4*width; break;
52 case 4:
53 xPad = 2; yPad = 2; width = 600; height = width; break;
54 default:
55 xPad = 3; yPad = 2; width = 800; height = 0.55*width; break;
56 }
57
58 Int_t noPadPerCanv = xPad * yPad ;
59
60 // counter variables
61 Int_t countCanvas = 0;
62 Int_t countPad = 0;
63
64 // loop over all objects in directory
65 TCanvas* canv = 0;
66 TKey* key = 0;
67 Bool_t createNewFig = kFALSE;
68 TIter next(dir->GetListOfKeys());
69 while ((key = (TKey*)next())) {
70 if (key->GetCycle() != 1) continue;
71
72 if (!TString(key->GetName()).Contains("__Signal") &&
73 !(isRegression && TString(key->GetName()).Contains("__Regression"))) continue;
74
75 // make sure, that we only look at histograms
76 TClass *cl = gROOT->GetClass(key->GetClassName());
77 if (!cl->InheritsFrom("TH1")) continue;
78 TH1 *sig = (TH1*)key->ReadObj();
79 TString hname(sig->GetName());
80
81 // create new canvas
82 if (countPad%noPadPerCanv==0) {
83 ++countCanvas;
84 canv = new TCanvas( Form("canvas%d", countCanvas), title,
85 countCanvas*50+50, countCanvas*20, width, height );
86 canv->Divide(xPad,yPad);
87 canv->Draw();
88 }
89
90 TPad* cPad = (TPad*)canv->cd(countPad++%noPadPerCanv+1);
91
92 // find the corredponding backgrouns histo
93 TString bgname = hname;
94 bgname.ReplaceAll("__Signal","__Background");
95 TH1 *bgd = (TH1*)dir->Get(bgname);
96 if (bgd == NULL) {
97 cout << "ERROR!!! couldn't find background histo for" << hname << endl;
98 return;
99 }
100
101 // this is set but not stored during plot creation in MVA_Factory
102 TMVAGlob::SetSignalAndBackgroundStyle( sig, (isRegression ? 0 : bgd) );
103
104 sig->SetTitle( TString( htitle ) + ": " + sig->GetTitle() );
105 TMVAGlob::SetFrameStyle( sig, 1.2 );
106
107 // normalise both signal and background
108 if (!isRegression) TMVAGlob::NormalizeHists( sig, bgd );
109 else {
110 // change histogram title for target
111 TString nme = sig->GetName();
112 if (nme.Contains( "_target" )) {
113 TString tit = sig->GetTitle();
114 sig->SetTitle( tit.ReplaceAll("Input variable", "Regression target" ) );
115 }
116 }
117
118 // finally plot and overlay
119 Float_t sc = 1.1;
120 if (countPad == 1) sc = 1.3;
121 sig->SetMaximum( TMath::Max( sig->GetMaximum(), bgd->GetMaximum() )*sc );
122 sig->Draw( "hist" );
123 cPad->SetLeftMargin( 0.17 );
124
125 sig->GetYaxis()->SetTitleOffset( 1.70 );
126 if (!isRegression) {
127 bgd->Draw("histsame");
128 TString ytit = TString("(1/N) ") + sig->GetYaxis()->GetTitle();
129 sig->GetYaxis()->SetTitle( ytit ); // histograms are normalised
130 }
131
132 // Draw legend
133 if (countPad == 1 && !isRegression) {
134 TLegend *legend= new TLegend( cPad->GetLeftMargin(),
135 1-cPad->GetTopMargin()-.15,
136 cPad->GetLeftMargin()+.4,
137 1-cPad->GetTopMargin() );
138 legend->SetFillStyle(1);
139 legend->AddEntry(sig,"Signal","F");
140 legend->AddEntry(bgd,"Background","F");
141 legend->SetBorderSize(1);
142 legend->SetMargin( 0.3 );
143 legend->Draw("same");
144 }
145
146 // redraw axes
147 sig->Draw("sameaxis");
148
149 // text for overflows
150 Int_t nbin = sig->GetNbinsX();
151 Double_t dxu = sig->GetBinWidth(0);
152 Double_t dxo = sig->GetBinWidth(nbin+1);
153 TString uoflow = "";
154 if (isRegression) {
155 uoflow = Form( "U/O-flow: %.1f%% / %.1f%%",
156 sig->GetBinContent(0)*dxu*100, sig->GetBinContent(nbin+1)*dxo*100 );
157 }
158 else {
159 uoflow = Form( "U/O-flow (S,B): (%.1f, %.1f)%% / (%.1f, %.1f)%%",
160 sig->GetBinContent(0)*dxu*100, bgd->GetBinContent(0)*dxu*100,
161 sig->GetBinContent(nbin+1)*dxo*100, bgd->GetBinContent(nbin+1)*dxo*100 );
162 }
163
164 TText* t = new TText( 0.98, 0.14, uoflow );
165 t->SetNDC();
166 t->SetTextSize( 0.040 );
167 t->SetTextAngle( 90 );
168 t->AppendPad();
169
170 // save canvas to file
171 if (countPad%noPadPerCanv==0) {
172 TString fname = Form( "%s/plots/%s_c%i",dataset.Data(), outfname.Data(), countCanvas );
174 TMVAGlob::imgconv( canv, fname );
175 createNewFig = kFALSE;
176 }
177 else {
178 createNewFig = kTRUE;
179 }
180 }
181
182 if (createNewFig) {
183 TString fname = Form( "%s/plots/%s_c%i",dataset.Data(), outfname.Data(), countCanvas );
185 TMVAGlob::imgconv( canv, fname );
186 createNewFig = kFALSE;
187 }
188
189 return;
190}
int Int_t
Definition: RtypesCore.h:41
const Bool_t kFALSE
Definition: RtypesCore.h:88
bool Bool_t
Definition: RtypesCore.h:59
double Double_t
Definition: RtypesCore.h:55
float Float_t
Definition: RtypesCore.h:53
const Bool_t kTRUE
Definition: RtypesCore.h:87
include TDocParser_001 C image html pict1_TDocParser_001 png width
Definition: TDocParser.cxx:121
#define gROOT
Definition: TROOT.h:415
char * Form(const char *fmt,...)
virtual void SetTitleOffset(Float_t offset=1)
Set distance between the axis and the axis title.
Definition: TAttAxis.cxx:294
virtual void SetFillStyle(Style_t fstyle)
Set the fill area style.
Definition: TAttFill.h:39
virtual void SetLeftMargin(Float_t leftmargin)
Set Pad left margin in fraction of the pad width.
Definition: TAttPad.cxx:110
Float_t GetLeftMargin() const
Definition: TAttPad.h:44
Float_t GetTopMargin() const
Definition: TAttPad.h:46
virtual void SetTextAngle(Float_t tangle=0)
Set the text angle.
Definition: TAttText.h:42
virtual void SetTextSize(Float_t tsize=1)
Set the text size.
Definition: TAttText.h:46
const char * GetTitle() const
Returns title of object.
Definition: TAxis.h:129
The Canvas class.
Definition: TCanvas.h:31
virtual void Draw(Option_t *option="")
Draw a canvas.
Definition: TCanvas.cxx:833
TVirtualPad * cd(Int_t subpadnumber=0)
Set current canvas & pad.
Definition: TCanvas.cxx:696
TClass instances represent classes, structs and namespaces in the ROOT type system.
Definition: TClass.h:75
Bool_t InheritsFrom(const char *cl) const
Return kTRUE if this class inherits from a class with name "classname".
Definition: TClass.cxx:4708
Describe directory structure in memory.
Definition: TDirectory.h:34
virtual TObject * Get(const char *namecycle)
Return pointer to object identified by namecycle.
Definition: TDirectory.cxx:805
virtual TList * GetListOfKeys() const
Definition: TDirectory.h:160
virtual Bool_t cd(const char *path=nullptr)
Change current directory to "this" directory.
Definition: TDirectory.cxx:497
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format.
Definition: TFile.h:48
The TH1 histogram class.
Definition: TH1.h:56
virtual void SetTitle(const char *title)
See GetStatOverflows for more information.
Definition: TH1.cxx:6333
virtual Double_t GetMaximum(Double_t maxval=FLT_MAX) const
Return maximum value smaller than maxval of bins in the range, unless the value has been overridden b...
Definition: TH1.cxx:7994
virtual Int_t GetNbinsX() const
Definition: TH1.h:292
virtual void SetMaximum(Double_t maximum=-1111)
Definition: TH1.h:394
TAxis * GetYaxis()
Definition: TH1.h:317
virtual void Draw(Option_t *option="")
Draw this histogram with options.
Definition: TH1.cxx:2998
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
Definition: TH1.cxx:4899
virtual Double_t GetBinWidth(Int_t bin) const
Return bin width for 1D histogram.
Definition: TH1.cxx:8607
Book space in a file, create I/O buffers, to fill them, (un)compress them.
Definition: TKey.h:24
virtual const char * GetClassName() const
Definition: TKey.h:72
Short_t GetCycle() const
Return cycle number associated to this key.
Definition: TKey.cxx:568
virtual TObject * ReadObj()
To read a TObject* from the file.
Definition: TKey.cxx:729
This class displays a legend box (TPaveText) containing several legend entries.
Definition: TLegend.h:23
TLegendEntry * AddEntry(const TObject *obj, const char *label="", Option_t *option="lpf")
Add a new entry to this legend.
Definition: TLegend.cxx:330
virtual void Draw(Option_t *option="")
Draw this legend with its current attributes.
Definition: TLegend.cxx:423
void SetMargin(Float_t margin)
Definition: TLegend.h:69
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
Definition: TNamed.cxx:164
virtual const char * GetTitle() const
Returns title of object.
Definition: TNamed.h:48
virtual const char * GetName() const
Returns name of object.
Definition: TNamed.h:47
virtual void AppendPad(Option_t *option="")
Append graphics object to current pad.
Definition: TObject.cxx:105
The most important graphics class in the ROOT system.
Definition: TPad.h:29
virtual void Divide(Int_t nx=1, Int_t ny=1, Float_t xmargin=0.01, Float_t ymargin=0.01, Int_t color=0)
Automatic pad generation by division.
Definition: TPad.cxx:1163
virtual void SetBorderSize(Int_t bordersize=4)
Definition: TPave.h:73
Basic string class.
Definition: TString.h:131
void ToLower()
Change string to lower-case.
Definition: TString.cxx:1125
const char * Data() const
Definition: TString.h:364
TString & ReplaceAll(const TString &s1, const TString &s2)
Definition: TString.h:687
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Definition: TString.h:619
Base class for several text objects.
Definition: TText.h:23
virtual void SetNDC(Bool_t isNDC=kTRUE)
Set NDC mode on if isNDC = kTRUE, off otherwise.
Definition: TText.cxx:812
void Initialize(Bool_t useTMVAStyle=kTRUE)
Definition: tmvaglob.cxx:176
void NormalizeHists(TH1 *sig, TH1 *bkg=0)
Definition: tmvaglob.cxx:317
Int_t GetNumberOfInputVariables(TDirectory *dir)
Definition: tmvaglob.cxx:413
void plot_logo(Float_t v_scale=1.0, Float_t skew=1.0)
Definition: tmvaglob.cxx:263
TFile * OpenFile(const TString &fin)
Definition: tmvaglob.cxx:192
void SetFrameStyle(TH1 *frame, Float_t scale=1.0)
Definition: tmvaglob.cxx:77
Int_t GetNumberOfTargets(TDirectory *dir)
Definition: tmvaglob.cxx:396
void SetSignalAndBackgroundStyle(TH1 *sig, TH1 *bkg, TH1 *all=0)
Definition: tmvaglob.cxx:8
void imgconv(TCanvas *c, const TString &fname)
Definition: tmvaglob.cxx:212
void variables(TString dataset, TString fin="TMVA.root", TString dirName="InputVariables_Id", TString title="TMVA Input Variables", Bool_t isRegression=kFALSE, Bool_t useTMVAStyle=kTRUE)
Short_t Max(Short_t a, Short_t b)
Definition: TMathBase.h:212
Definition: file.py:1