// @(#)root/hist:$Id$ // Author: Olivier Couet, Deniz Gunceler /************************************************************************* * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. * * All rights reserved. * * * * For the licensing terms see $ROOTSYS/LICENSE. * * For the list of contributors see $ROOTSYS/README/CREDITS. * *************************************************************************/ #ifndef ROOT_TH2Poly #define ROOT_TH2Poly ////////////////////////////////////////////////////////////////////////// // // // TH2Poly // // // // 2-Dim histogram with polygon bins // // // ////////////////////////////////////////////////////////////////////////// #include "TH2.h" class TH2PolyBin: public TObject{ public: TH2PolyBin(); TH2PolyBin(TObject *poly, Int_t bin_number); ~TH2PolyBin() override; void ClearContent(){fContent = 0;} void Fill(Double_t w) {fContent = fContent+w; SetChanged(true);} Double_t GetArea(); Double_t GetContent() const{return fContent;} Bool_t GetChanged() const{return fChanged;} Int_t GetBinNumber() const {return fNumber;} TObject *GetPolygon() const {return fPoly;} Double_t GetXMax(); Double_t GetXMin(); Double_t GetYMax(); Double_t GetYMin(); Bool_t IsInside(Double_t x, Double_t y) const; void SetChanged(Bool_t flag){fChanged = flag;} void SetContent(Double_t content){fContent = content; SetChanged(true);} protected: Bool_t fChanged; ///< For the 3D Painter Int_t fNumber; ///< Bin number of the bin in TH2Poly TObject *fPoly; ///< Object holding the polygon definition Double_t fArea; ///< Bin area Double_t fContent; ///< Bin content Double_t fXmin; ///< X minimum value Double_t fYmin; ///< Y minimum value Double_t fXmax; ///< X maximum value Double_t fYmax; ///< Y maximum value ClassDefOverride(TH2PolyBin,1) //2-Dim polygon bins }; class TList; class TGraph; class TMultiGraph; class TPad; class TH2Poly : public TH2 { public: TH2Poly(); TH2Poly(const char *name,const char *title, Double_t xlow, Double_t xup, Double_t ylow, Double_t yup); TH2Poly(const char *name,const char *title, Int_t nX, Double_t xlow, Double_t xup, Int_t nY, Double_t ylow, Double_t yup); ~TH2Poly() override; virtual TH2PolyBin *CreateBin(TObject *poly); virtual Int_t AddBin(TObject *poly); Int_t AddBin(Int_t n, const Double_t *x, const Double_t *y); Int_t AddBin(Double_t x1, Double_t y1, Double_t x2, Double_t y2); Bool_t Add(const TH1 *h1, Double_t c1) override; Bool_t Add(const TH1 *h1, const TH1 *h2, Double_t c1=1, Double_t c2=1) override; Bool_t Add(TF1 *h1, Double_t c1=1, Option_t *option="") override; void ClearBinContents(); // Clears the content of all bins TObject *Clone(const char* newname = "") const override; void ChangePartition(Int_t n, Int_t m); // Sets the number of partition cells to another value using TH2::Multiply; using TH2::Divide; using TH2::Interpolate; Bool_t Divide(TF1 *, Double_t) override; Bool_t Multiply(TF1 *, Double_t) override; Double_t ComputeIntegral(Bool_t) override; TH1 * FFT(TH1*, Option_t * ) override; virtual TH1 * GetAsymmetry(TH1* , Double_t, Double_t); virtual Double_t Interpolate(Double_t, Double_t); Int_t Fill(Double_t x,Double_t y) override; Int_t Fill(Double_t x,Double_t y, Double_t w) override; Int_t Fill(const char* name, Double_t w) override; void FillN(Int_t ntimes, const Double_t* x, const Double_t* y, const Double_t* w, Int_t stride = 1) override; Int_t FindBin(Double_t x, Double_t y, Double_t z = 0) override; TList *GetBins(){return fBins;} ///< Returns the TList of all bins in the histogram Double_t GetBinContent(Int_t bin) const override; Bool_t GetBinContentChanged() const{return fBinContentChanged;} Double_t GetBinError(Int_t bin) const override; const char *GetBinName(Int_t bin) const; const char *GetBinTitle(Int_t bin) const; Bool_t GetFloat(){return fFloat;} Double_t GetMaximum() const; Double_t GetMaximum(Double_t maxval) const override; Double_t GetMinimum() const; Double_t GetMinimum(Double_t minval) const override; Bool_t GetNewBinAdded() const{return fNewBinAdded;} Int_t GetNumberOfBins() const{return fNcells-kNOverflow;} void Honeycomb(Double_t xstart, Double_t ystart, Double_t a, Int_t k, Int_t s, Option_t* option = "v"); Double_t Integral(Option_t* option = "") const override; Long64_t Merge(TCollection *) override; void Reset(Option_t *option) override; void Scale(Double_t c1 = 1, Option_t* option = "") override; void SavePrimitive(std::ostream& out, Option_t* option = "") override; void SetBinContent(Int_t bin, Double_t content) override; void SetBinError(Int_t bin, Double_t error) override; void SetBinContentChanged(Bool_t flag){fBinContentChanged = flag;} void SetFloat(Bool_t flag = true); void SetNewBinAdded(Bool_t flag){fNewBinAdded = flag;} Bool_t IsInsideBin(Int_t binnr, Double_t x, Double_t y); void GetStats(Double_t *stats) const override; protected: //functions not to be used for TH2Poly Int_t Fill(Double_t) override{return -1;} ///< NOT IMPLEMENTED for TH2Poly Int_t Fill(Double_t , const char *, Double_t) override{return -1;} ///< NOT IMPLEMENTED for TH2Poly Int_t Fill(const char *, Double_t , Double_t ) override{return -1;} ///< NOT IMPLEMENTED for TH2Poly Int_t Fill(const char *, const char *, Double_t ) override{return -1;} ///< NOT IMPLEMENTED for TH2Poly void FillN(Int_t, const Double_t*, const Double_t*, Int_t) override{return;} ///< NOT IMPLEMENTED for TH2Poly Double_t Integral(Int_t, Int_t, const Option_t*) const override{return 0;} ///< NOT IMPLEMENTED for TH2Poly Double_t Integral(Int_t, Int_t, Int_t, Int_t, const Option_t*) const override{return 0;} ///< NOT IMPLEMENTED for TH2Poly Double_t Integral(Int_t, Int_t, Int_t, Int_t, Int_t, Int_t, const Option_t*) const override{return 0;} ///< NOT IMPLEMENTED for TH2Poly Double_t GetBinContent(Int_t, Int_t) const override {return 0;} ///< NOT IMPLEMENTED for TH2Poly Double_t GetBinContent(Int_t, Int_t, Int_t) const override {return 0;} ///< NOT IMPLEMENTED for TH2Poly Double_t GetBinError(Int_t , Int_t) const override {return 0;} ///< NOT IMPLEMENTED for TH2Poly Double_t GetBinError(Int_t , Int_t , Int_t) const override {return 0;} ///< NOT IMPLEMENTED for TH2Poly void SetBinContent(Int_t, Int_t, Double_t) override{} ///< NOT IMPLEMENTED for TH2Poly void SetBinContent(Int_t, Int_t, Int_t, Double_t) override{} ///< NOT IMPLEMENTED for TH2Poly void SetBinError(Int_t, Int_t, Double_t) override {} ///< NOT IMPLEMENTED for TH2Poly void SetBinError(Int_t, Int_t, Int_t, Double_t) override {} ///< NOT IMPLEMENTED for TH2Poly protected: enum { kNOverflow = 9 /// Number of overflows bins }; Double_t fOverflow[kNOverflow]; ///< Overflow bins Int_t fCellX; ///< Number of partition cells in the x-direction of the histogram Int_t fCellY; ///< Number of partition cells in the y-direction of the histogram Int_t fNCells; ///< Number of partition cells: fCellX*fCellY TList *fCells; ///<[fNCells] The array of TLists that store the bins that intersect with each cell. List do not own the contained objects Double_t fStepX, fStepY; ///< Dimensions of a partition cell Bool_t *fIsEmpty; ///<[fNCells] The array that returns true if the cell at the given coordinate is empty Bool_t *fCompletelyInside; ///<[fNCells] The array that returns true if the cell at the given coordinate is completely inside a bin Bool_t fFloat; ///< When set to kTRUE, allows the histogram to expand if a bin outside the limits is added. Bool_t fNewBinAdded; ///=kNOverflow) ? GetBinContent(bin-kNOverflow+1) : GetBinContent(-bin-1); } void UpdateBinContent(Int_t bin, Double_t content) override { return (bin>=kNOverflow) ? SetBinContent(bin-kNOverflow+1,content) : SetBinContent(-bin-1,content); } ClassDefOverride(TH2Poly,3) //2-Dim histogram with polygon bins }; #endif