// @(#)root/tmva $Id$
// Author: Alexander Voigt

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Classes: PDEFoamDecisionTreeDensity                                            *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      Class PDEFoamDecisionTreeDensity is a class representing                  *
 *      n-dimensional real positive integrand function                            *
 *      The main function is Density() which provides the event density at a      *
 *      given point during the foam build-up (sampling).                          *
 *                                                                                *
 * Authors (alphabetical):                                                        *
 *      Tancredi Carli   - CERN, Switzerland                                      *
 *      Dominik Dannheim - CERN, Switzerland                                      *
 *      S. Jadach        - Institute of Nuclear Physics, Cracow, Poland           *
 *      Alexander Voigt  - TU Dresden, Germany                                    *
 *      Peter Speckmayer - CERN, Switzerland                                      *
 *                                                                                *
 * Copyright (c) 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_PDEFoamDecisionTreeDensity
#define ROOT_TMVA_PDEFoamDecisionTreeDensity

#include <vector>

#ifndef ROOT_TH2
#include "TH2.h"
#endif

#ifndef ROOT_TMVA_PDEFoamDensityBase
#include "TMVA/PDEFoamDensityBase.h"
#endif
#ifndef ROOT_TMVA_Volume
#include "TMVA/Volume.h"
#endif

namespace TMVA
{

   // class definition of underlying event density
   class PDEFoamDecisionTreeDensity : public PDEFoamDensityBase
   {

   protected:
      UInt_t fClass; // signal class

   public:
      PDEFoamDecisionTreeDensity();
      PDEFoamDecisionTreeDensity(std::vector<Double_t> box, UInt_t cls);
      PDEFoamDecisionTreeDensity(const PDEFoamDecisionTreeDensity&);
      virtual ~PDEFoamDecisionTreeDensity() {}

      // returns allways 0
      virtual Double_t Density(std::vector<Double_t> &Xarg, Double_t &event_density);

      // fill histograms with events found in volume
      virtual void FillHistograms(TMVA::Volume&, std::vector<TH1D*>&, std::vector<TH1D*>&, std::vector<TH1D*>&, std::vector<TH1D*>&);

      ClassDef(PDEFoamDecisionTreeDensity, 1) // Class for decision tree like PDEFoam density
   };  //end of PDEFoamDecisionTreeDensity

}  // namespace TMVA

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