49                const RooArgSet& _normSet, 
const char* isetRangeName, 
const char* normRangeName, 
bool doFactorize) :
 
   51  _compSetN(
"compSetN",
"Set of integral components owned by numerator",this,false),
 
   52  _compSetD(
"compSetD",
"Set of integral components owned by denominator",this,false),
 
   53  _intList(
"intList",
"List of integrals",this,true)
 
   88  _compSetN(
"compSetN",
"Set of integral components owned by numerator",this),
 
   89  _compSetD(
"compSetD",
"Set of integral components owned by denominator",this),
 
   90  _intList(
"intList",
"List of integrals",this)
 
  131                RooArgSet& saveSet, 
const char* isetRangeName, 
bool doFactorize)
 
  136  for (
const auto arg : intSet) {
 
  137    auto count = std::count_if(compSet.
begin(), compSet.
end(), [arg](
const RooAbsArg* pdfAsArg){
 
  138      auto pdf = static_cast<const RooAbsPdf*>(pdfAsArg);
 
  139      return (pdf->dependsOn(*arg));
 
  143      anaIntSet.
add(*arg) ;
 
  149  numIntSet.
add(intSet) ;
 
  169  for (
const auto pdfAsArg : compSet) {
 
  170    auto pdf = 
static_cast<const RooAbsPdf*
>(pdfAsArg);
 
  172    if (doFactorize && pdf->dependsOn(anaIntSet)) {
 
  174      Int_t code = pdf->getAnalyticalIntegralWN(anaIntSet,anaSet,
nullptr,isetRangeName) ;
 
  177        std::unique_ptr<RooAbsReal> pai{pdf->createIntegral(anaSet,emptyNormSet,isetRangeName)};
 
  184        numIntSet.
remove(anaSet) ;
 
  213  prodSet.
snapshot(prodSetClone, 
false);
 
  215  auto prod = std::make_unique<RooProduct>(prodName, 
"product", prodSetClone);
 
  220  std::unique_ptr<RooAbsReal> integral{prod->createIntegral(numIntSet,emptyNormSet,isetRangeName)};
 
  222  auto ret = integral.get();
 
  225  saveSet.
addOwned(std::move(prodSetClone));
 
  227  saveSet.
addOwned(std::move(integral)) ;
 
char * Form(const char *fmt,...)
Formats a string in a circular formatting buffer.
Common abstract base class for objects that represent a value and a "shape" in RooFit.
RooExpensiveObjectCache & expensiveObjectCache() const
void setOperMode(OperMode mode, bool recurseADirty=true)
Set the operation mode of this node.
virtual void setExpensiveObjectCache(RooExpensiveObjectCache &cache)
virtual bool remove(const RooAbsArg &var, bool silent=false, bool matchByNameOnly=false)
Remove the specified argument from our list.
virtual bool add(const RooAbsArg &var, bool silent=false)
Add the specified argument to list.
const_iterator end() const
RooAbsArg * first() const
virtual bool addOwned(RooAbsArg &var, bool silent=false)
Add an argument and transfer the ownership to the collection.
const_iterator begin() const
RooAbsArg * find(const char *name) const
Find object with given name in list.
Abstract interface for all probability density functions.
const RooArgSet * nset() const
Abstract base class for objects that represent a real value and implements functionality common to al...
double getVal(const RooArgSet *normalisationSet=nullptr) const
Evaluate object.
RooAbsArg * at(Int_t idx) const
Return object at given index, or nullptr if index is out of range.
RooArgSet is a container object that can hold multiple RooAbsArg objects.
RooArgSet * snapshot(bool deepCopy=true) const
Use RooAbsCollection::snapshot(), but return as RooArgSet.
bool add(const RooAbsArg &var, bool valueServer, bool shapeServer, bool silent)
Overloaded RooCollection_t::add() method insert object into set and registers object as server to own...
General form of projected integral of product of PDFs, utility class for RooProdPdf.
void operModeHook() override
Intercept cache mode operation changes and propagate them to the components.
double evaluate() const override
Calculate and return value of normalization projection.
RooAbsReal * makeIntegral(const char *name, const RooArgSet &compSet, const RooArgSet &intSet, RooArgSet &saveSet, const char *isetRangeName, bool doFactorize)
Utility function to create integral for product over certain observables.
RooSetProxy _compSetD
Set proxy for denominator components.
RooListProxy _intList
Master integrals representing numerator and denominator.
std::unique_ptr< RooArgSet > _compSetOwnedN
Owner of numerator components.
std::unique_ptr< RooArgSet > _compSetOwnedD
Owner of denominator components.
bool _haveD
Do we have a denominator term?
RooGenProdProj(const char *name, const char *title, const RooArgSet &_prodSet, const RooArgSet &_intSet, const RooArgSet &_normSet, const char *isetRangeName, const char *normRangeName=nullptr, bool doFactorize=true)
Constructor for a normalization projection of the product of p.d.f.s _prodSet integrated over _intSet...
RooSetProxy _compSetN
Set proxy for numerator components.
const char * GetName() const override
Returns name of object.