Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
RooMCIntegrator.h
Go to the documentation of this file.
1/*****************************************************************************
2 * Project: RooFit *
3 * Package: RooFitCore *
4 * File: $Id: RooMCIntegrator.h,v 1.15 2007/05/11 09:11:30 verkerke Exp $
5 * Authors: *
6 * WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.edu *
7 * DK, David Kirkby, UC Irvine, dkirkby@uci.edu *
8 * *
9 * Copyright (c) 2000-2005, Regents of the University of California *
10 * and Stanford University. All rights reserved. *
11 * *
12 * Redistribution and use in source and binary forms, *
13 * with or without modification, are permitted according to the terms *
14 * listed in LICENSE (http://roofit.sourceforge.net/license.txt) *
15 *****************************************************************************/
16#ifndef ROO_MC_INTEGRATOR
17#define ROO_MC_INTEGRATOR
18
19#include "RooAbsIntegrator.h"
20#include "RooGrid.h"
21#include "RooNumIntConfig.h"
22#include "TStopwatch.h"
23
25public:
26
27 // Constructors, assignment etc
31 GeneratorType genType= QuasiRandom, bool verbose= false);
32 RooMCIntegrator(const RooAbsFunc& function, const RooNumIntConfig& config);
33 ~RooMCIntegrator() override;
34
35 bool checkLimits() const override;
36 double integral(const double* yvec=nullptr) override;
37
39 double vegas(Stage stage, UInt_t calls, UInt_t iterations, double *absError= nullptr);
40
41 double getAlpha() const { return _alpha; }
42 void setAlpha(double alpha) { _alpha= alpha; }
43
44 GeneratorType getGenType() const { return _genType; }
46
47 const RooGrid &grid() const { return _grid; }
48
49protected:
50
51 friend class RooNumIntFactory ;
52 static void registerIntegrator(RooNumIntFactory& fact) ;
53
54 mutable RooGrid _grid; // Sampling grid definition
55
56 // control variables
57 bool _verbose; ///< Verbosity control
58 double _alpha; ///< Grid stiffness parameter
59 Int_t _mode; ///< Sampling mode
60 GeneratorType _genType; ///< Generator type
61 Int_t _nRefineIter ; ///< Number of refinement iterations
62 Int_t _nRefinePerDim ; ///< Number of refinement samplings (per dim)
63 Int_t _nIntegratePerDim ; ///< Number of integration samplings (per dim)
64
65 TStopwatch _timer; ///< Timer
66
67 double _jac,_wtd_int_sum,_sum_wgts,_chi_sum,_chisq,_result,_sigma; ///< Scratch variables preserved between calls to vegas1/2/2
68 UInt_t _it_start,_it_num,_samples,_calls_per_box; ///< Scratch variables preserved between calls to vegas1/2/2
69
70 ClassDefOverride(RooMCIntegrator,0) // VEGAS based multi-dimensional numerical integration engine
71};
72
73#endif
#define ClassDefOverride(name, id)
Definition Rtypes.h:341
Option_t Option_t TPoint TPoint const char mode
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t type
Abstract interface for evaluating a real-valued function of one real variable and performing numerica...
Definition RooAbsFunc.h:27
Abstract interface for integrators of real-valued functions that implement the RooAbsFunc interface.
RooGrid is a utility class for RooMCIntegrator which implements an adaptive multi-dimensional Monte C...
Definition RooGrid.h:27
RooMCIntegrator implements an adaptive multi-dimensional Monte Carlo numerical integration,...
GeneratorType _genType
Generator type.
static void registerIntegrator(RooNumIntFactory &fact)
This function registers class RooMCIntegrator, its configuration options and its capabilities with Ro...
TStopwatch _timer
Timer.
Int_t _nIntegratePerDim
Number of integration samplings (per dim)
~RooMCIntegrator() override
Destructor.
const RooGrid & grid() const
bool checkLimits() const override
Check if we can integrate over the current domain.
double _sigma
Scratch variables preserved between calls to vegas1/2/2.
GeneratorType getGenType() const
double vegas(Stage stage, UInt_t calls, UInt_t iterations, double *absError=nullptr)
Perform one step of Monte Carlo integration using the specified number of iterations with (approximat...
void setGenType(GeneratorType type)
bool _verbose
Verbosity control.
double getAlpha() const
Int_t _mode
Sampling mode.
Int_t _nRefinePerDim
Number of refinement samplings (per dim)
double _alpha
Grid stiffness parameter.
void setAlpha(double alpha)
UInt_t _calls_per_box
Scratch variables preserved between calls to vegas1/2/2.
Int_t _nRefineIter
Number of refinement iterations.
double integral(const double *yvec=nullptr) override
Evaluate the integral using a fixed number of calls to evaluate the integrand equal to about 10k per ...
RooNumIntConfig holds the configuration parameters of the various numeric integrators used by RooReal...
RooNumIntFactory is a factory to instantiate numeric integrators from a given function binding and a ...
Stopwatch class.
Definition TStopwatch.h:28