// @(#)root/tmva $Id$
// Author: Andreas Hoecker, Joerg Stelzer, Helge Voss, Kai Voss 

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Class  : RegressionVariance                                                    *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description: Calculate the separation critiera useded in regression            *
 *                                                                                *
 *          There are two things: the Separation Index, and the Separation Gain   *
 *          Separation Index:                                                     *
 *          Measure of the "Variance" of a sample.                                *
 *                                                                                *
 *          Separation Gain:                                                      *
 *          the measure of how the quality of separation of the sample increases  *
 *          by splitting the sample e.g. into a "left-node" and a "right-node"    *
 *          (N * Index_parent) - (N_left * Index_left) - (N_right * Index_right)  *
 *          this is then the quality crition which is optimized for when trying   *
 *          to increase the information in the system (making the best selection  *
 *                                                                                *
 *                                                                                *
 * Authors (alphabetical):                                                        *
 *      Helge Voss      <Helge.Voss@cern.ch>     - MPI-K Heidelberg, Germany      *
 *                                                                                *
 * Copyright (c) 2005:                                                            *
 *      CERN, Switzerland                                                         * 
 *      U. of Victoria, Canada                                                    * 
 *      Heidelberg U., Germany                                                    * 
 *                                                                                *
 * Redistribution and use in source and binary forms, with or without             *
 * modification, are permitted according to the terms listed in LICENSE           *
 * (http://tmva.sourceforge.net/LICENSE)                                          *
 **********************************************************************************/

#ifndef ROOT_TMVA_RegressionVariance
#define ROOT_TMVA_RegressionVariance

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// RegressionVariance                                                   //
//                                                                      //
// Calculate the "SeparationGain" for Regression analysis               //
// separation critiera used in various training algorithms              //
//                                                                      //
// There are two things: the Separation Index, and the Separation Gain  //
// Separation Index:                                                    //
// Measure of the "Variance" of a sample.                               //
//                                                                      //
// Separation Gain:                                                     //
// the measure of how the quality of separation of the sample increases //
// by splitting the sample e.g. into a "left-node" and a "right-node"   //
// (N * Index_parent) - (N_left * Index_left) - (N_right * Index_right) //
// this is then the quality crition which is optimized for when trying  //
// to increase the information in the system (making the best selection //            
//                                                                      //
//////////////////////////////////////////////////////////////////////////

#ifndef ROOT_Rtypes
#include "Rtypes.h"
#endif

#ifndef ROOT_TString
#include "TString.h"
#endif

namespace TMVA {

   class RegressionVariance {

   public:

      //default constructor
      RegressionVariance(){fName = "Variance for Regression";}

      //copy constructor
      RegressionVariance( const RegressionVariance& s ): fName ( s.fName ) {}

      // destructor
      virtual ~RegressionVariance(){}

      // Return the gain in separation of the original sample is splitted in two sub-samples
      // (N * Index_parent) - (N_left * Index_left) - (N_right * Index_right) 
      Double_t GetSeparationGain( const Double_t &nLeft, const Double_t &targetLeft, const Double_t &target2Left,
                                  const Double_t &nTot, const Double_t &targetTot, const Double_t &target2Tot );

      // Return the separation index (a measure for "purity" of the sample")
      virtual Double_t GetSeparationIndex( const Double_t &n, const Double_t &target, const Double_t &target2 );

      // Return the name of the concrete Index implementation
      TString GetName() { return fName; }

   protected:

      TString fName;  // name of the concrete Separation Index impementation
 
      ClassDef(RegressionVariance,0) // Interface to different separation critiera used in training algorithms
   };


} // namespace TMVA

#endif
 RegressionVariance.h:1
 RegressionVariance.h:2
 RegressionVariance.h:3
 RegressionVariance.h:4
 RegressionVariance.h:5
 RegressionVariance.h:6
 RegressionVariance.h:7
 RegressionVariance.h:8
 RegressionVariance.h:9
 RegressionVariance.h:10
 RegressionVariance.h:11
 RegressionVariance.h:12
 RegressionVariance.h:13
 RegressionVariance.h:14
 RegressionVariance.h:15
 RegressionVariance.h:16
 RegressionVariance.h:17
 RegressionVariance.h:18
 RegressionVariance.h:19
 RegressionVariance.h:20
 RegressionVariance.h:21
 RegressionVariance.h:22
 RegressionVariance.h:23
 RegressionVariance.h:24
 RegressionVariance.h:25
 RegressionVariance.h:26
 RegressionVariance.h:27
 RegressionVariance.h:28
 RegressionVariance.h:29
 RegressionVariance.h:30
 RegressionVariance.h:31
 RegressionVariance.h:32
 RegressionVariance.h:33
 RegressionVariance.h:34
 RegressionVariance.h:35
 RegressionVariance.h:36
 RegressionVariance.h:37
 RegressionVariance.h:38
 RegressionVariance.h:39
 RegressionVariance.h:40
 RegressionVariance.h:41
 RegressionVariance.h:42
 RegressionVariance.h:43
 RegressionVariance.h:44
 RegressionVariance.h:45
 RegressionVariance.h:46
 RegressionVariance.h:47
 RegressionVariance.h:48
 RegressionVariance.h:49
 RegressionVariance.h:50
 RegressionVariance.h:51
 RegressionVariance.h:52
 RegressionVariance.h:53
 RegressionVariance.h:54
 RegressionVariance.h:55
 RegressionVariance.h:56
 RegressionVariance.h:57
 RegressionVariance.h:58
 RegressionVariance.h:59
 RegressionVariance.h:60
 RegressionVariance.h:61
 RegressionVariance.h:62
 RegressionVariance.h:63
 RegressionVariance.h:64
 RegressionVariance.h:65
 RegressionVariance.h:66
 RegressionVariance.h:67
 RegressionVariance.h:68
 RegressionVariance.h:69
 RegressionVariance.h:70
 RegressionVariance.h:71
 RegressionVariance.h:72
 RegressionVariance.h:73
 RegressionVariance.h:74
 RegressionVariance.h:75
 RegressionVariance.h:76
 RegressionVariance.h:77
 RegressionVariance.h:78
 RegressionVariance.h:79
 RegressionVariance.h:80
 RegressionVariance.h:81
 RegressionVariance.h:82
 RegressionVariance.h:83
 RegressionVariance.h:84
 RegressionVariance.h:85
 RegressionVariance.h:86
 RegressionVariance.h:87
 RegressionVariance.h:88
 RegressionVariance.h:89
 RegressionVariance.h:90
 RegressionVariance.h:91
 RegressionVariance.h:92
 RegressionVariance.h:93
 RegressionVariance.h:94
 RegressionVariance.h:95
 RegressionVariance.h:96
 RegressionVariance.h:97
 RegressionVariance.h:98
 RegressionVariance.h:99
 RegressionVariance.h:100
 RegressionVariance.h:101
 RegressionVariance.h:102
 RegressionVariance.h:103
 RegressionVariance.h:104