Logo ROOT  
Reference Guide
 
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
Loading...
Searching...
No Matches
RooProdPdf.h
Go to the documentation of this file.
1/*****************************************************************************
2 * Project: RooFit *
3 * Package: RooFitCore *
4 * File: $Id: RooProdPdf.h,v 1.44 2007/07/16 21:04:28 wouter Exp $
5 * Authors: *
6 * WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.edu *
7 * DK, David Kirkby, UC Irvine, dkirkby@uci.edu *
8 * *
9 * Copyright (c) 2000-2005, Regents of the University of California *
10 * and Stanford University. All rights reserved. *
11 * *
12 * Redistribution and use in source and binary forms, *
13 * with or without modification, are permitted according to the terms *
14 * listed in LICENSE (http://roofit.sourceforge.net/license.txt) *
15 *****************************************************************************/
16#ifndef ROO_PROD_PDF
17#define ROO_PROD_PDF
18
19#include "RooAbsPdf.h"
20#include "RooListProxy.h"
21#include "RooLinkedList.h"
22#include "RooAICRegistry.h"
23#include "RooObjCacheManager.h"
24#include "RooCmdArg.h"
25
26#include <vector>
27#include <list>
28#include <string>
29
30namespace RooFit {
31namespace Detail {
32class RooFixedProdPdf;
33}
34}
35
36class RooProdPdf : public RooAbsPdf {
37public:
38
39 RooProdPdf() ;
40 RooProdPdf(const char *name, const char *title,
41 RooAbsPdf& pdf1, RooAbsPdf& pdf2, double cutOff=0.0) ;
42 RooProdPdf(const char* name, const char* title, const RooArgList& pdfList, double cutOff=0.0) ;
43 RooProdPdf(const char* name, const char* title, const RooArgSet& fullPdfSet, const RooLinkedList& cmdArgList) ;
44
45 RooProdPdf(const char* name, const char* title, const RooArgSet& fullPdfSet,
46 const RooCmdArg& arg1 , const RooCmdArg& arg2={},
47 const RooCmdArg& arg3={}, const RooCmdArg& arg4={},
48 const RooCmdArg& arg5={}, const RooCmdArg& arg6={},
49 const RooCmdArg& arg7={}, const RooCmdArg& arg8={}) ;
50
51 RooProdPdf(const char* name, const char* title,
52 const RooCmdArg& arg1, const RooCmdArg& arg2={},
53 const RooCmdArg& arg3={}, const RooCmdArg& arg4={},
54 const RooCmdArg& arg5={}, const RooCmdArg& arg6={},
55 const RooCmdArg& arg7={}, const RooCmdArg& arg8={}) ;
56
57 RooProdPdf(const RooProdPdf& other, const char* name=nullptr) ;
58 TObject* clone(const char* newname) const override { return new RooProdPdf(*this,newname) ; }
59 ~RooProdPdf() override ;
60
61 bool forceAnalyticalInt(const RooAbsArg& dep) const override ;
62 Int_t getAnalyticalIntegralWN(RooArgSet& allVars, RooArgSet& numVars, const RooArgSet* normSet, const char* rangeName=nullptr) const override ;
63 double analyticalIntegralWN(Int_t code, const RooArgSet* normSet, const char* rangeName=nullptr) const override ;
64 bool selfNormalized() const override { return _selfNorm ; }
65
66 ExtendMode extendMode() const override ;
67 double expectedEvents(const RooArgSet* nset) const override ;
68 std::unique_ptr<RooAbsReal> createExpectedEventsFunc(const RooArgSet* nset) const override;
69
70 const RooArgList& pdfList() const { return _pdfList ; }
71
72 void addPdfs(RooAbsCollection const& pdfs);
73 void removePdfs(RooAbsCollection const& pdfs);
74
75 Int_t getGenerator(const RooArgSet& directVars, RooArgSet &generateVars, bool staticInitOK=true) const override;
76 void initGenerator(Int_t code) override ;
77 void generateEvent(Int_t code) override;
78 bool isDirectGenSafe(const RooAbsArg& arg) const override ;
79
80 // Constraint management
81 RooArgSet* getConstraints(const RooArgSet& observables, RooArgSet const& constrainedParams, RooArgSet &pdfParams) const override ;
82
83 std::list<double>* plotSamplingHint(RooAbsRealLValue& obs, double xlo, double xhi) const override ;
84 std::list<double>* binBoundaries(RooAbsRealLValue& /*obs*/, double /*xlo*/, double /*xhi*/) const override ;
85 bool isBinnedDistribution(const RooArgSet& obs) const override ;
86
87 void printMetaArgs(std::ostream& os) const override ;
88
89 void selectNormalizationRange(const char* rangeName=nullptr, bool force=false) override ;
90 void fixRefRange(const char* rangeName) ;
91
94
95
96 bool redirectServersHook(const RooAbsCollection& /*newServerList*/, bool /*mustReplaceAll*/, bool /*nameChange*/, bool /*isRecursive*/) override ;
97
98 RooArgSet* getConnectedParameters(const RooArgSet& observables) const ;
99
100 RooArgSet* findPdfNSet(RooAbsPdf const& pdf) const ;
101
102 std::unique_ptr<RooAbsArg> compileForNormSet(RooArgSet const &normSet, RooFit::Detail::CompileContext & ctx) const override;
103
104 // The cache object. Internal, do not use.
106 public:
108 // Payload
113 std::vector<std::unique_ptr<RooArgSet>> _normList;
115 std::unique_ptr<RooAbsReal> _rearrangedNum{};
116 std::unique_ptr<RooAbsReal> _rearrangedDen{};
117 // Cache management functions
119 void printCompactTreeHook(std::ostream&, const char *, Int_t, Int_t) override ;
120 void writeToStream(std::ostream& os) const ;
121 } ;
122
123private:
124
125 std::unique_ptr<RooArgSet> fillNormSetForServer(RooArgSet const& normSet, RooAbsArg const& server) const;
126
127 double evaluate() const override ;
128
129 std::unique_ptr<RooAbsReal> makeCondPdfRatioCorr(RooAbsReal& term, const RooArgSet& termNset, const RooArgSet& termImpSet, const char* normRange, const char* refRange) const ;
130
131 void getParametersHook(const RooArgSet* /*nset*/, RooArgSet* /*list*/, bool stripDisconnected) const override ;
132
134
135 struct Factorized {
136 ~Factorized();
137
138 RooArgSet *termNormDeps(int i) const { return static_cast<RooArgSet*>(norms.At(i)); }
139 RooArgSet *termIntDeps(int i) const { return static_cast<RooArgSet*>(ints.At(i)); }
140 RooArgSet *termImpDeps(int i) const { return static_cast<RooArgSet*>(imps.At(i)); }
141 RooArgSet *termCrossDeps(int i) const { return static_cast<RooArgSet*>(cross.At(i)); }
142
148 };
149
151 std::string makeRGPPName(const char* pfx, const RooArgSet& term, const RooArgSet& iset, const RooArgSet& nset, const char* isetRangeName) const ;
152 void groupProductTerms(std::list<std::vector<RooArgSet*>>& groupedTerms, RooArgSet& outerIntDeps, Factorized const &factorized) const;
153
154
155
156 Int_t getPartIntList(const RooArgSet* nset, const RooArgSet* iset, const char* isetRangeName=nullptr) const ;
157
159 bool isOwned = false;
160 RooAbsReal* x0 = nullptr;
161 std::unique_ptr<RooAbsReal> x1;
162 std::unique_ptr<RooAbsReal> x2;
163 };
164
166 const RooArgSet* term,const RooArgSet& termNSet, const RooArgSet& termISet,
167 bool forceWrap=false) const ;
168
169
170 CacheMode canNodeBeCached() const override { return RooAbsArg::NotAdvised ; } ;
171 void setCacheAndTrackHints(RooArgSet&) override ;
172
173 std::unique_ptr<CacheElem> createCacheElem(const RooArgSet* nset, const RooArgSet* iset, const char* isetRangeName=nullptr) const;
174
175 mutable RooObjCacheManager _cacheMgr ; //! The cache manager
176
177 CacheElem* getCacheElem(RooArgSet const* nset) const ;
178 void rearrangeProduct(CacheElem&) const;
179 std::unique_ptr<RooAbsReal> specializeIntegral(RooAbsReal& orig, const char* targetRangeName) const ;
180 std::unique_ptr<RooAbsReal> specializeRatio(RooFormulaVar& input, const char* targetRangeName) const ;
181 double calculate(const RooProdPdf::CacheElem& cache, bool verbose=false) const ;
182 void doEvalImpl(RooAbsArg const* caller, const RooProdPdf::CacheElem &cache, RooFit::EvalContext &) const;
183
184
185 friend class RooProdGenContext ;
187 RooAbsGenContext* genContext(const RooArgSet &vars, const RooDataSet *prototype=nullptr,
188 const RooArgSet *auxProto=nullptr, bool verbose= false) const override ;
189
190
191 mutable RooAICRegistry _genCode ; ///<! Registry of composite direct generator codes
192
193 double _cutOff = 0.0; ///< Cutoff parameter for running product
194 RooListProxy _pdfList ; ///< List of PDF components
195 std::vector<std::unique_ptr<RooArgSet>> _pdfNSetList ; ///< List of PDF component normalization sets
196 Int_t _extendedIndex = -1; ///< Index of extended PDF (if any)
197
198 void useDefaultGen(bool flag=true) { _useDefaultGen = flag ; }
199 bool _useDefaultGen = false; ///< Use default or distributed event generator
200
201 mutable TNamed* _refRangeName = nullptr; ///< Reference range name for interpretation of conditional products
202
203 bool _selfNorm = true; ///< Is self-normalized
204 RooArgSet _defNormSet ; ///< Default normalization set
205
206private:
207
208
209
210 ClassDefOverride(RooProdPdf,6) // PDF representing a product of PDFs
211};
212
213namespace RooFit {
214namespace Detail {
215
216/// A RooProdPdf with a fixed normalization set can be replaced by this class.
217/// Its purpose is to provide the right client-server interface for the
218/// evaluation of RooProdPdf cache elements that were created for a given
219/// normalization set.
221public:
222 RooFixedProdPdf(std::unique_ptr<RooProdPdf> &&prodPdf, RooArgSet const &normSet);
223 RooFixedProdPdf(const RooFixedProdPdf &other, const char *name = nullptr);
224
225 inline TObject *clone(const char *newname) const override { return new RooFixedProdPdf(*this, newname); }
226
227 inline bool selfNormalized() const override { return true; }
228
229 inline bool canComputeBatchWithCuda() const override { return true; }
230
231 inline void doEval(RooFit::EvalContext &ctx) const override { _prodPdf->doEvalImpl(this, *_cache, ctx); }
232
233 inline ExtendMode extendMode() const override { return _prodPdf->extendMode(); }
234 inline double expectedEvents(const RooArgSet * /*nset*/) const override
235 {
236 return _prodPdf->expectedEvents(&_normSet);
237 }
238 inline std::unique_ptr<RooAbsReal> createExpectedEventsFunc(const RooArgSet * /*nset*/) const override
239 {
240 return _prodPdf->createExpectedEventsFunc(&_normSet);
241 }
242
243 // Analytical Integration handling
244 inline bool forceAnalyticalInt(const RooAbsArg &dep) const override { return _prodPdf->forceAnalyticalInt(dep); }
246 const char *rangeName = nullptr) const override
247 {
248 return _prodPdf->getAnalyticalIntegralWN(allVars, analVars, normSet, rangeName);
249 }
250 inline Int_t
251 getAnalyticalIntegral(RooArgSet &allVars, RooArgSet &numVars, const char *rangeName = nullptr) const override
252 {
253 return _prodPdf->getAnalyticalIntegral(allVars, numVars, rangeName);
254 }
255 inline double analyticalIntegralWN(Int_t code, const RooArgSet *normSet, const char *rangeName) const override
256 {
257 return _prodPdf->analyticalIntegralWN(code, normSet, rangeName);
258 }
259 inline double analyticalIntegral(Int_t code, const char *rangeName = nullptr) const override
260 {
261 return _prodPdf->analyticalIntegral(code, rangeName);
262 }
263
264 RooProdPdf::CacheElem const &cache() const { return *_cache; }
265
266private:
267 void initialize();
268
269 inline double evaluate() const override { return _prodPdf->calculate(*_cache); }
270
272 std::unique_ptr<RooProdPdf::CacheElem> _cache;
274 std::unique_ptr<RooProdPdf> _prodPdf;
275
277};
278
279} // namespace Detail
280} // namespace RooFit
281
282#endif
#define ClassDefOverride(name, id)
Definition Rtypes.h:346
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void input
char name[80]
Definition TGX11.cxx:110
Utility class for operator p.d.f classes that keeps track of analytical integration codes and associa...
Common abstract base class for objects that represent a value and a "shape" in RooFit.
Definition RooAbsArg.h:77
Abstract base class for objects to be stored in RooAbsCache cache manager objects.
Abstract container object that can hold multiple RooAbsArg objects.
virtual void removeAll()
Remove all arguments from our set, deleting them if we own them.
virtual RooAbsArg * addClone(const RooAbsArg &var, bool silent=false)
Add a clone of the specified argument to list.
Abstract base class for generator contexts of RooAbsPdf objects.
Abstract interface for all probability density functions.
Definition RooAbsPdf.h:40
const char * normRange() const
Definition RooAbsPdf.h:250
Abstract base class for objects that represent a real value that may appear on the left hand side of ...
Abstract base class for objects that represent a real value and implements functionality common to al...
Definition RooAbsReal.h:59
RooArgList is a container object that can hold multiple RooAbsArg objects.
Definition RooArgList.h:22
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Definition RooArgSet.h:24
Named container for two doubles, two integers two object points and three string pointers that can be...
Definition RooCmdArg.h:26
Container class to hold unbinned data.
Definition RooDataSet.h:34
A RooProdPdf with a fixed normalization set can be replaced by this class.
Definition RooProdPdf.h:220
double expectedEvents(const RooArgSet *) const override
Return expected number of events to be used in calculation of extended likelihood.
Definition RooProdPdf.h:234
RooFixedProdPdf(std::unique_ptr< RooProdPdf > &&prodPdf, RooArgSet const &normSet)
Int_t getAnalyticalIntegral(RooArgSet &allVars, RooArgSet &numVars, const char *rangeName=nullptr) const override
Interface function getAnalyticalIntergral advertises the analytical integrals that are supported.
Definition RooProdPdf.h:251
bool selfNormalized() const override
Shows if a PDF is self-normalized, which means that no attempt is made to add a normalization term.
Definition RooProdPdf.h:227
double analyticalIntegralWN(Int_t code, const RooArgSet *normSet, const char *rangeName) const override
Analytical integral with normalization (see RooAbsReal::analyticalIntegralWN() for further informatio...
Definition RooProdPdf.h:255
double evaluate() const override
Evaluate this PDF / function / constant. Needs to be overridden by all derived classes.
Definition RooProdPdf.h:269
Int_t getAnalyticalIntegralWN(RooArgSet &allVars, RooArgSet &analVars, const RooArgSet *normSet, const char *rangeName=nullptr) const override
Variant of getAnalyticalIntegral that is also passed the normalization set that should be applied to ...
Definition RooProdPdf.h:245
void doEval(RooFit::EvalContext &ctx) const override
Base function for computing multiple values of a RooAbsReal.
Definition RooProdPdf.h:231
std::unique_ptr< RooProdPdf > _prodPdf
Definition RooProdPdf.h:274
bool canComputeBatchWithCuda() const override
Definition RooProdPdf.h:229
RooProdPdf::CacheElem const & cache() const
Definition RooProdPdf.h:264
TObject * clone(const char *newname) const override
Definition RooProdPdf.h:225
bool forceAnalyticalInt(const RooAbsArg &dep) const override
Definition RooProdPdf.h:244
std::unique_ptr< RooAbsReal > createExpectedEventsFunc(const RooArgSet *) const override
Returns an object that represents the expected number of events for a given normalization set,...
Definition RooProdPdf.h:238
ExtendMode extendMode() const override
Returns ability of PDF to provide extended likelihood terms.
Definition RooProdPdf.h:233
std::unique_ptr< RooProdPdf::CacheElem > _cache
Definition RooProdPdf.h:272
double analyticalIntegral(Int_t code, const char *rangeName=nullptr) const override
Implements the actual analytical integral(s) advertised by getAnalyticalIntegral.
Definition RooProdPdf.h:259
A RooFormulaVar is a generic implementation of a real-valued object, which takes a RooArgList of serv...
Collection class for internal use, storing a collection of RooAbsArg pointers in a doubly linked list...
TObject * At(int index) const
Return object stored in sequential position given by index.
Implementation of a RooCacheManager<RooAbsCacheElement> that specializes in the storage of cache elem...
Efficient implementation of the generator context specific for RooProdPdf PDFs.
RooArgList containedArgs(Action) override
Return RooAbsArg components contained in the cache.
std::unique_ptr< RooAbsReal > _rearrangedNum
Definition RooProdPdf.h:115
void printCompactTreeHook(std::ostream &, const char *, Int_t, Int_t) override
Hook function to print cache contents in tree printing of RooProdPdf.
std::vector< std::unique_ptr< RooArgSet > > _normList
Definition RooProdPdf.h:113
std::unique_ptr< RooAbsReal > _rearrangedDen
Definition RooProdPdf.h:116
void writeToStream(std::ostream &os) const
Efficient implementation of a product of PDFs of the form.
Definition RooProdPdf.h:36
void setCacheAndTrackHints(RooArgSet &) override
Label OK'ed components of a RooProdPdf with cache-and-track, and label all RooProdPdf descendants wit...
Int_t getGenerator(const RooArgSet &directVars, RooArgSet &generateVars, bool staticInitOK=true) const override
Query internal generation capabilities of component p.d.f.s and aggregate capabilities into master co...
void rearrangeProduct(CacheElem &) const
bool selfNormalized() const override
Shows if a PDF is self-normalized, which means that no attempt is made to add a normalization term.
Definition RooProdPdf.h:64
double analyticalIntegralWN(Int_t code, const RooArgSet *normSet, const char *rangeName=nullptr) const override
Return analytical integral defined by given scenario code.
~RooProdPdf() override
Destructor.
Int_t _extendedIndex
Index of extended PDF (if any)
Definition RooProdPdf.h:196
std::unique_ptr< RooAbsReal > specializeRatio(RooFormulaVar &input, const char *targetRangeName) const
RooProdPdf()
Default constructor.
void removePdfs(RooAbsCollection const &pdfs)
Remove some PDFs from the factors of this RooProdPdf.
bool _useDefaultGen
Use default or distributed event generator.
Definition RooProdPdf.h:199
std::vector< std::unique_ptr< RooArgSet > > _pdfNSetList
List of PDF component normalization sets.
Definition RooProdPdf.h:195
std::unique_ptr< RooArgSet > fillNormSetForServer(RooArgSet const &normSet, RooAbsArg const &server) const
std::unique_ptr< RooAbsReal > specializeIntegral(RooAbsReal &orig, const char *targetRangeName) const
void factorizeProduct(const RooArgSet &normSet, const RooArgSet &intSet, Factorized &factorized) const
Factorize product in irreducible terms for given choice of integration/normalization.
void useDefaultGen(bool flag=true)
Definition RooProdPdf.h:198
bool forceAnalyticalInt(const RooAbsArg &dep) const override
Force RooRealIntegral to offer all observables for internal integration.
std::unique_ptr< RooAbsArg > compileForNormSet(RooArgSet const &normSet, RooFit::Detail::CompileContext &ctx) const override
void getParametersHook(const RooArgSet *, RooArgSet *, bool stripDisconnected) const override
RooAbsGenContext * genContext(const RooArgSet &vars, const RooDataSet *prototype=nullptr, const RooArgSet *auxProto=nullptr, bool verbose=false) const override
Return generator context optimized for generating events from product p.d.f.s.
void setSelfNormalized(bool flag)
Definition RooProdPdf.h:92
RooArgSet * getConstraints(const RooArgSet &observables, RooArgSet const &constrainedParams, RooArgSet &pdfParams) const override
Return all parameter constraint p.d.f.s on parameters listed in constrainedParams.
TNamed * _refRangeName
Reference range name for interpretation of conditional products.
Definition RooProdPdf.h:201
RooAICRegistry _genCode
! Registry of composite direct generator codes
Definition RooProdPdf.h:191
void addPdfs(RooAbsCollection const &pdfs)
Add some full PDFs to the factors of this RooProdPdf.
RooListProxy _pdfList
List of PDF components.
Definition RooProdPdf.h:194
Int_t getPartIntList(const RooArgSet *nset, const RooArgSet *iset, const char *isetRangeName=nullptr) const
Return list of (partial) integrals of product terms for integration of p.d.f over observables iset wh...
void printMetaArgs(std::ostream &os) const override
Customized printing of arguments of a RooProdPdf to more intuitively reflect the contents of the prod...
std::list< double > * binBoundaries(RooAbsRealLValue &, double, double) const override
Forward the plot sampling hint from the p.d.f. that defines the observable obs.
CacheMode canNodeBeCached() const override
Definition RooProdPdf.h:170
RooObjCacheManager _cacheMgr
Definition RooProdPdf.h:175
std::string makeRGPPName(const char *pfx, const RooArgSet &term, const RooArgSet &iset, const RooArgSet &nset, const char *isetRangeName) const
Make an appropriate automatic name for a RooGenProdProj object in getPartIntList()
bool isDirectGenSafe(const RooAbsArg &arg) const override
Forward determination of safety of internal generator code to component p.d.f that would generate the...
ProcessProductTermOutput processProductTerm(const RooArgSet *nset, const RooArgSet *iset, const char *isetRangeName, const RooArgSet *term, const RooArgSet &termNSet, const RooArgSet &termISet, bool forceWrap=false) const
Calculate integrals of factorized product terms over observables iset while normalized to observables...
std::unique_ptr< RooAbsReal > makeCondPdfRatioCorr(RooAbsReal &term, const RooArgSet &termNset, const RooArgSet &termImpSet, const char *normRange, const char *refRange) const
For single normalization ranges.
RooArgSet * findPdfNSet(RooAbsPdf const &pdf) const
Look up user specified normalization set for given input PDF component.
ExtendMode extendMode() const override
If this product contains exactly one extendable p.d.f return the extension abilities of that p....
std::list< double > * plotSamplingHint(RooAbsRealLValue &obs, double xlo, double xhi) const override
Forward the plot sampling hint from the p.d.f. that defines the observable obs.
double expectedEvents(const RooArgSet *nset) const override
Return the expected number of events associated with the extendable input PDF in the product.
TObject * clone(const char *newname) const override
Definition RooProdPdf.h:58
Int_t getAnalyticalIntegralWN(RooArgSet &allVars, RooArgSet &numVars, const RooArgSet *normSet, const char *rangeName=nullptr) const override
Determine which part (if any) of given integral can be performed analytically.
bool isBinnedDistribution(const RooArgSet &obs) const override
If all components that depend on obs are binned that so is the product.
RooArgSet * getConnectedParameters(const RooArgSet &observables) const
Return all parameter constraint p.d.f.s on parameters listed in constrainedParams.
double calculate(const RooProdPdf::CacheElem &cache, bool verbose=false) const
Calculate running product of pdfs terms, using the supplied normalization set in 'normSetList' for ea...
RooArgSet _defNormSet
Default normalization set.
Definition RooProdPdf.h:204
std::unique_ptr< RooAbsReal > createExpectedEventsFunc(const RooArgSet *nset) const override
Returns an object that represents the expected number of events for a given normalization set,...
CacheElem * getCacheElem(RooArgSet const *nset) const
The cache manager.
bool redirectServersHook(const RooAbsCollection &, bool, bool, bool) override
Implement support for node removal.
void groupProductTerms(std::list< std::vector< RooArgSet * > > &groupedTerms, RooArgSet &outerIntDeps, Factorized const &factorized) const
Group product into terms that can be calculated independently.
void initGenerator(Int_t code) override
Forward one-time initialization call to component generation initialization methods.
void doEvalImpl(RooAbsArg const *caller, const RooProdPdf::CacheElem &cache, RooFit::EvalContext &) const
Evaluate product of PDFs in batch mode.
void generateEvent(Int_t code) override
Generate a single event with configuration specified by 'code' Defer internal generation to component...
const RooArgList & pdfList() const
Definition RooProdPdf.h:70
void fixRefRange(const char *rangeName)
std::unique_ptr< CacheElem > createCacheElem(const RooArgSet *nset, const RooArgSet *iset, const char *isetRangeName=nullptr) const
double evaluate() const override
Calculate current value of object.
void initializeFromCmdArgList(const RooArgSet &fullPdfSet, const RooLinkedList &l)
Initialize RooProdPdf configuration from given list of RooCmdArg configuration arguments and set of '...
void selectNormalizationRange(const char *rangeName=nullptr, bool force=false) override
Interface function used by test statistics to freeze choice of range for interpretation of conditiona...
bool _selfNorm
Is self-normalized.
Definition RooProdPdf.h:203
double _cutOff
Cutoff parameter for running product.
Definition RooProdPdf.h:193
void setDefNormSet(const RooArgSet &nset)
Definition RooProdPdf.h:93
The TNamed class is the base class for all named ROOT classes.
Definition TNamed.h:29
Mother of all ROOT objects.
Definition TObject.h:41
The namespace RooFit contains mostly switches that change the behaviour of functions of PDFs (or othe...
Definition CodegenImpl.h:64
RooLinkedList cross
Definition RooProdPdf.h:147
RooLinkedList norms
Definition RooProdPdf.h:144
RooArgSet * termNormDeps(int i) const
Definition RooProdPdf.h:138
RooLinkedList terms
Definition RooProdPdf.h:143
RooArgSet * termImpDeps(int i) const
Definition RooProdPdf.h:140
RooArgSet * termIntDeps(int i) const
Definition RooProdPdf.h:139
RooArgSet * termCrossDeps(int i) const
Definition RooProdPdf.h:141
std::unique_ptr< RooAbsReal > x1
Definition RooProdPdf.h:161
std::unique_ptr< RooAbsReal > x2
Definition RooProdPdf.h:162
TLine l
Definition textangle.C:4