#ifndef ROO_REAL_SUM_PDF
#define ROO_REAL_SUM_PDF
#include "RooAbsPdf.h"
#include "RooListProxy.h"
#include "RooAICRegistry.h"
#include "RooObjCacheManager.h"
class RooRealSumPdf : public RooAbsPdf {
public:
RooRealSumPdf() ;
RooRealSumPdf(const char *name, const char *title);
RooRealSumPdf(const char *name, const char *title, const RooArgList& funcList, const RooArgList& coefList, Bool_t extended=kFALSE) ;
RooRealSumPdf(const char *name, const char *title,
RooAbsReal& func1, RooAbsReal& func2, RooAbsReal& coef1) ;
RooRealSumPdf(const RooRealSumPdf& other, const char* name=0) ;
virtual TObject* clone(const char* newname) const { return new RooRealSumPdf(*this,newname) ; }
virtual ~RooRealSumPdf() ;
Double_t evaluate() const ;
virtual Bool_t checkObservables(const RooArgSet* nset) const ;
virtual Bool_t forceAnalyticalInt(const RooAbsArg& arg) const { return arg.isFundamental() ; }
Int_t getAnalyticalIntegralWN(RooArgSet& allVars, RooArgSet& numVars, const RooArgSet* normSet, const char* rangeName=0) const ;
Double_t analyticalIntegralWN(Int_t code, const RooArgSet* normSet, const char* rangeName=0) const ;
const RooArgList& funcList() const { return _funcList ; }
const RooArgList& coefList() const { return _coefList ; }
virtual ExtendMode extendMode() const ;
virtual Double_t expectedEvents(const RooArgSet* nset) const ;
virtual Double_t expectedEvents(const RooArgSet& nset) const {
return expectedEvents(&nset) ;
}
virtual Bool_t selfNormalized() const { return getAttribute("BinnedLikelihoodActive") ; }
void printMetaArgs(std::ostream& os) const ;
virtual std::list<Double_t>* binBoundaries(RooAbsRealLValue& , Double_t , Double_t ) const ;
virtual std::list<Double_t>* plotSamplingHint(RooAbsRealLValue& , Double_t , Double_t ) const ;
Bool_t isBinnedDistribution(const RooArgSet& obs) const ;
void setFloor(Bool_t flag) { _doFloor = flag ; }
Bool_t getFloor() const { return _doFloor ; }
static void setFloorGlobal(Bool_t flag) { _doFloorGlobal = flag ; }
static Bool_t getFloorGlobal() { return _doFloorGlobal ; }
virtual CacheMode canNodeBeCached() const { return RooAbsArg::NotAdvised ; } ;
virtual void setCacheAndTrackHints(RooArgSet&) ;
protected:
class CacheElem : public RooAbsCacheElement {
public:
CacheElem() {} ;
virtual ~CacheElem() {} ;
virtual RooArgList containedArgs(Action) { RooArgList ret(_funcIntList) ; ret.add(_funcNormList) ; return ret ; }
RooArgList _funcIntList ;
RooArgList _funcNormList ;
} ;
mutable RooObjCacheManager _normIntMgr ;
Bool_t _haveLastCoef ;
RooListProxy _funcList ;
RooListProxy _coefList ;
TIterator* _funcIter ;
TIterator* _coefIter ;
Bool_t _extended ;
Bool_t _doFloor ;
static Bool_t _doFloorGlobal ;
private:
ClassDef(RooRealSumPdf,3)
};
#endif