#ifndef ROO_BINNING
#define ROO_BINNING
#include "Rtypes.h"
#include "TList.h"
#include "RooDouble.h"
#include "RooAbsBinning.h"
#include "RooNumber.h"
#include <vector>
class RooAbsPdf;
class RooRealVar;
class RooBinning : public RooAbsBinning {
public:
RooBinning(Double_t xlo = -RooNumber::infinity(), Double_t xhi = RooNumber::infinity(), const char* name = 0);
RooBinning(Int_t nBins, Double_t xlo, Double_t xhi, const char* name = 0);
RooBinning(Int_t nBins, const Double_t* boundaries, const char* name = 0);
RooBinning(const RooBinning& other, const char* name = 0);
RooAbsBinning* clone(const char* name = 0) const { return new RooBinning(*this,name?name:GetName()); }
~RooBinning();
virtual Int_t numBoundaries() const {
return _nbins+1;
}
virtual Int_t binNumber(Double_t x) const;
virtual Int_t rawBinNumber(Double_t x) const;
virtual Double_t nearestBoundary(Double_t x) const;
virtual void setRange(Double_t xlo, Double_t xhi);
virtual Double_t lowBound() const {
return _xlo;
}
virtual Double_t highBound() const {
return _xhi;
}
virtual Double_t averageBinWidth() const {
return (highBound() - lowBound()) / numBins();
}
virtual Double_t* array() const;
virtual Double_t binCenter(Int_t bin) const;
virtual Double_t binWidth(Int_t bin) const;
virtual Double_t binLow(Int_t bin) const;
virtual Double_t binHigh(Int_t bin) const;
Bool_t addBoundary(Double_t boundary);
void addBoundaryPair(Double_t boundary, Double_t mirrorPoint = 0);
void addUniform(Int_t nBins, Double_t xlo, Double_t xhi);
Bool_t removeBoundary(Double_t boundary);
Bool_t hasBoundary(Double_t boundary);
protected:
Bool_t binEdges(Int_t bin, Double_t& xlo, Double_t& xhi) const;
void updateBinCount();
Double_t _xlo;
Double_t _xhi;
Bool_t _ownBoundLo;
Bool_t _ownBoundHi;
Int_t _nbins;
std::vector<Double_t> _boundaries;
mutable Double_t* _array;
mutable Int_t _blo;
ClassDef(RooBinning,3)
};
#endif