ROOT  6.07/01
Reference Guide
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
VariableNormalizeTransform.h
Go to the documentation of this file.
1 // @(#)root/tmva $Id$
2 // Author: Andreas Hoecker, Joerg Stelzer, Helge Voss
3 
4 /**********************************************************************************
5  * Project: TMVA - a Root-integrated toolkit for multivariate data analysis *
6  * Package: TMVA *
7  * Class : VariableNormalizeTransform *
8  * Web : http://tmva.sourceforge.net *
9  * *
10  * Description: *
11  * Decorrelation of input variables *
12  * *
13  * Authors (alphabetical): *
14  * Andreas Hoecker <Andreas.Hocker@cern.ch> - CERN, Switzerland *
15  * Peter Speckmayer <Peter.Speckmayer@cern.ch> - CERN, Switzerland *
16  * Joerg Stelzer <Joerg.Stelzer@cern.ch> - CERN, Switzerland *
17  * Helge Voss <Helge.Voss@cern.ch> - MPI-K Heidelberg, Germany *
18  * *
19  * Copyright (c) 2005: *
20  * CERN, Switzerland *
21  * U. of Victoria, Canada *
22  * MPI-K Heidelberg, Germany *
23  * *
24  * Redistribution and use in source and binary forms, with or without *
25  * modification, are permitted according to the terms listed in LICENSE *
26  * (http://tmva.sourceforge.net/LICENSE) *
27  **********************************************************************************/
28 
29 #ifndef ROOT_TMVA_VariableNormalizeTransform
30 #define ROOT_TMVA_VariableNormalizeTransform
31 
32 //////////////////////////////////////////////////////////////////////////
33 // //
34 // VariableNormalizeTransform //
35 // //
36 // Linear interpolation class //
37 // //
38 //////////////////////////////////////////////////////////////////////////
39 
40 #ifndef ROOT_TMatrixDfwd
41 #include "TMatrixDfwd.h"
42 #endif
43 
44 #ifndef ROOT_TMVA_VariableTransformBase
46 #endif
47 
48 namespace TMVA {
49 
51 
52  public:
53 
54  typedef std::vector<Float_t> FloatVector;
55  typedef std::vector< FloatVector > VectorOfFloatVectors;
57  virtual ~VariableNormalizeTransform( void );
58 
59  void Initialize();
60  Bool_t PrepareTransformation (const std::vector<Event*>&);
61 
62  virtual const Event* Transform(const Event* const, Int_t cls ) const;
63  virtual const Event* InverseTransform( const Event* const, Int_t cls ) const;
64 
65  void WriteTransformationToStream ( std::ostream& ) const;
66  void ReadTransformationFromStream( std::istream&, const TString& );
67  void BuildTransformationFromVarInfo( const std::vector<TMVA::VariableInfo>& var );
68 
69  virtual void AttachXMLTo(void* parent);
70  virtual void ReadFromXML( void* trfnode );
71 
72  virtual void PrintTransformation( std::ostream & o );
73 
74  // writer of function code
75  virtual void MakeFunction( std::ostream& fout, const TString& fncName, Int_t part, UInt_t trCounter, Int_t cls );
76 
77  // provides string vector giving explicit transformation
78  std::vector<TString>* GetTransformationStrings( Int_t cls ) const;
79 
80  private:
81 
82  void CalcNormalizationParams( const std::vector< Event*>& events);
83 
84  // mutable Event* fTransformedEvent;
85 
86  VectorOfFloatVectors fMin; //! Min of source range
87  VectorOfFloatVectors fMax; //! Max of source range
88 
89  ClassDef(VariableNormalizeTransform,0) // Variable transformation: normalization
90  };
91 
92 } // namespace TMVA
93 
94 #endif
std::vector< FloatVector > VectorOfFloatVectors
void CalcNormalizationParams(const std::vector< Event * > &events)
compute offset and scale from min and max
virtual void MakeFunction(std::ostream &fout, const TString &fncName, Int_t part, UInt_t trCounter, Int_t cls)
creates a normalizing function TODO include target-transformation into makefunction ...
VariableNormalizeTransform(DataSetInfo &dsi)
Basic string class.
Definition: TString.h:137
int Int_t
Definition: RtypesCore.h:41
bool Bool_t
Definition: RtypesCore.h:59
Bool_t PrepareTransformation(const std::vector< Event * > &)
prepare transformation
#define ClassDef(name, id)
Definition: Rtypes.h:254
virtual const Event * Transform(const Event *const, Int_t cls) const
virtual void PrintTransformation(std::ostream &o)
prints the transformation ranges
virtual const Event * InverseTransform(const Event *const, Int_t cls) const
apply the inverse transformation
void WriteTransformationToStream(std::ostream &) const
write the transformation to the stream
virtual void AttachXMLTo(void *parent)
create XML description of Normalize transformation
unsigned int UInt_t
Definition: RtypesCore.h:42
std::vector< TString > * GetTransformationStrings(Int_t cls) const
creates string with variable transformations applied
void Initialize()
initialization of the normalization transformation
void BuildTransformationFromVarInfo(const std::vector< TMVA::VariableInfo > &var)
this method is only used when building a normalization transformation from old text files in this cas...
VectorOfFloatVectors fMax
Min of source range.
virtual void ReadFromXML(void *trfnode)
Read the transformation matrices from the xml node.
void ReadTransformationFromStream(std::istream &, const TString &)
Read the variable ranges from an input stream.