184fIsEmpty(nullptr), fCompletelyInside(nullptr), fBins(nullptr) {
228 delete[]
newth2p.fCompletelyInside;
234 for (
int i = 0; i<
fNCells; i++) {
246 Error(
"Copy",
"Error cloning the TH2Poly bin list");
251 for (
auto bin : *(
newth2p.fBins)) {
276 if (!
poly)
return nullptr;
278 if (
fBins ==
nullptr) {
372 Error(
"Add",
"Attempt to add histograms with different number of bins");
386 Error(
"Add",
"Attempt to add histograms with different bin limits");
412 if (
h1p->GetNormFactor() != 0)
413 factor =
h1p->GetNormFactor() /
h1p->GetSumOfWeights();
414 for (bin = 0; bin <
fNcells; bin++) {
418 Double_t esq = factor * factor *
h1p->GetBinErrorSqUnchecked(bin);
429 if (i == 1)
s1[i] +=
c1 *
c1 *
s2[i];
469 for (
int i =
nl; i <=
nr; i++) {
472 for (
int j =
mb;
j <= mt;
j++) {
535 for (
int i = 0; i<
fNCells; i++) {
544 while((obj = next())){
559 while ((obj = next())) {
584 while ((obj = next())) {
617 if (overflow != -5)
return overflow;
637 while ((obj=next())) {
679 if (overflow != -5) {
707 while ((obj=next())) {
749 while ((obj = next())) {
798 while ((obj = next())) {
806 while ((obj = next())) {
866 Fatal(
"GetNumberOfBins",
"Object has an invalid number of bins");
897 if (bin <= 0)
return "";
907 if (bin <= 0)
return "";
927 while ((obj=next())) {
951 while ((obj=next())) {
975 while ((obj=next())) {
999 while ((obj=next())) {
1001 c =
b->GetContent();
1038 y[2] =
y[1] +
a / 2.0;
1044 y[5] =
y[4] -
a/2.0;
1069 x[1] =
x[0] +
a/2.0;
1073 x[3] =
x[2] +
a/2.0;
1091 Error(
"Honeycomb",
"Unknown option");
1174 while ((
g = (
TGraph*) next())) {
1198 for (
int counter = 0; counter < (
bn-1); counter++) {
1202 if (
p0L &&
p1L)
continue;
1205 if (
p0R &&
p1R)
continue;
1208 if (
p0T &&
p1T)
continue;
1211 if (
p0B &&
p1B)
continue;
1309 Warning(
"Merge",
"An issue was encountered during the merge operation.");
1335 while (
auto obj = next()) {
1345 out <<
" " <<
hname <<
"->SetBinContent(" << bin <<
"," <<
bc <<
");\n";
1353 out <<
" " <<
hname <<
"->SetBinError(" << bin <<
"," <<
be <<
");\n";
1404 if (!
fBins)
return false;
1406 if (!bin)
return false;
1486 while ((
g = (
TGraph*) next())) {
1521 while ((
g = (
TGraph*) next())) {
1557 while ((
g = (
TGraph*) next())) {
1593 while ((
g = (
TGraph*) next())) {
1629 while ((
g = (
TGraph*) next())) {
1649 in =
g->IsInside(
x,
y);
1669 Error(
"Add",
"Not implemented for TH2Poly");
1677 Error(
"Add",
"Not implemented for TH2Poly");
1685 Error(
"Divide",
"Not implemented for TH2Poly");
1693 Error(
"Multiply",
"Not implemented for TH2Poly");
1700 Error(
"ComputeIntegral",
"Not implemented for TH2Poly");
1707 Error(
"FFT",
"Not implemented for TH2Poly");
1714 Error(
"GetAsymmetry",
"Not implemented for TH2Poly");
1721 Error(
"Interpolate",
"Not implemented for TH2Poly");
1728 Error(
"AddBinContent",
"Not implemented for TH2Poly");
1734 Error(
"AddBinContent",
"Not implemented for TH2Poly");
int Int_t
Signed integer 4 bytes (int)
const char Option_t
Option string (const char)
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
Option_t Option_t TPoint TPoint const char x2
Option_t Option_t TPoint TPoint const char x1
Option_t Option_t TPoint TPoint const char y2
Option_t Option_t TPoint TPoint const char y1
void Set(Int_t n) override
Set size of this array to n doubles.
virtual void Set(Int_t nbins, Double_t xmin, Double_t xmax)
Initialize axis with fix bins.
Collection abstract base class.
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
TObject * Clone(const char *newname="") const override
Make a clone of an collection using the Streamer facility.
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
A TGraph is an object made of two arrays X and Y with npoints each.
TH1 is the base class of all histogram classes in ROOT.
Double_t * fBuffer
[fBufferSize] entry buffer
@ kNstat
Size of statistics data (up to TProfile3D)
Int_t fNcells
Number of bins(1D), cells (2D) +U/Overflows.
virtual void GetStats(Double_t *stats) const
fill the array stats from the contents of this histogram The array stats must be correctly dimensione...
void SetTitle(const char *title) override
Change/set the title.
Double_t fTsumw
Total Sum of weights.
Double_t fTsumw2
Total Sum of squares of weights.
Double_t fTsumwx2
Total Sum of weight*X*X.
@ kIsNotW
Histogram is forced to be not weighted even when the histogram is filled with weighted.
Double_t fMaximum
Maximum value for plotting.
TString ProvideSaveName(Option_t *option, Bool_t testfdir=kFALSE)
Provide variable name for histogram for saving as primitive Histogram pointer has by default the hist...
Int_t fDimension
! Histogram dimension (1, 2 or 3 dim)
virtual void SetContent(const Double_t *content)
Replace bin contents by the contents of array content.
virtual void SavePrimitiveHelp(std::ostream &out, const char *hname, Option_t *option="")
Helper function for the SavePrimitive functions from TH1 or classes derived from TH1,...
Double_t fMinimum
Minimum value for plotting.
virtual Double_t GetEntries() const
Return the current number of entries.
void SetName(const char *name) override
Change the name of this histogram.
virtual void ResetStats()
Reset the statistics including the number of entries and replace with values calculated from bin cont...
virtual void SetBinErrorOption(EBinErrorOpt type)
Double_t fEntries
Number of entries.
@ kNormal
Errors with Normal (Wald) approximation: errorUp=errorLow= sqrt(N)
TAxis fXaxis
X axis descriptor.
TArrayD fSumw2
Array of sum of squares of weights.
TAxis fYaxis
Y axis descriptor.
virtual void Sumw2(Bool_t flag=kTRUE)
Create structure to store sum of squares of weights.
virtual void SetEntries(Double_t n)
Double_t fTsumwx
Total Sum of weight*X.
Helper class to represent a bin in the TH2Poly histogram.
Double_t GetXMin()
Returns the minimum value for the x coordinates of the bin.
~TH2PolyBin() override
Destructor.
Double_t GetYMax()
Returns the maximum value for the y coordinates of the bin.
Double_t GetArea()
Returns the area of the bin.
Double_t GetYMin()
Returns the minimum value for the y coordinates of the bin.
Double_t fContent
Bin content.
Bool_t IsInside(Double_t x, Double_t y) const
Return "true" if the point (x,y) is inside the bin.
Double_t fXmax
X maximum value.
Int_t fNumber
Bin number of the bin in TH2Poly.
TH2PolyBin()
Default constructor.
Double_t fYmax
Y maximum value.
Double_t GetXMax()
Returns the maximum value for the x coordinates of the bin.
Double_t GetContent() const
Double_t fYmin
Y minimum value.
void SetChanged(Bool_t flag)
Int_t GetBinNumber() const
Double_t fXmin
X minimum value.
TObject * GetPolygon() const
TObject * fPoly
Object holding the polygon definition.
2D Histogram with Polygonal Bins
Bool_t Multiply(TF1 *, Double_t) override
NOT IMPLEMENTED for TH2Poly.
void UpdateBinContent(Int_t bin, Double_t content) override
Raw update of bin content on internal data structure see convention for numbering bins in TH1::GetBin...
TH2Poly & operator=(const TH2Poly &rhs)
Assignment operator.
void ClearBinContents()
Clears the contents of all bins in the histogram.
Double_t fOverflow[kNOverflow]
Overflow bins.
Bool_t fFloat
When set to kTRUE, allows the histogram to expand if a bin outside the limits is added.
Bool_t IsIntersecting(TH2PolyBin *bin, Double_t xclipl, Double_t xclipr, Double_t yclipb, Double_t yclipt)
Returns kTRUE if the input bin is intersecting with the input rectangle (xclipl, xclipr,...
void SetFloat(Bool_t flag=true)
When set to kTRUE, allows the histogram to expand if a bin outside the limits is added.
Double_t Integral(Option_t *option="") const override
Returns the integral of bin contents.
virtual TH2PolyBin * CreateBin(TObject *poly)
Create appropriate histogram bin.
Double_t GetBinContent(Int_t bin) const override
Returns the content of the input bin Bin numbers are from [1,nbins] and for the overflow/underflow/se...
Bool_t * fIsEmpty
[fNCells] The array that returns true if the cell at the given coordinate is empty
Double_t RetrieveBinContent(Int_t bin) const override
Raw retrieval of bin content on internal data structure see convention for numbering bins in TH1::Get...
TList * fBins
List of bins. The list owns the contained objects.
void AddBinToPartition(TH2PolyBin *bin)
Adds the input bin into the partition cell matrix.
Bool_t fBinContentChanged
!For the 3D Painter
Int_t Fill(Double_t x, Double_t y) override
Increment the bin containing (x,y) by 1.
Int_t GetNumberOfBins() const
Return the number of bins : it should be the size of the bin list.
void SetBinContentChanged(Bool_t flag)
void GetStats(Double_t *stats) const override
Fill the array stats from the contents of this histogram The array stats must be correctly dimensione...
Bool_t * fCompletelyInside
[fNCells] The array that returns true if the cell at the given coordinate is completely inside a bin
TH2Poly()
Default Constructor. No boundaries specified.
Bool_t IsInsideBin(Int_t binnr, Double_t x, Double_t y)
Return "true" if the point (x,y) is inside the bin of binnr.
Bool_t fNewBinAdded
!For the 3D Painter
void Copy(TObject &newth2p) const override
Copy function for TH2Poly.
void AddBinContent(Int_t) override
NOT IMPLEMENTED for TH2Poly.
void SetBinError(Int_t bin, Double_t error) override
Set the bin Error.
const char * GetBinTitle(Int_t bin) const
Returns the bin title.
void SetNewBinAdded(Bool_t flag)
void Scale(Double_t c1=1, Option_t *option="") override
Multiply this histogram by a constant c1.
void ChangePartition(Int_t n, Int_t m)
Changes the number of partition cells in the histogram.
virtual Double_t Interpolate(Double_t, Double_t)
NOT IMPLEMENTED for TH2Poly.
Double_t GetMinimum() const
Returns the minimum value of the histogram.
const char * GetBinName(Int_t bin) const
Returns the bin name.
void FillN(Int_t ntimes, const Double_t *x, const Double_t *y, const Double_t *w, Int_t stride=1) override
Fills a 2-D histogram with an array of values and weights.
Int_t fNCells
Number of partition cells: fCellX*fCellY.
Int_t FindBin(Double_t x, Double_t y, Double_t z=0) override
Returns the bin number of the bin at the given coordinate.
Bool_t Divide(TF1 *, Double_t) override
NOT IMPLEMENTED for TH2Poly.
void Initialize(Double_t xlow, Double_t xup, Double_t ylow, Double_t yup, Int_t n, Int_t m)
Initializes the TH2Poly object. This method is called by the constructor.
Int_t fCellX
Number of partition cells in the x-direction of the histogram.
~TH2Poly() override
Destructor.
virtual Int_t AddBin(TObject *poly)
Adds a new bin to the histogram.
Double_t GetBinError(Int_t bin) const override
Returns the value of error associated to bin number bin.
Bool_t IsIntersectingPolygon(Int_t bn, Double_t *x, Double_t *y, Double_t xclipl, Double_t xclipr, Double_t yclipb, Double_t yclipt)
Returns kTRUE if the input polygon (bn, x, y) is intersecting with the input rectangle (xclipl,...
Bool_t Add(const TH1 *h1, Double_t c1) override
Performs the operation: this = this + c1*h1.
virtual TH1 * GetAsymmetry(TH1 *, Double_t, Double_t)
NOT IMPLEMENTED for TH2Poly.
void Honeycomb(Double_t xstart, Double_t ystart, Double_t a, Int_t k, Int_t s, Option_t *option="v")
Bins the histogram using a honeycomb structure If the option "v" is specified, the hexagons are drawn...
Long64_t Merge(TCollection *) override
Merge TH2Polys Given the special nature of the TH2Poly, the merge is implemented in terms of subseque...
void SetBinContent(Int_t bin, Double_t content) override
Sets the contents of the input bin to the input content Negative values between -1 and -9 are for the...
Double_t GetMaximum() const
Returns the maximum value of the histogram.
void Reset(Option_t *option) override
Reset this histogram: contents, errors, etc.
Double_t fStepY
Dimensions of a partition cell.
void SavePrimitive(std::ostream &out, Option_t *option="") override
Save primitive as a C++ statement(s) on output stream out.
TH1 * FFT(TH1 *, Option_t *) override
NOT IMPLEMENTED for TH2Poly.
Double_t ComputeIntegral(Bool_t, Option_t *) override
NOT IMPLEMENTED for TH2Poly.
TList * fCells
[fNCells] The array of TLists that store the bins that intersect with each cell. List do not own the ...
Int_t fCellY
Number of partition cells in the y-direction of the histogram.
Service class for 2-D histogram classes.
void Copy(TObject &hnew) const override
Copy.
Double_t fTsumwxy
Total Sum of weight*X*Y.
void Reset(Option_t *option="") override
Reset this histogram: contents, errors, etc.
Double_t fTsumwy2
Total Sum of weight*Y*Y.
Double_t fTsumwy
Total Sum of weight*Y.
void PutStats(Double_t *stats) override
Replace current statistics with the values in array stats.
void Add(TObject *obj) override
TObject * At(Int_t idx) const override
Returns the object at position idx. Returns 0 if idx is out of range.
A TMultiGraph is a collection of TGraph (or derived) objects.
TList * GetListOfGraphs() const
virtual Int_t IsInside(Double_t x, Double_t y) const
Return 1 if the point (x,y) is inside one of the graphs 0 otherwise.
const char * GetName() const override
Returns name of object.
const char * GetTitle() const override
Returns title of object.
Mother of all ROOT objects.
virtual const char * GetName() const
Returns name of object.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual const char * ClassName() const
Returns name of class to which the object belongs.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Fatal(const char *method, const char *msgfmt,...) const
Issue fatal error message.
virtual TClass * IsA() const
void ToLower()
Change string to lower-case.
TString & ReplaceSpecialCppChars()
Find special characters which are typically used in printf() calls and replace them by appropriate es...
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Bool_t IsInside(T xp, T yp, Int_t np, T *x, T *y)
Function which returns kTRUE if point xp,yp lies inside the polygon defined by the np points in array...
Double_t QuietNaN()
Returns a quiet NaN as defined by IEEE 754.
Double_t Sqrt(Double_t x)
Returns the square root of x.
Short_t Abs(Short_t d)
Returns the absolute value of parameter Short_t d.