/***************************************************************************** * Project: RooFit * * * * Copyright (c) 2000-2005, Regents of the University of California * * and Stanford University. All rights reserved. * * * * Redistribution and use in source and binary forms, * * with or without modification, are permitted according to the terms * * listed in LICENSE (http://roofit.sourceforge.net/license.txt) * *****************************************************************************/ ////////////////////////////////////////////////////////////////////////////// // // BEGIN_HTML // RooCachedPdf is an implementation of RooAbsCachedPdf that can cache // any external RooAbsPdf input function provided in the constructor. // END_HTML // #include "Riostream.h" #include "RooAbsPdf.h" #include "RooCachedPdf.h" #include "RooAbsReal.h" #include "RooMsgService.h" #include "RooDataHist.h" #include "RooHistPdf.h" ClassImp(RooCachedPdf) ; //_____________________________________________________________________________ RooCachedPdf::RooCachedPdf(const char *name, const char *title, RooAbsPdf& _pdf) : RooAbsCachedPdf(name,title), pdf("pdf","pdf",this,_pdf), _cacheObs("cacheObs","cacheObs",this,kFALSE,kFALSE) { // Constructor taking name, title and function to be cached. To control // granularity of the binning of the cache histogram set the desired properties // in the binning named "cache" in the observables of the function. The dimensions // of the cache are automatically matched to the number of observables used // in each use context. Multiple cache in different observable may exists // simultanously if the cached p.d.f is used with multiple observable // configurations simultaneously } //_____________________________________________________________________________ RooCachedPdf::RooCachedPdf(const char *name, const char *title, RooAbsPdf& _pdf, const RooArgSet& cacheObs) : RooAbsCachedPdf(name,title), pdf("pdf","pdf",this,_pdf), _cacheObs("cacheObs","cacheObs",this,kFALSE,kFALSE) { // Constructor taking name, title and function to be cached and // fixed choice of variable to cache. To control granularity of the // binning of the cache histogram set the desired properties in the // binning named "cache" in the observables of the function. // If the fixed set of cache observables does not match the observables // defined in the use context of the p.d.f the cache is still filled // completely. Ee.g. when it is specified to cache x and p and only x // is a observable in the given use context the cache histogram will // store sampled values for all values of observable x and parameter p. // In such a mode of operation the cache will also not be recalculated // if the observable p changes _cacheObs.add(cacheObs) ; } //_____________________________________________________________________________ RooCachedPdf::RooCachedPdf(const RooCachedPdf& other, const char* name) : RooAbsCachedPdf(other,name), pdf("pdf",this,other.pdf), _cacheObs("cacheObs",this,other._cacheObs) { // Copy constructor } //_____________________________________________________________________________ RooCachedPdf::~RooCachedPdf() { // Destructor } //_____________________________________________________________________________ void RooCachedPdf::fillCacheObject(RooAbsCachedPdf::PdfCacheElem& cache) const { // Update contents of cache histogram by resampling the input p.d.f. Note that // the cache is filled with normalized p.d.f values so that the RooHistPdf // that represents the cache contents can be explicitly declared as self normalized // eliminating the need for superfluous numeric calculations of unit normalization.s if (cache.hist()->get()->getSize()>1) { coutP(Eval) << "RooCachedPdf::fillCacheObject(" << GetName() << ") filling multi-dimensional cache" ; } // Update contents of histogram ((RooAbsPdf&)pdf.arg()).fillDataHist(cache.hist(),&cache.nset(),1.0,kFALSE,kTRUE) ; if (cache.hist()->get()->getSize()>1) { ccoutP(Eval) << endl ; } cache.pdf()->setUnitNorm(kTRUE) ; } //_____________________________________________________________________________ void RooCachedPdf::preferredObservableScanOrder(const RooArgSet& obs, RooArgSet& orderedObs) const { // Defer preferred scan order to cached pdf prefernece pdf.arg().preferredObservableScanOrder(obs,orderedObs) ; } //_____________________________________________________________________________ RooArgSet* RooCachedPdf::actualObservables(const RooArgSet& nset) const { // If this pdf is operated with a fixed set of observables, return // the subset of the fixed observables that are actual dependents // of the external input p.d.f. If this p.d.f is operated without // a fixed set of cache observables, return the actual observables // of the external input p.d.f given the choice of observables defined // in nset if (_cacheObs.getSize()>0) { return pdf.arg().getObservables(_cacheObs) ; } return pdf.arg().getObservables(nset) ; } //_____________________________________________________________________________ RooArgSet* RooCachedPdf::actualParameters(const RooArgSet& nset) const { // If this p.d.f is operated with a fixed set of observables, return // all variables of the external input p.d.f that are not one of // the cache observables. If this p.d.f is operated in automatic mode, // return the parameters of the external input p.d.f if (_cacheObs.getSize()>0) { return pdf.arg().getParameters(_cacheObs) ; } return pdf.arg().getParameters(nset) ; }