22 struct CounterRange_t {
39 ~THnBinIter() {
delete [] fCounter; }
42 Int_t GetCoord(
Int_t dim)
const {
return fCounter[dim].i; }
44 THnBinIter(
const THnBinIter&);
51 CounterRange_t* fCounter;
60 ROOT::Internal::THnBaseBinIter(respectAxisRange),
61 fNdimensions(dim), fIndex(-1), fArray(arr) {
62 fCounter =
new CounterRange_t[dim]();
63 for (
Int_t i = 0; i < dim; ++i) {
65 fCounter[i].len = axis->
GetNbins() + 2;
68 fCounter[i].first = 0;
69 fCounter[i].last = fCounter[i].len - 1;
73 fHaveSkippedBin =
kTRUE;
76 if (min == 0 && max == 0) {
83 fCounter[i].first = min;
84 fCounter[i].last = max;
86 fIndex += fCounter[i].first * fCounter[i].cellSize;
89 --fCounter[dim - 1].i;
97 if (fNdimensions < 0)
return -1;
98 ++fCounter[fNdimensions - 1].i;
101 for (
Int_t d = fNdimensions - 1; d > 0 && fCounter[d].i > fCounter[d].last; --d) {
103 Int_t skippedCells = fCounter[d].len - (fCounter[d].last + 1);
104 skippedCells += fCounter[d].first;
105 fIndex += skippedCells * fCounter[d].cellSize;
106 fCounter[d].i = fCounter[d].first;
109 if (fCounter[0].i > fCounter[0].last) {
114 for (
Int_t d = 0; d < fNdimensions; ++d) {
115 coord[d] = fCounter[d].i;
187 THnBase(name, title, dim, nbins, xmin, xmax),
188 fSumw2(dim, nbins,
kTRUE ),
ROOT::Internal::THnBaseBinIter * CreateIter(Bool_t respectAxisRange) const
Create an iterator over all bins. Public interface is THnIter.
Bool_t GetCalculateErrors() const
Int_t GetFirst() const
Return first bin on the axis i.e.
Namespace for new ROOT classes and functions.
Bool_t TestBit(UInt_t f) const
virtual Double_t AtAsDouble(ULong64_t linidx) const =0
TObject * At(Int_t idx) const
void Init(Int_t ndim, const Int_t *nbins, bool addOverflow=false)
virtual void Reset(Option_t *option="")=0
Long64_t GetNbins() const
void Sumw2()
Enable calculation of errors.
TNDArrayT< Double_t > fSumw2
void InitStorage(Int_t *nbins, Int_t chunkSize)
Initialize the storage of a histogram created via Init()
void AllocCoordBuf() const
Create the coordinate buffer.
Int_t GetLast() const
Return last bin on the axis i.e.
Class to manage histogram axis.
T At(const Int_t *idx) const
void Reset(Option_t *="")
Iterator over THnBase bins (internal implementation).
Multidimensional histogram.
virtual void Init(Int_t ndim, const Int_t *nbins, bool addOverflow=false)
Int_t GetNdimensions() const
Binding & operator=(OUT(*fun)(void))
virtual ~THn()
Destruct a THn.
TObjArray * GetListOfAxes()
Long64_t GetCellSize(Int_t dim) const
Multidimensional histogram base.
void Reset(Option_t *option="")
Reset the contents of a THn.
virtual const TNDArray & GetArray() const =0