00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027 #ifndef ROOT_TMVA_DataSetInfo
00028 #define ROOT_TMVA_DataSetInfo
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038 #include <iosfwd>
00039
00040 #ifndef ROOT_TObject
00041 #include "TObject.h"
00042 #endif
00043 #ifndef ROOT_TString
00044 #include "TString.h"
00045 #endif
00046 #ifndef ROOT_TTree
00047 #include "TTree.h"
00048 #endif
00049 #ifndef ROOT_TCut
00050 #include "TCut.h"
00051 #endif
00052 #ifndef ROOT_TMatrixDfwd
00053 #include "TMatrixDfwd.h"
00054 #endif
00055
00056 #ifndef ROOT_TMVA_Types
00057 #include "TMVA/Types.h"
00058 #endif
00059 #ifndef ROOT_TMVA_VariableInfo
00060 #include "TMVA/VariableInfo.h"
00061 #endif
00062 #ifndef ROOT_TMVA_ClassInfo
00063 #include "TMVA/ClassInfo.h"
00064 #endif
00065 #ifndef ROOT_TMVA_Event
00066 #include "TMVA/Event.h"
00067 #endif
00068
00069 class TH2;
00070
00071 namespace TMVA {
00072
00073 class DataSet;
00074 class VariableTransformBase;
00075 class MsgLogger;
00076 class DataSetManager;
00077
00078 class DataSetInfo : public TObject {
00079
00080 public:
00081
00082 DataSetInfo(const TString& name = "Default");
00083 virtual ~DataSetInfo();
00084
00085 virtual const char* GetName() const { return fName.Data(); }
00086
00087
00088 void ClearDataSet() const;
00089 DataSet* GetDataSet() const;
00090
00091
00092
00093
00094 VariableInfo& AddVariable( const TString& expression, const TString& title = "", const TString& unit = "",
00095 Double_t min = 0, Double_t max = 0, char varType='F',
00096 Bool_t normalized = kTRUE, void* external = 0 );
00097 VariableInfo& AddVariable( const VariableInfo& varInfo );
00098
00099 VariableInfo& AddTarget ( const TString& expression, const TString& title, const TString& unit,
00100 Double_t min, Double_t max, Bool_t normalized = kTRUE, void* external = 0 );
00101 VariableInfo& AddTarget ( const VariableInfo& varInfo );
00102
00103 VariableInfo& AddSpectator ( const TString& expression, const TString& title, const TString& unit,
00104 Double_t min, Double_t max, char type = 'F', Bool_t normalized = kTRUE, void* external = 0 );
00105 VariableInfo& AddSpectator ( const VariableInfo& varInfo );
00106
00107 ClassInfo* AddClass ( const TString& className );
00108
00109
00110
00111
00112 std::vector<VariableInfo>& GetVariableInfos() { return fVariables; }
00113 const std::vector<VariableInfo>& GetVariableInfos() const { return fVariables; }
00114 VariableInfo& GetVariableInfo( Int_t i ) { return fVariables.at(i); }
00115 const VariableInfo& GetVariableInfo( Int_t i ) const { return fVariables.at(i); }
00116
00117 std::vector<VariableInfo>& GetTargetInfos() { return fTargets; }
00118 const std::vector<VariableInfo>& GetTargetInfos() const { return fTargets; }
00119 VariableInfo& GetTargetInfo( Int_t i ) { return fTargets.at(i); }
00120 const VariableInfo& GetTargetInfo( Int_t i ) const { return fTargets.at(i); }
00121
00122 std::vector<VariableInfo>& GetSpectatorInfos() { return fSpectators; }
00123 const std::vector<VariableInfo>& GetSpectatorInfos() const { return fSpectators; }
00124 VariableInfo& GetSpectatorInfo( Int_t i ) { return fSpectators.at(i); }
00125 const VariableInfo& GetSpectatorInfo( Int_t i ) const { return fSpectators.at(i); }
00126
00127
00128 UInt_t GetNVariables() const { return fVariables.size(); }
00129 UInt_t GetNTargets() const { return fTargets.size(); }
00130 UInt_t GetNSpectators(bool all=kTRUE) const;
00131
00132 const TString& GetNormalization() const { return fNormalization; }
00133 void SetNormalization( const TString& norm ) { fNormalization = norm; }
00134
00135
00136 Int_t GetClassNameMaxLength() const;
00137 ClassInfo* GetClassInfo( Int_t clNum ) const;
00138 ClassInfo* GetClassInfo( const TString& name ) const;
00139 void PrintClasses() const;
00140 UInt_t GetNClasses() const { return fClasses.size(); }
00141 Bool_t IsSignal( const Event* ev ) const;
00142 std::vector<Float_t>* GetTargetsForMulticlass( const Event* ev );
00143
00144
00145 Int_t FindVarIndex( const TString& ) const;
00146
00147
00148 const TString GetWeightExpression(Int_t i) const { return GetClassInfo(i)->GetWeight(); }
00149 void SetWeightExpression( const TString& exp, const TString& className = "" );
00150
00151
00152 const TCut& GetCut (Int_t i) const { return GetClassInfo(i)->GetCut(); }
00153 const TCut& GetCut ( const TString& className ) const { return GetClassInfo(className)->GetCut(); }
00154 void SetCut ( const TCut& cut, const TString& className );
00155 void AddCut ( const TCut& cut, const TString& className );
00156 Bool_t HasCuts() const;
00157
00158 std::vector<TString> GetListOfVariables() const;
00159
00160
00161 const TMatrixD* CorrelationMatrix ( const TString& className ) const;
00162 void SetCorrelationMatrix ( const TString& className, TMatrixD* matrix );
00163 void PrintCorrelationMatrix( const TString& className );
00164 TH2* CreateCorrelationMatrixHist( const TMatrixD* m,
00165 const TString& hName,
00166 const TString& hTitle ) const;
00167
00168
00169 void SetSplitOptions(const TString& so) { fSplitOptions = so; fNeedsRebuilding = kTRUE; }
00170 const TString& GetSplitOptions() const { return fSplitOptions; }
00171
00172
00173 void SetRootDir(TDirectory* d) { fOwnRootDir = d; }
00174 TDirectory* GetRootDir() const { return fOwnRootDir; }
00175
00176 void SetMsgType( EMsgType t ) const;
00177
00178 private:
00179
00180 TMVA::DataSetManager* fDataSetManager;
00181 void SetDataSetManager( DataSetManager* dsm ) { fDataSetManager = dsm; }
00182 friend class DataSetManager;
00183
00184 DataSetInfo( const DataSetInfo& ) : TObject() {}
00185
00186 void PrintCorrelationMatrix( TTree* theTree );
00187
00188 TString fName;
00189
00190 mutable DataSet* fDataSet;
00191 mutable Bool_t fNeedsRebuilding;
00192
00193
00194 std::vector<VariableInfo> fVariables;
00195 std::vector<VariableInfo> fTargets;
00196 std::vector<VariableInfo> fSpectators;
00197
00198
00199 mutable std::vector<ClassInfo*> fClasses;
00200
00201 TString fNormalization;
00202 TString fSplitOptions;
00203
00204 TDirectory* fOwnRootDir;
00205 Bool_t fVerbose;
00206
00207 UInt_t fSignalClass;
00208
00209 std::vector<Float_t>* fTargetsForMulticlass;
00210
00211 mutable MsgLogger* fLogger;
00212 MsgLogger& Log() const { return *fLogger; }
00213
00214
00215 };
00216 }
00217
00218 #endif