54 RooBinIntegrator::registerIntegrator(*
this) ;
55 RooRombergIntegrator::registerIntegrator(*
this) ;
56 RooImproperIntegrator1D::registerIntegrator(*
this) ;
57 RooMCIntegrator::registerIntegrator(*
this) ;
61 RooAdaptiveIntegratorND::registerIntegrator(*
this) ;
72 oocoutE(
nullptr, Integration) <<
" RooNumIntFactory::Init : libRooFitMore cannot be loaded. GSL integrators will not be available ! " << std::endl;
83 static std::unique_ptr<RooNumIntFactory>
instance;
105 bool canIntegrate1D,
bool canIntegrate2D,
bool canIntegrateND,
106 bool canIntegrateOpenEnded,
const char *depName)
115 info.creator = creator;
116 info.canIntegrate1D = canIntegrate1D;
117 info.canIntegrate2D = canIntegrate2D;
118 info.canIntegrateND = canIntegrateND;
119 info.canIntegrateOpenEnded = canIntegrateOpenEnded;
120 info.depName = depName;
135 for (i=0 ; i<ndim ; i++) {
160 method =
"RooBinIntegrator" ;
165 oocoutE(
nullptr,Integration) <<
"RooNumIntFactory: No integration method has been defined for "
166 << (
openEnded?
"an open ended ":
"a ") << ndim <<
"-dimensional integral" << std::endl;
193 engine->setPrintEvalCounter(
true) ;
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
R__EXTERN TSystem * gSystem
virtual const char * getCurrentLabel() const
Return label string of current state.
Abstract interface for evaluating a real-valued function of one real variable and performing numerica...
virtual double getMaxLimit(UInt_t dimension) const =0
virtual double getMinLimit(UInt_t dimension) const =0
UInt_t getDimension() const
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Holds the configuration parameters of the various numeric integrators used by RooRealIntegral.
RooCategory & method2DOpen()
RooCategory & methodNDOpen()
RooCategory & method1DOpen()
bool printEvalCounter() const
static RooNumIntConfig & defaultConfig()
Return reference to instance of default numeric integrator configuration object.
Factory to instantiate numeric integrators from a given function binding and a given configuration.
PluginInfo const * getPluginInfo(std::string const &name) const
std::unique_ptr< RooAbsIntegrator > createIntegrator(RooAbsFunc &func, const RooNumIntConfig &config, int ndim=0, bool isBinned=false) const
Construct a numeric integrator instance that operates on function 'func' and is configured with 'conf...
void init()
Register all known integrators by calling their static registration functions.
std::string getIntegratorName(RooAbsFunc &func, const RooNumIntConfig &config, int ndim=0, bool isBinned=false) const
std::function< std::unique_ptr< RooAbsIntegrator >(RooAbsFunc const &function, const RooNumIntConfig &config)> Creator
std::map< std::string, PluginInfo > _map
static RooNumIntFactory & instance()
Static method returning reference to singleton instance of factory.
bool registerPlugin(std::string const &name, Creator const &creator, const RooArgSet &defConfig, bool canIntegrate1D, bool canIntegrate2D, bool canIntegrateND, bool canIntegrateOpenEnded, const char *depName="")
Method accepting registration of a prototype numeric integrator along with a RooArgSet of its default...
static constexpr int isInfinite(double x)
Return true if x is infinite by RooNumber internal specification.
virtual int Load(const char *module, const char *entry="", Bool_t system=kFALSE)
Load a shared library.