// @(#)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 : CrossEntropy * * Web : http://tmva.sourceforge.net * * * * Description: Implementation of the CrossEntropy as separation criterion * * * * Authors (alphabetical): * * Andreas Hoecker - CERN, Switzerland * * Helge Voss - MPI-K Heidelberg, Germany * * Kai Voss - U. of Victoria, Canada * * * * 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_CrossEntropy #define ROOT_TMVA_CrossEntropy ////////////////////////////////////////////////////////////////////////// // // // CrossEntropy // // // // Implementation of the CrossEntropy as separation criterion // // -p log (p) - (1-p)log(1-p); p=purity = s/(s+b) // // // ////////////////////////////////////////////////////////////////////////// #ifndef ROOT_TMVA_SeparationBase #include "TMVA/SeparationBase.h" #endif namespace TMVA { class CrossEntropy : public SeparationBase { public: // default constructor CrossEntropy(): SeparationBase() { fName = "CE"; } // copy constructor CrossEntropy( const CrossEntropy& g): SeparationBase(g) {} // destructor virtual ~CrossEntropy(){} // return the separation Index -p log (p) - (1-p)log(1-p); p=purity = s/(s+b) virtual Double_t GetSeparationIndex( const Double_t &s, const Double_t &b ); protected: ClassDef(CrossEntropy,0) // Implementation of the CrossEntropy as separation criterion }; } // namespace TMVA #endif