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

/**********************************************************************************
 * Project: TMVA - a Root-integrated toolkit for multivariate data analysis       *
 * Package: TMVA                                                                  *
 * Classes: PDEFoamTarget                                                         *
 * Web    : http://tmva.sourceforge.net                                           *
 *                                                                                *
 * Description:                                                                   *
 *      Concrete PDEFoam sub-class.  This foam stores the first target            *
 *      (index 0) with every cell, as well as the statistical error on            *
 *      the target.                                                               *
 *                                                                                *
 * 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_PDEFoamTarget
#define ROOT_TMVA_PDEFoamTarget

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

namespace TMVA
{

   class PDEFoamTarget : public PDEFoam
   {

   protected:
      UInt_t fTarget; // the target to fill the cells with

      // specific function used during evaluation; determines, whether
      // a cell value is undefined
      Bool_t CellValueIsUndefined(PDEFoamCell* cell);

      // calculate the average of the neighbor cell values
      Float_t GetAverageNeighborsValue(std::vector<Float_t>&, ECellValue);

      PDEFoamTarget(const PDEFoamTarget&); // Copy Constructor  NOT USED

      // ---------- Public functions ----------------------------------
   public:
      PDEFoamTarget();                  // Default constructor (used only by ROOT streamer)
      PDEFoamTarget(const TString&, UInt_t); // Principal user-defined constructor
      virtual ~PDEFoamTarget() {}       // Default destructor

      // function to fill created cell with given value
      virtual void FillFoamCells(const Event* ev, Float_t wt);

      // function to call after foam is grown
      virtual void Finalize();

      virtual Float_t GetCellValue(const std::vector<Float_t> &xvec, ECellValue cv, PDEFoamKernelBase*);
      using PDEFoam::GetCellValue;

      // ---------- ROOT class definition
      ClassDef(PDEFoamTarget, 1) // Tree of PDEFoamCells
   }; // end of PDEFoamTarget

}  // namespace TMVA

// ---------- Inline functions

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