Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TFoamSampler.cxx
Go to the documentation of this file.
1// @(#)root/unuran:$Id$
2// Authors: L. Moneta, Dec 2010
3
4/**********************************************************************
5 * *
6 * Copyright (c) 2010 LCG ROOT Math Team, CERN/PH-SFT *
7 * *
8 * *
9 **********************************************************************/
10
11// Implementation file for class TFoamSampler
12
13#include "TFoamSampler.h"
15
16#include "TFoam.h"
17#include "TFoamIntegrand.h"
19#include "Math/IOptions.h"
20#include "Fit/DataRange.h"
21
22#include "TRandom.h"
23#include "TError.h"
24
25#include "TF1.h"
26#include <cassert>
27#include <cmath>
28
30
31public:
32
34 fFunc(f),
35 fX(std::vector<double>(f.NDim() ) ),
36 fMinX(std::vector<double>(f.NDim() ) ),
37 fDeltaX(std::vector<double>(f.NDim() ) )
38 {
39 assert(f.NDim() == range.NDim() );
40 std::vector<double> xmax(f.NDim() );
41 for (unsigned int i = 0; i < range.NDim(); ++i) {
42 if (range.Size(i) == 0)
43 Error("FoamDistribution","Range is not set for coordinate dim %d",i);
44 else if (range.Size(i)>1)
45 Warning("FoamDistribution","Using only first range in coordinate dim %d",i);
46
47 std::pair<double,double> r = range(i);
48 fMinX[i] = r.first;
49 fDeltaX[i] = r.second - r.first;
50 }
51 }
52 // in principle function does not need to be cloned
53
54 virtual double Density(int ndim, double * x) {
55 assert(ndim == (int) fFunc.NDim() );
56 for (int i = 0; i < ndim; ++i)
57 fX[i] = fMinX[i] + x[i] * fDeltaX[i];
58
59 return (fFunc)(&fX[0]);
60 }
61
62 double MinX(unsigned int i) { return fMinX[i]; }
63 double DeltaX(unsigned int i) { return fDeltaX[i]; }
64
65private:
66
68 std::vector<double> fX;
69 std::vector<double> fMinX;
70 std::vector<double> fDeltaX;
71
72};
73
74/** \class TFoamSampler
75 class implementing the ROOT::Math::DistSampler interface using FOAM
76 for sampling arbitrary distributions.
77*/
78
80
81
83// fOneDim(false)
84// fDiscrete(false),
85// fHasMode(false), fHasArea(false),
86// fMode(0), fArea(0),
87 fFunc1D(0),
88 fFoam(new TFoam("FOAM") ),
89 fFoamDist(0)
90{}
91
93 assert(fFoam != 0);
94 delete fFoam;
95 if (fFoamDist) delete fFoamDist;
96}
97
98bool TFoamSampler::Init(const char *) {
99
100 // initialize using default options
103 if (foamOpt) opt.SetExtraOptions(*foamOpt);
104 return Init(opt);
105}
106
108 // initialize foam classes using the given algorithm
109 assert (fFoam != 0 );
110 if (NDim() == 0) {
111 Error("TFoamSampler::Init","Distribution function has not been set ! Need to call SetFunction first.");
112 return false;
113 }
114
115 // initialize the foam
116 fFoam->SetkDim(NDim() );
117
118 // initialize random number
119 if (!GetRandom()) SetRandom(gRandom);
120
121 // create TFoamIntegrand class
122 if (fFoamDist) delete fFoamDist;
124
126 // set print level
127 fFoam->SetChat(opt.PrintLevel());
128
129 // get extra options
130 ROOT::Math::IOptions * fopt = opt.ExtraOptions();
131 if (fopt) {
132 int nval = 0;
133 double fval = 0;
134 if (fopt->GetIntValue("nCells", nval) ) fFoam->SetnCells(nval);
135 if (fopt->GetIntValue("nCell1D", nval) && NDim() ==1) fFoam->SetnCells(nval);
136 if (fopt->GetIntValue("nCellND", nval) && NDim() >1) fFoam->SetnCells(nval);
137 if (fopt->GetIntValue("nCell2D", nval) && NDim() ==2) fFoam->SetnCells(nval);
138 if (fopt->GetIntValue("nCell3D", nval) && NDim() ==3) fFoam->SetnCells(nval);
139
140 if (fopt->GetIntValue("nSample", nval) ) fFoam->SetnSampl(nval);
141 if (fopt->GetIntValue("nBin", nval) ) fFoam->SetnBin(nval);
142 if (fopt->GetIntValue("OptDrive",nval) ) fFoam->SetOptDrive(nval);
143 if (fopt->GetIntValue("OptRej",nval) ) fFoam->SetOptRej(nval);
144 if (fopt->GetRealValue("MaxWtRej",fval) ) fFoam->SetMaxWtRej(fval);
145
146
147 if (fopt->GetIntValue("chatLevel", nval) ) fFoam->SetChat(nval);
148 }
149 fFoam->Initialize();
150
151 return true;
152
153}
154
155
157 // set function from a TF1 pointer
158 SetFunction<TF1>(*pdf, pdf->GetNdim());
159}
160
162 // set random generator (must be called before Init to have effect)
163 fFoam->SetPseRan(r);
164}
165
166void TFoamSampler::SetSeed(unsigned int seed) {
167 // set random generator seed (must be called before Init to have effect)
168 TRandom * r = fFoam->GetPseRan();
169 if (r) r->SetSeed(seed);
170}
171
173 // get random generator used
174 return fFoam->GetPseRan();
175}
176
177// double TFoamSampler::Sample1D() {
178// // sample 1D distributions
179// return (fDiscrete) ? (double) fFoam->SampleDiscr() : fFoam->Sample();
180// }
181
182bool TFoamSampler::Sample(double * x) {
183 // sample multi-dim distributions
184
185 fFoam->MakeEvent();
186 fFoam->GetMCvect(x);
187 // adjust for the range
188 for (unsigned int i = 0; i < NDim(); ++i)
189 x[i] = ( (FoamDistribution*)fFoamDist)->MinX(i) + ( ( (FoamDistribution*) fFoamDist)->DeltaX(i))*x[i];
190
191 return true;
192}
193
194
195bool TFoamSampler::SampleBin(double prob, double & value, double *error) {
196 // sample a bin according to Poisson statistics
197
198 TRandom * r = GetRandom();
199 if (!r) return false;
200 value = r->Poisson(prob);
201 if (error) *error = std::sqrt(value);
202 return true;
203}
double
ROOT::R::TRInterface & r
Definition Object.C:4
#define f(i)
Definition RSha256.hxx:104
#define ClassImp(name)
Definition Rtypes.h:364
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
Definition TError.cxx:187
float xmax
R__EXTERN TRandom * gRandom
Definition TRandom.h:62
std::vector< double > fMinX
virtual double Density(int ndim, double *x)
std::vector< double > fDeltaX
FoamDistribution(const ROOT::Math::IMultiGenFunction &f, const ROOT::Fit::DataRange &range)
const ROOT::Math::IMultiGenFunction & fFunc
double MinX(unsigned int i)
std::vector< double > fX
double DeltaX(unsigned int i)
class describing the range in the coordinates it supports multiple range in a coordinate.
Definition DataRange.h:35
unsigned int NDim() const
get range dimension
Definition DataRange.h:65
unsigned int Size(unsigned int icoord=0) const
return range size for coordinate icoord (starts from zero) Size == 0 indicates no range is present [-...
Definition DataRange.h:71
DistSampler options class.
int PrintLevel() const
non-static methods for retrivieng options
void SetExtraOptions(const IOptions &opt)
set extra options (in this case pointer is cloned)
IOptions * ExtraOptions() const
return extra options (NULL pointer if they are not present)
static ROOT::Math::IOptions * FindDefault(const char *name)
const double * Sample()
Sample one event and return an array x with sample coordinates values.
const ROOT::Math::IMultiGenFunction & ParentPdf() const
Get the parent distribution function (must be called after setting the function).
unsigned int NDim() const
return the dimension of the parent distribution (and the data)
Definition DistSampler.h:91
const ROOT::Fit::DataRange & PdfRange() const
return the data range of the Pdf . Must be called after setting the function
Documentation for the abstract class IBaseFunctionMultiDim.
Definition IFunction.h:62
virtual unsigned int NDim() const =0
Retrieve the dimension of the function.
Generic interface for defining configuration options of a numerical algorithm.
Definition IOptions.h:31
virtual bool GetIntValue(const char *, int &) const
Definition IOptions.h:86
virtual bool GetRealValue(const char *, double &) const
Definition IOptions.h:84
1-Dim function class
Definition TF1.h:213
virtual Int_t GetNdim() const
Definition TF1.h:485
Abstract class representing n-dimensional real positive integrand function.
class implementing the ROOT::Math::DistSampler interface using FOAM for sampling arbitrary distributi...
void SetSeed(unsigned int seed)
Set the random seed for the TRandom instances used by the sampler classes Needs to be called before I...
TFoamSampler()
default constructor
bool SampleBin(double prob, double &value, double *error=0)
sample one bin given an estimated of the pdf in the bin (this can be function value at the center or ...
void SetRandom(TRandom *r)
Set the random engine to be used Needs to be called before Init to have effect.
TFoamIntegrand * fFoamDist
bool Init(const char *="")
initialize the generators with the default options
virtual ~TFoamSampler()
virtual destructor
void SetFunction(const ROOT::Math::IGenFunction &func)
set the parent function distribution to use for random sampling (one dim case)
TRandom * GetRandom()
Get the random engine used by the sampler.
TFoam is the main class of the multi-dimensional general purpose Monte Carlo event generator (integra...
Definition TFoam.h:21
virtual void GetMCvect(Double_t *)
User may get generated MC point/vector with help of this method.
Definition TFoam.cxx:1176
virtual void MakeEvent()
User method.
Definition TFoam.cxx:1126
virtual void Initialize()
Basic initialization of FOAM invoked by the user.
Definition TFoam.cxx:323
virtual void SetnSampl(Long_t nSampl)
Definition TFoam.h:117
virtual void SetMaxWtRej(Double_t MaxWtRej)
Definition TFoam.h:123
virtual TRandom * GetPseRan() const
Definition TFoam.h:108
virtual void SetChat(Int_t Chat)
Definition TFoam.h:119
virtual void SetOptDrive(Int_t OptDrive)
Definition TFoam.h:121
virtual void SetnCells(Long_t nCells)
Definition TFoam.h:116
virtual void SetRho(TFoamIntegrand *Rho)
User may use this method to set the distribution object.
Definition TFoam.cxx:1022
virtual void SetOptRej(Int_t OptRej)
Definition TFoam.h:120
virtual void SetPseRan(TRandom *PseRan)
Definition TFoam.h:112
virtual void SetnBin(Int_t nBin)
Definition TFoam.h:118
virtual void SetkDim(Int_t kDim)
Definition TFoam.h:115
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
Definition TObject.cxx:949
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Definition TObject.cxx:963
This is the base class for the ROOT Random number generators.
Definition TRandom.h:27
Double_t x[n]
Definition legend1.C:17
Namespace for new Math classes and functions.
tbb::task_arena is an alias of tbb::interface7::task_arena, which doesn't allow to forward declare tb...