Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
DecisionTreeNode.h
Go to the documentation of this file.
1// @(#)root/tmva $Id$
2// Author: Andreas Hoecker, Joerg Stelzer, Helge Voss, Kai Voss, Eckhard von Toerne
3
4/**********************************************************************************
5 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis *
6 * Package: TMVA *
7 * Class : DecisionTreeNode *
8 * *
9 * *
10 * Description: *
11 * Node for the Decision Tree *
12 * *
13 * Authors (alphabetical): *
14 * Andreas Hoecker <Andreas.Hocker@cern.ch> - CERN, Switzerland *
15 * Helge Voss <Helge.Voss@cern.ch> - MPI-K Heidelberg, Germany *
16 * Kai Voss <Kai.Voss@cern.ch> - U. of Victoria, Canada *
17 * Eckhard von Toerne <evt@physik.uni-bonn.de> - U. of Bonn, Germany *
18 * *
19 * Copyright (c) 2009: *
20 * CERN, Switzerland *
21 * U. of Victoria, Canada *
22 * MPI-K Heidelberg, Germany *
23 * U. of Bonn, Germany *
24 * *
25 * Redistribution and use in source and binary forms, with or without *
26 * modification, are permitted according to the terms listed in LICENSE *
27 * (see tmva/doc/LICENSE) *
28 **********************************************************************************/
29
30#ifndef ROOT_TMVA_DecisionTreeNode
31#define ROOT_TMVA_DecisionTreeNode
32
33//////////////////////////////////////////////////////////////////////////
34// //
35// DecisionTreeNode //
36// //
37// Node for the Decision Tree //
38// //
39//////////////////////////////////////////////////////////////////////////
40
41#include "TMVA/Node.h"
42
43#include "TMVA/Version.h"
44
45#include <sstream>
46#include <vector>
47#include <string>
48
49namespace TMVA {
50
52 {
53 public:
55 fSampleMax(),
56 fNodeR(0),fSubTreeR(0),fAlpha(0),fG(0),fNTerminal(0),
57 fNB(0),fNS(0),fSumTarget(0),fSumTarget2(0),fCC(0),
58 fNSigEvents ( 0 ), fNBkgEvents ( 0 ),
59 fNEvents ( -1 ),
66 fSeparationIndex (-1 ),
67 fSeparationGain ( -1 )
68 {
69 }
70 std::vector< Float_t > fSampleMin; ///< the minima for each ivar of the sample on the node during training
71 std::vector< Float_t > fSampleMax; ///< the maxima for each ivar of the sample on the node during training
72 Double_t fNodeR; ///< node resubstitution estimate, R(t)
73 Double_t fSubTreeR; ///< R(T) = Sum(R(t) : t in ~T)
74 Double_t fAlpha; ///< critical alpha for this node
75 Double_t fG; ///< minimum alpha in subtree rooted at this node
76 Int_t fNTerminal; ///< number of terminal nodes in subtree rooted at this node
77 Double_t fNB; ///< sum of weights of background events from the pruning sample in this node
78 Double_t fNS; ///< ditto for the signal events
79 Float_t fSumTarget; ///< sum of weight*target used for the calculation of the variance (regression)
80 Float_t fSumTarget2; ///< sum of weight*target^2 used for the calculation of the variance (regression)
81 Double_t fCC; ///< debug variable for cost complexity pruning ..
82
83 Float_t fNSigEvents; ///< sum of weights of signal event in the node
84 Float_t fNBkgEvents; ///< sum of weights of backgr event in the node
85 Float_t fNEvents; ///< number of events in that entered the node (during training)
86 Float_t fNSigEvents_unweighted; ///< sum of signal event in the node
87 Float_t fNBkgEvents_unweighted; ///< sum of backgr event in the node
88 Float_t fNEvents_unweighted; ///< number of events in that entered the node (during training)
89 Float_t fNSigEvents_unboosted; ///< sum of signal event in the node
90 Float_t fNBkgEvents_unboosted; ///< sum of backgr event in the node
91 Float_t fNEvents_unboosted; ///< number of events in that entered the node (during training)
92 Float_t fSeparationIndex; ///< measure of "purity" (separation between S and B) AT this node
93 Float_t fSeparationGain; ///< measure of "purity", separation, or information gained BY this nodes selection
94
95 // copy constructor
97 fSampleMin(),fSampleMax(), ///< Samplemin and max are reset in copy constructor
99 fAlpha(n.fAlpha), fG(n.fG),
101 fNB(n.fNB), fNS(n.fNS),
102 fSumTarget(0),fSumTarget2(0), ///< SumTarget reset in copy constructor
103 fCC(0),
105 fNEvents ( n.fNEvents ),
111 { }
112 };
113
114 class Event;
115 class MsgLogger;
116
117 class DecisionTreeNode: public Node {
118
119 public:
120
121 // constructor of an essentially "empty" node floating in space
123 // constructor of a daughter node as a daughter of 'p'
124 DecisionTreeNode (Node* p, char pos);
125
126 // copy constructor
127 DecisionTreeNode (const DecisionTreeNode &n, DecisionTreeNode* parent = nullptr);
128
129 // destructor
130 virtual ~DecisionTreeNode();
131
132 virtual Node* CreateNode() const { return new DecisionTreeNode(); }
133
134 inline void SetNFisherCoeff(Int_t nvars){fFisherCoeff.resize(nvars);}
135 inline UInt_t GetNFisherCoeff() const { return fFisherCoeff.size();}
136 // set fisher coefficients
137 void SetFisherCoeff(Int_t ivar, Double_t coeff);
138 /// get fisher coefficients
139 Double_t GetFisherCoeff(Int_t ivar) const {return fFisherCoeff.at(ivar);}
140
141 // test event if it descends the tree at this node to the right
142 virtual Bool_t GoesRight( const Event & ) const;
143
144 // test event if it descends the tree at this node to the left
145 virtual Bool_t GoesLeft ( const Event & ) const;
146
147 /// set index of variable used for discrimination at this node
148 void SetSelector( Short_t i) { fSelector = i; }
149 /// return index of variable used for discrimination at this node
150 Short_t GetSelector() const { return fSelector; }
151
152 /// set the cut value applied at this node
154 /// return the cut value applied at this node
155 Float_t GetCutValue ( void ) const { return fCutValue; }
156
157 /// set true: if event variable > cutValue ==> signal , false otherwise
158 void SetCutType( Bool_t t ) { fCutType = t; }
159 /// return kTRUE: Cuts select signal, kFALSE: Cuts select bkg
160 Bool_t GetCutType( void ) const { return fCutType; }
161
162 /// set node type: 1 signal node, -1 bkg leave, 0 intermediate Node
163 void SetNodeType( Int_t t ) { fNodeType = t;}
164 /// return node type: 1 signal node, -1 bkg leave, 0 intermediate Node
165 Int_t GetNodeType( void ) const { return fNodeType; }
166
167 /// return S/(S+B) (purity) at this node (from training)
168 Float_t GetPurity( void ) const { return fPurity;}
169 // calculate S/(S+B) (purity) at this node (from training)
170 void SetPurity( void );
171
172 /// set the response of the node (for regression)
174
175 /// return the response of the node (for regression)
176 Float_t GetResponse( void ) const { return fResponse;}
177
178 /// set the RMS of the response of the node (for regression)
179 void SetRMS( Float_t r ) { fRMS = r;}
180
181 /// return the RMS of the response of the node (for regression)
182 Float_t GetRMS( void ) const { return fRMS;}
183
184 /// set the sum of the signal weights in the node, if traininfo defined
186
187 /// set the sum of the backgr weights in the node, if traininfo defined
189
190 /// set the number of events that entered the node (during training), if traininfo defined
192
193 /// set the sum of the unweighted signal events in the node, if traininfo defined
195
196 /// set the sum of the unweighted backgr events in the node, if traininfo defined
198
199 /// set the number of unweighted events that entered the node (during training), if traininfo defined
201
202 /// set the sum of the unboosted signal events in the node, if traininfo defined
204
205 /// set the sum of the unboosted backgr events in the node, if traininfo defined
207
208 /// set the number of unboosted events that entered the node (during training), if traininfo defined
210
211 /// increment the sum of the signal weights in the node, if traininfo defined
213
214 /// increment the sum of the backgr weights in the node, if traininfo defined
216
217 // increment the number of events that entered the node (during training), if traininfo defined
219
220 /// increment the sum of the signal weights in the node, if traininfo defined
222
223 /// increment the sum of the backgr weights in the node, if traininfo defined
225
226 /// increment the number of events that entered the node (during training), if traininfo defined
228
229 /// return the sum of the signal weights in the node, or -1 if traininfo undefined
230 Float_t GetNSigEvents( void ) const { return fTrainInfo ? fTrainInfo->fNSigEvents : -1.; }
231
232 /// return the sum of the backgr weights in the node, or -1 if traininfo undefined
233 Float_t GetNBkgEvents( void ) const { return fTrainInfo ? fTrainInfo->fNBkgEvents : -1.; }
234
235 /// return the number of events that entered the node (during training), or -1 if traininfo undefined
236 Float_t GetNEvents( void ) const { return fTrainInfo ? fTrainInfo->fNEvents : -1.; }
237
238 // return the sum of unweighted signal weights in the node, or -1 if traininfo undefined
240
241 /// return the sum of unweighted backgr weights in the node, or -1 if traininfo undefined
243
244 /// return the number of unweighted events that entered the node (during training), or -1 if traininfo undefined
246
247 /// return the sum of unboosted signal weights in the node, or -1 if traininfo undefined
249
250 /// return the sum of unboosted backgr weights in the node, or -1 if traininfo undefined
252
253 /// return the number of unboosted events that entered the node (during training), or -1 if traininfo undefined
255
256 /// set the chosen index, measure of "purity" (separation between S and B) AT this node, if traininfo defined
258
259 /// return the separation index AT this node, or 0 if traininfo undefined
261
262 /// set the separation, or information gained BY this node's selection, if traininfo defined
264
265 /// return the gain in separation obtained by this node's selection, or -1 if traininfo undefined
267
268 // printout of the node
269 virtual void Print( std::ostream& os ) const;
270
271 // recursively print the node and its daughters (--> print the 'tree')
272 virtual void PrintRec( std::ostream& os ) const;
273
274 virtual void AddAttributesToNode(void* node) const;
275 virtual void AddContentToNode(std::stringstream& s) const;
276
277 // recursively clear the nodes content (S/N etc, but not the cut criteria)
279
280 // get pointers to children, mother in the tree
281
282 // return pointer to the left/right daughter or parent node
283 inline virtual DecisionTreeNode* GetLeft( ) const { return static_cast<DecisionTreeNode*>(fLeft); }
284 inline virtual DecisionTreeNode* GetRight( ) const { return static_cast<DecisionTreeNode*>(fRight); }
285 inline virtual DecisionTreeNode* GetParent( ) const { return static_cast<DecisionTreeNode*>(fParent); }
286
287 // set pointer to the left/right daughter and parent node
288 inline virtual void SetLeft (Node* l) { fLeft = l;}
289 inline virtual void SetRight (Node* r) { fRight = r;}
290 inline virtual void SetParent(Node* p) { fParent = p;}
291
292 /// set the node resubstitution estimate, R(t), for Cost Complexity pruning, if traininfo defined
293 inline void SetNodeR( Double_t r ) { if(fTrainInfo) fTrainInfo->fNodeR = r; }
294 /// return the node resubstitution estimate, R(t), for Cost Complexity pruning, or -1 if traininfo undefined
295 inline Double_t GetNodeR( ) const { return fTrainInfo ? fTrainInfo->fNodeR : -1.; }
296
297 /// set the resubstitution estimate, R(T_t), of the tree rooted at this node, if traininfo defined
299 /// return the resubstitution estimate, R(T_t), of the tree rooted at this node, or -1 if traininfo undefined
300 inline Double_t GetSubTreeR( ) const { return fTrainInfo ? fTrainInfo->fSubTreeR : -1.; }
301
302 // R(t) - R(T_t)
303 // the critical point alpha = -------------
304 // |~T_t| - 1
305 /// set the critical point alpha, if traininfo defined
306 inline void SetAlpha( Double_t alpha ) { if(fTrainInfo) fTrainInfo->fAlpha = alpha; }
307 /// return the critical point alpha, or -1 if traininfo undefined
308 inline Double_t GetAlpha( ) const { return fTrainInfo ? fTrainInfo->fAlpha : -1.; }
309
310 /// set the minimum alpha in the tree rooted at this node, if traininfo defined
312 /// return the minimum alpha in the tree rooted at this node, or -1 if traininfo undefined
313 inline Double_t GetAlphaMinSubtree( ) const { return fTrainInfo ? fTrainInfo->fG : -1.; }
314
315 /// set number of terminal nodes in the subtree rooted here, if traininfo defined
317 /// return number of terminal nodes in the subtree rooted here, or -1 if traininfo undefined
318 inline Int_t GetNTerminal( ) const { return fTrainInfo ? fTrainInfo->fNTerminal : -1.; }
319
320 /// set number of background events from the pruning validation sample, if traininfo defined
322 /// set number of signal events from the pruning validation sample, if traininfo defined
323 inline void SetNSValidation( Double_t s ) { if(fTrainInfo) fTrainInfo->fNS = s; }
324 /// return number of background events from the pruning validation sample, or -1 if traininfo undefined
325 inline Double_t GetNBValidation( ) const { return fTrainInfo ? fTrainInfo->fNB : -1.; }
326 /// return number of signal events from the pruning validation sample, or -1 if traininfo undefined
327 inline Double_t GetNSValidation( ) const { return fTrainInfo ? fTrainInfo->fNS : -1.; }
328
329 /// set sum target, if traininfo defined
331 /// set sum target 2, if traininfo defined
333
334 /// add to sum target, if traininfo defined
336 /// add to sum target 2, if traininfo defined
338
339 /// return sum target, or -9999 if traininfo undefined
340 inline Float_t GetSumTarget() const {return fTrainInfo? fTrainInfo->fSumTarget : -9999;}
341 /// return sum target 2, or -9999 if traininfo undefined
342 inline Float_t GetSumTarget2() const {return fTrainInfo? fTrainInfo->fSumTarget2: -9999;}
343
344
345 // reset the pruning validation data
346 void ResetValidationData( );
347
348 /// flag indicates whether this node is terminal
349 inline Bool_t IsTerminal() const { return fIsTerminalNode; }
350 inline void SetTerminal( Bool_t s = kTRUE ) { fIsTerminalNode = s; }
351 void PrintPrune( std::ostream& os ) const ;
352 void PrintRecPrune( std::ostream& os ) const;
353
354 void SetCC(Double_t cc);
355 /// return CC, or -1 if traininfo undefined
356 Double_t GetCC() const {return (fTrainInfo? fTrainInfo->fCC : -1.);}
357
358 Float_t GetSampleMin(UInt_t ivar) const;
359 Float_t GetSampleMax(UInt_t ivar) const;
360 void SetSampleMin(UInt_t ivar, Float_t xmin);
361 void SetSampleMax(UInt_t ivar, Float_t xmax);
362
363 static void SetIsTraining(bool on);
364 static void SetTmvaVersionCode(UInt_t code);
365
366 static bool IsTraining();
367 static UInt_t GetTmvaVersionCode();
368
369 virtual Bool_t ReadDataRecord( std::istream& is, UInt_t tmva_Version_Code = TMVA_VERSION_CODE );
370 virtual void ReadAttributes(void* node, UInt_t tmva_Version_Code = TMVA_VERSION_CODE );
371 virtual void ReadContent(std::stringstream& s);
372
373 protected:
374
375 static MsgLogger& Log();
376
377 static bool fgIsTraining; ///< static variable to flag training phase in which we need fTrainInfo
378 static UInt_t fgTmva_Version_Code; ///< set only when read from weightfile
379
380 std::vector<Double_t> fFisherCoeff; ///< the fisher coeff (offset at the last element)
381
382 Float_t fCutValue; ///< cut value applied on this node to discriminate bkg against sig
383 Bool_t fCutType; ///< true: if event variable > cutValue ==> signal , false otherwise
384 Short_t fSelector; ///< index of variable used in node selection (decision tree)
385
386 Float_t fResponse; ///< response value in case of regression
387 Float_t fRMS; ///< response RMS of the regression node
388 Int_t fNodeType; ///< Type of node: -1 == Bkg-leaf, 1 == Signal-leaf, 0 = internal
389 Float_t fPurity; ///< the node purity
390
391 Bool_t fIsTerminalNode; ///<! flag to set node as terminal (i.e., without deleting its descendants)
392
394
395 private:
396
397 ClassDef(DecisionTreeNode,0); // Node for the Decision Tree
398 };
399} // namespace TMVA
400
401#endif
#define b(i)
Definition RSha256.hxx:100
#define c(i)
Definition RSha256.hxx:101
#define g(i)
Definition RSha256.hxx:105
bool Bool_t
Definition RtypesCore.h:63
unsigned int UInt_t
Definition RtypesCore.h:46
float Float_t
Definition RtypesCore.h:57
short Short_t
Definition RtypesCore.h:39
double Double_t
Definition RtypesCore.h:59
constexpr Bool_t kTRUE
Definition RtypesCore.h:93
#define ClassDef(name, id)
Definition Rtypes.h:337
winID h TVirtualViewer3D TVirtualGLPainter p
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
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void on
float xmin
float xmax
#define TMVA_VERSION_CODE
Definition Version.h:47
Float_t fSumTarget2
sum of weight*target^2 used for the calculation of the variance (regression)
Double_t fG
minimum alpha in subtree rooted at this node
Double_t fAlpha
critical alpha for this node
Double_t fNodeR
node resubstitution estimate, R(t)
std::vector< Float_t > fSampleMax
the maxima for each ivar of the sample on the node during training
Float_t fNEvents
number of events in that entered the node (during training)
Float_t fNEvents_unboosted
number of events in that entered the node (during training)
Float_t fSeparationIndex
measure of "purity" (separation between S and B) AT this node
Float_t fNEvents_unweighted
number of events in that entered the node (during training)
Float_t fNSigEvents
sum of weights of signal event in the node
Float_t fNSigEvents_unweighted
sum of signal event in the node
Float_t fSeparationGain
measure of "purity", separation, or information gained BY this nodes selection
Float_t fNSigEvents_unboosted
sum of signal event in the node
DTNodeTrainingInfo(const DTNodeTrainingInfo &n)
Float_t fNBkgEvents_unboosted
sum of backgr event in the node
Double_t fSubTreeR
R(T) = Sum(R(t) : t in ~T)
Double_t fNB
sum of weights of background events from the pruning sample in this node
Double_t fCC
debug variable for cost complexity pruning ..
std::vector< Float_t > fSampleMin
the minima for each ivar of the sample on the node during training
Float_t fSumTarget
sum of weight*target used for the calculation of the variance (regression)
Double_t fNS
ditto for the signal events
Float_t fNBkgEvents
sum of weights of backgr event in the node
Int_t fNTerminal
number of terminal nodes in subtree rooted at this node
Float_t fNBkgEvents_unweighted
sum of backgr event in the node
virtual void AddContentToNode(std::stringstream &s) const
adding attributes to tree node (well, was used in BinarySearchTree, and somehow I guess someone progr...
void SetNEvents_unweighted(Float_t nev)
set the number of unweighted events that entered the node (during training), if traininfo defined
Float_t GetNBkgEvents_unboosted(void) const
return the sum of unboosted backgr weights in the node, or -1 if traininfo undefined
virtual void ReadAttributes(void *node, UInt_t tmva_Version_Code=262657)
void SetCC(Double_t cc)
Set CC, if traininfo defined, otherwise Log Fatal.
DTNodeTrainingInfo * fTrainInfo
Bool_t fIsTerminalNode
! flag to set node as terminal (i.e., without deleting its descendants)
virtual ~DecisionTreeNode()
destructor
Float_t GetNSigEvents_unweighted(void) const
Float_t GetNBkgEvents_unweighted(void) const
return the sum of unweighted backgr weights in the node, or -1 if traininfo undefined
void SetNodeType(Int_t t)
set node type: 1 signal node, -1 bkg leave, 0 intermediate Node
Int_t fNodeType
Type of node: -1 == Bkg-leaf, 1 == Signal-leaf, 0 = internal.
Double_t GetSubTreeR() const
return the resubstitution estimate, R(T_t), of the tree rooted at this node, or -1 if traininfo undef...
Float_t GetSeparationIndex(void) const
return the separation index AT this node, or 0 if traininfo undefined
void SetSeparationGain(Float_t sep)
set the separation, or information gained BY this node's selection, if traininfo defined
void SetNBkgEvents(Float_t b)
set the sum of the backgr weights in the node, if traininfo defined
void SetCutType(Bool_t t)
set true: if event variable > cutValue ==> signal , false otherwise
Float_t GetNSigEvents_unboosted(void) const
return the sum of unboosted signal weights in the node, or -1 if traininfo undefined
Double_t GetNSValidation() const
return number of signal events from the pruning validation sample, or -1 if traininfo undefined
static void SetIsTraining(bool on)
void PrintPrune(std::ostream &os) const
printout of the node (can be read in with ReadDataRecord)
Float_t GetSumTarget() const
return sum target, or -9999 if traininfo undefined
void IncrementNEvents_unweighted()
increment the number of events that entered the node (during training), if traininfo defined
void PrintRecPrune(std::ostream &os) const
recursive printout of the node and its daughters
void SetFisherCoeff(Int_t ivar, Double_t coeff)
set fisher coefficients
void SetNSigEvents_unboosted(Float_t s)
set the sum of the unboosted signal events in the node, if traininfo defined
void SetSumTarget2(Float_t t2)
set sum target 2, if traininfo defined
Float_t fRMS
response RMS of the regression node
void SetAlphaMinSubtree(Double_t g)
set the minimum alpha in the tree rooted at this node, if traininfo defined
static UInt_t fgTmva_Version_Code
set only when read from weightfile
void IncrementNBkgEvents(Float_t b)
increment the sum of the backgr weights in the node, if traininfo defined
Short_t fSelector
index of variable used in node selection (decision tree)
void SetNEvents_unboosted(Float_t nev)
set the number of unboosted events that entered the node (during training), if traininfo defined
Float_t GetNSigEvents(void) const
return the sum of the signal weights in the node, or -1 if traininfo undefined
Float_t fPurity
the node purity
virtual void SetLeft(Node *l)
Double_t GetAlphaMinSubtree() const
return the minimum alpha in the tree rooted at this node, or -1 if traininfo undefined
void SetTerminal(Bool_t s=kTRUE)
Float_t GetNEvents_unweighted(void) const
return the number of unweighted events that entered the node (during training), or -1 if traininfo un...
void SetResponse(Float_t r)
set the response of the node (for regression)
UInt_t GetNFisherCoeff() const
void SetSampleMax(UInt_t ivar, Float_t xmax)
set the maximum of variable ivar from the training sample that pass/end up in this node,...
void ClearNodeAndAllDaughters()
clear the nodes (their S/N, Nevents etc), just keep the structure of the tree
virtual Bool_t GoesLeft(const Event &) const
test event if it descends the tree at this node to the left
static void SetTmvaVersionCode(UInt_t code)
virtual void ReadContent(std::stringstream &s)
reading attributes from tree node (well, was used in BinarySearchTree, and somehow I guess someone pr...
void SetNBValidation(Double_t b)
set number of background events from the pruning validation sample, if traininfo defined
Float_t GetRMS(void) const
return the RMS of the response of the node (for regression)
void IncrementNEvents(Float_t nev)
void SetPurity(void)
return the S/(S+B) (purity) for the node REM: even if nodes with purity 0.01 are very PURE background...
void SetSubTreeR(Double_t r)
set the resubstitution estimate, R(T_t), of the tree rooted at this node, if traininfo defined
void AddToSumTarget2(Float_t t2)
add to sum target 2, if traininfo defined
virtual void Print(std::ostream &os) const
print the node
virtual DecisionTreeNode * GetLeft() const
Double_t GetNodeR() const
return the node resubstitution estimate, R(t), for Cost Complexity pruning, or -1 if traininfo undefi...
Float_t fCutValue
cut value applied on this node to discriminate bkg against sig
Float_t GetSumTarget2() const
return sum target 2, or -9999 if traininfo undefined
virtual Bool_t GoesRight(const Event &) const
test event if it descends the tree at this node to the right
DecisionTreeNode()
constructor of an essentially "empty" node floating in space
void SetNFisherCoeff(Int_t nvars)
virtual void AddAttributesToNode(void *node) const
add attribute to xml
Short_t GetSelector() const
return index of variable used for discrimination at this node
virtual Bool_t ReadDataRecord(std::istream &is, UInt_t tmva_Version_Code=262657)
Read the data block.
static UInt_t GetTmvaVersionCode()
void SetNSigEvents(Float_t s)
set the sum of the signal weights in the node, if traininfo defined
Float_t GetResponse(void) const
return the response of the node (for regression)
Float_t GetCutValue(void) const
return the cut value applied at this node
Int_t GetNodeType(void) const
return node type: 1 signal node, -1 bkg leave, 0 intermediate Node
Double_t GetAlpha() const
return the critical point alpha, or -1 if traininfo undefined
Int_t GetNTerminal() const
return number of terminal nodes in the subtree rooted here, or -1 if traininfo undefined
void IncrementNBkgEvents_unweighted()
increment the sum of the backgr weights in the node, if traininfo defined
Bool_t fCutType
true: if event variable > cutValue ==> signal , false otherwise
Bool_t GetCutType(void) const
return kTRUE: Cuts select signal, kFALSE: Cuts select bkg
static MsgLogger & Log()
void ResetValidationData()
temporary stored node values (number of events, etc.) that originate not from the training but from t...
virtual void PrintRec(std::ostream &os) const
recursively print the node and its daughters (--> print the 'tree')
void SetNSigEvents_unweighted(Float_t s)
set the sum of the unweighted signal events in the node, if traininfo defined
Float_t GetNEvents(void) const
return the number of events that entered the node (during training), or -1 if traininfo undefined
Double_t GetCC() const
return CC, or -1 if traininfo undefined
virtual Node * CreateNode() const
Double_t GetNBValidation() const
return number of background events from the pruning validation sample, or -1 if traininfo undefined
static bool fgIsTraining
static variable to flag training phase in which we need fTrainInfo
void SetAlpha(Double_t alpha)
set the critical point alpha, if traininfo defined
void SetSeparationIndex(Float_t sep)
set the chosen index, measure of "purity" (separation between S and B) AT this node,...
virtual void SetRight(Node *r)
void SetRMS(Float_t r)
set the RMS of the response of the node (for regression)
Float_t fResponse
response value in case of regression
void IncrementNSigEvents_unweighted()
increment the sum of the signal weights in the node, if traininfo defined
void SetSumTarget(Float_t t)
set sum target, if traininfo defined
virtual void SetParent(Node *p)
void SetNodeR(Double_t r)
set the node resubstitution estimate, R(t), for Cost Complexity pruning, if traininfo defined
void SetNBkgEvents_unboosted(Float_t b)
set the sum of the unboosted backgr events in the node, if traininfo defined
Float_t GetPurity(void) const
return S/(S+B) (purity) at this node (from training)
Float_t GetNEvents_unboosted(void) const
return the number of unboosted events that entered the node (during training), or -1 if traininfo und...
void IncrementNSigEvents(Float_t s)
increment the sum of the signal weights in the node, if traininfo defined
Float_t GetSeparationGain(void) const
return the gain in separation obtained by this node's selection, or -1 if traininfo undefined
Float_t GetSampleMax(UInt_t ivar) const
return the maximum of variable ivar from the training sample that pass/end up in this node,...
void SetCutValue(Float_t c)
set the cut value applied at this node
Float_t GetNBkgEvents(void) const
return the sum of the backgr weights in the node, or -1 if traininfo undefined
Float_t GetSampleMin(UInt_t ivar) const
return the minimum of variable ivar from the training sample that pass/end up in this node,...
void SetSampleMin(UInt_t ivar, Float_t xmin)
set the minimum of variable ivar from the training sample that pass/end up in this node,...
void SetSelector(Short_t i)
set index of variable used for discrimination at this node
std::vector< Double_t > fFisherCoeff
the fisher coeff (offset at the last element)
virtual DecisionTreeNode * GetParent() const
Double_t GetFisherCoeff(Int_t ivar) const
get fisher coefficients
void SetNBkgEvents_unweighted(Float_t b)
set the sum of the unweighted backgr events in the node, if traininfo defined
void SetNSValidation(Double_t s)
set number of signal events from the pruning validation sample, if traininfo defined
void AddToSumTarget(Float_t t)
add to sum target, if traininfo defined
Bool_t IsTerminal() const
flag indicates whether this node is terminal
void SetNTerminal(Int_t n)
set number of terminal nodes in the subtree rooted here, if traininfo defined
void SetNEvents(Float_t nev)
set the number of events that entered the node (during training), if traininfo defined
virtual DecisionTreeNode * GetRight() const
Node for the BinarySearch or Decision Trees.
Definition Node.h:58
Node * fLeft
pointers to the two "daughter" nodes
Definition Node.h:139
Node * fParent
the previous (parent) node
Definition Node.h:138
Node * fRight
pointers to the two "daughter" nodes
Definition Node.h:140
const Int_t n
Definition legend1.C:16
create variable transformations
TLine l
Definition textangle.C:4