File indexing completed on 2025-09-18 09:33:02
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016 #ifndef ROO_WRAPPER_PDF
0017 #define ROO_WRAPPER_PDF
0018
0019 #include "RooAbsReal.h"
0020 #include "RooRealProxy.h"
0021 #include "RooAbsPdf.h"
0022 #include <list>
0023
0024 class RooWrapperPdf final : public RooAbsPdf {
0025 public:
0026
0027 RooWrapperPdf() { };
0028
0029
0030
0031
0032
0033
0034
0035
0036
0037
0038
0039 RooWrapperPdf(const char *name, const char *title, RooAbsReal& inputFunction, bool selfNormalized=false) :
0040 RooAbsPdf(name, title),
0041 _func("inputFunction", "Function to be converted into a PDF", this, inputFunction),
0042 _selfNormalized{selfNormalized} { }
0043
0044 RooWrapperPdf(const RooWrapperPdf& other, const char *name = nullptr) :
0045 RooAbsPdf(other, name),
0046 _func("inputFunction", this, other._func),
0047 _selfNormalized{other._selfNormalized} { }
0048
0049 TObject* clone(const char* newname=nullptr) const override {
0050 return new RooWrapperPdf(*this, newname);
0051 }
0052
0053 bool selfNormalized() const override { return _selfNormalized; }
0054
0055
0056 bool forceAnalyticalInt(const RooAbsArg& ) const override {
0057
0058
0059
0060 return true;
0061 }
0062 Int_t getAnalyticalIntegralWN(RooArgSet& allVars, RooArgSet& analVars, const RooArgSet* normSet,
0063 const char* rangeName=nullptr) const override {
0064 return _func->getAnalyticalIntegralWN(allVars, analVars, normSet, rangeName);
0065 }
0066 Int_t getAnalyticalIntegral(RooArgSet& allVars, RooArgSet& numVars,
0067 const char* rangeName=nullptr) const override {
0068 return _func->getAnalyticalIntegral(allVars, numVars, rangeName);
0069 }
0070 double analyticalIntegralWN(Int_t code, const RooArgSet* normSet, const char* rangeName) const override {
0071 return _func->analyticalIntegralWN(code, normSet, rangeName);
0072 }
0073 double analyticalIntegral(Int_t code, const char* rangeName=nullptr) const override {
0074 return _func->analyticalIntegral(code, rangeName);
0075 }
0076
0077
0078
0079
0080
0081
0082
0083
0084
0085
0086
0087
0088
0089 Int_t getMaxVal(const RooArgSet& vars) const override {
0090 return _func.arg().getMaxVal(vars);
0091 }
0092 double maxVal(Int_t code) const override {
0093 return _func.arg().maxVal(code);
0094 }
0095 Int_t minTrialSamples(const RooArgSet& arGenObs) const override {
0096 return _func.arg().minTrialSamples(arGenObs);
0097 }
0098
0099
0100 bool isBinnedDistribution(const RooArgSet& obs) const override {
0101 return _func.arg().isBinnedDistribution(obs);
0102 }
0103 std::list<double>* binBoundaries(RooAbsRealLValue& obs, double xlo, double xhi) const override {
0104 return _func.arg().binBoundaries(obs, xlo, xhi);
0105 }
0106 std::list<double>* plotSamplingHint(RooAbsRealLValue& obs, double xlo, double xhi) const override {
0107 return _func.arg().plotSamplingHint(obs, xlo, xhi);
0108 }
0109
0110 RooAbsReal const &function() const { return *_func; }
0111
0112 private:
0113 RooRealProxy _func;
0114 bool _selfNormalized = false;
0115
0116 double evaluate() const override {
0117 return _func;
0118 }
0119
0120 ClassDefOverride(RooWrapperPdf,2);
0121 };
0122
0123 #endif