File indexing completed on 2025-11-04 10:27:16
0001 
0002 
0003 
0004 
0005 
0006 
0007 
0008 
0009 
0010 
0011 
0012 #ifndef ROONUMRUNNINGINT
0013 #define ROONUMRUNNINGINT
0014 
0015 #include "RooAbsCachedReal.h"
0016 #include "RooRealProxy.h"
0017 #include "RooAbsReal.h"
0018 
0019 #include <string>
0020 #include <vector>
0021 
0022 class RooNumRunningInt : public RooAbsCachedReal {
0023 public:
0024   RooNumRunningInt(const char *name, const char *title, RooAbsReal& _func, RooRealVar& _x, const char* binningName="cache");
0025   RooNumRunningInt(const RooNumRunningInt& other, const char* name=nullptr) ;
0026   TObject* clone(const char* newname=nullptr) const override { return new RooNumRunningInt(*this,newname); }
0027   ~RooNumRunningInt() override ;
0028 
0029 protected:
0030 
0031   class RICacheElem: public FuncCacheElem {
0032   public:
0033     RICacheElem(const RooNumRunningInt& ri, const RooArgSet* nset) ;
0034     RooArgList containedArgs(Action) override ;
0035     void calculate(bool cdfmode) ;
0036     void addRange(Int_t ixlo, Int_t ixhi, Int_t nbins) ;
0037     void addPoint(Int_t ix) ;
0038 
0039     RooNumRunningInt* _self ;
0040     std::vector<double> _ax ;
0041     std::vector<double> _ay ;
0042     RooRealVar* _xx ;
0043 
0044   } ;
0045 
0046   friend class RICacheElem ;
0047   const char* binningName() const override { return _binningName.c_str() ; }
0048   FuncCacheElem* createCache(const RooArgSet* nset) const override ;
0049   const char* inputBaseName() const override ;
0050   RooFit::OwningPtr<RooArgSet> actualObservables(const RooArgSet& nset) const override ;
0051   RooFit::OwningPtr<RooArgSet> actualParameters(const RooArgSet& nset) const override ;
0052   void fillCacheObject(FuncCacheElem& cacheFunc) const override ;
0053   double evaluate() const override ;
0054 
0055   const char* payloadUniqueSuffix() const override { return func.arg().aggregateCacheUniqueSuffix() ; }
0056 
0057   RooRealProxy func ; 
0058   RooRealProxy x   ; 
0059   std::string _binningName ; 
0060 
0061 private:
0062 
0063   ClassDefOverride(RooNumRunningInt,1) 
0064 
0065 };
0066 
0067 #endif