55 RooRealVar numBins(
"numBins",
"Number of bins in range",100) ;
57 std::string
name =
"RooBinIntegrator";
60 return std::make_unique<RooBinIntegrator>(function, config);
96 oocoutW(
nullptr,Integration) <<
"RooBinIntegrator::RooBinIntegrator WARNING: integrand provide no binning definition observable #"
97 << i <<
" substituting default binning of " <<
_numBins <<
" bins" << endl ;
98 tmp = std::make_unique<list<double>>( );
103 _binb.emplace_back(tmp->begin(), tmp->end());
115 RooBinIntegrator(function, static_cast<
int>(config.getConfigSection(
"RooBinIntegrator").getRealValue(
"numBins")))
136 oocoutE(
nullptr,Integration) <<
"RooBinIntegrator::setLimits: cannot override integrand's limits" << endl;
162 oocoutE(
nullptr,Integration) <<
"RooBinIntegrator::checkLimits: bad range with min >= max (_xmin = " <<
_xmin[i] <<
" _xmax = " <<
_xmax[i] <<
")" << endl;
183 const std::vector<double>& binb =
_binb[0];
185 for (
unsigned int ibin=0; ibin < binb.size() - 1; ++ibin) {
186 const double xhi = binb[ibin + 1];
187 const double xlo = binb[ibin];
188 const double xcenter = (xhi+xlo)/2.;
193 const std::vector<double>& binbx =
_binb[0];
194 const std::vector<double>& binby =
_binb[1];
196 for (
unsigned int ibin1=0; ibin1 < binbx.size() - 1; ++ibin1) {
197 const double x1hi = binbx[ibin1 + 1];
198 const double x1lo = binbx[ibin1];
199 double x1center = (x1hi+x1lo)/2 ;
201 for (
unsigned int ibin2=0; ibin2 < binby.size() - 1; ++ibin2) {
202 const double x2hi = binby[ibin2 + 1];
203 const double x2lo = binby[ibin2];
204 const double x2center = (x2hi+x2lo)/2.;
206 const double binInt =
integrand(
xvec(x1center,x2center))*(x1hi-x1lo)*(x2hi-x2lo) ;
211 const std::vector<double>& binbx =
_binb[0];
212 const std::vector<double>& binby =
_binb[1];
213 const std::vector<double>& binbz =
_binb[2];
215 for (
unsigned int ibin1=0; ibin1 < binbx.size() - 1; ++ibin1) {
216 const double x1hi = binbx[ibin1 + 1];
217 const double x1lo = binbx[ibin1];
218 double x1center = (x1hi+x1lo)/2 ;
220 for (
unsigned int ibin2=0; ibin2 < binby.size() - 1; ++ibin2) {
221 const double x2hi = binby[ibin2 + 1];
222 const double x2lo = binby[ibin2];
223 const double x2center = (x2hi+x2lo)/2.;
225 for (
unsigned int ibin3=0; ibin3 < binbz.size() - 1; ++ibin3) {
226 const double x3hi = binbz[ibin3 + 1];
227 const double x3lo = binbz[ibin3];
228 const double x3center = (x3hi+x3lo)/2.;
230 const double binInt =
integrand(
xvec(x1center,x2center,x3center))*(x1hi-x1lo)*(x2hi-x2lo)*(x3hi-x3lo);
The Kahan summation is a compensated summation algorithm, which significantly reduces numerical error...
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
virtual std::list< double > * binBoundaries(Int_t) const
Abstract interface for integrators of real-valued functions that implement the RooAbsFunc interface.
bool isValid() const
Is integrator in valid state.
const RooAbsFunc * _function
Pointer to function binding of integrand.
const RooAbsFunc * integrand() const
Return integrand function binding.
Computes the integral over a binned distribution by summing the bin contents of all bins.
std::vector< double > _xmax
! Upper integration bound
static void registerIntegrator(RooNumIntFactory &fact)
Register RooBinIntegrator, is parameters and capabilities with RooNumIntFactory.
Int_t _numBins
! Size of integration range
bool setLimits(double *xmin, double *xmax) override
Change our integration limits.
std::vector< std::vector< double > > _binb
! list of bin boundaries
std::vector< double > _xmin
! Lower integration bound
RooBinIntegrator(const RooAbsFunc &function, int numBins=100)
Construct integrator on given function binding binding.
std::vector< double > _x
! do not persist
bool _useIntegrandLimits
If true limits of function binding are ued.
bool checkLimits() const override
Check that our integration range is finite and otherwise return false.
double integral(const double *yvec=nullptr) override
Calculate numeric integral at given set of function binding parameters.
~RooBinIntegrator() override
Destructor.
bool setLabel(const char *label, bool printError=true) override
Set value by specifying the name of the desired state.
RooNumIntConfig holds the configuration parameters of the various numeric integrators used by RooReal...
static RooNumIntConfig & defaultConfig()
Return reference to instance of default numeric integrator configuration object.
RooNumIntFactory is a factory to instantiate numeric integrators from a given function binding and a ...
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.
RooRealVar represents a variable that can be changed from the outside.
static uint64_t sum(uint64_t i)