File indexing completed on 2025-09-15 09:12:17
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016 #ifndef ROO_DATA_HIST
0017 #define ROO_DATA_HIST
0018
0019 #include <RooAbsData.h>
0020 #include <RooArgSet.h>
0021 #include <RooDirItem.h>
0022 #include <RooGlobalFunc.h>
0023
0024 #include <Rtypes.h>
0025
0026 #include <functional>
0027 #include <map>
0028 #include <memory>
0029 #include <string>
0030 #include <string_view>
0031 #include <unordered_map>
0032 #include <vector>
0033
0034 class TAxis ;
0035 class RooAbsArg;
0036 class RooCategory ;
0037 class RooPlot;
0038 class RooAbsLValue ;
0039
0040 class RooDataHist : public RooAbsData, public RooDirItem {
0041 public:
0042
0043
0044 RooDataHist() ;
0045 RooDataHist(RooStringView name, RooStringView title, const RooArgSet& vars, const char* binningName=nullptr) ;
0046 RooDataHist(RooStringView name, RooStringView title, const RooArgSet& vars, const RooAbsData& data, double initWgt=1.0) ;
0047 RooDataHist(RooStringView name, RooStringView title, const RooArgList& vars, const TH1* hist, double initWgt=1.0) ;
0048 RooDataHist(RooStringView name, RooStringView title, const RooArgList& vars, RooCategory& indexCat, std::map<std::string,TH1*> histMap, double initWgt=1.0) ;
0049 RooDataHist(RooStringView name, RooStringView title, const RooArgList& vars, RooCategory& indexCat, std::map<std::string,RooDataHist*> dhistMap, double wgt=1.0) ;
0050 RooDataHist(RooStringView name, RooStringView title, const RooArgList& vars, const RooCmdArg& arg1, const RooCmdArg& arg2={}, const RooCmdArg& arg3={},
0051 const RooCmdArg& arg4={},const RooCmdArg& arg5={},const RooCmdArg& arg6={},const RooCmdArg& arg7={},const RooCmdArg& arg8={}) ;
0052
0053
0054 template<class Val_t>
0055 inline RooDataHist(RooStringView name, RooStringView title, const RooArgList& vars, RooCategory& indexCat, RooFit::Detail::FlatMap<std::string,Val_t> const& histMap, double initWgt=1.0)
0056 : RooDataHist(name, title, vars, indexCat, RooFit::Detail::flatMapToStdMap(histMap), initWgt) {}
0057
0058 RooDataHist& operator=(const RooDataHist&) = delete;
0059
0060 RooDataHist(const RooDataHist& other, const char* newname = nullptr) ;
0061 TObject* Clone(const char* newname="") const override {
0062 return new RooDataHist(*this, newname && newname[0] != '\0' ? newname : GetName());
0063 }
0064 ~RooDataHist() override ;
0065
0066
0067 RooFit::OwningPtr<RooAbsData> emptyClone(const char* newName=nullptr, const char* newTitle=nullptr, const RooArgSet*vars=nullptr, const char* =nullptr) const override {
0068 return RooFit::makeOwningPtr(std::make_unique<RooDataHist>(newName?newName:GetName(),newTitle?newTitle:GetTitle(),vars?*vars:*get()));
0069 }
0070
0071
0072 void add(const RooArgSet& row, double wgt=1.0) override { add(row,wgt,-1.); }
0073 void add(const RooArgSet& row, double weight, double sumw2);
0074 void set(std::size_t binNumber, double weight, double wgtErr);
0075 void set(const RooArgSet& row, double weight, double wgtErr=-1.) ;
0076 void set(const RooArgSet& row, double weight, double wgtErrLo, double wgtErrHi) ;
0077
0078 void add(const RooAbsData& dset, const RooFormulaVar* cutVar=nullptr, double weight=1.0 ) ;
0079 void add(const RooAbsData& dset, const char* cut, double weight=1.0 ) ;
0080
0081
0082 const RooArgSet* get() const override { return &_vars; }
0083 const RooArgSet* get(Int_t binNumber) const override;
0084 virtual const RooArgSet* get(const RooArgSet& coord) const;
0085 double sumEntries() const override;
0086 double sumEntries(const char* cutSpec, const char* cutRange=nullptr) const override;
0087
0088
0089 bool isWeighted() const override { return true; }
0090 bool isNonPoissonWeighted() const override ;
0091
0092 std::span<const double> getWeightBatch(std::size_t first, std::size_t len, bool sumW2=false) const override;
0093
0094
0095 std::span<const double> binVolumes(std::size_t first, std::size_t len) const {
0096 return {_binv + first, len};
0097 }
0098
0099 double sum(bool correctForBinSize, bool inverseCorr=false) const ;
0100 double sum(const RooArgSet& sumSet, const RooArgSet& sliceSet, bool correctForBinSize, bool inverseCorr=false) ;
0101 double sum(const RooArgSet& sumSet,
0102 const RooArgSet& sliceSet,
0103 bool correctForBinSize,
0104 bool inverseCorr,
0105 const std::map<const RooAbsArg*, std::pair<double, double> >& ranges,
0106 std::function<double(int)> getBinScale = [](int){ return 1.0; } );
0107
0108 void weights(double* output, std::span<double const> xVals, int intOrder, bool correctForBinSize, bool cdfBoundaries);
0109
0110 double weight(std::size_t i) const { return _wgt[i]; }
0111 double weightFast(const RooArgSet& bin, int intOrder, bool correctForBinSize, bool cdfBoundaries);
0112 double weight(const RooArgSet& bin, Int_t intOrder=1, bool correctForBinSize=false, bool cdfBoundaries=false, bool oneSafe=false);
0113
0114
0115
0116
0117 double weightSquared(std::size_t i) const { return _sumw2 ? _sumw2[i] : _wgt[i]; }
0118
0119 double binVolume(std::size_t i) const { return _binv[i]; }
0120 double binVolume(const RooArgSet& bin) const;
0121
0122 TIterator* sliceIterator(RooAbsArg& sliceArg, const RooArgSet& otherArgs) ;
0123
0124 void weightError(double& lo, double& hi, ErrorType etype=Poisson) const override;
0125
0126 double weightError(ErrorType etype=Poisson) const override {
0127
0128 double lo;
0129 double hi;
0130 weightError(lo,hi,etype) ;
0131 return (lo+hi)/2 ;
0132 }
0133
0134 using RooAbsData::plotOn ;
0135 RooPlot *plotOn(RooPlot *frame, PlotOpt o) const override;
0136
0137 void reset() override;
0138
0139 void printMultiline(std::ostream& os, Int_t content, bool verbose=false, TString indent="") const override;
0140 void printArgs(std::ostream& os) const override;
0141 void printValue(std::ostream& os) const override;
0142 void printDataHistogram(std::ostream& os, RooRealVar* obs) const;
0143
0144 void SetName(const char *name) override;
0145 void SetNameTitle(const char *name, const char* title) override;
0146
0147 Int_t getIndex(const RooAbsCollection& coord, bool fast = false) const;
0148
0149
0150
0151
0152
0153
0154
0155
0156
0157
0158
0159
0160
0161 Int_t getIndex(const RooArgSet& coord, bool fast = false) const {
0162 return getIndex(static_cast<const RooAbsCollection&>(coord), fast);
0163 }
0164
0165 void removeSelfFromDir() { removeFromDir(this) ; }
0166
0167
0168
0169
0170
0171
0172
0173
0174
0175
0176
0177
0178
0179
0180
0181
0182
0183
0184
0185
0186 double weight() const override
0187 R__SUGGEST_ALTERNATIVE("Use the safer weight(std::size_t) const.")
0188 { return _wgt[_curIndex]; }
0189
0190
0191 double weightSquared() const override
0192 R__SUGGEST_ALTERNATIVE("Use the safer weightSquared(std::size_t) const.")
0193 { return weightSquared(_curIndex); }
0194
0195 double binVolume() const
0196 R__SUGGEST_ALTERNATIVE("Use binVolume(std::size_t) const.")
0197 { return _binv[_curIndex]; }
0198
0199 void set(double wgt, double wgtErr=-1)
0200 R__SUGGEST_ALTERNATIVE("Use set(std::size_t,double,double).");
0201
0202
0203
0204
0205
0206
0207 struct VarInfo {
0208 size_t nRealVars = 0;
0209 size_t realVarIdx1 = 0;
0210 size_t realVarIdx2 = 0;
0211 bool initialized = false;
0212 };
0213
0214 std::vector<std::unique_ptr<const RooAbsBinning>> const& getBinnings() const { return _lvbins; }
0215
0216 int arraySize() const { return _arrSize; }
0217 double const* weightArray() const { return _wgt; }
0218 double const* wgtErrLoArray() const { return _errLo; }
0219 double const* wgtErrHiArray() const { return _errHi; }
0220 double const* sumW2Array() const { return _sumw2; }
0221
0222 std::string calculateTreeIndexForCodeSquash(RooFit::Experimental::CodegenContext &ctx,
0223 const RooAbsCollection &coords, bool reverse = false) const;
0224 std::string declWeightArrayForCodeSquash(RooFit::Experimental::CodegenContext &ctx,
0225 bool correctForBinSize) const;
0226
0227 protected:
0228 friend class RooDataHistSliceIter ;
0229
0230 std::size_t calcTreeIndex(const RooAbsCollection& coords, bool fast) const;
0231
0232
0233 Int_t calcTreeIndex() const { return static_cast<Int_t>(calcTreeIndex(_vars, true)); }
0234
0235 void initialize(const char* binningName=nullptr,bool fillTree=true) ;
0236 std::unique_ptr<RooAbsData> reduceEng(const RooArgSet& varSubset, const RooFormulaVar* cutVar, const char* cutRange=nullptr,
0237 std::size_t nStart=0, std::size_t nStop=std::numeric_limits<std::size_t>::max()) const override;
0238 double interpolateDim(int iDim, double xval, size_t centralIdx, int intOrder, bool correctForBinSize, bool cdfBoundaries) ;
0239 const std::vector<double>& calculatePartialBinVolume(const RooArgSet& dimSet) const ;
0240 void checkBinBounds() const;
0241
0242 void adjustBinning(const RooArgList& vars, const TH1& href, Int_t* offset=nullptr) ;
0243 void importTH1(const RooArgList& vars, const TH1& histo, double initWgt, bool doDensityCorrection) ;
0244 void importTH1Set(const RooArgList& vars, RooCategory& indexCat, std::map<std::string,TH1*> hmap, double initWgt, bool doDensityCorrection) ;
0245 void importDHistSet(const RooArgList& vars, RooCategory& indexCat, std::map<std::string,RooDataHist*> dmap, double initWgt) ;
0246
0247 Int_t _arrSize{0};
0248 std::vector<Int_t> _idxMult ;
0249
0250 double* _wgt {nullptr};
0251 mutable double* _errLo{nullptr};
0252 mutable double* _errHi{nullptr};
0253 mutable double* _sumw2{nullptr};
0254 double* _binv {nullptr};
0255
0256 mutable ULong64_t _curIndex{std::numeric_limits<ULong64_t>::max()};
0257
0258 mutable std::unordered_map<int,std::vector<double>> _pbinvCache ;
0259 std::vector<RooAbsLValue*> _lvvars ;
0260 std::vector<std::unique_ptr<const RooAbsBinning>> _lvbins ;
0261 mutable std::vector<std::vector<double> > _binbounds;
0262
0263 enum CacheSumState_t{kInvalid = 0, kNoBinCorrection = 1, kCorrectForBinSize = 2, kInverseBinCorr = 3};
0264 mutable Int_t _cache_sum_valid{kInvalid};
0265 mutable double _cache_sum{0.};
0266
0267 private:
0268 void interpolateQuadratic(double* output, std::span<const double> xVals, bool correctForBinSize, bool cdfBoundaries);
0269 void interpolateLinear(double* output, std::span<const double> xVals, bool correctForBinSize, bool cdfBoundaries);
0270 double weightInterpolated(const RooArgSet& bin, int intOrder, bool correctForBinSize, bool cdfBoundaries);
0271
0272 void _adjustBinning(RooRealVar &theirVar, const TAxis &axis, RooRealVar *ourVar, Int_t *offset);
0273 void registerWeightArraysToDataStore() const;
0274 void initializeAsymErrArrays() const;
0275 VarInfo const& getVarInfo();
0276
0277 static std::unique_ptr<RooAbsDataStore>
0278 makeDefaultDataStore(RooStringView name, RooStringView title, RooArgSet const &vars);
0279
0280 VarInfo _varInfo;
0281 std::vector<double> _interpolationBuffer;
0282
0283 ClassDefOverride(RooDataHist, 8)
0284 };
0285
0286 #endif