66 Int_t overBins = addOverflow ? 2 : 0;
68 for (
Int_t i = 0; i < ndim; ++i) {
69 fSizes[ndim - i - 1] =
fSizes[ndim - i] * (nbins[ndim - i - 1] + overBins);
83 bin +=
fSizes[d + 1] * idx[d];
102 template <
typename T>
106 fData(data),
fSizes(sizes) {}
114 if (!fData)
return T();
115 R__ASSERT(
fSizes == 0 &&
"Element operator can only be used on non-array element. Missing an operator[] level?");
125 template <
typename T>
132 fNumData(), fData() {
151 new (fData)
T[fNumData]();
170 if (!fData)
return T();
171 return fData[linidx];
174 if (!fData) fData =
new T[fNumData]();
175 return fData[linidx];
179 if (!fData)
return 0.;
180 return fData[linidx];
183 if (!fData) fData =
new T[fNumData]();
184 fData[linidx] = (
T) value;
187 if (!fData) fData =
new T[fNumData]();
188 fData[linidx] += (
T) value;
210 #endif // ROOT_TNDArray TNDArrayT(Int_t ndim, const Int_t *nbins, bool addOverflow=false)
virtual Double_t AtAsDouble(ULong64_t linidx) const =0
Buffer base class used for serializing objects.
void SetAsDouble(ULong64_t linidx, Double_t value)
virtual void SetAsDouble(ULong64_t linidx, Double_t value)=0
Long64_t GetNbins() const
TNDArray & operator=(const TNDArray &)
void Init(Int_t ndim, const Int_t *nbins, bool addOverflow=false)
#define ClassDef(name, id)
virtual void Reset(Option_t *option="")=0
void Streamer(TBuffer &R__b)
TNDArray(Int_t ndim, const Int_t *nbins, bool addOverflow=false)
T At(const Int_t *idx) const
void Reset(Option_t *="")
#define ClassDefNV(name, id)
void AddAt(ULong64_t linidx, Double_t value)
The ROOT global object gROOT contains a list of all defined classes.
TNDArrayRef< T > operator[](Int_t idx) const
TNDArrayRef(const T *data, const Long64_t *sizes)
unsigned long long ULong64_t
Double_t AtAsDouble(ULong64_t linidx) const
virtual void Init(Int_t ndim, const Int_t *nbins, bool addOverflow=false)
Mother of all ROOT objects.
Int_t GetNdimensions() const
Long64_t GetBin(const Int_t *idx) const
Long64_t GetCellSize(Int_t dim) const
T At(ULong64_t linidx) const
virtual void AddAt(ULong64_t linidx, Double_t value)=0