Definition at line 74 of file GSLMCIntegrator.h.
Public Types | |
typedef double(* | GSLMonteFuncPointer) (double *, size_t, void *) |
typedef MCIntegration::Type | Type |
Public Member Functions | |
GSLMCIntegrator (const char *type, double absTol, double relTol, unsigned int calls) | |
constructor of GSL MCIntegrator. | |
GSLMCIntegrator (MCIntegration::Type type=MCIntegration::kVEGAS, double absTol=-1, double relTol=-1, unsigned int calls=0) | |
constructor of GSL MCIntegrator. | |
virtual | ~GSLMCIntegrator () |
destructor | |
double | ChiSqr () |
returns chi-squared per degree of freedom for the estimate of the integral in the Vegas algorithm | |
double | Error () const |
return the estimate of the absolute Error of the last Integral calculation | |
ROOT::Math::IOptions * | ExtraOptions () const |
get the specific options (for Vegas or Miser) in term of string- name | |
MCIntegration::Type | GetType () const |
return the type (need to be called GetType to avois a conflict with typedef) | |
const char * | GetTypeName () const |
return the name | |
double | Integral (const double *a, const double *b) |
evaluate the integral using the previously defined function | |
double | Integral (const GSLMonteFuncPointer &f, unsigned int dim, double *a, double *b, void *p=0) |
evaluate the Integral of a function f over the defined hypercube (a,b) | |
int | NEval () const |
return number of function evaluations in calculating the integral (This is an fixed by the user) | |
ROOT::Math::IntegratorMultiDimOptions | Options () const |
get the option used for the integration | |
double | Result () const |
return the type of the integration used | |
void | SetAbsTolerance (double absTolerance) |
set the desired absolute Error | |
void | SetFunction (const IMultiGenFunction &f) |
method to set the a generic integration function | |
void | SetFunction (GSLMonteFuncPointer f, unsigned int dim, void *p=0) |
void | SetGenerator (GSLRandomEngine &r) |
set random number generator | |
void | SetMode (MCIntegration::Mode mode) |
set integration mode for VEGAS method The possible MODE are : MCIntegration::kIMPORTANCE (default) : VEGAS will use importance sampling MCIntegration::kSTRATIFIED : VEGAS will use stratified sampling if certain condition are satisfied MCIntegration::kIMPORTANCE_ONLY : VEGAS will always use importance smapling | |
void | SetOptions (const ROOT::Math::IntegratorMultiDimOptions &opt) |
set the integration options | |
void | SetParameters (const MiserParameters &p) |
set default parameters for MISER method | |
void | SetParameters (const VegasParameters &p) |
set default parameters for VEGAS method | |
void | SetRelTolerance (double relTolerance) |
set the desired relative Error | |
void | SetType (MCIntegration::Type type) |
set integration method | |
void | SetTypeName (const char *typeName) |
set integration method using a name instead of an enumeration | |
double | Sigma () |
set parameters for PLAIN method | |
int | Status () const |
return the Error Status of the last Integral calculation | |
Public Member Functions inherited from ROOT::Math::VirtualIntegratorMultiDim | |
virtual | ~VirtualIntegratorMultiDim () |
destructor: no operation | |
virtual ROOT::Math::IntegrationMultiDim::Type | Type () const |
Public Member Functions inherited from ROOT::Math::VirtualIntegrator | |
virtual | ~VirtualIntegrator () |
Protected Member Functions | |
bool | CheckFunction () |
void | DoInitialize () |
Private Member Functions | |
GSLMCIntegrator (const GSLMCIntegrator &) | |
GSLMCIntegrator & | operator= (const GSLMCIntegrator &) |
Private Attributes | |
double | fAbsTol |
unsigned int | fCalls |
unsigned int | fDim |
double | fError |
bool | fExtGen |
GSLMonteFunctionWrapper * | fFunction |
double | fRelTol |
double | fResult |
GSLRngWrapper * | fRng |
int | fStatus |
MCIntegration::Type | fType |
GSLMCIntegrationWorkspace * | fWorkspace |
#include <Math/GSLMCIntegrator.h>
Definition at line 141 of file GSLMCIntegrator.h.
Definition at line 78 of file GSLMCIntegrator.h.
|
explicit |
constructor of GSL MCIntegrator.
VEGAS MC is set as default integration type
type | type of integration. The possible types are defined in the MCIntegration::Type enumeration Default is VEGAS |
absTol | desired absolute Error (this parameter is actually not used and it can be ignored. The tolerance is fixed by the number of given calls) |
relTol | desired relative Error (this parameter is actually not used and it can be ignored. The tolerance is fixed by the number of given calls) |
calls | maximum number of function calls |
NOTE: When the default values are used , the options are taken from teh static method of ROOT::Math::IntegratorMultiDimOptions
Definition at line 73 of file GSLMCIntegrator.cxx.
ROOT::Math::GSLMCIntegrator::GSLMCIntegrator | ( | const char * | type, |
double | absTol, | ||
double | relTol, | ||
unsigned int | calls | ||
) |
constructor of GSL MCIntegrator.
VEGAS MC is set as default integration type
type | type of integration using a char * (required by plug-in manager) |
absTol | desired absolute Error |
relTol | desired relative Error |
calls | maximum number of function calls |
Definition at line 102 of file GSLMCIntegrator.cxx.
|
virtual |
destructor
Definition at line 133 of file GSLMCIntegrator.cxx.
|
private |
Definition at line 147 of file GSLMCIntegrator.cxx.
|
protected |
Definition at line 452 of file GSLMCIntegrator.cxx.
double ROOT::Math::GSLMCIntegrator::ChiSqr | ( | ) |
returns chi-squared per degree of freedom for the estimate of the integral in the Vegas algorithm
Definition at line 434 of file GSLMCIntegrator.cxx.
|
protected |
Definition at line 396 of file GSLMCIntegrator.cxx.
|
virtual |
return the estimate of the absolute Error of the last Integral calculation
Implements ROOT::Math::VirtualIntegrator.
Definition at line 247 of file GSLMCIntegrator.cxx.
ROOT::Math::IOptions * ROOT::Math::GSLMCIntegrator::ExtraOptions | ( | ) | const |
get the specific options (for Vegas or Miser) in term of string- name
Definition at line 479 of file GSLMCIntegrator.cxx.
|
inline |
return the type (need to be called GetType to avois a conflict with typedef)
Definition at line 271 of file GSLMCIntegrator.h.
const char * ROOT::Math::GSLMCIntegrator::GetTypeName | ( | ) | const |
return the name
Definition at line 461 of file GSLMCIntegrator.cxx.
evaluate the integral using the previously defined function
Implements ROOT::Math::VirtualIntegratorMultiDim.
Definition at line 176 of file GSLMCIntegrator.cxx.
double ROOT::Math::GSLMCIntegrator::Integral | ( | const GSLMonteFuncPointer & | f, |
unsigned int | dim, | ||
double * | a, | ||
double * | b, | ||
void * | p = 0 |
||
) |
evaluate the Integral of a function f over the defined hypercube (a,b)
f | integration function. The function type must implement the mathlib::IGenFunction interface |
a | lower value of the integration interval |
b | upper value of the integration interval |
Definition at line 222 of file GSLMCIntegrator.cxx.
|
inlinevirtual |
return number of function evaluations in calculating the integral (This is an fixed by the user)
Reimplemented from ROOT::Math::VirtualIntegrator.
Definition at line 193 of file GSLMCIntegrator.h.
|
private |
Definition at line 151 of file GSLMCIntegrator.cxx.
|
virtual |
get the option used for the integration
Implements ROOT::Math::VirtualIntegratorMultiDim.
Definition at line 468 of file GSLMCIntegrator.cxx.
|
virtual |
return the type of the integration used
return the Result of the last Integral calculation
Implements ROOT::Math::VirtualIntegrator.
Definition at line 242 of file GSLMCIntegrator.cxx.
set the desired absolute Error
Implements ROOT::Math::VirtualIntegrator.
Definition at line 265 of file GSLMCIntegrator.cxx.
|
virtual |
method to set the a generic integration function
f | integration function. The function type must implement the assigment operator, double operator() ( double x ) |
Implements ROOT::Math::VirtualIntegratorMultiDim.
Definition at line 157 of file GSLMCIntegrator.cxx.
void ROOT::Math::GSLMCIntegrator::SetFunction | ( | GSLMonteFuncPointer | f, |
unsigned int | dim, | ||
void * | p = 0 |
||
) |
Definition at line 165 of file GSLMCIntegrator.cxx.
void ROOT::Math::GSLMCIntegrator::SetGenerator | ( | GSLRandomEngine & | r | ) |
set random number generator
Definition at line 267 of file GSLMCIntegrator.cxx.
void ROOT::Math::GSLMCIntegrator::SetMode | ( | MCIntegration::Mode | mode | ) |
set integration mode for VEGAS method The possible MODE are : MCIntegration::kIMPORTANCE (default) : VEGAS will use importance sampling MCIntegration::kSTRATIFIED : VEGAS will use stratified sampling if certain condition are satisfied MCIntegration::kIMPORTANCE_ONLY : VEGAS will always use importance smapling
Definition at line 325 of file GSLMCIntegrator.cxx.
|
virtual |
set the integration options
Reimplemented from ROOT::Math::VirtualIntegratorMultiDim.
Definition at line 340 of file GSLMCIntegrator.cxx.
void ROOT::Math::GSLMCIntegrator::SetParameters | ( | const MiserParameters & | p | ) |
set default parameters for MISER method
Definition at line 382 of file GSLMCIntegrator.cxx.
void ROOT::Math::GSLMCIntegrator::SetParameters | ( | const VegasParameters & | p | ) |
set default parameters for VEGAS method
Definition at line 369 of file GSLMCIntegrator.cxx.
set the desired relative Error
Implements ROOT::Math::VirtualIntegrator.
Definition at line 260 of file GSLMCIntegrator.cxx.
void ROOT::Math::GSLMCIntegrator::SetType | ( | MCIntegration::Type | type | ) |
set integration method
Definition at line 274 of file GSLMCIntegrator.cxx.
void ROOT::Math::GSLMCIntegrator::SetTypeName | ( | const char * | typeName | ) |
set integration method using a name instead of an enumeration
Definition at line 300 of file GSLMCIntegrator.cxx.
double ROOT::Math::GSLMCIntegrator::Sigma | ( | ) |
set parameters for PLAIN method
returns the error sigma from the last iteration of the Vegas algorithm
Definition at line 414 of file GSLMCIntegrator.cxx.
|
virtual |
return the Error Status of the last Integral calculation
Implements ROOT::Math::VirtualIntegrator.
Definition at line 252 of file GSLMCIntegrator.cxx.
|
private |
Definition at line 307 of file GSLMCIntegrator.h.
|
private |
Definition at line 306 of file GSLMCIntegrator.h.
|
private |
Definition at line 305 of file GSLMCIntegrator.h.
|
private |
Definition at line 313 of file GSLMCIntegrator.h.
|
private |
Definition at line 315 of file GSLMCIntegrator.h.
|
private |
Definition at line 319 of file GSLMCIntegrator.h.
|
private |
Definition at line 308 of file GSLMCIntegrator.h.
|
private |
Definition at line 312 of file GSLMCIntegrator.h.
|
private |
Definition at line 303 of file GSLMCIntegrator.h.
|
private |
Definition at line 314 of file GSLMCIntegrator.h.
|
private |
Definition at line 301 of file GSLMCIntegrator.h.
|
private |
Definition at line 318 of file GSLMCIntegrator.h.