#ifndef ROOTFNPDFBINDING
#define ROOTFNPDFBINDING
#include "RooListProxy.h"
#include "RooAbsPdf.h"
class TF1 ;
class TF2 ;
class TF3 ;
class RooTFnPdfBinding : public RooAbsPdf {
public:
RooTFnPdfBinding() : _func(0) {} ;
RooTFnPdfBinding(const char *name, const char *title, TF1* func, const RooArgList& list);
RooTFnPdfBinding(const RooTFnPdfBinding& other, const char* name=0) ;
virtual TObject* clone(const char* newname) const { return new RooTFnPdfBinding(*this,newname); }
inline virtual ~RooTFnPdfBinding() { }
void printArgs(std::ostream& os) const ;
protected:
RooListProxy _list ;
TF1* _func ;
Double_t evaluate() const ;
private:
ClassDef(RooTFnPdfBinding,1)
};
namespace RooFit {
RooAbsPdf* bindPdf(TF1* func,RooAbsReal& x) ;
RooAbsPdf* bindPdf(TF2* func,RooAbsReal& x, RooAbsReal& y) ;
RooAbsPdf* bindPdf(TF3* func,RooAbsReal& x, RooAbsReal& y, RooAbsReal& z) ;
}
#endif