Logo ROOT   6.18/05
Reference Guide
Event.h
Go to the documentation of this file.
1// @(#)root/tmva $Id$
2// Author: Andreas Hoecker, Peter Speckmayer, Joerg Stelzer, Helge Voss, Jan Therhaag
3
4/**********************************************************************************
5 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis *
6 * Package: TMVA *
7 * Class : Event *
8 * Web : http://tmva.sourceforge.net *
9 * *
10 * Description: *
11 * Event container *
12 * *
13 * Authors (alphabetical): *
14 * Andreas Hoecker <Andreas.Hocker@cern.ch> - CERN, Switzerland *
15 * Joerg Stelzer <Joerg.Stelzer@cern.ch> - CERN, Switzerland *
16 * Peter Speckmayer <Peter.Speckmayer@cern.ch> - CERN, Switzerland *
17 * Jan Therhaag <Jan.Therhaag@cern.ch> - U of Bonn, Germany *
18 * Helge Voss <Helge.Voss@cern.ch> - MPI-K Heidelberg, Germany *
19 * *
20 * Copyright (c) 2005-2011: *
21 * CERN, Switzerland *
22 * U. of Victoria, Canada *
23 * MPI-K Heidelberg, Germany *
24 * U. of Bonn, Germany *
25 * *
26 * Redistribution and use in source and binary forms, with or without *
27 * modification, are permitted according to the terms listed in LICENSE *
28 * (http://mva.sourceforge.net/license.txt) *
29 **********************************************************************************/
30
31#ifndef ROOT_TMVA_Event
32#define ROOT_TMVA_Event
33
34#include <iosfwd>
35#include <vector>
36
37#include "Rtypes.h"
38#include "ThreadLocalStorage.h"
39#include "TMVA/Types.h"
40
41#include "TObject.h"
42
43
44class TCut;
45
46namespace TMVA {
47
48 class Event;
49
50 std::ostream& operator<<( std::ostream& os, const Event& event );
51
52 class Event:public TObject {
53
54 friend std::ostream& operator<<( std::ostream& os, const Event& event );
55
56 public:
57
58 // constructors
59 Event();
60 Event( const Event& );
61 explicit Event( const std::vector<Float_t>& values,
62 const std::vector<Float_t>& targetValues,
63 const std::vector<Float_t>& spectatorValues,
64 UInt_t theClass = 0, Double_t weight = 1.0, Double_t boostweight = 1.0 );
65 explicit Event( const std::vector<Float_t>& values,
66 const std::vector<Float_t>& targetValues,
67 UInt_t theClass = 0, Double_t weight = 1.0, Double_t boostweight = 1.0 );
68 explicit Event( const std::vector<Float_t>&,
69 UInt_t theClass, Double_t weight = 1.0, Double_t boostweight = 1.0 );
70 explicit Event( const std::vector<Float_t*>*&, UInt_t nvar );
71
72 ~Event();
73
74 // operators
75 // NOTE: Because we do not want to change the behaviour of the Event class
76 // as a public interface, we use the explicit default assignment operator,
77 // which is similar to the implicit one but silences gcc9 warnings.
78 Event& operator=( const Event& ) = default;
79
80 // accessors
81 Bool_t IsDynamic() const {return fDynamic; }
82
83 // Double_t GetWeight() const { return fWeight*fBoostWeight; }
84 Double_t GetWeight() const;
87 UInt_t GetClass() const { return fClass; }
88
89 UInt_t GetNVariables() const;
90 UInt_t GetNTargets() const;
91 UInt_t GetNSpectators() const;
92
93 Float_t GetValue( UInt_t ivar) const;
94 Float_t GetValueFast(UInt_t ivar) const { return fDynamic ? *(*fValuesDynamic)[ivar] : fValues[ivar]; }
95 std::vector<Float_t>& GetValues()
96 {
97 //For a detailed explanation, please see the heading "Avoid Duplication in const and Non-const Member Function," on p. 23, in Item 3 "Use const whenever possible," in Effective C++, 3d ed by Scott Meyers, ISBN-13: 9780321334879.
98 // http://stackoverflow.com/questions/123758/how-do-i-remove-code-duplication-between-similar-const-and-non-const-member-func
99 return const_cast<std::vector<Float_t>&>( static_cast<const Event&>(*this).GetValues() );
100 }
101 const std::vector<Float_t>& GetValues() const;
102
103 Float_t GetTarget( UInt_t itgt ) const { return fTargets.at(itgt); }
104 std::vector<Float_t>& GetTargets() { return fTargets; }
105 const std::vector<Float_t>& GetTargets() const { return fTargets; }
106
107 Float_t GetSpectator( UInt_t ivar) const;
108 std::vector<Float_t>& GetSpectators() { return fSpectators; }
109 const std::vector<Float_t>& GetSpectators() const { return fSpectators; }
110
111 void SetWeight ( Double_t w ) { fWeight=w; }
114 void SetClass ( UInt_t t ) { fClass=t; }
115 void SetVal ( UInt_t ivar, Float_t val );
116 void SetTarget ( UInt_t itgt, Float_t value );
117 void SetSpectator ( UInt_t ivar, Float_t value );
118 void SetVariableArrangement( std::vector<UInt_t>* const m ) const;
119
120 void SetDoNotBoost () const { fDoNotBoost = kTRUE; }
121 static void ClearDynamicVariables() {}
122
123 void CopyVarValues( const Event& other );
124 using TObject::Print;
125 void Print ( std::ostream & o ) const;
126
127 static void SetIsTraining(Bool_t);
129
130 private:
131
132 static Bool_t fgIsTraining; // mark if we are in an actual training or "evaluation/testing" phase --> ignoreNegWeights only in actual training !
134
135
136 mutable std::vector<Float_t> fValues; // the event values ; mutable, to be able to copy the dynamic values in there
137
138 mutable std::vector<Float_t> fValuesRearranged; // the event values ; mutable, to be able to copy the dynamic values in there
139 mutable std::vector<Float_t*> *fValuesDynamic; //! the event values
140 std::vector<Float_t> fTargets; // target values for regression
141 mutable std::vector<Float_t> fSpectators; // "visisting" variables not used in MVAs ; mutable, to be able to copy the dynamic values in there
142 mutable std::vector<UInt_t> fVariableArrangement; // needed for MethodCategories, where we can train on other than the main variables
143
144 UInt_t fClass; // class number
145 Double_t fWeight; // event weight (product of global and individual weights)
146 mutable Double_t fBoostWeight; // internal weight to be set by boosting algorithm
147 Bool_t fDynamic; // is set when the dynamic values are taken
148 mutable Bool_t fDoNotBoost; // mark event as not to be boosted (used to compensate for events with negative event weights
149 public:
150
151 ClassDef(Event,1);
152
153 };
154}
155
156#endif
unsigned int UInt_t
Definition: RtypesCore.h:42
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
#define ClassDef(name, id)
Definition: Rtypes.h:326
A specialized string object used for TTree selections.
Definition: TCut.h:25
std::vector< Float_t > fValues
Definition: Event.h:136
void ScaleBoostWeight(Double_t s) const
Definition: Event.h:113
static Bool_t fgIsTraining
Definition: Event.h:132
Double_t fWeight
Definition: Event.h:145
void SetBoostWeight(Double_t w) const
Definition: Event.h:112
Float_t GetValue(UInt_t ivar) const
return value of i'th variable
Definition: Event.cxx:237
void SetTarget(UInt_t itgt, Float_t value)
set the target value (dimension itgt) to value
Definition: Event.cxx:360
std::vector< Float_t > fTargets
the event values
Definition: Event.h:140
Double_t fBoostWeight
Definition: Event.h:146
std::vector< Float_t > & GetTargets()
Definition: Event.h:104
static void ClearDynamicVariables()
Definition: Event.h:121
Bool_t fDynamic
Definition: Event.h:147
std::vector< Float_t > fSpectators
Definition: Event.h:141
UInt_t GetNSpectators() const
accessor to the number of spectators
Definition: Event.cxx:328
std::vector< UInt_t > fVariableArrangement
Definition: Event.h:142
void SetWeight(Double_t w)
Definition: Event.h:111
Double_t GetOriginalWeight() const
Definition: Event.h:85
~Event()
Event destructor.
Definition: Event.cxx:185
std::vector< Float_t > & GetSpectators()
Definition: Event.h:108
std::vector< Float_t * > * fValuesDynamic
Definition: Event.h:139
void SetDoNotBoost() const
Definition: Event.h:120
Event()
copy constructor
Definition: Event.cxx:49
UInt_t GetNVariables() const
accessor to the number of variables
Definition: Event.cxx:309
Event & operator=(const Event &)=default
void CopyVarValues(const Event &other)
copies only the variable values
Definition: Event.cxx:204
const std::vector< Float_t > & GetSpectators() const
Definition: Event.h:109
UInt_t GetNTargets() const
accessor to the number of targets
Definition: Event.cxx:320
static Bool_t fgIgnoreNegWeightsInTraining
Definition: Event.h:133
const std::vector< Float_t > & GetTargets() const
Definition: Event.h:105
Double_t GetWeight() const
return the event weight - depending on whether the flag IgnoreNegWeightsInTraining is or not.
Definition: Event.cxx:382
void SetVal(UInt_t ivar, Float_t val)
set variable ivar to val
Definition: Event.cxx:341
friend std::ostream & operator<<(std::ostream &os, const Event &event)
static void SetIsTraining(Bool_t)
when this static function is called, it sets the flag whether events with negative event weight shoul...
Definition: Event.cxx:392
void SetVariableArrangement(std::vector< UInt_t > *const m) const
set the variable arrangement
Definition: Event.cxx:192
Float_t GetSpectator(UInt_t ivar) const
return spectator content
Definition: Event.cxx:262
Bool_t IsDynamic() const
Definition: Event.h:81
UInt_t GetClass() const
Definition: Event.h:87
void SetClass(UInt_t t)
Definition: Event.h:114
Double_t GetBoostWeight() const
Definition: Event.h:86
void SetSpectator(UInt_t ivar, Float_t value)
set spectator value (dimension ivar) to value
Definition: Event.cxx:369
Float_t GetValueFast(UInt_t ivar) const
Definition: Event.h:94
Bool_t fDoNotBoost
Definition: Event.h:148
std::vector< Float_t > fValuesRearranged
Definition: Event.h:138
std::vector< Float_t > & GetValues()
Definition: Event.h:95
Float_t GetTarget(UInt_t itgt) const
Definition: Event.h:103
static void SetIgnoreNegWeightsInTraining(Bool_t)
when this static function is called, it sets the flag whether events with negative event weight shoul...
Definition: Event.cxx:401
void Print(std::ostream &o) const
print method
Definition: Event.cxx:352
UInt_t fClass
Definition: Event.h:144
Mother of all ROOT objects.
Definition: TObject.h:37
virtual void Print(Option_t *option="") const
This method must be overridden when a class wants to print itself.
Definition: TObject.cxx:550
static constexpr double s
create variable transformations
std::ostream & operator<<(std::ostream &os, const BinaryTree &tree)
Short_t Max(Short_t a, Short_t b)
Definition: TMathBase.h:212
auto * m
Definition: textangle.C:8