40 using namespace RooFit ;
70 <<
" generate the index category" << endl ;
90 if (anyServer && !allServers) {
92 <<
" generate all components of a derived index category" << endl ;
104 <<
" to calculate number of events per category" << endl ;
148 oocoutE(
_pdf,
Generation) <<
"RooSimSplitGenContext::RooSimSplitGenContext(" <<
GetName() <<
") Couldn't deep-clone index category, abort," << endl ;
149 throw std::string(
"RooSimSplitGenContext::RooSimSplitGenContext() Couldn't deep-clone index category, abort") ;
183 (*iter)->attach(args) ;
203 (*iter)->initGenerator(theEvent) ;
225 << nEvents <<
" events" << endl;
236 vector<Double_t> nGen(
_numPdf) ;
264 while (nGenSoFar<nEvents) {
281 map<string,RooAbsData*> dataMap ;
288 dataMap[proxy->
GetName()] =
_gcList[icomp]->generate(nGen[icomp],skipInit,extendedMode) ;
307 (*iter)->setExpectedData(flag) ;
349 os << indent <<
"--- RooSimSplitGenContext ---" << endl ;
350 os << indent <<
"Using PDF ";
RooCategoryProxy _indexCat
virtual Bool_t isDerived() const
virtual void generateEvent(RooArgSet &theEvent, Int_t remaining)
this method is empty because it is not used in this type of context
TIterator * serverIterator() const
virtual void printStream(std::ostream &os, Int_t contents, StyleOption style, TString indent="") const
Print description of object on ostream, printing contents set by contents integer, which is interpreted as an OR of 'enum ContentsOptions' values and in the style given by 'enum StyleOption'.
virtual void setExpectedData(Bool_t)
Forward to components.
ClassImp(RooSimSplitGenContext)
virtual void SetName(const char *name)
Change (i.e.
RooArgSet * getObservables(const RooArgSet &set, Bool_t valueOnly=kTRUE) const
RooCmdArg Link(const char *state, RooAbsData &data)
virtual const char * name() const
RooSimSplitGenContext is an efficient implementation of the generator context specific for RooSimulta...
virtual Double_t expectedEvents(const RooArgSet *nset) const
Return expected number of events from this p.d.f for use in extended likelihood calculations.
Iterator abstract base class.
RooDataSet * createDataSet(const char *name, const char *title, const RooArgSet &obs)
this method is empty because it is not used by this context
virtual void attach(const RooArgSet ¶ms)
Attach the index category clone to the given event buffer.
std::map< std::string, std::string >::const_iterator iter
virtual void initGenerator(const RooArgSet &theEvent)
Perform one-time initialization of generator context.
RooCatType is an auxilary class for RooAbsCategory and defines a a single category state...
virtual RooAbsGenContext * autoGenContext(const RooArgSet &vars, const RooDataSet *prototype=0, const RooArgSet *auxProto=0, Bool_t verbose=kFALSE, Bool_t autoBinned=kTRUE, const char *binnedTag="") const
RooAbsGenContext is the abstract base class for generator contexts of RooAbsPdf objects.
RooAbsCategoryLValue is the common abstract base class for objects that represent a discrete value th...
RooAbsArg * find(const char *name) const
Find object with given name in list.
virtual const char * ClassName() const
Returns name of class to which the object belongs.
RooAbsArg * absArg() const
virtual const char * GetName() const
Returns name of object.
static void indent(ostringstream &buf, int indent_level)
virtual void Print(Option_t *options=0) const
Print TNamed name and title.
const RooSimultaneous * _pdf
RooDataSet is a container class to hold unbinned data.
RooCategory represents a fundamental (non-derived) discrete value object.
RooCmdArg Index(RooCategory &icat)
virtual Int_t GetSize() const
static Double_t uniform(TRandom *generator=randomGenerator())
Return a number uniformly distributed from (0,1)
Bool_t canBeExtended() const
virtual void printMultiline(std::ostream &os, Int_t contents, Bool_t verbose=kFALSE, TString indent="") const
Interface for multi-line printing.
std::vector< int > _gcIndex
virtual void setProtoDataOrder(Int_t *lut)
this method is empty because proto datasets are not supported by this context
virtual Bool_t remove(const RooAbsArg &var, Bool_t silent=kFALSE, Bool_t matchByNameOnly=kFALSE)
Remove the specified argument from our list.
RooAbsPdf is the abstract interface for all probability density functions The class provides hybrid a...
virtual TObject * Next()=0
RooAbsCategory is the common abstract base class for objects that represent a discrete value with a f...
RooRealProxy is the concrete proxy for RooAbsReal objects A RooRealProxy is the general mechanism to ...
virtual ~RooSimSplitGenContext()
Destructor. Delete all owned subgenerator contexts.
virtual TIterator * MakeIterator(Bool_t dir=kIterForward) const
Return a list iterator.
const RooAbsCategory & arg() const
RooAbsCategoryLValue * _idxCat
std::vector< RooAbsGenContext * > _gcList
virtual RooDataSet * generate(Double_t nEvents=0, Bool_t skipInit=kFALSE, Bool_t extendedMode=kFALSE)
Generate the specified number of events with nEvents>0 and and return a dataset containing the genera...
RooAbsArg is the common abstract base class for objects that represent a value (of arbitrary type) an...
virtual void printMultiline(std::ostream &os, Int_t content, Bool_t verbose=kFALSE, TString indent="") const
Detailed printing interface.
Bool_t recursiveRedirectServers(const RooAbsCollection &newServerList, Bool_t mustReplaceAll=kFALSE, Bool_t nameChange=kFALSE, Bool_t recurseInNewSet=kTRUE)
RooSimultaneous facilitates simultaneous fitting of multiple PDFs to subsets of a given dataset...
RooSimSplitGenContext(const RooSimultaneous &model, const RooArgSet &vars, Bool_t _verbose=kFALSE, Bool_t autoBinned=kTRUE, const char *binnedTag="")
Constructor of specialized generator context for RooSimultaneous p.d.f.s.
virtual Bool_t add(const RooAbsArg &var, Bool_t silent=kFALSE)
Add element to non-owning set.
const RooCatType * lookupType(Int_t index, Bool_t printError=kFALSE) const
Find our type corresponding to the specified index, or return 0 for no match.