ROOT logo
// @(#)root/tmva $Id$
// Author: Dominik Dannheim, Alexander Voigt

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Classes: PDEFoamKernelGauss                                                    *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      PDEFoam kernel, which weights all cell values by a gauss function.        *
 *                                                                                *
 * Authors (alphabetical):                                                        *
 *      S. Jadach        - Institute of Nuclear Physics, Cracow, Poland           *
 *      Tancredi Carli   - CERN, Switzerland                                      *
 *      Dominik Dannheim - CERN, Switzerland                                      *
 *      Alexander Voigt  - TU Dresden, Germany                                    *
 *                                                                                *
 * Copyright (c) 2008, 2010:                                                      *
 *      CERN, Switzerland                                                         *
 *      MPI-K Heidelberg, 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_PDEFoamKernelGauss
#define ROOT_TMVA_PDEFoamKernelGauss

#ifndef ROOT_TMVA_PDEFoam
#include "TMVA/PDEFoam.h"
#endif
#ifndef ROOT_TMVA_PDEFoamKernelBase
#include "TMVA/PDEFoamKernelBase.h"
#endif

namespace TMVA
{

   class PDEFoamKernelGauss : public PDEFoamKernelBase
   {

   protected:
      Float_t fSigma;          // width of gauss curve

      // Square function (fastest implementation)
      template<typename T> T Sqr(T x) const { return x * x; }

      // calculate gaussian weight
      Float_t WeightGaus(PDEFoam*, PDEFoamCell*, std::vector<Float_t>&);

      // estimate the cell value by its neighbors
      Float_t GetAverageNeighborsValue(PDEFoam*, std::vector<Float_t>&, ECellValue);

   public:
      PDEFoamKernelGauss(Float_t sigma);    // Constructor
      PDEFoamKernelGauss(const PDEFoamKernelGauss&); // Copy Constructor
      virtual ~PDEFoamKernelGauss() {}      // Destructor

      // kernel estimator
      virtual Float_t Estimate(PDEFoam*, std::vector<Float_t>&, ECellValue);

      ClassDef(PDEFoamKernelGauss, 1) // Gaussian PDEFoam kernel estimator
   }; // end of PDEFoamKernelGauss
}  // namespace TMVA

#endif
 PDEFoamKernelGauss.h:1
 PDEFoamKernelGauss.h:2
 PDEFoamKernelGauss.h:3
 PDEFoamKernelGauss.h:4
 PDEFoamKernelGauss.h:5
 PDEFoamKernelGauss.h:6
 PDEFoamKernelGauss.h:7
 PDEFoamKernelGauss.h:8
 PDEFoamKernelGauss.h:9
 PDEFoamKernelGauss.h:10
 PDEFoamKernelGauss.h:11
 PDEFoamKernelGauss.h:12
 PDEFoamKernelGauss.h:13
 PDEFoamKernelGauss.h:14
 PDEFoamKernelGauss.h:15
 PDEFoamKernelGauss.h:16
 PDEFoamKernelGauss.h:17
 PDEFoamKernelGauss.h:18
 PDEFoamKernelGauss.h:19
 PDEFoamKernelGauss.h:20
 PDEFoamKernelGauss.h:21
 PDEFoamKernelGauss.h:22
 PDEFoamKernelGauss.h:23
 PDEFoamKernelGauss.h:24
 PDEFoamKernelGauss.h:25
 PDEFoamKernelGauss.h:26
 PDEFoamKernelGauss.h:27
 PDEFoamKernelGauss.h:28
 PDEFoamKernelGauss.h:29
 PDEFoamKernelGauss.h:30
 PDEFoamKernelGauss.h:31
 PDEFoamKernelGauss.h:32
 PDEFoamKernelGauss.h:33
 PDEFoamKernelGauss.h:34
 PDEFoamKernelGauss.h:35
 PDEFoamKernelGauss.h:36
 PDEFoamKernelGauss.h:37
 PDEFoamKernelGauss.h:38
 PDEFoamKernelGauss.h:39
 PDEFoamKernelGauss.h:40
 PDEFoamKernelGauss.h:41
 PDEFoamKernelGauss.h:42
 PDEFoamKernelGauss.h:43
 PDEFoamKernelGauss.h:44
 PDEFoamKernelGauss.h:45
 PDEFoamKernelGauss.h:46
 PDEFoamKernelGauss.h:47
 PDEFoamKernelGauss.h:48
 PDEFoamKernelGauss.h:49
 PDEFoamKernelGauss.h:50
 PDEFoamKernelGauss.h:51
 PDEFoamKernelGauss.h:52
 PDEFoamKernelGauss.h:53
 PDEFoamKernelGauss.h:54
 PDEFoamKernelGauss.h:55
 PDEFoamKernelGauss.h:56
 PDEFoamKernelGauss.h:57
 PDEFoamKernelGauss.h:58
 PDEFoamKernelGauss.h:59
 PDEFoamKernelGauss.h:60
 PDEFoamKernelGauss.h:61
 PDEFoamKernelGauss.h:62
 PDEFoamKernelGauss.h:63
 PDEFoamKernelGauss.h:64
 PDEFoamKernelGauss.h:65
 PDEFoamKernelGauss.h:66
 PDEFoamKernelGauss.h:67
 PDEFoamKernelGauss.h:68