YAP
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
ImportanceSampler.h
Go to the documentation of this file.
1 /* YAP - Yet another PWA toolkit
2  Copyright 2015, Technische Universitaet Muenchen,
3  Authors: Daniel Greenwald, Johannes Rauch
4 
5  This program is free software: you can redistribute it and/or modify
6  it under the terms of the GNU General Public License as published by
7  the Free Software Foundation, either version 3 of the License, or
8  (at your option) any later version.
9 
10  This program is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU General Public License for more details.
14 
15  You should have received a copy of the GNU General Public License
16  along with this program. If not, see <http://www.gnu.org/licenses/>.
17  */
18 
20 
21 #ifndef yap_ImportanceSampler_h
22 #define yap_ImportanceSampler_h
23 
24 #include "Integrator.h"
25 
26 #include "fwd/DataPartition.h"
27 #include "fwd/DecayTreeVectorIntegral.h"
28 #include "fwd/ModelIntegral.h"
29 
30 namespace yap {
31 
37 {
38 
39 public:
40 
42  static void calculate(ModelIntegral& I, DataPartitionVector& DPV);
43 
45  static void calculate(ModelIntegral& I, DataPartition& D);
46 
47 private:
48 
50  static std::vector<DecayTreeVectorIntegral*> select_changed(ModelIntegral& I);
51 
54 
56  static unsigned partially_calculate(std::vector<DecayTreeVectorIntegral*>& J, DataPartition& D);
57 
58 };
59 
60 }
61 
62 #endif
static unsigned partially_calculate_subIntegral(DecayTreeVectorIntegral &I, DataPartition &D)
perform partial calculation of one integral component for one data partition
Definition: ImportanceSampler.cxx:19
Stores integral of a full model.
Definition: ModelIntegral.h:38
Calculates DecayTreeVectorIntegral using importance sampling.
Definition: ImportanceSampler.h:36
static void calculate(ModelIntegral &I, DataPartitionVector &DPV)
Update calculation of ModelIntegral.
Definition: ImportanceSampler.cxx:109
Integrates a model.
Definition: Integrator.h:34
Class defining a partition of the DataSet.
Definition: DataPartition.h:158
static unsigned partially_calculate(std::vector< DecayTreeVectorIntegral * > &J, DataPartition &D)
perform partial calculation for one data partition
Definition: ImportanceSampler.cxx:58
static std::vector< DecayTreeVectorIntegral * > select_changed(ModelIntegral &I)
Definition: ImportanceSampler.cxx:77
Stores integral components for a vector of decay trees.
Definition: DecayTreeVectorIntegral.h:50