84  _funcList(
"!funcList",
"List of functions",this),
 
   85  _coefList(
"!coefList",
"List of coefficients",this),
 
  103  _normIntMgr(this,10),
 
  105  _funcList(
"!funcList",
"List of functions",this),
 
  106  _coefList(
"!coefList",
"List of coefficients",this),
 
  130  _normIntMgr(this,10),
 
  132  _funcList(
"!funcList",
"List of functions",this),
 
  133  _coefList(
"!coefList",
"List of coefficients",this),
 
  139           << 
") number of pdfs and coefficients inconsistent, must have Nfunc=Ncoef or Nfunc=Ncoef+1" << endl ;
 
  170      coutE(
InputArguments) << 
"RooRealSumPdf::RooRealSumPdf(" << 
GetName() << 
") last func " << coef->
GetName() << 
" is not of type RooAbsReal, fatal error" << endl ;
 
  190  _normIntMgr(other._normIntMgr,this),
 
  191  _haveLastCoef(other._haveLastCoef),
 
  192  _funcList(
"!funcList",this,other._funcList),
 
  193  _coefList(
"!coefList",this,other._coefList),
 
  194  _extended(other._extended),
 
  195  _doFloor(other._doFloor)
 
  245      cxcoutD(
Eval) << 
"RooRealSumPdf::eval(" << 
GetName() << 
") coefVal = " << coefVal << 
" funcVal = " << func->IsA()->
GetName() << 
"::" << func->
GetName() << 
" = " << func->
getVal() << endl ;
 
  247   value += func->
getVal()*coefVal ;
 
  249      lastCoef -= coef->
getVal() ;
 
  257      value += func->
getVal()*lastCoef ;
 
  260    cxcoutD(
Eval) << 
"RooRealSumPdf::eval(" << 
GetName() << 
") lastCoef = " << lastCoef << 
" funcVal = " << func->
getVal() << endl ;
 
  263    if (lastCoef<0 || lastCoef>1) {
 
  265        << 
" WARNING: sum of FUNC coefficients not in range [0-1], value="  
  266        << 1-lastCoef << endl ;
 
  301             << 
" and FUNC " << func->
GetName() << 
" have one or more observables in common" << endl ;
 
  306             << 
" depends on one or more of the following observables" ; nset->
Print(
"1") ;
 
  322                    const RooArgSet* normSet2, 
const char* rangeName)
 const  
  325  if (allVars.
getSize()==0) 
return 0 ;
 
  329  analVars.
add(allVars) ;
 
  334  Int_t sterileIdx(-1) ;
 
  351    if (normSet && normSet->
getSize()>0) {
 
  379  if (code==0) 
return getVal(normSet2) ;
 
  407    Double_t coefVal = coef->getVal(normSet2) ;
 
  412   value += funcInt->getVal()*coefVal ;
 
  414      lastCoef -= coef->getVal(normSet2) ;
 
  423      value += funcInt->getVal()*lastCoef ;
 
  427    if (lastCoef<0 || lastCoef>1) {
 
  429        << 
" WARNING: sum of FUNC coefficients not in range [0-1], value="  
  430        << 1-lastCoef << endl ;
 
  435  if (normSet2 && normSet2->
getSize()>0) {
 
  444      Double_t coefVal = coef->getVal(normSet2) ;
 
  447   normVal += funcNorm->
getVal()*coefVal ;
 
  455      normVal += funcNorm->
getVal()*lastCoef ;
 
  459  return value / normVal;
 
  479  list<Double_t>* sumBinB = 0 ;
 
  487    list<Double_t>* funcBinB = func->
binBoundaries(obs,xlo,xhi) ;
 
  496   list<Double_t>* newSumBinB = 
new list<Double_t>(sumBinB->size()+funcBinB->size()) ;
 
  499   merge(funcBinB->begin(),funcBinB->end(),sumBinB->begin(),sumBinB->end(),newSumBinB->begin()) ;
 
  504   sumBinB = newSumBinB ;
 
  512    list<Double_t>::iterator new_end = unique(sumBinB->begin(),sumBinB->end()) ;
 
  513    sumBinB->erase(new_end,sumBinB->end()) ;
 
  545  list<Double_t>* sumHint = 0 ;
 
  564   list<Double_t>* newSumHint = 
new list<Double_t>(sumHint->size()+funcHint->size()) ;
 
  567   merge(funcHint->begin(),funcHint->end(),sumHint->begin(),sumHint->end(),newSumHint->begin()) ;
 
  571   sumHint = newSumHint ;
 
  579    list<Double_t>::iterator new_end = unique(sumHint->begin(),sumHint->end()) ;
 
  580    sumHint->erase(new_end,sumHint->end()) ;
 
  596  while ((sarg=siter.
next())) {
 
  598      trackNodes.
add(*sarg) ;
 
  630      os << 
" + [%] * " << func->
GetName() ;
 
static RooMathCoreReg dummy
RooAbsArg is the common abstract base class for objects that represent a value (of arbitrary type) an...
RooArgSet * getObservables(const RooArgSet &set, Bool_t valueOnly=kTRUE) const
Bool_t dependsOn(const RooAbsCollection &serverList, const RooAbsArg *ignoreArg=0, Bool_t valueOnly=kFALSE) const
Test whether we depend on (ie, are served by) any object in the specified collection.
virtual CacheMode canNodeBeCached() 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...
Bool_t observableOverlaps(const RooAbsData *dset, const RooAbsArg &testArg) const
Test if any of the dependents of the arg tree (as determined by getObservables) overlaps with those o...
RooAbsCacheElement is the abstract base class for objects to be stored in RooAbsCache cache manager o...
virtual Bool_t addOwned(RooAbsArg &var, Bool_t silent=kFALSE)
Add the specified argument to list.
RooFIter fwdIterator() const
virtual void Print(Option_t *options=0) const
This method must be overridden when a class wants to print itself.
TIterator * createIterator(Bool_t dir=kIterForward) const
RooAbsPdf is the abstract interface for all probability density functions The class provides hybrid a...
Double_t getNorm(const RooArgSet &nset) const
RooAbsRealLValue is the common abstract base class for objects that represent a real value that may a...
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
Bool_t isSelectedComp() const
If true, the current pdf is a selected component (for use in plotting)
virtual std::list< Double_t > * plotSamplingHint(RooAbsRealLValue &, Double_t, Double_t) const
virtual std::list< Double_t > * binBoundaries(RooAbsRealLValue &, Double_t, Double_t) const
Double_t getVal(const RooArgSet *set=0) const
Evaluate object. Returns either cached value or triggers a recalculation.
RooAbsReal * createIntegral(const RooArgSet &iset, const RooCmdArg &arg1, const RooCmdArg &arg2=RooCmdArg::none(), const RooCmdArg &arg3=RooCmdArg::none(), const RooCmdArg &arg4=RooCmdArg::none(), const RooCmdArg &arg5=RooCmdArg::none(), const RooCmdArg &arg6=RooCmdArg::none(), const RooCmdArg &arg7=RooCmdArg::none(), const RooCmdArg &arg8=RooCmdArg::none()) const
Create an object that represents the integral of the function over one or more observables listed in ...
virtual Bool_t isBinnedDistribution(const RooArgSet &) const
void logEvalError(const char *message, const char *serverValueString=0) const
Log evaluation error message.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
virtual Bool_t add(const RooAbsCollection &col, Bool_t silent=kFALSE)
Add a collection of arguments to this collection by calling add() for each element in the source coll...
T * getObj(const RooArgSet *nset, Int_t *sterileIndex=0, const TNamed *isetRangeName=0)
const RooNameSet * nameSet2ByIndex(Int_t index) const
T * getObjByIndex(Int_t index) const
const RooNameSet * nameSet1ByIndex(Int_t index) const
Int_t setObj(const RooArgSet *nset, T *obj, const TNamed *isetRangeName=0)
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Reimplementation of standard RooArgList::add()
static const TNamed * ptr(const char *stringPtr)
Return a unique TNamed pointer for given C++ string.
RooArgSet * select(const RooArgSet &list) const
Construct a RooArgSet of objects in input 'list' whose names match to those in the internal name list...
RooRealIntegral performs hybrid numerical/analytical integrals of RooAbsReal objects.
Class RooRealSumPdf implements a PDF constructed from a sum of functions:
virtual ExtendMode extendMode() const
const RooArgList & funcList() const
RooObjCacheManager _normIntMgr
Double_t evaluate() const
Calculate the current value.
RooRealSumPdf()
Default constructor coverity[UNINIT_CTOR].
virtual Double_t expectedEvents(const RooArgSet *nset) const
Return expected number of events from this p.d.f for use in extended likelihood calculations.
Bool_t isBinnedDistribution(const RooArgSet &obs) const
static Bool_t _doFloorGlobal
virtual std::list< Double_t > * plotSamplingHint(RooAbsRealLValue &, Double_t, Double_t) const
virtual ~RooRealSumPdf()
Destructor.
virtual Bool_t checkObservables(const RooArgSet *nset) const
Check if FUNC is valid for given normalization set.
void printMetaArgs(std::ostream &os) const
Customized printing of arguments of a RooRealSumPdf to more intuitively reflect the contents of the p...
virtual void setCacheAndTrackHints(RooArgSet &)
Label OK'ed components of a RooRealSumPdf with cache-and-track.
Bool_t _extended
Iterator over coefficient list.
TIterator * _coefIter
Iterator over FUNC list.
virtual std::list< Double_t > * binBoundaries(RooAbsRealLValue &, Double_t, Double_t) const
Int_t getAnalyticalIntegralWN(RooArgSet &allVars, RooArgSet &numVars, const RooArgSet *normSet, const char *rangeName=0) const
cout << "RooRealSumPdf::getAnalyticalIntegralWN:"<<GetName()<<"("<<allVars<<",analVars,...
Double_t analyticalIntegralWN(Int_t code, const RooArgSet *normSet, const char *rangeName=0) const
cout << "RooRealSumPdf::analyticalIntegralWN:"<<GetName()<<"("<<code<<","<<(normSet2?...
Iterator abstract base class.
virtual TObject * Next()=0
virtual const char * GetName() const
Returns name of object.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".