// RooAbsSelfCachedPdf is an abstract base class for probability
// density functions whose output is cached in terms of a histogram in
// all observables between getVal() and evaluate(). For certain
// p.d.f.s that are very expensive to calculate it may be beneficial
// to implement them as a RooAbsSelfCachedPdf rather than a
// RooAbsPdf. Class RooAbsSelfCachedPdf is designed to have its
// interface identical to that of RooAbsPdf, so any p.d.f can make use
// of its caching functionality by merely switching its base class.
// Existing RooAbsPdf objects can also be cached a posteriori with the
// RooCachedPdf wrapper p.d.f. that takes any RooAbsPdf object as
// input.
// END_HTML
#include "Riostream.h"
#include "RooFit.h"
#include "RooAbsSelfCachedPdf.h"
#include "RooAbsReal.h"
#include "RooMsgService.h"
#include "RooDataHist.h"
#include "RooHistPdf.h"
using namespace std ;
ClassImp(RooAbsSelfCachedPdf)
RooAbsSelfCachedPdf::RooAbsSelfCachedPdf(const char *name, const char *title, Int_t ipOrder) :
RooAbsCachedPdf(name,title,ipOrder)
{
}
RooAbsSelfCachedPdf::RooAbsSelfCachedPdf(const RooAbsSelfCachedPdf& other, const char* name) :
RooAbsCachedPdf(other,name)
{
}
RooAbsSelfCachedPdf::~RooAbsSelfCachedPdf()
{
}
void RooAbsSelfCachedPdf::fillCacheObject(RooAbsCachedPdf::PdfCacheElem& cache) const
{
RooDataHist& cacheHist = *cache.hist() ;
RooArgSet* cloneSet = (RooArgSet*) RooArgSet(*this).snapshot(kTRUE) ;
RooAbsSelfCachedPdf* clone2 = (RooAbsSelfCachedPdf*) cloneSet->find(GetName()) ;
clone2->disableCache(kTRUE) ;
clone2->attachDataSet(cacheHist) ;
for (Int_t i=0 ; i<cacheHist.numEntries() ; i++) {
const RooArgSet* obs = cacheHist.get(i) ;
Double_t wgt = clone2->getVal(obs) ;
cacheHist.set(wgt) ;
}
cache.pdf()->setUnitNorm(kTRUE) ;
delete cloneSet ;
}
RooArgSet* RooAbsSelfCachedPdf::actualObservables(const RooArgSet& ) const
{
RooArgSet servers ;
TIterator* siter = serverIterator() ;
siter->Reset() ;
RooAbsArg* server ;
while((server=(RooAbsArg*)siter->Next())) {
servers.add(*server) ;
}
return new RooArgSet(servers) ;
}
RooArgSet* RooAbsSelfCachedPdf::actualParameters(const RooArgSet& nset) const
{
RooArgSet *servers = new RooArgSet ;
TIterator* siter = serverIterator() ;
siter->Reset() ;
RooAbsArg* server ;
while((server=(RooAbsArg*)siter->Next())) {
servers->add(*server) ;
}
servers->remove(nset,kTRUE,kTRUE) ;
return servers ;
}
Last change: Mon Aug 25 11:35:05 2008
Last generated: 2008-08-25 11:35
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.