ROOT  6.07/01
Reference Guide
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
PDEFoamEvent.cxx
Go to the documentation of this file.
1 // @(#)root/tmva $Id$
2 // Author: Tancredi Carli, Dominik Dannheim, Alexander Voigt
3 
4 /**********************************************************************************
5  * Project: TMVA - a Root-integrated toolkit for multivariate data analysis *
6  * Package: TMVA *
7  * Classes: PDEFoamEvent *
8  * Web : http://tmva.sourceforge.net *
9  * *
10  * Description: *
11  * Implementation. *
12  * *
13  * Authors (alphabetical): *
14  * Tancredi Carli - CERN, Switzerland *
15  * Dominik Dannheim - CERN, Switzerland *
16  * S. Jadach - Institute of Nuclear Physics, Cracow, Poland *
17  * Alexander Voigt - TU Dresden, Germany *
18  * Peter Speckmayer - CERN, Switzerland *
19  * *
20  * Copyright (c) 2008, 2010: *
21  * CERN, Switzerland *
22  * MPI-K Heidelberg, Germany *
23  * *
24  * Redistribution and use in source and binary forms, with or without *
25  * modification, are permitted according to the terms listed in LICENSE *
26  * (http://tmva.sourceforge.net/LICENSE) *
27  **********************************************************************************/
28 
29 //_____________________________________________________________________
30 //
31 // PDEFoamEvent
32 //
33 // This PDEFoam variant stores in every cell the sum of event weights
34 // and the sum of the squared event weights. It therefore acts as
35 // event density estimator. It should be booked together with the
36 // PDEFoamEventDensity density estimator, which returns the event
37 // weight density at a given phase space point during the foam
38 // build-up.
39 //
40 //_____________________________________________________________________
41 
42 #include "TMVA/PDEFoamEvent.h"
43 
44 #include "TMVA/Event.h"
45 #include "TMVA/MsgLogger.h"
46 #include "TMVA/Types.h"
47 
48 #include "Rtypes.h"
49 
50 namespace TMVA {
51  class PDEFoamCell;
52 }
53 class TString;
54 
56 
57 ////////////////////////////////////////////////////////////////////////////////
58 /// Default constructor for streamer, user should not use it.
59 
60 TMVA::PDEFoamEvent::PDEFoamEvent()
61  : PDEFoam()
62 {
63 }
64 
65 ////////////////////////////////////////////////////////////////////////////////
66 
68  : PDEFoam(name)
69 {}
70 
71 ////////////////////////////////////////////////////////////////////////////////
72 /// Copy Constructor NOT IMPLEMENTED (NEVER USED)
73 
75  : PDEFoam(from)
76 {
77  Log() << kFATAL << "COPY CONSTRUCTOR NOT IMPLEMENTED" << Endl;
78 }
79 
80 ////////////////////////////////////////////////////////////////////////////////
81 /// This function fills an event weight 'wt' into the PDEFoam. Cell
82 /// element 0 is filled with the weight 'wt', and element 1 is
83 /// filled with the squared weight.
84 
86 {
87  // find corresponding foam cell
88  std::vector<Float_t> values = ev->GetValues();
89  std::vector<Float_t> tvalues = VarTransform(values);
90  PDEFoamCell *cell = FindCell(tvalues);
91 
92  // 0. Element: Sum of event weights 'wt'
93  // 1. Element: Sum of squared event weights 'wt'
94  SetCellElement(cell, 0, GetCellElement(cell, 0) + wt);
95  SetCellElement(cell, 1, GetCellElement(cell, 1) + wt * wt);
96 }
MsgLogger & Endl(MsgLogger &ml)
Definition: MsgLogger.h:162
float Float_t
Definition: RtypesCore.h:53
ClassImp(TMVA::PDEFoamEvent) TMVA
Default constructor for streamer, user should not use it.
virtual void FillFoamCells(const Event *ev, Float_t wt)
This function fills an event weight 'wt' into the PDEFoam.
MsgLogger & Log() const
Definition: PDEFoam.h:262
std::vector< double > values
Definition: TwoHistoFit2D.C:32
Basic string class.
Definition: TString.h:137
#define name(a, b)
Definition: linkTestLib0.cpp:5
std::vector< Float_t > & GetValues()
Definition: Event.h:93