Logo ROOT  
Reference Guide
RooDataHist Class Reference

The RooDataHist is a container class to hold N-dimensional binned data.

Each bin's central coordinates in N-dimensional space are represented by a RooArgSet containing RooRealVar, RooCategory or RooStringVar objects, thus data can be binned in real and/or discrete dimensions.

Definition at line 40 of file RooDataHist.h.

Public Member Functions

 RooDataHist ()
 Default constructor. More...
 
 RooDataHist (const char *name, const char *title, const RooArgList &vars, const RooCmdArg &arg1, const RooCmdArg &arg2=RooCmdArg(), const RooCmdArg &arg3=RooCmdArg(), const RooCmdArg &arg4=RooCmdArg(), const RooCmdArg &arg5=RooCmdArg(), const RooCmdArg &arg6=RooCmdArg(), const RooCmdArg &arg7=RooCmdArg(), const RooCmdArg &arg8=RooCmdArg())
 Constructor of a binned dataset from a RooArgSet defining the dimensions of the data space. More...
 
 RooDataHist (const char *name, const char *title, const RooArgList &vars, const TH1 *hist, Double_t initWgt=1.0)
 Constructor of a data hist from an TH1,TH2 or TH3 The RooArgSet 'vars' defines the dimensions of the histogram. More...
 
 RooDataHist (const char *name, const char *title, const RooArgList &vars, RooCategory &indexCat, std::map< std::string, RooDataHist * > dhistMap, Double_t wgt=1.0)
 Constructor of a data hist from a map of RooDataHists that are collated into a x+1 dimensional RooDataHist where the added dimension is a category that labels the input source as defined in the histMap argument. More...
 
 RooDataHist (const char *name, const char *title, const RooArgList &vars, RooCategory &indexCat, std::map< std::string, TH1 * > histMap, Double_t initWgt=1.0)
 Constructor of a data hist from a map of TH1,TH2 or TH3 that are collated into a x+1 dimensional RooDataHist where the added dimension is a category that labels the input source as defined in the histMap argument. More...
 
 RooDataHist (const char *name, const char *title, const RooArgSet &vars, const char *binningName=0)
 Constructor of an empty data hist from a RooArgSet defining the dimensions of the data space. More...
 
 RooDataHist (const char *name, const char *title, const RooArgSet &vars, const RooAbsData &data, Double_t initWgt=1.0)
 Constructor of a data hist from an existing data collection (binned or unbinned) The RooArgSet 'vars' defines the dimensions of the histogram. More...
 
 RooDataHist (const RooDataHist &other, const char *newname=0)
 Copy constructor. More...
 
virtual ~RooDataHist ()
 Destructor. More...
 
void add (const RooAbsData &dset, const char *cut, Double_t weight=1.0)
 Add all data points contained in 'dset' to this data set with given weight. More...
 
void add (const RooAbsData &dset, const RooFormulaVar *cutVar=0, Double_t weight=1.0)
 Add all data points contained in 'dset' to this data set with given weight. More...
 
virtual void add (const RooArgSet &row, Double_t weight, Double_t sumw2)
 Increment the weight of the bin enclosing the coordinates given by 'row' by the specified amount. More...
 
virtual void add (const RooArgSet &row, Double_t wgt=1.0)
 
Double_t binVolume () const
 
Double_t binVolume (const RooArgSet &bin)
 Return the volume of the bin enclosing coordinates 'coord'. More...
 
virtual TObjectClone (const char *newname="") const
 Make a clone of an object using the Streamer facility. More...
 
void dump2 ()
 Debug stuff, should go... More...
 
virtual RooAbsDataemptyClone (const char *newName=0, const char *newTitle=0, const RooArgSet *vars=0, const char *=0) const
 
virtual const RooArgSetget () const
 
virtual const RooArgSetget (const RooArgSet &coord) const
 Return a RooArgSet with center coordinates of the bin enclosing the point 'coord'. More...
 
virtual const RooArgSetget (Int_t masterIdx) const
 Return an argset with the bin center coordinates for bin sequential number 'masterIdx'. More...
 
Int_t getIndex (const RooArgSet &coord, Bool_t fast=kFALSE)
 
virtual RooSpan< const doublegetWeightBatch (std::size_t, std::size_t) const
 Return event weights of all events in range [first, first+len). More...
 
virtual Bool_t isNonPoissonWeighted () const
 Returns true if datasets contains entries with a non-integer weight. More...
 
virtual Bool_t isWeighted () const
 
virtual Int_t numEntries () const
 Return the number of bins. More...
 
RooDataHistoperator= (const RooDataHist &)=delete
 
virtual RooPlotplotOn (RooPlot *frame, const RooCmdArg &arg1=RooCmdArg::none(), const RooCmdArg &arg2=RooCmdArg::none(), const RooCmdArg &arg3=RooCmdArg::none(), const RooCmdArg &arg4=RooCmdArg::none(), const RooCmdArg &arg5=RooCmdArg::none(), const RooCmdArg &arg6=RooCmdArg::none(), const RooCmdArg &arg7=RooCmdArg::none(), const RooCmdArg &arg8=RooCmdArg::none()) const
 Calls RooPlot* plotOn(RooPlot* frame, const RooLinkedList& cmdList) const ;. More...
 
virtual RooPlotplotOn (RooPlot *frame, const RooLinkedList &cmdList) const
 Plot dataset on specified frame. More...
 
virtual RooPlotplotOn (RooPlot *frame, PlotOpt o) const
 Create and fill a histogram of the frame's variable and append it to the frame. More...
 
virtual RooPlotplotOn (RooPlot *frame, PlotOpt o) const
 Back end function to plotting functionality. More...
 
virtual void printArgs (std::ostream &os) const
 Print argument of dataset, i.e. the observable names. More...
 
virtual void printMultiline (std::ostream &os, Int_t content, Bool_t verbose=kFALSE, TString indent="") const
 Print the details on the dataset contents. More...
 
virtual void printValue (std::ostream &os) const
 Print value of the dataset, i.e. the sum of weights contained in the dataset. More...
 
void removeSelfFromDir ()
 
virtual void reset ()
 Reset all bin weights to zero. More...
 
void set (const RooArgSet &row, Double_t weight, Double_t wgtErr=-1)
 Set the weight and weight error of the bin enclosing the coordinates given by row. More...
 
void set (const RooArgSet &row, Double_t weight, Double_t wgtErrLo, Double_t wgtErrHi)
 Set the weight and errors of the bin enclosing the coordinates given by row. More...
 
void set (Double_t weight, Double_t wgtErr=-1)
 Set the weight and weight error of the bin enclosing the current (i.e. More...
 
void SetName (const char *name)
 Change the name of the RooDataHist. More...
 
void SetNameTitle (const char *name, const char *title)
 Change the title of this RooDataHist. More...
 
TIteratorsliceIterator (RooAbsArg &sliceArg, const RooArgSet &otherArgs)
 Create an iterator over all bins in a slice defined by the subset of observables listed in sliceArg. More...
 
Double_t sum (Bool_t correctForBinSize, Bool_t inverseCorr=kFALSE) const
 Return the sum of the weights of all hist bins. More...
 
Double_t sum (const RooArgSet &sumSet, const RooArgSet &sliceSet, Bool_t correctForBinSize, Bool_t inverseCorr, const std::map< const RooAbsArg *, std::pair< Double_t, Double_t > > &ranges)
 Return the sum of the weights of a multi-dimensional slice of the histogram by summing only over the dimensions specified in sumSet. More...
 
Double_t sum (const RooArgSet &sumSet, const RooArgSet &sliceSet, Bool_t correctForBinSize, Bool_t inverseCorr=kFALSE)
 Return the sum of the weights of a multi-dimensional slice of the histogram by summing only over the dimensions specified in sumSet. More...
 
virtual Double_t sumEntries () const
 
virtual Double_t sumEntries (const char *cutSpec, const char *cutRange=0) const
 Return the sum of weights in all entries matching cutSpec (if specified) and in named range cutRange (if specified) Return the. More...
 
virtual Bool_t valid () const
 Return true if currently loaded coordinate is considered valid within the current range definitions of all observables. More...
 
virtual Double_t weight () const
 
Double_t weight (const RooArgSet &bin, Int_t intOrder=1, Bool_t correctForBinSize=kFALSE, Bool_t cdfBoundaries=kFALSE, Bool_t oneSafe=kFALSE)
 Return the weight at given coordinates with optional interpolation. More...
 
virtual void weightError (Double_t &lo, Double_t &hi, ErrorType etype=Poisson) const
 Return the error on current weight. More...
 
virtual Double_t weightError (ErrorType etype=Poisson) const
 Return error on current weight (dummy implementation returning zero) More...
 
Double_t weightSquared () const
 
- Public Member Functions inherited from RooAbsData
 RooAbsData ()
 Default constructor. More...
 
 RooAbsData (const char *name, const char *title, const RooArgSet &vars, RooAbsDataStore *store=0)
 Constructor from a set of variables. More...
 
 RooAbsData (const RooAbsData &other, const char *newname=0)
 Copy constructor. More...
 
virtual ~RooAbsData ()
 Destructor. More...
 
virtual void add (const RooArgSet &row, Double_t weight=1, Double_t weightError=0)=0
 
void addOwnedComponent (const char *idxlabel, RooAbsData &data)
 
void attachBuffers (const RooArgSet &extObs)
 
Bool_t canSplitFast () const
 
virtual Bool_t changeObservableName (const char *from, const char *to)
 
void checkInit () const
 
virtual void convertToTreeStore ()
 Convert vector-based storage to tree-based storage. More...
 
void convertToVectorStore ()
 Convert tree-based storage to vector-based storage. More...
 
Double_t correlation (RooRealVar &x, RooRealVar &y, const char *cutSpec=0, const char *cutRange=0) const
 
TMatrixDSymcorrelationMatrix (const char *cutSpec=0, const char *cutRange=0) const
 
TMatrixDSymcorrelationMatrix (const RooArgList &vars, const char *cutSpec=0, const char *cutRange=0) const
 
Double_t covariance (RooRealVar &x, RooRealVar &y, const char *cutSpec=0, const char *cutRange=0) const
 
TMatrixDSymcovarianceMatrix (const char *cutSpec=0, const char *cutRange=0) const
 
TMatrixDSymcovarianceMatrix (const RooArgList &vars, const char *cutSpec=0, const char *cutRange=0) const
 
TH1createHistogram (const char *name, const RooAbsRealLValue &xvar, const RooCmdArg &arg1=RooCmdArg::none(), const RooCmdArg &arg2=RooCmdArg::none(), const RooCmdArg &arg3=RooCmdArg::none(), const RooCmdArg &arg4=RooCmdArg::none(), const RooCmdArg &arg5=RooCmdArg::none(), const RooCmdArg &arg6=RooCmdArg::none(), const RooCmdArg &arg7=RooCmdArg::none(), const RooCmdArg &arg8=RooCmdArg::none()) const
 Calls createHistogram(const char *name, const RooAbsRealLValue& xvar, const RooLinkedList& argList) const. More...
 
TH1createHistogram (const char *name, const RooAbsRealLValue &xvar, const RooLinkedList &argList) const
 Create and fill a ROOT histogram TH1,TH2 or TH3 with the values of this dataset. More...
 
TH1createHistogram (const char *varNameList, Int_t xbins=0, Int_t ybins=0, Int_t zbins=0) const
 Create and fill a ROOT histogram TH1,TH2 or TH3 with the values of this dataset for the variables with given names The range of each observable that is histogrammed is always automatically calculated from the distribution in the dataset. More...
 
virtual Int_t defaultPrintContents (Option_t *opt) const
 Define default print options, for a given print style. More...
 
virtual void Draw (Option_t *option="")
 Forward draw command to data store. More...
 
virtual RooAbsDataemptyClone (const char *newName=0, const char *newTitle=0, const RooArgSet *vars=0, const char *wgtVarName=0) const =0
 
virtual void fill ()
 
virtual TH1fillHistogram (TH1 *hist, const RooArgList &plotVars, const char *cuts="", const char *cutRange=0) const
 Loop over columns of our tree data and fill the input histogram. More...
 
virtual const RooArgSetget () const
 
virtual const RooArgSetget (Int_t index) const
 
TTreeGetClonedTree () const
 Return a clone of the TTree which stores the data or create such a tree if vector storage is used. More...
 
Bool_t getRange (const RooAbsRealLValue &var, Double_t &lowest, Double_t &highest, Double_t marginFrac=0, Bool_t symMode=kFALSE) const
 Fill Doubles 'lowest' and 'highest' with the lowest and highest value of observable 'var' in this dataset. More...
 
RooAbsDatagetSimData (const char *idxstate)
 
virtual RooSpan< const doublegetWeightBatch (std::size_t first, std::size_t len) const =0
 Return event weights of all events in range [first, first+len). More...
 
Bool_t hasFilledCache () const
 
virtual Bool_t isNonPoissonWeighted () const
 
virtual Bool_t isWeighted () const
 
Double_t kurtosis (const RooRealVar &var, const char *cutSpec=0, const char *cutRange=0) const
 
Double_t mean (const RooRealVar &var, const char *cutSpec=0, const char *cutRange=0) const
 
RooRealVarmeanVar (const RooRealVar &var, const char *cutSpec=0, const char *cutRange=0) const
 Create a RooRealVar containing the mean of observable 'var' in this dataset. More...
 
Double_t moment (const RooRealVar &var, Double_t order, const char *cutSpec=0, const char *cutRange=0) const
 Calculate moment of requested order. More...
 
Double_t moment (const RooRealVar &var, Double_t order, Double_t offset, const char *cutSpec=0, const char *cutRange=0) const
 Return the 'order'-ed moment of observable 'var' in this dataset. More...
 
virtual Int_t numEntries () const
 
RooAbsDataoperator= (const RooAbsData &other)
 
virtual RooPlotplotOn (RooPlot *frame, const RooCmdArg &arg1=RooCmdArg::none(), const RooCmdArg &arg2=RooCmdArg::none(), const RooCmdArg &arg3=RooCmdArg::none(), const RooCmdArg &arg4=RooCmdArg::none(), const RooCmdArg &arg5=RooCmdArg::none(), const RooCmdArg &arg6=RooCmdArg::none(), const RooCmdArg &arg7=RooCmdArg::none(), const RooCmdArg &arg8=RooCmdArg::none()) const
 Calls RooPlot* plotOn(RooPlot* frame, const RooLinkedList& cmdList) const ;. More...
 
virtual RooPlotplotOn (RooPlot *frame, const RooLinkedList &cmdList) const
 Plot dataset on specified frame. More...
 
virtual void Print (Option_t *options=0) const
 Print TNamed name and title. More...
 
virtual void printClassName (std::ostream &os) const
 Print class name of dataset. More...
 
void printMultiline (std::ostream &os, Int_t contents, Bool_t verbose=kFALSE, TString indent="") const
 Interface for detailed printing of object. More...
 
virtual void printName (std::ostream &os) const
 Print name of dataset. More...
 
virtual void printTitle (std::ostream &os) const
 Print title of dataset. More...
 
virtual void RecursiveRemove (TObject *obj)
 If one of the TObject we have a referenced to is deleted, remove the reference. More...
 
RooAbsDatareduce (const char *cut)
 Create a subset of the data set by applying the given cut on the data points. More...
 
RooAbsDatareduce (const RooArgSet &varSubset, const char *cut=0)
 Create a subset of the data set by applying the given cut on the data points and reducing the dimensions to the specified set. More...
 
RooAbsDatareduce (const RooArgSet &varSubset, const RooFormulaVar &cutVar)
 Create a subset of the data set by applying the given cut on the data points and reducing the dimensions to the specified set. More...
 
RooAbsDatareduce (const RooCmdArg &arg1, const RooCmdArg &arg2=RooCmdArg(), const RooCmdArg &arg3=RooCmdArg(), const RooCmdArg &arg4=RooCmdArg(), const RooCmdArg &arg5=RooCmdArg(), const RooCmdArg &arg6=RooCmdArg(), const RooCmdArg &arg7=RooCmdArg(), const RooCmdArg &arg8=RooCmdArg())
 Create a reduced copy of this dataset. More...
 
RooAbsDatareduce (const RooFormulaVar &cutVar)
 Create a subset of the data set by applying the given cut on the data points. More...
 
virtual void reset ()
 
void resetBuffers ()
 
RooRealVarrmsVar (const RooRealVar &var, const char *cutSpec=0, const char *cutRange=0) const
 Create a RooRealVar containing the RMS of observable 'var' in this dataset. More...
 
void setDirtyProp (Bool_t flag)
 Control propagation of dirty flags from observables in dataset. More...
 
Double_t sigma (const RooRealVar &var, const char *cutSpec=0, const char *cutRange=0) const
 
Double_t skewness (const RooRealVar &var, const char *cutSpec=0, const char *cutRange=0) const
 
virtual TListsplit (const RooAbsCategory &splitCat, Bool_t createEmptyDataSets=kFALSE) const
 Split dataset into subsets based on states of given splitCat in this dataset. More...
 
Double_t standMoment (const RooRealVar &var, Double_t order, const char *cutSpec=0, const char *cutRange=0) const
 Calculate standardized moment. More...
 
virtual RooPlotstatOn (RooPlot *frame, const char *what, const char *label="", Int_t sigDigits=2, Option_t *options="NELU", Double_t xmin=0.15, Double_t xmax=0.65, Double_t ymax=0.85, const char *cutSpec=0, const char *cutRange=0, const RooCmdArg *formatCmd=0)
 Implementation back-end of statOn() method with named arguments. More...
 
virtual RooPlotstatOn (RooPlot *frame, const RooCmdArg &arg1=RooCmdArg::none(), const RooCmdArg &arg2=RooCmdArg::none(), const RooCmdArg &arg3=RooCmdArg::none(), const RooCmdArg &arg4=RooCmdArg::none(), const RooCmdArg &arg5=RooCmdArg::none(), const RooCmdArg &arg6=RooCmdArg::none(), const RooCmdArg &arg7=RooCmdArg::none(), const RooCmdArg &arg8=RooCmdArg::none())
 Add a box with statistics information to the specified frame. More...
 
RooAbsDataStorestore ()
 
const RooAbsDataStorestore () const
 
virtual Double_t sumEntries () const =0
 
virtual Double_t sumEntries (const char *cutSpec, const char *cutRange=0) const =0
 
virtual Roo1DTabletable (const RooAbsCategory &cat, const char *cuts="", const char *opts="") const
 Create and fill a 1-dimensional table for given category column This functions is the equivalent of plotOn() for category dimensions. More...
 
virtual Roo1DTabletable (const RooArgSet &catSet, const char *cuts="", const char *opts="") const
 Construct table for product of categories in catSet. More...
 
const TTreetree () const
 Return a pointer to the TTree which stores the data. More...
 
virtual Bool_t valid () const
 
virtual Double_t weight () const =0
 
virtual void weightError (Double_t &lo, Double_t &hi, ErrorType etype=Poisson) const
 Return asymmetric error on weight. (Dummy implementation returning zero) More...
 
virtual Double_t weightError (ErrorType etype=Poisson) const
 Return error on current weight (dummy implementation returning zero) More...
 
virtual Double_t weightSquared () const =0
 
- Public Member Functions inherited from TNamed
 TNamed ()
 
 TNamed (const char *name, const char *title)
 
 TNamed (const TNamed &named)
 TNamed copy ctor. More...
 
 TNamed (const TString &name, const TString &title)
 
virtual ~TNamed ()
 TNamed destructor. More...
 
virtual void Clear (Option_t *option="")
 Set name and title to empty strings (""). More...
 
virtual TObjectClone (const char *newname="") const
 Make a clone of an object using the Streamer facility. More...
 
virtual Int_t Compare (const TObject *obj) const
 Compare two TNamed objects. More...
 
virtual void Copy (TObject &named) const
 Copy this to obj. More...
 
virtual void FillBuffer (char *&buffer)
 Encode TNamed into output buffer. More...
 
virtual const char * GetName () const
 Returns name of object. More...
 
virtual const char * GetTitle () const
 Returns title of object. More...
 
virtual ULong_t Hash () const
 Return hash value for this object. More...
 
virtual Bool_t IsSortable () const
 
virtual void ls (Option_t *option="") const
 List TNamed name and title. More...
 
TNamedoperator= (const TNamed &rhs)
 TNamed assignment operator. More...
 
virtual void Print (Option_t *option="") const
 Print TNamed name and title. More...
 
virtual void SetName (const char *name)
 Set the name of the TNamed. More...
 
virtual void SetNameTitle (const char *name, const char *title)
 Set all the TNamed parameters (name and title). More...
 
virtual void SetTitle (const char *title="")
 Set the title of the TNamed. More...
 
virtual Int_t Sizeof () const
 Return size of the TNamed part of the TObject. More...
 
- Public Member Functions inherited from TObject
 TObject ()
 TObject constructor. More...
 
 TObject (const TObject &object)
 TObject copy ctor. More...
 
virtual ~TObject ()
 TObject destructor. More...
 
void AbstractMethod (const char *method) const
 Use this method to implement an "abstract" method that you don't want to leave purely abstract. More...
 
virtual void AppendPad (Option_t *option="")
 Append graphics object to current pad. More...
 
virtual void Browse (TBrowser *b)
 Browse object. May be overridden for another default action. More...
 
ULong_t CheckedHash ()
 Check and record whether this class has a consistent Hash/RecursiveRemove setup (*) and then return the regular Hash value for this object. More...
 
virtual const char * ClassName () const
 Returns name of class to which the object belongs. More...
 
virtual void Clear (Option_t *="")
 
virtual TObjectClone (const char *newname="") const
 Make a clone of an object using the Streamer facility. More...
 
virtual Int_t Compare (const TObject *obj) const
 Compare abstract method. More...
 
virtual void Copy (TObject &object) const
 Copy this to obj. More...
 
virtual void Delete (Option_t *option="")
 Delete this object. More...
 
virtual Int_t DistancetoPrimitive (Int_t px, Int_t py)
 Computes distance from point (px,py) to the object. More...
 
virtual void Draw (Option_t *option="")
 Default Draw method for all objects. More...
 
virtual void DrawClass () const
 Draw class inheritance tree of the class to which this object belongs. More...
 
virtual TObjectDrawClone (Option_t *option="") const
 Draw a clone of this object in the current selected pad for instance with: gROOT->SetSelectedPad(gPad). More...
 
virtual void Dump () const
 Dump contents of object on stdout. More...
 
virtual void Error (const char *method, const char *msgfmt,...) const
 Issue error message. More...
 
virtual void Execute (const char *method, const char *params, Int_t *error=0)
 Execute method on this object with the given parameter string, e.g. More...
 
virtual void Execute (TMethod *method, TObjArray *params, Int_t *error=0)
 Execute method on this object with parameters stored in the TObjArray. More...
 
virtual void ExecuteEvent (Int_t event, Int_t px, Int_t py)
 Execute action corresponding to an event at (px,py). More...
 
virtual void Fatal (const char *method, const char *msgfmt,...) const
 Issue fatal error message. More...
 
virtual TObjectFindObject (const char *name) const
 Must be redefined in derived classes. More...
 
virtual TObjectFindObject (const TObject *obj) const
 Must be redefined in derived classes. More...
 
virtual Option_tGetDrawOption () const
 Get option used by the graphics system to draw this object. More...
 
virtual const char * GetIconName () const
 Returns mime type name of object. More...
 
virtual const char * GetName () const
 Returns name of object. More...
 
virtual char * GetObjectInfo (Int_t px, Int_t py) const
 Returns string containing info about the object at position (px,py). More...
 
virtual Option_tGetOption () const
 
virtual const char * GetTitle () const
 Returns title of object. More...
 
virtual UInt_t GetUniqueID () const
 Return the unique object id. More...
 
virtual Bool_t HandleTimer (TTimer *timer)
 Execute action in response of a timer timing out. More...
 
virtual ULong_t Hash () const
 Return hash value for this object. More...
 
Bool_t HasInconsistentHash () const
 Return true is the type of this object is known to have an inconsistent setup for Hash and RecursiveRemove (i.e. More...
 
virtual void Info (const char *method, const char *msgfmt,...) const
 Issue info message. More...
 
virtual Bool_t InheritsFrom (const char *classname) const
 Returns kTRUE if object inherits from class "classname". More...
 
virtual Bool_t InheritsFrom (const TClass *cl) const
 Returns kTRUE if object inherits from TClass cl. More...
 
virtual void Inspect () const
 Dump contents of this object in a graphics canvas. More...
 
void InvertBit (UInt_t f)
 
virtual Bool_t IsEqual (const TObject *obj) const
 Default equal comparison (objects are equal if they have the same address in memory). More...
 
virtual Bool_t IsFolder () const
 Returns kTRUE in case object contains browsable objects (like containers or lists of other objects). More...
 
R__ALWAYS_INLINE Bool_t IsOnHeap () const
 
virtual Bool_t IsSortable () const
 
R__ALWAYS_INLINE Bool_t IsZombie () const
 
virtual void ls (Option_t *option="") const
 The ls function lists the contents of a class on stdout. More...
 
void MayNotUse (const char *method) const
 Use this method to signal that a method (defined in a base class) may not be called in a derived class (in principle against good design since a child class should not provide less functionality than its parent, however, sometimes it is necessary). More...
 
virtual Bool_t Notify ()
 This method must be overridden to handle object notification. More...
 
void Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const
 Use this method to declare a method obsolete. More...
 
void operator delete (void *ptr)
 Operator delete. More...
 
void operator delete[] (void *ptr)
 Operator delete []. More...
 
voidoperator new (size_t sz)
 
voidoperator new (size_t sz, void *vp)
 
voidoperator new[] (size_t sz)
 
voidoperator new[] (size_t sz, void *vp)
 
TObjectoperator= (const TObject &rhs)
 TObject assignment operator. More...
 
virtual void Paint (Option_t *option="")
 This method must be overridden if a class wants to paint itself. More...
 
virtual void Pop ()
 Pop on object drawn in a pad to the top of the display list. More...
 
virtual void Print (Option_t *option="") const
 This method must be overridden when a class wants to print itself. More...
 
virtual Int_t Read (const char *name)
 Read contents of object with specified name from the current directory. More...
 
virtual void RecursiveRemove (TObject *obj)
 Recursively remove this object from a list. More...
 
void ResetBit (UInt_t f)
 
virtual void SaveAs (const char *filename="", Option_t *option="") const
 Save this object in the file specified by filename. More...
 
virtual void SavePrimitive (std::ostream &out, Option_t *option="")
 Save a primitive as a C++ statement(s) on output stream "out". More...
 
void SetBit (UInt_t f)
 
void SetBit (UInt_t f, Bool_t set)
 Set or unset the user status bits as specified in f. More...
 
virtual void SetDrawOption (Option_t *option="")
 Set drawing option for object. More...
 
virtual void SetUniqueID (UInt_t uid)
 Set the unique object id. More...
 
virtual void SysError (const char *method, const char *msgfmt,...) const
 Issue system error message. More...
 
R__ALWAYS_INLINE Bool_t TestBit (UInt_t f) const
 
Int_t TestBits (UInt_t f) const
 
virtual void UseCurrentStyle ()
 Set current style settings in this object This function is called when either TCanvas::UseCurrentStyle or TROOT::ForceStyle have been invoked. More...
 
virtual void Warning (const char *method, const char *msgfmt,...) const
 Issue warning message. More...
 
virtual Int_t Write (const char *name=0, Int_t option=0, Int_t bufsize=0)
 Write this object to the current directory. More...
 
virtual Int_t Write (const char *name=0, Int_t option=0, Int_t bufsize=0) const
 Write this object to the current directory. More...
 
- Public Member Functions inherited from RooPrintable
 RooPrintable ()
 
virtual ~RooPrintable ()
 
virtual Int_t defaultPrintContents (Option_t *opt) const
 Default choice of contents to be printed (name and value) More...
 
virtual StyleOption defaultPrintStyle (Option_t *opt) const
 
virtual void printAddress (std::ostream &os) const
 Print class name of object. More...
 
virtual void printArgs (std::ostream &os) const
 Interface for printing of object arguments. More...
 
virtual void printClassName (std::ostream &os) const
 Print class name of object. More...
 
virtual void printExtras (std::ostream &os) const
 Interface to print extras of object. More...
 
virtual void printMultiline (std::ostream &os, Int_t contents, Bool_t verbose=kFALSE, TString indent="") const
 Interface for detailed printing of object. More...
 
virtual void printName (std::ostream &os) const
 Print name of object. More...
 
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'. More...
 
virtual void printTitle (std::ostream &os) const
 Print title of object. More...
 
virtual void printTree (std::ostream &os, TString indent="") const
 Interface for tree structure printing of object. More...
 
virtual void printValue (std::ostream &os) const
 Interface to print value of object. More...
 
- Public Member Functions inherited from RooDirItem
 RooDirItem ()
 
 RooDirItem (const RooDirItem &)
 
virtual ~RooDirItem ()
 

Protected Member Functions

 RooDataHist (const char *name, const char *title, RooDataHist *h, const RooArgSet &varSubset, const RooFormulaVar *cutVar, const char *cutRange, Int_t nStart, Int_t nStop, Bool_t copyCache)
 Constructor of a data hist from (part of) an existing data hist. More...
 
void adjustBinning (const RooArgList &vars, const TH1 &href, Int_t *offset=0)
 Adjust binning specification on first and optionally second and third observable to binning in given reference TH1. More...
 
virtual RooAbsDatacacheClone (const RooAbsArg *newCacheOwner, const RooArgSet *newCacheVars, const char *newName=0)
 Construct a clone of this dataset that contains only the cached variables. More...
 
void cacheValidEntries ()
 Cache the datahist entries with bin centers that are inside/outside the current observable definitio. More...
 
Int_t calcTreeIndex () const
 Calculate the index for the weights array corresponding to to the bin enclosing the current coordinates of the internal argset. More...
 
void calculatePartialBinVolume (const RooArgSet &dimSet) const
 Fill the transient cache with partial bin volumes with up-to-date values for the partial volume specified by observables 'dimSet'. More...
 
void checkBinBounds () const
 
Int_t get_curIndex () const
 
Double_t get_curSumW2 () const
 
Double_t get_curWeight () const
 
Double_t get_curWgtErrHi () const
 
Double_t get_curWgtErrLo () const
 
Double_t get_errHi (const Int_t &idx) const
 
Double_t get_errLo (const Int_t &idx) const
 
Double_t get_sumw2 (const Int_t &idx) const
 
Double_t get_wgt (const Int_t &idx) const
 
void importDHistSet (const RooArgList &vars, RooCategory &indexCat, std::map< std::string, RooDataHist * > dmap, Double_t initWgt)
 Import data from given set of TH1/2/3 into this RooDataHist. More...
 
void importTH1 (const RooArgList &vars, const TH1 &histo, Double_t initWgt, Bool_t doDensityCorrection)
 Import data from given TH1/2/3 into this RooDataHist. More...
 
void importTH1Set (const RooArgList &vars, RooCategory &indexCat, std::map< std::string, TH1 * > hmap, Double_t initWgt, Bool_t doDensityCorrection)
 Import data from given set of TH1/2/3 into this RooDataHist. More...
 
void initialize (const char *binningName=0, Bool_t fillTree=kTRUE)
 Initialization procedure: allocate weights array, calculate multipliers needed for N-space to 1-dim array jump table, and fill the internal tree with all bin center coordinates. More...
 
Double_t interpolateDim (RooRealVar &dim, const RooAbsBinning *binning, Double_t xval, Int_t intOrder, Bool_t correctForBinSize, Bool_t cdfBoundaries)
 Perform boundary safe 'intOrder'-th interpolation of weights in dimension 'dim' at current value 'xval'. More...
 
RooAbsDatareduceEng (const RooArgSet &varSubset, const RooFormulaVar *cutVar, const char *cutRange=0, std::size_t nStart=0, std::size_t nStop=std::numeric_limits< std::size_t >::max(), Bool_t copyCache=kTRUE)
 Implementation of RooAbsData virtual method that drives the RooAbsData::reduce() methods. More...
 
void setAllWeights (Double_t value)
 Set all the event weight of all bins to the specified value. More...
 
- Protected Member Functions inherited from RooAbsData
Bool_t allClientsCached (RooAbsArg *, const RooArgSet &)
 Utility function that determines if all clients of object 'var' appear in given list of cached nodes. More...
 
virtual void attachCache (const RooAbsArg *newOwner, const RooArgSet &cachedVars)
 Internal method – Attach dataset copied with cache contents to copied instances of functions. More...
 
virtual void cacheArgs (const RooAbsArg *owner, RooArgSet &varSet, const RooArgSet *nset=0, Bool_t skipZeroWeights=kFALSE)
 Internal method – Cache given set of functions with data. More...
 
virtual RooAbsDatacacheClone (const RooAbsArg *newCacheOwner, const RooArgSet *newCacheVars, const char *newName=0)=0
 
Double_t corrcov (const RooRealVar &x, const RooRealVar &y, const char *cutSpec, const char *cutRange, Bool_t corr) const
 Internal method to calculate single correlation and covariance elements. More...
 
TMatrixDSymcorrcovMatrix (const RooArgList &vars, const char *cutSpec, const char *cutRange, Bool_t corr) const
 Return covariance matrix from data for given list of observables. More...
 
RooRealVardataRealVar (const char *methodname, const RooRealVar &extVar) const
 Internal method to check if given RooRealVar maps to a RooRealVar in this dataset. More...
 
virtual void optimizeReadingWithCaching (RooAbsArg &arg, const RooArgSet &cacheList, const RooArgSet &keepObsList)
 Prepare dataset for use with cached constant terms listed in 'cacheList' of expression 'arg'. More...
 
virtual RooPlotplotAsymOn (RooPlot *frame, const RooAbsCategoryLValue &asymCat, PlotOpt o) const
 Create and fill a histogram with the asymmetry N[+] - N[-] / ( N[+] + N[-] ), where N(+/-) is the number of data points with asymCat=+1 and asymCat=-1 as function of the frames variable. More...
 
virtual RooPlotplotEffOn (RooPlot *frame, const RooAbsCategoryLValue &effCat, PlotOpt o) const
 Create and fill a histogram with the efficiency N[1] / ( N[1] + N[0] ), where N(1/0) is the number of data points with effCat=1 and effCat=0 as function of the frames variable. More...
 
virtual RooPlotplotOn (RooPlot *frame, PlotOpt o) const
 Create and fill a histogram of the frame's variable and append it to the frame. More...
 
virtual RooAbsDatareduceEng (const RooArgSet &varSubset, const RooFormulaVar *cutVar, const char *cutRange=0, std::size_t nStart=0, std::size_t=std::numeric_limits< std::size_t >::max(), Bool_t copyCache=kTRUE)=0
 
virtual void resetCache ()
 Internal method – Remove cached function values. More...
 
virtual void setArgStatus (const RooArgSet &set, Bool_t active)
 
- Protected Member Functions inherited from TObject
virtual void DoError (int level, const char *location, const char *fmt, va_list va) const
 Interface to ErrorHandler (protected). More...
 
void MakeZombie ()
 
- Protected Member Functions inherited from RooDirItem
void appendToDir (TObject *obj, Bool_t forceMemoryResident=kFALSE)
 Append object to directory. More...
 
void removeFromDir (TObject *obj)
 Remove object from directory it was added to. More...
 

Protected Attributes

Int_t _arrSize
 
std::vector< std::vector< Double_t > > _binbounds
 List of used binnings associated with lvalues. More...
 
Double_t_binv
 
Bool_t_binValid
 
Double_t _cache_sum {0.}
 Is cache sum valid. More...
 
Int_t _cache_sum_valid {0}
 list of bin bounds per dimension More...
 
Int_t _curIndex {0}
 
Double_t _curSumW2 {0.}
 
Double_t _curVolume {0.}
 
Double_t _curWeight {0.}
 Valid bins with current range definition. More...
 
Double_t _curWgtErrHi {0.}
 
Double_t _curWgtErrLo {0.}
 
Double_t_errHi
 
Double_t_errLo
 
std::vector< Int_t_idxMult
 
std::vector< const RooAbsBinning * > _lvbins
 List of observables casted as RooAbsLValue. More...
 
std::vector< RooAbsLValue * > _lvvars
 Cache manager for arrays of partial bin volumes. More...
 
std::vector< Double_t > * _pbinv
 
RooCacheManager< std::vector< Double_t > > _pbinvCacheMgr
 Partial bin volume array. More...
 
RooArgSet _realVars
 
Double_t_sumw2
 
Double_t_wgt
 
- Protected Attributes inherited from RooAbsData
RooArgSet _cachedVars
 
RooAbsDataStore_dstore
 External variables cached with this data set. More...
 
std::map< std::string, RooAbsData * > _ownedComponents
 
RooArgSet _vars
 
StorageType storageType
 
- Protected Attributes inherited from TNamed
TString fName
 
TString fTitle
 
- Protected Attributes inherited from RooDirItem
TDirectory_dir {nullptr}
 

Private Member Functions

void _adjustBinning (RooRealVar &theirVar, const TAxis &axis, RooRealVar *ourVar, Int_t *offset)
 Cache for sum of entries ;. More...
 

Friends

class RooAbsCachedPdf
 
class RooAbsCachedReal
 
class RooAbsOptTestStatistic
 
class RooDataHistSliceIter
 

Additional Inherited Members

- Public Types inherited from RooAbsData
enum  ErrorType {
  Poisson , SumW2 , None , Auto ,
  Expected
}
 
enum  StorageType { Tree , Vector , Composite }
 
- Public Types inherited from TObject
enum  {
  kIsOnHeap = 0x01000000 , kNotDeleted = 0x02000000 , kZombie = 0x04000000 , kInconsistent = 0x08000000 ,
  kBitMask = 0x00ffffff
}
 
enum  { kSingleKey = BIT(0) , kOverwrite = BIT(1) , kWriteDelete = BIT(2) }
 
enum  EDeprecatedStatusBits { kObjInCanvas = BIT(3) }
 
enum  EStatusBits {
  kCanDelete = BIT(0) , kMustCleanup = BIT(3) , kIsReferenced = BIT(4) , kHasUUID = BIT(5) ,
  kCannotPick = BIT(6) , kNoContextMenu = BIT(8) , kInvalidObject = BIT(13)
}
 
- Public Types inherited from RooPrintable
enum  ContentsOption {
  kName =1 , kClassName =2 , kValue =4 , kArgs =8 ,
  kExtras =16 , kAddress =32 , kTitle =64 , kCollectionHeader =128
}
 
enum  StyleOption {
  kInline =1 , kSingleLine =2 , kStandard =3 , kVerbose =4 ,
  kTreeStructure =5
}
 
- Static Public Member Functions inherited from RooAbsData
static void claimVars (RooAbsData *)
 
static StorageType getDefaultStorageType ()
 
static Bool_t releaseVars (RooAbsData *)
 If return value is true variables can be deleted. More...
 
static void setDefaultStorageType (StorageType s)
 
- Static Public Member Functions inherited from TObject
static Long_t GetDtorOnly ()
 Return destructor only flag. More...
 
static Bool_t GetObjectStat ()
 Get status of object stat flag. More...
 
static void SetDtorOnly (void *obj)
 Set destructor only flag. More...
 
static void SetObjectStat (Bool_t stat)
 Turn on/off tracking of objects in the TObjectTable. More...
 
- Static Public Member Functions inherited from RooPrintable
static std::ostream & defaultPrintStream (std::ostream *os=0)
 Return a reference to the current default stream to use in Print(). More...
 
static void nameFieldLength (Int_t newLen)
 Set length of field reserved from printing name of RooAbsArgs in multi-line collection printing to given amount. More...
 
- Protected Types inherited from TObject
enum  { kOnlyPrepStep = BIT(3) }
 
- Static Protected Attributes inherited from RooAbsData
static StorageType defaultStorageType =RooAbsData::Vector
 
- Static Protected Attributes inherited from RooPrintable
static Int_t _nameLength
 

#include <RooDataHist.h>

Inheritance diagram for RooDataHist:
[legend]

Constructor & Destructor Documentation

◆ RooDataHist() [1/9]

RooDataHist::RooDataHist ( )

Default constructor.

Definition at line 69 of file RooDataHist.cxx.

◆ RooDataHist() [2/9]

RooDataHist::RooDataHist ( const char *  name,
const char *  title,
const RooArgSet vars,
const char *  binningName = 0 
)

Constructor of an empty data hist from a RooArgSet defining the dimensions of the data space.

The range and number of bins in each dimensions are taken from getMin()getMax(),getBins() of each RooAbsArg representing that dimension.

For real dimensions, the fit range and number of bins can be set independently of the plot range and number of bins, but it is advisable to keep the ratio of the plot bin width and the fit bin width an integer value. For category dimensions, the fit ranges always comprises all defined states and each state is always has its individual bin

To effective achive binning of real dimensions with variable bins sizes, construct a RooThresholdCategory of the real dimension to be binned variably. Set the thresholds at the desired bin boundaries, and construct the data hist as function of the threshold category instead of the real variable.

Definition at line 108 of file RooDataHist.cxx.

◆ RooDataHist() [3/9]

RooDataHist::RooDataHist ( const char *  name,
const char *  title,
const RooArgSet vars,
const RooAbsData data,
Double_t  wgt = 1.0 
)

Constructor of a data hist from an existing data collection (binned or unbinned) The RooArgSet 'vars' defines the dimensions of the histogram.

The range and number of bins in each dimensions are taken from getMin(), getMax(), getBins() of each argument passed.

For real dimensions, the fit range and number of bins can be set independently of the plot range and number of bins, but it is advisable to keep the ratio of the plot bin width and the fit bin width an integer value. For category dimensions, the fit ranges always comprises all defined states and each state is always has its individual bin

To effective achive binning of real dimensions with variable bins sizes, construct a RooThresholdCategory of the real dimension to be binned variably. Set the thresholds at the desired bin boundaries, and construct the data hist as function of the threshold category instead of the real variable.

If the constructed data hist has less dimensions that in source data collection, all missing dimensions will be projected.

Definition at line 145 of file RooDataHist.cxx.

◆ RooDataHist() [4/9]

RooDataHist::RooDataHist ( const char *  name,
const char *  title,
const RooArgList vars,
const TH1 hist,
Double_t  wgt = 1.0 
)

Constructor of a data hist from an TH1,TH2 or TH3 The RooArgSet 'vars' defines the dimensions of the histogram.

The ranges and number of bins are taken from the input histogram, and the corresponding values are set accordingly on the arguments in 'vars'

Definition at line 220 of file RooDataHist.cxx.

◆ RooDataHist() [5/9]

RooDataHist::RooDataHist ( const char *  name,
const char *  title,
const RooArgList vars,
RooCategory indexCat,
std::map< std::string, TH1 * >  histMap,
Double_t  wgt = 1.0 
)

Constructor of a data hist from a map of TH1,TH2 or TH3 that are collated into a x+1 dimensional RooDataHist where the added dimension is a category that labels the input source as defined in the histMap argument.

The state names used in histMap must correspond to predefined states 'indexCat'

The RooArgList 'vars' defines the dimensions of the histogram. The ranges and number of bins are taken from the input histogram and must be the same in all histograms

Definition at line 171 of file RooDataHist.cxx.

◆ RooDataHist() [6/9]

RooDataHist::RooDataHist ( const char *  name,
const char *  title,
const RooArgList vars,
RooCategory indexCat,
std::map< std::string, RooDataHist * >  dhistMap,
Double_t  wgt = 1.0 
)

Constructor of a data hist from a map of RooDataHists that are collated into a x+1 dimensional RooDataHist where the added dimension is a category that labels the input source as defined in the histMap argument.

The state names used in histMap must correspond to predefined states 'indexCat'

The RooArgList 'vars' defines the dimensions of the histogram. The ranges and number of bins are taken from the input histogram and must be the same in all histograms

Definition at line 197 of file RooDataHist.cxx.

◆ RooDataHist() [7/9]

RooDataHist::RooDataHist ( const char *  name,
const char *  title,
const RooArgList vars,
const RooCmdArg arg1,
const RooCmdArg arg2 = RooCmdArg(),
const RooCmdArg arg3 = RooCmdArg(),
const RooCmdArg arg4 = RooCmdArg(),
const RooCmdArg arg5 = RooCmdArg(),
const RooCmdArg arg6 = RooCmdArg(),
const RooCmdArg arg7 = RooCmdArg(),
const RooCmdArg arg8 = RooCmdArg() 
)

Constructor of a binned dataset from a RooArgSet defining the dimensions of the data space.

The range and number of bins in each dimensions are taken from getMin() getMax(),getBins() of each RooAbsArg representing that dimension.

Optional Argument Effect
Import(TH1&, Bool_t impDens)

Import contents of the given TH1/2/3 into this binned dataset. The ranges and binning of the binned dataset are automatically adjusted to match those of the imported histogram.

Please note: for TH1& with unequal binning only, you should decide if you want to import the absolute bin content, or the bin content expressed as density. The latter is default and will result in the same histogram as the original TH1. For certain types of bin contents (containing efficiencies, asymmetries, or ratio is general) you should import the absolute value and set impDens to kFALSE

Weight(Double_t)

Apply given weight factor when importing histograms

Index(RooCategory&)

Prepare import of multiple TH1/1/2/3 into a N+1 dimensional RooDataHist where the extra discrete dimension labels the source of the imported histogram If the index category defines states for which no histogram is be imported the corresponding bins will be left empty.

Import(const char*, TH1&) Import a THx to be associated with the given state name of the index category specified in Index(). If the given state name is not yet defined in the index category it will be added on the fly. The import command can be specified multiple times.
Import(map<string,TH1*>&) As above, but allows specification of many imports in a single operation

Definition at line 276 of file RooDataHist.cxx.

◆ RooDataHist() [8/9]

RooDataHist::RooDataHist ( const RooDataHist other,
const char *  newname = 0 
)

Copy constructor.

Definition at line 782 of file RooDataHist.cxx.

◆ ~RooDataHist()

RooDataHist::~RooDataHist ( )
virtual

Destructor.

Definition at line 937 of file RooDataHist.cxx.

◆ RooDataHist() [9/9]

RooDataHist::RooDataHist ( const char *  name,
const char *  title,
RooDataHist h,
const RooArgSet varSubset,
const RooFormulaVar cutVar,
const char *  cutRange,
Int_t  nStart,
Int_t  nStop,
Bool_t  copyCache 
)
protected

Constructor of a data hist from (part of) an existing data hist.

The dimensions of the data set are defined by the 'vars' RooArgSet, which can be identical to 'dset' dimensions, or a subset thereof. Reduced dimensions will be projected in the output data hist. The optional 'cutVar' formula variable can used to select the subset of bins to be copied.

For most uses the RooAbsData::reduce() wrapper function, which uses this constructor, is the most convenient way to create a subset of an existing data

Definition at line 833 of file RooDataHist.cxx.

Member Function Documentation

◆ _adjustBinning()

void RooDataHist::_adjustBinning ( RooRealVar theirVar,
const TAxis axis,
RooRealVar ourVar,
Int_t offset 
)
private

Cache for sum of entries ;.

Helper doing the actual work of adjustBinning().

Definition at line 576 of file RooDataHist.cxx.

◆ add() [1/4]

void RooDataHist::add ( const RooAbsData dset,
const char *  cut,
Double_t  wgt = 1.0 
)

Add all data points contained in 'dset' to this data set with given weight.

Optional cut string expression selects the data points to be added and can reference any variable contained in this data set

Definition at line 1372 of file RooDataHist.cxx.

◆ add() [2/4]

void RooDataHist::add ( const RooAbsData dset,
const RooFormulaVar cutVar = 0,
Double_t  wgt = 1.0 
)

Add all data points contained in 'dset' to this data set with given weight.

Optional RooFormulaVar pointer selects the data points to be added.

Definition at line 1384 of file RooDataHist.cxx.

◆ add() [3/4]

void RooDataHist::add ( const RooArgSet row,
Double_t  wgt,
Double_t  sumw2 
)
virtual

Increment the weight of the bin enclosing the coordinates given by 'row' by the specified amount.

Add the sum of weights squared for the bin by 'sumw2' rather than wgt^2

Implements RooAbsData.

Definition at line 1290 of file RooDataHist.cxx.

◆ add() [4/4]

virtual void RooDataHist::add ( const RooArgSet row,
Double_t  wgt = 1.0 
)
inlinevirtual

Definition at line 67 of file RooDataHist.h.

◆ adjustBinning()

void RooDataHist::adjustBinning ( const RooArgList vars,
const TH1 href,
Int_t offset = 0 
)
protected

Adjust binning specification on first and optionally second and third observable to binning in given reference TH1.

Used by constructors that import data from an external TH1. Both the variables in vars and in this RooDataHist are adjusted.

Parameters
Listwith variables that are supposed to have their binning adjusted.
Referencehistogram that dictates the binning
offsetIf not nullptr, a possible bin count offset for the axes x,y,z is saved here as Int_t[3]

Definition at line 642 of file RooDataHist.cxx.

◆ binVolume() [1/2]

Double_t RooDataHist::binVolume ( ) const
inline

Definition at line 112 of file RooDataHist.h.

◆ binVolume() [2/2]

Double_t RooDataHist::binVolume ( const RooArgSet bin)

Return the volume of the bin enclosing coordinates 'coord'.

Definition at line 1820 of file RooDataHist.cxx.

◆ cacheClone()

RooAbsData * RooDataHist::cacheClone ( const RooAbsArg newCacheOwner,
const RooArgSet newCacheVars,
const char *  newName = 0 
)
protectedvirtual

Construct a clone of this dataset that contains only the cached variables.

Implements RooAbsData.

Definition at line 864 of file RooDataHist.cxx.

◆ cacheValidEntries()

void RooDataHist::cacheValidEntries ( )
protected

Cache the datahist entries with bin centers that are inside/outside the current observable definitio.

Definition at line 1918 of file RooDataHist.cxx.

◆ calcTreeIndex()

Int_t RooDataHist::calcTreeIndex ( ) const
protected

Calculate the index for the weights array corresponding to to the bin enclosing the current coordinates of the internal argset.

Definition at line 978 of file RooDataHist.cxx.

◆ calculatePartialBinVolume()

void RooDataHist::calculatePartialBinVolume ( const RooArgSet dimSet) const
protected

Fill the transient cache with partial bin volumes with up-to-date values for the partial volume specified by observables 'dimSet'.

Definition at line 1641 of file RooDataHist.cxx.

◆ checkBinBounds()

void RooDataHist::checkBinBounds ( ) const
protected

Definition at line 762 of file RooDataHist.cxx.

◆ Clone()

virtual TObject * RooDataHist::Clone ( const char *  newname = "") const
inlinevirtual

Make a clone of an object using the Streamer facility.

If newname is specified, this will be the name of the new object.

Reimplemented from TNamed.

Definition at line 56 of file RooDataHist.h.

◆ dump2()

void RooDataHist::dump2 ( )

Debug stuff, should go...

Definition at line 995 of file RooDataHist.cxx.

◆ emptyClone()

virtual RooAbsData * RooDataHist::emptyClone ( const char *  newName = 0,
const char *  newTitle = 0,
const RooArgSet vars = 0,
const char *  = 0 
) const
inlinevirtual

Implements RooAbsData.

Definition at line 61 of file RooDataHist.h.

◆ get() [1/3]

virtual const RooArgSet * RooDataHist::get ( ) const
inlinevirtual

Reimplemented from RooAbsData.

Definition at line 79 of file RooDataHist.h.

◆ get() [2/3]

const RooArgSet * RooDataHist::get ( const RooArgSet coord) const
virtual

Return a RooArgSet with center coordinates of the bin enclosing the point 'coord'.

Definition at line 1809 of file RooDataHist.cxx.

◆ get() [3/3]

const RooArgSet * RooDataHist::get ( Int_t  masterIdx) const
virtual

Return an argset with the bin center coordinates for bin sequential number 'masterIdx'.

For iterative use.

Reimplemented from RooAbsData.

Definition at line 1791 of file RooDataHist.cxx.

◆ get_curIndex()

Int_t RooDataHist::get_curIndex ( ) const
inlineprotected

Definition at line 181 of file RooDataHist.h.

◆ get_curSumW2()

Double_t RooDataHist::get_curSumW2 ( ) const
inlineprotected

Definition at line 179 of file RooDataHist.h.

◆ get_curWeight()

Double_t RooDataHist::get_curWeight ( ) const
inlineprotected

Definition at line 176 of file RooDataHist.h.

◆ get_curWgtErrHi()

Double_t RooDataHist::get_curWgtErrHi ( ) const
inlineprotected

Definition at line 178 of file RooDataHist.h.

◆ get_curWgtErrLo()

Double_t RooDataHist::get_curWgtErrLo ( ) const
inlineprotected

Definition at line 177 of file RooDataHist.h.

◆ get_errHi()

Double_t RooDataHist::get_errHi ( const Int_t idx) const
inlineprotected

Definition at line 173 of file RooDataHist.h.

◆ get_errLo()

Double_t RooDataHist::get_errLo ( const Int_t idx) const
inlineprotected

Definition at line 172 of file RooDataHist.h.

◆ get_sumw2()

Double_t RooDataHist::get_sumw2 ( const Int_t idx) const
inlineprotected

Definition at line 174 of file RooDataHist.h.

◆ get_wgt()

Double_t RooDataHist::get_wgt ( const Int_t idx) const
inlineprotected

Definition at line 171 of file RooDataHist.h.

◆ getIndex()

Int_t RooDataHist::getIndex ( const RooArgSet coord,
Bool_t  fast = kFALSE 
)

Definition at line 960 of file RooDataHist.cxx.

◆ getWeightBatch()

virtual RooSpan< const double > RooDataHist::getWeightBatch ( std::size_t  first,
std::size_t  len 
) const
inlinevirtual

Return event weights of all events in range [first, first+len).

If no contiguous structure of weights is stored, an empty batch can be returned. This indicates that the weight is constant. Use weight() to retrieve it.

Implements RooAbsData.

Definition at line 94 of file RooDataHist.h.

◆ importDHistSet()

void RooDataHist::importDHistSet ( const RooArgList vars,
RooCategory indexCat,
std::map< std::string, RooDataHist * >  dmap,
Double_t  initWgt 
)
protected

Import data from given set of TH1/2/3 into this RooDataHist.

The category indexCat labels the sources in the constructed RooDataHist. The stl map provides the mapping between the indexCat state labels and the import source

Definition at line 538 of file RooDataHist.cxx.

◆ importTH1()

void RooDataHist::importTH1 ( const RooArgList vars,
const TH1 histo,
Double_t  initWgt,
Bool_t  doDensityCorrection 
)
protected

Import data from given TH1/2/3 into this RooDataHist.

Definition at line 374 of file RooDataHist.cxx.

◆ importTH1Set()

void RooDataHist::importTH1Set ( const RooArgList vars,
RooCategory indexCat,
std::map< std::string, TH1 * >  hmap,
Double_t  wgt,
Bool_t  doDensityCorrection 
)
protected

Import data from given set of TH1/2/3 into this RooDataHist.

The category indexCat labels the sources in the constructed RooDataHist. The stl map provides the mapping between the indexCat state labels and the import source

Definition at line 441 of file RooDataHist.cxx.

◆ initialize()

void RooDataHist::initialize ( const char *  binningName = 0,
Bool_t  fillTree = kTRUE 
)
protected

Initialization procedure: allocate weights array, calculate multipliers needed for N-space to 1-dim array jump table, and fill the internal tree with all bin center coordinates.

Definition at line 670 of file RooDataHist.cxx.

◆ interpolateDim()

Double_t RooDataHist::interpolateDim ( RooRealVar dim,
const RooAbsBinning binning,
Double_t  xval,
Int_t  intOrder,
Bool_t  correctForBinSize,
Bool_t  cdfBoundaries 
)
protected

Perform boundary safe 'intOrder'-th interpolation of weights in dimension 'dim' at current value 'xval'.

Definition at line 1219 of file RooDataHist.cxx.

◆ isNonPoissonWeighted()

Bool_t RooDataHist::isNonPoissonWeighted ( ) const
virtual

Returns true if datasets contains entries with a non-integer weight.

Reimplemented from RooAbsData.

Definition at line 1960 of file RooDataHist.cxx.

◆ isWeighted()

virtual Bool_t RooDataHist::isWeighted ( ) const
inlinevirtual

Reimplemented from RooAbsData.

Definition at line 88 of file RooDataHist.h.

◆ numEntries()

Int_t RooDataHist::numEntries ( ) const
virtual

Return the number of bins.

Reimplemented from RooAbsData.

Definition at line 1692 of file RooDataHist.cxx.

◆ operator=()

RooDataHist & RooDataHist::operator= ( const RooDataHist )
delete

◆ plotOn() [1/4]

RooPlot * RooAbsData::plotOn ( RooPlot frame,
const RooCmdArg arg1 = RooCmdArg::none(),
const RooCmdArg arg2 = RooCmdArg::none(),
const RooCmdArg arg3 = RooCmdArg::none(),
const RooCmdArg arg4 = RooCmdArg::none(),
const RooCmdArg arg5 = RooCmdArg::none(),
const RooCmdArg arg6 = RooCmdArg::none(),
const RooCmdArg arg7 = RooCmdArg::none(),
const RooCmdArg arg8 = RooCmdArg::none() 
) const
virtual

Calls RooPlot* plotOn(RooPlot* frame, const RooLinkedList& cmdList) const ;.

Reimplemented from RooAbsData.

Definition at line 125 of file RooAbsData.cxx.

◆ plotOn() [2/4]

RooPlot * RooAbsData::plotOn ( RooPlot frame,
const RooLinkedList argList 
) const
virtual

Plot dataset on specified frame.

By default an unbinned dataset will use the default binning of the target frame. A binned dataset will by default retain its intrinsic binning.

The following optional named arguments can be used to modify the default behavior

Data representation options
Asymmetry(const RooCategory& c) Show the asymmetry of the data in given two-state category [F(+)-F(-)] / [F(+)+F(-)]. Category must have two states with indices -1 and +1 or three states with indices -1,0 and +1.
Efficiency(const RooCategory& c) Show the efficiency F(acc)/[F(acc)+F(rej)]. Category must have two states with indices 0 and 1
DataError(RooAbsData::EType) Select the type of error drawn:
  • Auto(default) results in Poisson for unweighted data and SumW2 for weighted data
  • Poisson draws asymmetric Poisson confidence intervals.
  • SumW2 draws symmetric sum-of-weights error ( sum(w)^2/sum(w^2) )
  • None draws no error bars
Binning(int nbins, double xlo, double xhi) Use specified binning to draw dataset
Binning(const RooAbsBinning&) Use specified binning to draw dataset
Binning(const char* name) Use binning with specified name to draw dataset
RefreshNorm(Bool_t flag) Force refreshing for PDF normalization information in frame. If set, any subsequent PDF will normalize to this dataset, even if it is not the first one added to the frame. By default only the 1st dataset added to a frame will update the normalization information
Rescale(Double_t f) Rescale drawn histogram by given factor
CutRange(const char*) Apply cuts to dataset.
Note
This often requires passing the normalisation when plotting the PDF because RooFit does not save how many events were being plotted (it will only work for cutting slices out of uniformly distributed variables).
data->plotOn(frame01, CutRange("SB1"));
const double nData = data->sumEntries("", "SB1");
// Make clear that the target normalisation is nData. The enumerator NumEvent
// is needed to switch between relative and absolute scaling.
model.plotOn(frame01, Normalization(nData, RooAbsReal::NumEvent),
ProjectionRange("SB1"));
RooCmdArg ProjectionRange(const char *rangeName)
RooCmdArg CutRange(const char *rangeName)
RooCmdArg Normalization(Double_t scaleFactor)
Histogram drawing options
DrawOption(const char* opt) Select ROOT draw option for resulting TGraph object
LineStyle(Int_t style) Select line style by ROOT line style code, default is solid
LineColor(Int_t color) Select line color by ROOT color code, default is black
LineWidth(Int_t width) Select line with in pixels, default is 3
MarkerStyle(Int_t style) Select the ROOT marker style, default is 21
MarkerColor(Int_t color) Select the ROOT marker color, default is black
MarkerSize(Double_t size) Select the ROOT marker size
FillStyle(Int_t style) Select fill style, default is filled.
FillColor(Int_t color) Select fill color by ROOT color code
XErrorSize(Double_t frac)

Select size of X error bar as fraction of the bin width, default is 1

Misc. other options
Name(const chat* name) Give curve specified name in frame. Useful if curve is to be referenced later
Invisible() Add curve to frame, but do not display. Useful in combination AddTo()
AddTo(const char* name, double_t wgtSelf, double_t wgtOther) Add constructed histogram to already existing histogram with given name and relative weight factors

Reimplemented from RooAbsData.

Definition at line 131 of file RooAbsData.cxx.

◆ plotOn() [3/4]

RooPlot * RooAbsData::plotOn ( RooPlot frame,
PlotOpt  o 
) const
virtual

Create and fill a histogram of the frame's variable and append it to the frame.

The frame variable must be one of the data sets dimensions.

The plot range and the number of plot bins is determined by the parameters of the plot variable of the frame (RooAbsReal::setPlotRange(), RooAbsReal::setPlotBins())

The optional cut string expression can be used to select the events to be plotted. The cut specification may refer to any variable contained in the data set

The drawOptions are passed to the TH1::Draw() method

Reimplemented from RooAbsData.

Definition at line 250 of file RooAbsData.cxx.

◆ plotOn() [4/4]

RooPlot * RooDataHist::plotOn ( RooPlot frame,
PlotOpt  o 
) const
virtual

Back end function to plotting functionality.

Plot RooDataHist on given frame in mode specified by plot options 'o'. The main purpose of this function is to match the specified binning on 'o' to the internal binning of the plot observable in this RooDataHist.

Reimplemented from RooAbsData.

Definition at line 1011 of file RooDataHist.cxx.

◆ printArgs()

void RooDataHist::printArgs ( std::ostream &  os) const
virtual

Print argument of dataset, i.e. the observable names.

Reimplemented from RooPrintable.

Definition at line 1897 of file RooDataHist.cxx.

◆ printMultiline()

void RooDataHist::printMultiline ( std::ostream &  os,
Int_t  content,
Bool_t  verbose = kFALSE,
TString  indent = "" 
) const
virtual

Print the details on the dataset contents.

Reimplemented from RooAbsData.

Definition at line 1974 of file RooDataHist.cxx.

◆ printValue()

void RooDataHist::printValue ( std::ostream &  os) const
virtual

Print value of the dataset, i.e. the sum of weights contained in the dataset.

Reimplemented from RooPrintable.

Definition at line 1886 of file RooDataHist.cxx.

◆ reduceEng()

RooAbsData * RooDataHist::reduceEng ( const RooArgSet varSubset,
const RooFormulaVar cutVar,
const char *  cutRange = 0,
std::size_t  nStart = 0,
std::size_t  nStop = std::numeric_limits<std::size_t>::max(),
Bool_t  copyCache = kTRUE 
)
protectedvirtual

Implementation of RooAbsData virtual method that drives the RooAbsData::reduce() methods.

Implements RooAbsData.

Definition at line 882 of file RooDataHist.cxx.

◆ removeSelfFromDir()

void RooDataHist::removeSelfFromDir ( )
inline

Definition at line 141 of file RooDataHist.h.

◆ reset()

void RooDataHist::reset ( )
virtual

Reset all bin weights to zero.

Reimplemented from RooAbsData.

Definition at line 1765 of file RooDataHist.cxx.

◆ set() [1/3]

void RooDataHist::set ( const RooArgSet row,
Double_t  weight,
Double_t  wgtErr = -1 
)

Set the weight and weight error of the bin enclosing the coordinates given by row.

Definition at line 1351 of file RooDataHist.cxx.

◆ set() [2/3]

void RooDataHist::set ( const RooArgSet row,
Double_t  wgt,
Double_t  wgtErrLo,
Double_t  wgtErrHi 
)

Set the weight and errors of the bin enclosing the coordinates given by row.

Associate errors [wgtErrLo,wgtErrHi] with the event weight on this bin.

Definition at line 1312 of file RooDataHist.cxx.

◆ set() [3/3]

void RooDataHist::set ( Double_t  wgt,
Double_t  wgtErr = -1 
)

Set the weight and weight error of the bin enclosing the current (i.e.

last-used) coordinates.

Definition at line 1330 of file RooDataHist.cxx.

◆ setAllWeights()

void RooDataHist::setAllWeights ( Double_t  value)
protected

Set all the event weight of all bins to the specified value.

Definition at line 1831 of file RooDataHist.cxx.

◆ SetName()

void RooDataHist::SetName ( const char *  name)
virtual

Change the name of the RooDataHist.

Reimplemented from TNamed.

Definition at line 1864 of file RooDataHist.cxx.

◆ SetNameTitle()

void RooDataHist::SetNameTitle ( const char *  name,
const char *  title 
)
virtual

Change the title of this RooDataHist.

Reimplemented from TNamed.

Definition at line 1875 of file RooDataHist.cxx.

◆ sliceIterator()

TIterator * RooDataHist::sliceIterator ( RooAbsArg sliceArg,
const RooArgSet otherArgs 
)

Create an iterator over all bins in a slice defined by the subset of observables listed in sliceArg.

The position of the slice is given by otherArgs

Definition at line 1846 of file RooDataHist.cxx.

◆ sum() [1/3]

Double_t RooDataHist::sum ( Bool_t  correctForBinSize,
Bool_t  inverseBinCor = kFALSE 
) const

Return the sum of the weights of all hist bins.

If correctForBinSize is specified, the sum of weights is multiplied by the N-dimensional bin volume, making the return value the integral over the function represented by this histogram

Definition at line 1428 of file RooDataHist.cxx.

◆ sum() [2/3]

Double_t RooDataHist::sum ( const RooArgSet sumSet,
const RooArgSet sliceSet,
Bool_t  correctForBinSize,
Bool_t  inverseBinCor,
const std::map< const RooAbsArg *, std::pair< Double_t, Double_t > > &  ranges 
)

Return the sum of the weights of a multi-dimensional slice of the histogram by summing only over the dimensions specified in sumSet.

The coordinates of all other dimensions are fixed to those given in sliceSet

If correctForBinSize is specified, the sum of weights is multiplied by the M-dimensional bin volume, (M = N(sumSet)), or the fraction of it that falls inside the range rangeName, making the return value the integral over the function represented by this histogram.

If correctForBinSize is not specified, the weights are multiplied by the fraction of the bin volume that falls inside the range, i.e. a factor of binVolumeInRange/totalBinVolume.

Definition at line 1551 of file RooDataHist.cxx.

◆ sum() [3/3]

Double_t RooDataHist::sum ( const RooArgSet sumSet,
const RooArgSet sliceSet,
Bool_t  correctForBinSize,
Bool_t  inverseBinCor = kFALSE 
)

Return the sum of the weights of a multi-dimensional slice of the histogram by summing only over the dimensions specified in sumSet.

The coordinates of all other dimensions are fixed to those given in sliceSet

If correctForBinSize is specified, the sum of weights is multiplied by the M-dimensional bin volume, (M = N(sumSet)), making the return value the integral over the function represented by this histogram

Definition at line 1471 of file RooDataHist.cxx.

◆ sumEntries() [1/2]

Double_t RooDataHist::sumEntries ( ) const
virtual

Implements RooAbsData.

Definition at line 1701 of file RooDataHist.cxx.

◆ sumEntries() [2/2]

Double_t RooDataHist::sumEntries ( const char *  cutSpec,
const char *  cutRange = 0 
) const
virtual

Return the sum of weights in all entries matching cutSpec (if specified) and in named range cutRange (if specified) Return the.

Implements RooAbsData.

Definition at line 1724 of file RooDataHist.cxx.

◆ valid()

Bool_t RooDataHist::valid ( ) const
virtual

Return true if currently loaded coordinate is considered valid within the current range definitions of all observables.

Reimplemented from RooAbsData.

Definition at line 1945 of file RooDataHist.cxx.

◆ weight() [1/2]

virtual Double_t RooDataHist::weight ( ) const
inlinevirtual

Implements RooAbsData.

Definition at line 106 of file RooDataHist.h.

◆ weight() [2/2]

Double_t RooDataHist::weight ( const RooArgSet bin,
Int_t  intOrder = 1,
Bool_t  correctForBinSize = kFALSE,
Bool_t  cdfBoundaries = kFALSE,
Bool_t  oneSafe = kFALSE 
)

Return the weight at given coordinates with optional interpolation.

If intOrder is zero, the weight for the bin enclosing the coordinates contained in 'bin' is returned. For higher values, the result is interpolated in the real dimensions of the dataset

Definition at line 1058 of file RooDataHist.cxx.

◆ weightError() [1/2]

void RooDataHist::weightError ( Double_t lo,
Double_t hi,
ErrorType  etype = Poisson 
) const
virtual

Return the error on current weight.

Reimplemented from RooAbsData.

Definition at line 1167 of file RooDataHist.cxx.

◆ weightError() [2/2]

virtual Double_t RooDataHist::weightError ( ErrorType  etype = Poisson) const
inlinevirtual

Return error on current weight (dummy implementation returning zero)

Reimplemented from RooAbsData.

Definition at line 119 of file RooDataHist.h.

◆ weightSquared()

Double_t RooDataHist::weightSquared ( ) const
virtual

Implements RooAbsData.

Definition at line 1044 of file RooDataHist.cxx.

Friends And Related Function Documentation

◆ RooAbsCachedPdf

friend class RooAbsCachedPdf
friend

Definition at line 145 of file RooDataHist.h.

◆ RooAbsCachedReal

friend class RooAbsCachedReal
friend

Definition at line 146 of file RooDataHist.h.

◆ RooAbsOptTestStatistic

friend class RooAbsOptTestStatistic
friend

Definition at line 148 of file RooDataHist.h.

◆ RooDataHistSliceIter

friend class RooDataHistSliceIter
friend

Definition at line 147 of file RooDataHist.h.

Member Data Documentation

◆ _arrSize

Int_t RooDataHist::_arrSize
protected

Definition at line 183 of file RooDataHist.h.

◆ _binbounds

std::vector<std::vector<Double_t> > RooDataHist::_binbounds
mutableprotected

List of used binnings associated with lvalues.

Definition at line 206 of file RooDataHist.h.

◆ _binv

Double_t* RooDataHist::_binv
protected

Definition at line 190 of file RooDataHist.h.

◆ _binValid

Bool_t* RooDataHist::_binValid
protected

Definition at line 193 of file RooDataHist.h.

◆ _cache_sum

Double_t RooDataHist::_cache_sum {0.}
mutableprotected

Is cache sum valid.

Definition at line 209 of file RooDataHist.h.

◆ _cache_sum_valid

Int_t RooDataHist::_cache_sum_valid {0}
mutableprotected

list of bin bounds per dimension

Definition at line 208 of file RooDataHist.h.

◆ _curIndex

Int_t RooDataHist::_curIndex {0}
mutableprotected

Definition at line 200 of file RooDataHist.h.

◆ _curSumW2

Double_t RooDataHist::_curSumW2 {0.}
mutableprotected

Definition at line 198 of file RooDataHist.h.

◆ _curVolume

Double_t RooDataHist::_curVolume {0.}
mutableprotected

Definition at line 199 of file RooDataHist.h.

◆ _curWeight

Double_t RooDataHist::_curWeight {0.}
mutableprotected

Valid bins with current range definition.

Definition at line 195 of file RooDataHist.h.

◆ _curWgtErrHi

Double_t RooDataHist::_curWgtErrHi {0.}
mutableprotected

Definition at line 197 of file RooDataHist.h.

◆ _curWgtErrLo

Double_t RooDataHist::_curWgtErrLo {0.}
mutableprotected

Definition at line 196 of file RooDataHist.h.

◆ _errHi

Double_t* RooDataHist::_errHi
protected

Definition at line 188 of file RooDataHist.h.

◆ _errLo

Double_t* RooDataHist::_errLo
protected

Definition at line 187 of file RooDataHist.h.

◆ _idxMult

std::vector<Int_t> RooDataHist::_idxMult
protected

Definition at line 184 of file RooDataHist.h.

◆ _lvbins

std::vector<const RooAbsBinning*> RooDataHist::_lvbins
protected

List of observables casted as RooAbsLValue.

Definition at line 205 of file RooDataHist.h.

◆ _lvvars

std::vector<RooAbsLValue*> RooDataHist::_lvvars
protected

Cache manager for arrays of partial bin volumes.

Definition at line 204 of file RooDataHist.h.

◆ _pbinv

std::vector<Double_t>* RooDataHist::_pbinv
mutableprotected

Definition at line 202 of file RooDataHist.h.

◆ _pbinvCacheMgr

RooCacheManager<std::vector<Double_t> > RooDataHist::_pbinvCacheMgr
mutableprotected

Partial bin volume array.

Definition at line 203 of file RooDataHist.h.

◆ _realVars

RooArgSet RooDataHist::_realVars
protected

Definition at line 192 of file RooDataHist.h.

◆ _sumw2

Double_t* RooDataHist::_sumw2
protected

Definition at line 189 of file RooDataHist.h.

◆ _wgt

Double_t* RooDataHist::_wgt
protected

Definition at line 186 of file RooDataHist.h.

Libraries for RooDataHist:
[legend]

The documentation for this class was generated from the following files: