55 func(
"func",
"func",this,_func),
57 _binningName(bname?bname:
"cache")
72 _binningName(other._binningName)
112 for (
int i=0 ; i<hist()->numEntries() ; i++) {
159 Int_t nInitRange=32 ;
160 for (
int i=1 ; i<=nInitRange ; i++) {
163 addRange(lo,hi,nbins) ;
168 for (
int i=1 ; i<
nbins ; i++) {
173 Double_t binv = (_self->x.max()-_self->x.min())/nbins ;
174 for (
int i=0 ; i<
nbins ; i++) {
177 hist()->set(_ay[i]/_ay[nbins-1]) ;
179 hist()->set(_ay[i]*binv) ;
221 Int_t ixmid = (ixlo+ixhi)/2 ;
225 Double_t yInt = _ay[ixlo] + (_ay[ixhi]-_ay[ixlo])*(ixmid-ixlo)/(ixhi-ixlo) ;
228 if (
fabs(yInt-_ay[ixmid])*(_ax[nbins-1]-_ax[0])>1e-6) {
229 addRange(ixlo,ixmid,nbins) ;
230 addRange(ixmid,ixhi,nbins) ;
232 for (
Int_t j=ixlo+1 ; j<ixmid ; j++) {
233 _ay[j] = _ay[ixlo] + (_ay[ixmid]-_ay[ixlo])*(j-ixlo)/(ixmid-ixlo) ;
235 for (
Int_t j=ixmid+1 ; j<ixhi ; j++) {
236 _ay[j] = _ay[ixmid] + (_ay[ixhi]-_ay[ixmid])*(j-ixmid)/(ixhi-ixmid) ;
249 _self->x = _xx->getVal() ;
250 _ay[ix] = _self->func.arg().getVal(*_xx) ;
298 return new RICacheElem(*const_cast<RooNumRunningInt*>(
this),nset) ;
307 cout <<
"RooNumRunningInt::evaluate(" <<
GetName() <<
")" << endl ;
void setInterpolationOrder(Int_t order)
Set interpolation order of RooHistFunct representing cache histogram.
RooNumRunningInt(const char *name, const char *title, RooAbsReal &_func, RooRealVar &_x, const char *binningName="cache")
Construct running integral of function '_func' over x_print from the lower bound on _x to the present...
virtual RooArgSet * actualObservables(const RooArgSet &nset) const
Return observable in nset to be cached by RooAbsCachedPdf this is always the x observable that is int...
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Add the specified argument to list.
void addRange(Int_t ixlo, Int_t ixhi, Int_t nbins)
Fill all empty histogram bins in the range [ixlo,ixhi] where nbins is the total number of histogram b...
~RICacheElem()
Destructor.
ClassImp(RooNumRunningInt)
const RooAbsReal & arg() const
virtual FuncCacheElem * createCache(const RooArgSet *nset) const
Create custom cache element for running integral calculations.
Double_t getVal(const RooArgSet *set=0) const
RooArgSet * getParameters(const RooAbsData *data, Bool_t stripDisconnected=kTRUE) const
Create a list of leaf nodes in the arg tree starting with ourself as top node that don't match any of...
virtual ~RooNumRunningInt()
Destructor.
virtual void fillCacheObject(FuncCacheElem &cacheFunc) const
Fill the cache object by calling its calculate() method.
VecExpr< UnaryOp< Fabs< T >, VecExpr< A, T, D >, T >, T, D > fabs(const VecExpr< A, T, D > &rhs)
void addPoint(Int_t ix)
Sample function at bin ix.
virtual RooArgList containedArgs(Action)
Return list of contained RooAbsArg objects.
virtual const char * GetName() const
Returns name of object.
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
void calculate(Bool_t cdfmode)
Calculate the numeric running integral and store the result in the cache histogram provided by RooAbs...
double func(double *x, double *p)
virtual const char * inputBaseName() const
Return unique name for RooAbsCachedPdf cache components constructed from input function name...
virtual Bool_t remove(const RooAbsArg &var, Bool_t silent=kFALSE, Bool_t matchByNameOnly=kFALSE)
Remove the specified argument from our list.
virtual RooArgSet * actualParameters(const RooArgSet &nset) const
Return the parameters of the cache created by RooAbsCachedPdf.
RICacheElem(const RooNumRunningInt &ri, const RooArgSet *nset)
Construct RunningIntegral CacheElement.
float type_of_call hi(const int &, const int &)
virtual RooArgList containedArgs(Action)
Return all RooAbsArg components contained in cache element.
virtual Double_t evaluate() const
Dummy function that is never called.
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Add element to non-owning set.