152  _x(
"!x",
"Convolution Variable",this,convVar),
 
  153  _xprime(
"!xprime",
"External Convolution Variable",this,0),
 
  154  _pdf1(
"!pdf1",
"pdf1",this,pdf1,
kFALSE),
 
  155  _pdf2(
"!pdf2",
"pdf2",this,pdf2,
kFALSE),
 
  156  _params(
"!params",
"effective parameters",this),
 
  161  _cacheObs(
"!cacheObs",
"Cached observables",this,
kFALSE,
kFALSE)
 
  178  _x(
"!x",
"Convolution Variable",this,convVar,
kFALSE,
kFALSE),
 
  179  _xprime(
"!xprime",
"External Convolution Variable",this,pdfConvVar),
 
  180  _pdf1(
"!pdf1",
"pdf1",this,pdf1,
kFALSE),
 
  181  _pdf2(
"!pdf2",
"pdf2",this,pdf2,
kFALSE),
 
  182  _params(
"!params",
"effective parameters",this),
 
  187  _cacheObs(
"!cacheObs",
"Cached observables",this,
kFALSE,
kFALSE)
 
  203  _x(
"!x",this,other._x),
 
  204  _xprime(
"!xprime",this,other._xprime),
 
  205  _pdf1(
"!pdf1",this,other._pdf1),
 
  206  _pdf2(
"!pdf2",this,other._pdf2),
 
  207  _params(
"!params",this,other._params),
 
  208  _bufFrac(other._bufFrac),
 
  209  _bufStrat(other._bufStrat),
 
  210  _shift1(other._shift1),
 
  211  _shift2(other._shift2),
 
  212  _cacheObs(
"!cacheObs",this,other._cacheObs)
 
  239          << 
"' in FFT '" << 
fName << 
"'" 
  240          << 
" from " << varBinning.
numBins()
 
  241          << 
" to " << optimal << 
" to improve the precision of the numerical FFT." 
  242          << 
" This can be done manually by setting an additional binning named 'cache'." << std::endl;
 
  246          << 
" is not uniform. The numerical FFT will likely yield wrong results." << std::endl;
 
  258  static TString 
name ;
 
  260  name.Append(
"_CONV_") ;
 
  284  fftr2c1(0),fftr2c2(0),fftc2r(0) 
 
  295   string refName = 
Form(
"refrange_fft_%s",self.
GetName()) ;
 
  352    oocoutW(&self, 
Eval) << 
"The FFT convolution '" << self.
GetName() << 
"' will run with " << 
N 
  353        << 
" bins. A decent accuracy for difficult convolutions is typically only reached with n >= 1000. Suggest to increase the number" 
  354        " of bins of the observable '" << convObs->
GetName() << 
"'." << std::endl;
 
  387  ret.
add(*pdf1Clone) ;
 
  388  ret.
add(*pdf2Clone) ;
 
  389  if (pdf1Clone->ownedComponents()) {
 
  390    ret.
add(*pdf1Clone->ownedComponents()) ;
 
  392  if (pdf2Clone->ownedComponents()) {
 
  393    ret.
add(*pdf2Clone->ownedComponents()) ;
 
  481    while(binCur[curObs]==binMax[curObs]) {
 
  526  Int_t N,N2,binShift1,binShift2 ;
 
  554  for (
Int_t i=0 ; i<N2/2+1 ; i++) {
 
  567  Int_t totalShift = binShift1 + (N2-
N)/2 ;
 
  572  for (
Int_t i =0 ; i<
N ; i++) {
 
  575    Int_t j = i + totalShift ;
 
  577    while (j>=N2) j-= N2 ;
 
  621  } 
else if (histX->
getMin()>0) {
 
  631  zeroBin += binShift ;
 
  632  while(zeroBin>=N2) zeroBin-= N2 ;
 
  633  while(zeroBin<0) zeroBin+= N2 ;
 
  642    for (k=0 ; k<N2 ; k++) {
 
  654      for (k=0 ; k<Nbuf ; k++) {
 
  657      for (k=0 ; k<
N ; k++) {
 
  663      for (k=0 ; k<Nbuf ; k++) {
 
  664   tmp[
N+Nbuf+k] = val ;
 
  672    for (k=0 ; k<
N ; k++) {
 
  676    for (k=1 ; k<=Nbuf ; k++) {
 
  686  for (
Int_t i=0 ; i<N2 ; i++) {
 
  688    Int_t j = i - (zeroBin) ;
 
  797  return histObservable ;
 
  824         << 
" has internal generator that is safe to use in current context" << endl ;
 
  828         << 
" has internal generator that is safe to use in current context" << endl ;
 
  831    cxcoutI(
Generation) << 
"RooFFTConvPdf::genContext() generation requested for observables other than the convolution observable " << 
_x.
arg().
GetName() << endl ;
 
  835  if (numAddDep>0 || !pdfCanDir || !resCanDir) {
 
  838    cxcoutI(
Generation) << 
"RooFFTConvPdf::genContext() selecting accept/reject generator context because one or both of the input " 
  839         << 
"p.d.f.s cannot use internal generator and/or "  
  840         << 
"observables other than the convolution variable are requested for generation" << endl ;
 
  841    return new RooGenContext(*
this,vars,prototype,auxProto,verbose) ;
 
  845  cxcoutI(
Generation) << 
"RooFFTConvPdf::genContext() selecting specialized convolution generator context as both input " 
  846            << 
"p.d.fs are safe for internal generator and only " 
  847            << 
"the convolution observables is requested for generation" << endl ;
 
  860    coutE(
InputArguments) << 
"RooFFTConvPdf::setBufferFraction(" << 
GetName() << 
") fraction should be greater than or equal to zero" << endl ;
 
static RooMathCoreReg dummy
char * Form(const char *fmt,...)
RooAbsArg is the common abstract base class for objects that represent a value (of arbitrary type) an...
virtual RooAbsArg * cloneTree(const char *newname=0) const
Clone tree expression of objects.
RooArgSet * getObservables(const RooArgSet &set, Bool_t valueOnly=kTRUE) const
RooArgSet * getParameters(const RooAbsData *data, Bool_t stripDisconnected=kTRUE) const
Create a list of leaf nodes in the arg tree starting with ourself as top node that don't match any of...
RooArgSet * getVariables(Bool_t stripDisconnected=kTRUE) const
Return RooArgSet with all variables (tree leaf nodes of expresssion tree)
void setOperMode(OperMode mode, Bool_t recurseADirty=kTRUE)
Change cache operation mode to given mode.
Bool_t addOwnedComponents(const RooArgSet &comps)
Take ownership of the contents of 'comps'.
Bool_t recursiveRedirectServers(const RooAbsCollection &newServerList, Bool_t mustReplaceAll=kFALSE, Bool_t nameChange=kFALSE, Bool_t recurseInNewSet=kTRUE)
void attachDataSet(const RooAbsData &set)
Replace server nodes with names matching the dataset variable names with those data set variables,...
RooAbsBinning is the abstract base class for RooRealVar binning definitions This class defines the in...
virtual RooAbsBinning * clone(const char *name=0) const =0
virtual Bool_t isUniform() const
virtual Double_t highBound() const =0
virtual Int_t binNumber(Double_t x) const =0
virtual Double_t lowBound() const =0
virtual RooArgList containedArgs(Action)
Returns all RooAbsArg objects contained in the cache element.
RooAbsCachedPdf is the abstract base class for p.d.f.s that need or want to cache their evaluate() ou...
virtual const char * binningName() const
RooObjCacheManager _cacheMgr
RooAbsCollection is an abstract container object that can hold multiple RooAbsArg objects.
Bool_t contains(const RooAbsArg &var) const
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Add the specified argument to list.
virtual Bool_t remove(const RooAbsArg &var, Bool_t silent=kFALSE, Bool_t matchByNameOnly=kFALSE)
Remove the specified argument from our list.
TIterator * createIterator(Bool_t dir=kIterForward) const
RooAbsArg * find(const char *name) const
Find object with given name in list.
void setDirtyProp(Bool_t flag)
Control propagation of dirty flags from observables in dataset.
RooAbsGenContext is the abstract base class for generator contexts of RooAbsPdf objects.
Abstract base class for objects that are lvalues, i.e.
virtual Int_t numBins(const char *rangeName=0) const =0
virtual void setBin(Int_t ibin, const char *rangeName=0)=0
RooAbsPdf is the abstract interface for all probability density functions The class provides hybrid a...
virtual Int_t getGenerator(const RooArgSet &directVars, RooArgSet &generateVars, Bool_t staticInitOK=kTRUE) const
Load generatedVars with the subset of directVars that we can generate events for, and return a code t...
virtual Bool_t isDirectGenSafe(const RooAbsArg &arg) const
Check if given observable can be safely generated using the pdfs internal generator mechanism (if tha...
virtual Double_t getMax(const char *name=0) const
virtual void setBin(Int_t ibin, const char *rangeName=0)
Set value to center of bin 'ibin' of binning 'rangeName' (or of default binning if no range is specif...
virtual Int_t numBins(const char *rangeName=0) const
virtual Double_t getMin(const char *name=0) const
RooAbsReal is the common abstract base class for objects that represent a real value and implements f...
virtual void fixAddCoefRange(const char *rangeName=0, Bool_t force=kTRUE)
Fix the interpretation of the coefficient of any RooAddPdf component in the expression tree headed by...
Double_t getVal(const RooArgSet *set=0) const
Evaluate object. Returns either cached value or triggers a recalculation.
RooAbsArg * absArg() const
RooArgSet is a container object that can hold multiple RooAbsArg objects.
virtual Bool_t add(const RooAbsCollection &col, Bool_t silent=kFALSE)
Add a collection of arguments to this collection by calling add() for each element in the source coll...
void replaceArg(const RooAbsArg &orig, const RooAbsArg &subst)
Replace any occurence of arg 'orig' with arg 'subst'.
RooAbsArg * build(const char *masterCatState, Bool_t verbose=kFALSE)
Build a clone of the prototype executing all registered 'replace' rules and 'split' rules for the mas...
RooDataSet is a container class to hold N-dimensional binned data.
void set(Double_t weight, Double_t wgtErr=-1)
Increment the weight of the bin enclosing the coordinates given by 'row' by the specified amount.
virtual const RooArgSet * get() const
RooDataSet is a container class to hold unbinned data.
virtual RooArgList containedArgs(Action)
Returns all RooAbsArg objects contained in the cache element.
RooAbsBinning * histBinning
FFTCacheElem(const RooFFTConvPdf &self, const RooArgSet *nset)
Clone input pdf and attach to dataset.
RooAbsBinning * scanBinning
PDF for the numerical (FFT) convolution of two PDFs.
Bool_t redirectServersHook(const RooAbsCollection &newServerList, Bool_t mustReplaceAll, Bool_t nameChange, Bool_t isRecursive)
calcParams() ;
void printMetaArgs(std::ostream &os) const
Customized printing of arguments of a RooNumConvPdf to more intuitively reflect the contents of the p...
virtual PdfCacheElem * createCache(const RooArgSet *nset) const
Return specialized cache subclass for FFT calculations.
friend class RooConvGenContext
virtual ~RooFFTConvPdf()
Destructor.
void calcParams()
(Re)calculate effective parameters of this p.d.f.
virtual void fillCacheObject(PdfCacheElem &cache) const
Fill the contents of the cache the FFT convolution output.
void prepareFFTBinning(RooRealVar &convVar) const
Try to improve the binning and inform user if possible.
virtual TString histNameSuffix() const
Suffix for cache histogram (added in addition to suffix for cache name)
void fillCacheSlice(FFTCacheElem &cache, const RooArgSet &slicePosition) const
Fill a slice of cachePdf with the output of the FFT convolution calculation.
Double_t * scanPdf(RooRealVar &obs, RooAbsPdf &pdf, const RooDataHist &hist, const RooArgSet &slicePos, Int_t &N, Int_t &N2, Int_t &zeroBin, Double_t shift) const
Scan the values of 'pdf' in observable 'obs' using the bin values stored in 'hist' at slice position ...
virtual RooAbsGenContext * genContext(const RooArgSet &vars, const RooDataSet *prototype=0, const RooArgSet *auxProto=0, Bool_t verbose=kFALSE) const
Create appropriate generator context for this convolution.
virtual const char * inputBaseName() const
Return base name component for cache components in this case 'PDF1_CONV_PDF2'.
void setBufferFraction(Double_t frac)
Change the size of the buffer on either side of the observable range to frac times the size of the ra...
virtual RooArgSet * actualObservables(const RooArgSet &nset) const
Return the observables to be cached given the normalization set nset.
virtual RooAbsArg & pdfObservable(RooAbsArg &histObservable) const
Return p.d.f.
void setBufferStrategy(BufStrat bs)
Change strategy to fill the overflow buffer on either side of the convolution observable range.
virtual RooArgSet * actualParameters(const RooArgSet &nset) const
Return the parameters on which the cache depends given normalization set nset.
Double_t bufferFraction() const
friend class FFTCacheElem
Class RooGenContext implement a universal generator context for all RooAbsPdf classes that do not hav...
RooLinearVar is the most general form of a derived real-valued object that can be used by RooRealInte...
const RooAbsReal & arg() const
RooRealVar represents a fundamental (non-derived) real valued object.
Bool_t hasBinning(const char *name) const
Returns true if variable has a binning with 'name'.
void setRange(const char *name, Double_t min, Double_t max)
Set range named 'name to [min,max].
const RooAbsBinning & getBinning(const char *name=0, Bool_t verbose=kTRUE, Bool_t createOnTheFly=kFALSE) const
Return binning definition with name.
void setBinning(const RooAbsBinning &binning, const char *name=0)
Add given binning under name 'name' with this variable.
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Overloaded RooArgSet::add() method inserts 'var' into set and registers 'var' as server to owner with...
virtual void removeAll()
Remove all argument inset using remove(const RooAbsArg&).
Iterator abstract base class.
virtual TObject * Next()=0
virtual const char * GetName() const
Returns name of object.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
static TVirtualFFT * FFT(Int_t ndim, Int_t *n, Option_t *option)
Returns a pointer to the FFT of requested size and type.
virtual void SetPoints(const Double_t *data)=0
virtual void Transform()=0
virtual void GetPointComplex(Int_t ipoint, Double_t &re, Double_t &im, Bool_t fromInput=kFALSE) const =0
virtual void SetPointComplex(Int_t ipoint, TComplex &c)=0
virtual Double_t GetPointReal(Int_t ipoint, Bool_t fromInput=kFALSE) const =0
RooConstVar & RooConst(Double_t val)