#ifndef ROO_COMPOSITE_DATA_STORE
#define ROO_COMPOSITE_DATA_STORE
#include "RooAbsDataStore.h"
#include "TString.h"
#include <map>
#include <string>
class RooAbsArg ;
class RooArgList ;
class RooFormulaVar ;
class RooArgSet ;
class RooCategory ;
class RooCompositeDataStore : public RooAbsDataStore {
public:
RooCompositeDataStore() ;
RooCompositeDataStore(const char* name, const char* title, const RooArgSet& vars, RooCategory& indexCat, std::map<std::string,RooAbsDataStore*> inputData) ;
virtual RooAbsDataStore* clone(const char* newname=0) const { return new RooCompositeDataStore(*this,newname) ; }
virtual RooAbsDataStore* clone(const RooArgSet& vars, const char* newname=0) const { return new RooCompositeDataStore(*this,vars,newname) ; }
RooCompositeDataStore(const RooCompositeDataStore& other, const char* newname=0) ;
RooCompositeDataStore(const RooCompositeDataStore& other, const RooArgSet& vars, const char* newname=0) ;
virtual ~RooCompositeDataStore() ;
virtual void dump() ;
virtual Int_t fill() ;
virtual Double_t sumEntries() const ;
using RooAbsDataStore::get ;
virtual const RooArgSet* get(Int_t index) const ;
virtual Double_t weight() const ;
virtual Double_t weight(Int_t index) const ;
virtual Double_t weightError(RooAbsData::ErrorType etype=RooAbsData::Poisson) const ;
virtual void weightError(Double_t& lo, Double_t& hi, RooAbsData::ErrorType etype=RooAbsData::Poisson) const ;
virtual Bool_t isWeighted() const ;
virtual Bool_t changeObservableName(const char* from, const char* to) ;
virtual RooAbsArg* addColumn(RooAbsArg& var, Bool_t adjustRange=kTRUE) ;
virtual RooArgSet* addColumns(const RooArgList& varList) ;
RooAbsDataStore* merge(const RooArgSet& allvars, std::list<RooAbsDataStore*> dstoreList) ;
RooCategory* index() { return _indexCat ; }
virtual void append(RooAbsDataStore& other) ;
virtual Bool_t valid() const ;
virtual Int_t numEntries() const ;
virtual void reset() ;
virtual void attachBuffers(const RooArgSet& extObs) ;
virtual void resetBuffers() ;
virtual void cacheArgs(const RooAbsArg* owner, RooArgSet& varSet, const RooArgSet* nset=0) ;
virtual const RooAbsArg* cacheOwner() { return 0 ; }
virtual void setArgStatus(const RooArgSet& set, Bool_t active) ;
virtual void resetCache() ;
virtual void recalculateCache(const RooArgSet* , Int_t , Int_t , Int_t ) ;
void loadValues(const RooAbsDataStore *tds, const RooFormulaVar* select=0, const char* rangeName=0, Int_t nStart=0, Int_t nStop=2000000000) ;
protected:
void attachCache(const RooAbsArg* newOwner, const RooArgSet& cachedVars) ;
std::map<Int_t,RooAbsDataStore*> _dataMap ;
RooCategory* _indexCat ;
mutable RooAbsDataStore* _curStore ;
mutable Int_t _curIndex ;
Bool_t _ownComps ;
ClassDef(RooCompositeDataStore,1)
};
#endif
RooCompositeDataStore.h:1 RooCompositeDataStore.h:2 RooCompositeDataStore.h:3 RooCompositeDataStore.h:4 RooCompositeDataStore.h:5 RooCompositeDataStore.h:6 RooCompositeDataStore.h:7 RooCompositeDataStore.h:8 RooCompositeDataStore.h:9 RooCompositeDataStore.h:10 RooCompositeDataStore.h:11 RooCompositeDataStore.h:12 RooCompositeDataStore.h:13 RooCompositeDataStore.h:14 RooCompositeDataStore.h:15 RooCompositeDataStore.h:16 RooCompositeDataStore.h:17 RooCompositeDataStore.h:18 RooCompositeDataStore.h:19 RooCompositeDataStore.h:20 RooCompositeDataStore.h:21 RooCompositeDataStore.h:22 RooCompositeDataStore.h:23 RooCompositeDataStore.h:24 RooCompositeDataStore.h:25 RooCompositeDataStore.h:26 RooCompositeDataStore.h:27 RooCompositeDataStore.h:28 RooCompositeDataStore.h:29 RooCompositeDataStore.h:30 RooCompositeDataStore.h:31 RooCompositeDataStore.h:32 RooCompositeDataStore.h:33 RooCompositeDataStore.h:34 RooCompositeDataStore.h:35 RooCompositeDataStore.h:36 RooCompositeDataStore.h:37 RooCompositeDataStore.h:38 RooCompositeDataStore.h:39 RooCompositeDataStore.h:40 RooCompositeDataStore.h:41 RooCompositeDataStore.h:42 RooCompositeDataStore.h:43 RooCompositeDataStore.h:44 RooCompositeDataStore.h:45 RooCompositeDataStore.h:46 RooCompositeDataStore.h:47 RooCompositeDataStore.h:48 RooCompositeDataStore.h:49 RooCompositeDataStore.h:50 RooCompositeDataStore.h:51 RooCompositeDataStore.h:52 RooCompositeDataStore.h:53 RooCompositeDataStore.h:54 RooCompositeDataStore.h:55 RooCompositeDataStore.h:56 RooCompositeDataStore.h:57 RooCompositeDataStore.h:58 RooCompositeDataStore.h:59 RooCompositeDataStore.h:60 RooCompositeDataStore.h:61 RooCompositeDataStore.h:62 RooCompositeDataStore.h:63 RooCompositeDataStore.h:64 RooCompositeDataStore.h:65 RooCompositeDataStore.h:66 RooCompositeDataStore.h:67 RooCompositeDataStore.h:68 RooCompositeDataStore.h:69 RooCompositeDataStore.h:70 RooCompositeDataStore.h:71 RooCompositeDataStore.h:72 RooCompositeDataStore.h:73 RooCompositeDataStore.h:74 RooCompositeDataStore.h:75 RooCompositeDataStore.h:76 RooCompositeDataStore.h:77 RooCompositeDataStore.h:78 RooCompositeDataStore.h:79 RooCompositeDataStore.h:80 RooCompositeDataStore.h:81 RooCompositeDataStore.h:82 RooCompositeDataStore.h:83 RooCompositeDataStore.h:84 RooCompositeDataStore.h:85 RooCompositeDataStore.h:86 RooCompositeDataStore.h:87 RooCompositeDataStore.h:88 RooCompositeDataStore.h:89 RooCompositeDataStore.h:90 RooCompositeDataStore.h:91 RooCompositeDataStore.h:92 RooCompositeDataStore.h:93 RooCompositeDataStore.h:94 RooCompositeDataStore.h:95 RooCompositeDataStore.h:96 RooCompositeDataStore.h:97 RooCompositeDataStore.h:98 RooCompositeDataStore.h:99 RooCompositeDataStore.h:100 RooCompositeDataStore.h:101 RooCompositeDataStore.h:102 RooCompositeDataStore.h:103 RooCompositeDataStore.h:104 RooCompositeDataStore.h:105 RooCompositeDataStore.h:106 RooCompositeDataStore.h:107 RooCompositeDataStore.h:108 RooCompositeDataStore.h:109 RooCompositeDataStore.h:110 RooCompositeDataStore.h:111