ROOT » HIST » HIST » TProfile3D

class TProfile3D: public TH3D


  Profile3D histograms are used to display the mean
  value of T and its RMS for each cell in X,Y,Z.
  Profile3D histograms are in many cases an
  The inter-relation of three measured quantities X, Y, Z and T can always
  be visualized by a four-dimensional histogram or scatter-plot;
  its representation on the line-printer is not particularly
  satisfactory, except for sparse data. If T is an unknown (but single-valued)
  approximate function of X,Y,Z this function is displayed by a profile3D histogram with
  much better precision than by a scatter-plot.

  The following formulae show the cumulated contents (capital letters) and the values
  displayed by the printing or plotting routines (small letters) of the elements for cell I, J.

                                                                2
      H(I,J,K)  =  sum T                      E(I,J,K)  =  sum T
      l(I,J,K)  =  sum l                      L(I,J,K)  =  sum l
      h(I,J,K)  =  H(I,J,K)/L(I,J,K)          s(I,J,K)  =  sqrt(E(I,J,K)/L(I,J,K)- h(I,J,K)**2)
      e(I,J,K)  =  s(I,J,K)/sqrt(L(I,J,K))

  In the special case where s(I,J,K) is zero (eg, case of 1 entry only in one cell)
  e(I,J,K) is computed from the average of the s(I,J,K) for all cells,
  if the static function TProfile3D::Approximate has been called.
  This simple/crude approximation was suggested in order to keep the cell
  during a fit operation. But note that this approximation is not the default behaviour.

           Example of a profile3D histogram
{
  TCanvas *c1 = new TCanvas("c1","Profile histogram example",200,10,700,500);
  hprof3d  = new TProfile3D("hprof3d","Profile of pt versus px, py and pz",40,-4,4,40,-4,4,40,0,20);
  Double_t px, py, pz, pt;
  TRandom3 r(0);
  for ( Int_t i=0; i<25000; i++) {
     r.Rannor(px,py);
     pz = px*px + py*py;
     pt = r.Landau(0,1);
     hprof3d->Fill(px,py,pz,pt,1);
  }
  hprof3d->Draw();
}

 NOTE: A TProfile3D is drawn as it was a simple TH3

Function Members (Methods)

public:
virtual~TProfile3D()
voidTObject::AbstractMethod(const char* method) const
virtual Bool_tAdd(const TH1* h1, Double_t c1 = 1)
virtual Bool_tAdd(TF1* h1, Double_t c1 = 1, Option_t* option = "")
virtual Bool_tAdd(const TH1* h1, const TH1* h2, Double_t c1 = 1, Double_t c2 = 1)MENU
voidTArrayD::AddAt(Double_t c, Int_t i)
virtual voidTH3D::AddBinContent(Int_t bin)
virtual voidTH3D::AddBinContent(Int_t bin, Double_t w)
static voidTH1::AddDirectory(Bool_t add = kTRUE)
static Bool_tTH1::AddDirectoryStatus()
voidTArrayD::Adopt(Int_t n, Double_t* array)
virtual Double_tTH1::AndersonDarlingTest(const TH1* h2, Option_t* option = "") const
virtual Double_tTH1::AndersonDarlingTest(const TH1* h2, Double_t& advalue) const
virtual voidTObject::AppendPad(Option_t* option = "")
static voidApproximate(Bool_t approx = kTRUE)
Double_tTArrayD::At(Int_t i) const
virtual voidTH1::Browse(TBrowser* b)
virtual Int_tBufferEmpty(Int_t action = 0)
voidBuildOptions(Double_t tmin, Double_t tmax, Option_t* option)
virtual Bool_tTH1::CanExtendAllAxes() const
virtual Double_tTH1::Chi2Test(const TH1* h2, Option_t* option = "UU", Double_t* res = 0) const
virtual Double_tTH1::Chi2TestX(const TH1* h2, Double_t& chi2, Int_t& ndf, Int_t& igood, Option_t* option = "UU", Double_t* res = 0) const
virtual Double_tTH1::Chisquare(TF1* f1, Option_t* option = "") const
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTNamed::Clear(Option_t* option = "")
virtual voidTH1::ClearUnderflowAndOverflow()
virtual TObject*TH1::Clone(const char* newname = 0) const
virtual Int_tTNamed::Compare(const TObject* obj) const
virtual Double_tTH1::ComputeIntegral(Bool_t onlyPositive = false)
virtual voidCopy(TObject& hnew) const
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual voidTH1::DirectoryAutoAdd(TDirectory*)
Int_tTAttLine::DistancetoLine(Int_t px, Int_t py, Double_t xp1, Double_t yp1, Double_t xp2, Double_t yp2)
virtual Int_tTH1::DistancetoPrimitive(Int_t px, Int_t py)
virtual Bool_tDivide(const TH1* h1)
virtual Bool_tDivide(TF1* h1, Double_t c1 = 1)
virtual Bool_tDivide(const TH1* h1, const TH1* h2, Double_t c1 = 1, Double_t c2 = 1, Option_t* option = "")MENU
virtual voidTH1::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual TH1*TH1::DrawCopy(Option_t* option = "", const char* name_postfix = "_copy") const
virtual TH1*TH1::DrawNormalized(Option_t* option = "", Double_t norm = 1) const
virtual voidTH1::DrawPanel()MENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTH1::Eval(TF1* f1, Option_t* option = "")
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTH1::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidExtendAxis(Double_t x, TAxis* axis)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TH1*TH1::FFT(TH1* h_output, Option_t* option)
virtual Int_tFill(Double_t x, Double_t y, Double_t z, Double_t t)
virtual Int_tFill(Double_t x, Double_t y, Double_t z, Double_t t, Double_t w)
virtual voidTNamed::FillBuffer(char*& buffer)
virtual voidTH1::FillN(Int_t ntimes, const Double_t* x, const Double_t* w, Int_t stride = 1)
virtual voidTH1::FillN(Int_t, const Double_t*, const Double_t*, const Double_t*, Int_t)
virtual voidTH3::FillRandom(const char* fname, Int_t ntimes = 5000)
virtual voidTH3::FillRandom(TH1* h, Int_t ntimes = 5000)
virtual Int_tTH1::FindBin(Double_t x, Double_t y = 0, Double_t z = 0)
virtual Int_tTH3::FindFirstBinAbove(Double_t threshold = 0, Int_t axis = 1) const
virtual Int_tTH1::FindFixBin(Double_t x, Double_t y = 0, Double_t z = 0) const
virtual Int_tTH3::FindLastBinAbove(Double_t threshold = 0, Int_t axis = 1) const
virtual TObject*TH1::FindObject(const char* name) const
virtual TObject*TH1::FindObject(const TObject* obj) const
virtual TFitResultPtrTH1::Fit(const char* formula, Option_t* option = "", Option_t* goption = "", Double_t xmin = 0, Double_t xmax = 0)MENU
virtual TFitResultPtrTH1::Fit(TF1* f1, Option_t* option = "", Option_t* goption = "", Double_t xmin = 0, Double_t xmax = 0)
static Int_tTH1::FitOptionsMake(Option_t* option, Foption_t& Foption)
virtual voidTH1::FitPanel()MENU
virtual voidTH3::FitSlicesZ(TF1* f1 = 0, Int_t binminx = 1, Int_t binmaxx = 0, Int_t binminy = 1, Int_t binmaxy = 0, Int_t cut = 0, Option_t* option = "QNR")MENU
const Double_t*TArrayD::GetArray() const
Double_t*TArrayD::GetArray()
TH1*TH1::GetAsymmetry(TH1* h2, Double_t c2 = 1, Double_t dc2 = 0)
virtual Double_tTArrayD::GetAt(Int_t i) const
virtual Color_tTH1::GetAxisColor(Option_t* axis = "X") const
virtual Float_tTH1::GetBarOffset() const
virtual Float_tTH1::GetBarWidth() const
virtual Int_tTH3::GetBin(Int_t binx, Int_t biny, Int_t binz) const
virtual Double_tTH1::GetBinCenter(Int_t bin) const
virtual Double_tGetBinContent(Int_t bin) const
virtual Double_tGetBinContent(Int_t, Int_t) const
virtual Double_tGetBinContent(Int_t binx, Int_t biny, Int_t binz) const
virtual Double_tGetBinEffectiveEntries(Int_t bin)
virtual Double_tGetBinEntries(Int_t bin) const
virtual Double_tGetBinError(Int_t bin) const
virtual Double_tGetBinError(Int_t, Int_t) const
virtual Double_tGetBinError(Int_t binx, Int_t biny, Int_t binz) const
virtual Double_tTH3::GetBinErrorLow(Int_t binx, Int_t biny, Int_t binz)
virtual TH1::EBinErrorOptTH1::GetBinErrorOption() const
virtual Double_tTH3::GetBinErrorUp(Int_t binx, Int_t biny, Int_t binz)
virtual Double_tTH1::GetBinLowEdge(Int_t bin) const
virtual TArrayD*GetBinSumw2()
virtual const TArrayD*GetBinSumw2() const
virtual Double_tTH1::GetBinWidth(Int_t bin) const
virtual Double_tTH1::GetBinWithContent(Double_t c, Int_t& binx, Int_t firstx = 0, Int_t lastx = 0, Double_t maxdiff = 0) const
virtual Double_tTH3::GetBinWithContent3(Double_t c, Int_t& binx, Int_t& biny, Int_t& binz, Int_t firstx = 0, Int_t lastx = 0, Int_t firsty = 0, Int_t lasty = 0, Int_t firstz = 0, Int_t lastz = 0, Double_t maxdiff = 0) const
virtual voidTH1::GetBinXYZ(Int_t binglobal, Int_t& binx, Int_t& biny, Int_t& binz) const
const Double_t*TH1::GetBuffer() const
Int_tTH1::GetBufferLength() const
Int_tTH1::GetBufferSize() const
virtual Double_tTH1::GetCellContent(Int_t binx, Int_t biny) const
virtual Double_tTH1::GetCellError(Int_t binx, Int_t biny) const
virtual voidTH1::GetCenter(Double_t* center) const
virtual Int_tTH1::GetContour(Double_t* levels = 0)
virtual Double_tTH1::GetContourLevel(Int_t level) const
virtual Double_tTH1::GetContourLevelPad(Int_t level) const
virtual Double_tTH3::GetCorrelationFactor(Int_t axis1 = 1, Int_t axis2 = 2) const
virtual Double_tTH3::GetCovariance(Int_t axis1 = 1, Int_t axis2 = 2) const
TH1*TH1::GetCumulative(Bool_t forward = kTRUE, const char* suffix = "_cumulative") const
static Int_tTH1::GetDefaultBufferSize()
static Bool_tTH1::GetDefaultSumw2()
virtual Int_tTH1::GetDimension() const
TDirectory*TH1::GetDirectory() const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual Double_tTH1::GetEffectiveEntries() const
virtual Double_tTH1::GetEntries() const
Option_t*GetErrorOption() const
virtual Color_tTAttFill::GetFillColor() const
virtual Style_tTAttFill::GetFillStyle() const
virtual TF1*TH1::GetFunction(const char* name) const
virtual const char*TObject::GetIconName() const
virtual Double_t*TH1::GetIntegral()
virtual Double_tTH1::GetKurtosis(Int_t axis = 1) const
virtual Color_tTH1::GetLabelColor(Option_t* axis = "X") const
virtual Style_tTH1::GetLabelFont(Option_t* axis = "X") const
virtual Float_tTH1::GetLabelOffset(Option_t* axis = "X") const
virtual Float_tTH1::GetLabelSize(Option_t* axis = "X") const
virtual Color_tTAttLine::GetLineColor() const
virtual Style_tTAttLine::GetLineStyle() const
virtual Width_tTAttLine::GetLineWidth() const
TList*TH1::GetListOfFunctions() const
virtual voidTH1::GetLowEdge(Double_t* edge) const
virtual Color_tTAttMarker::GetMarkerColor() const
virtual Size_tTAttMarker::GetMarkerSize() const
virtual Style_tTAttMarker::GetMarkerStyle() const
virtual Double_tTH1::GetMaximum(Double_t maxval = 3.40282347E+38F) const
virtual Int_tTH1::GetMaximumBin() const
virtual Int_tTH1::GetMaximumBin(Int_t& locmax, Int_t& locmay, Int_t& locmaz) const
virtual Double_tTH1::GetMaximumStored() const
virtual Double_tTH1::GetMean(Int_t axis = 1) const
virtual Double_tTH1::GetMeanError(Int_t axis = 1) const
virtual Double_tTH1::GetMinimum(Double_t minval = -3.40282347E+38F) const
virtual Int_tTH1::GetMinimumBin() const
virtual Int_tTH1::GetMinimumBin(Int_t& locmix, Int_t& locmiy, Int_t& locmiz) const
virtual Double_tTH1::GetMinimumStored() const
virtual const char*TNamed::GetName() const
virtual Int_tTH1::GetNbinsX() const
virtual Int_tTH1::GetNbinsY() const
virtual Int_tTH1::GetNbinsZ() const
virtual Int_tTH1::GetNcells() const
virtual Int_tTH1::GetNdivisions(Option_t* axis = "X") const
virtual Double_tTH1::GetNormFactor() const
virtual char*TH1::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TH1::GetOption() const
TVirtualHistPainter*TH1::GetPainter(Option_t* option = "")
virtual Int_tTH1::GetQuantiles(Int_t nprobSum, Double_t* q, const Double_t* probSum = 0)
virtual Double_tTH1::GetRandom() const
virtual voidTH3::GetRandom3(Double_t& x, Double_t& y, Double_t& z)
virtual Double_tTH1::GetRMS(Int_t axis = 1) const
virtual Double_tTH1::GetRMSError(Int_t axis = 1) const
Int_tTArray::GetSize() const
virtual Double_tTH1::GetSkewness(Int_t axis = 1) const
virtual voidGetStats(Double_t* stats) const
Double_tTH1::GetStdDev(Int_t axis = 1) const
Double_tTH1::GetStdDevError(Int_t axis = 1) const
Stat_tTArrayD::GetSum() const
virtual Double_tTH1::GetSumOfWeights() const
virtual TArrayD*TH1::GetSumw2()
virtual const TArrayD*TH1::GetSumw2() const
virtual Int_tTH1::GetSumw2N() const
virtual Float_tTH1::GetTickLength(Option_t* axis = "X") const
virtual const char*TNamed::GetTitle() const
virtual Style_tTH1::GetTitleFont(Option_t* axis = "X") const
virtual Float_tTH1::GetTitleOffset(Option_t* axis = "X") const
virtual Float_tTH1::GetTitleSize(Option_t* axis = "X") const
virtual Double_tGetTmax() const
virtual Double_tGetTmin() const
virtual UInt_tTObject::GetUniqueID() const
TAxis*TH1::GetXaxis()
const TAxis*TH1::GetXaxis() const
TAxis*TH1::GetYaxis()
const TAxis*TH1::GetYaxis() const
TAxis*TH1::GetZaxis()
const TAxis*TH1::GetZaxis() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTNamed::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() constMENU
virtual Double_tTH3::Integral(Option_t* option = "") const
virtual Double_tTH3::Integral(Int_t binx1, Int_t binx2, Int_t biny1, Int_t biny2, Int_t binz1, Int_t binz2, Option_t* option = "") const
virtual Double_tTH3::IntegralAndError(Int_t binx1, Int_t binx2, Int_t biny1, Int_t biny2, Int_t binz1, Int_t binz2, Double_t& err, Option_t* option = "") const
virtual Double_tTH3::Interpolate(Double_t x)
virtual Double_tTH3::Interpolate(Double_t x, Double_t y)
virtual Double_tTH3::Interpolate(Double_t x, Double_t y, Double_t z)
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
Bool_tTH1::IsBinOverflow(Int_t bin) const
Bool_tTH1::IsBinUnderflow(Int_t bin) const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTNamed::IsSortable() const
virtual Bool_tTAttFill::IsTransparent() const
Bool_tTObject::IsZombie() const
virtual Double_tTH3::KolmogorovTest(const TH1* h2, Option_t* option = "") const
virtual voidTH1::LabelsDeflate(Option_t* axis = "X")
virtual voidTH1::LabelsInflate(Option_t* axis = "X")
virtual voidTH1::LabelsOption(Option_t* option = "h", Option_t* axis = "X")
virtual voidTNamed::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Long64_tMerge(TCollection* list)
virtual voidTAttLine::Modify()
virtual Bool_tMultiply(const TH1* h1)
virtual Bool_tMultiply(TF1* h1, Double_t c1 = 1)
virtual Bool_tMultiply(const TH1* h1, const TH1* h2, Double_t c1 = 1, Double_t c2 = 1, Option_t* option = "")MENU
virtual Bool_tTObject::Notify()
voidTObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const
voidTObject::operator delete(void* ptr)
voidTObject::operator delete(void* ptr, void* vp)
voidTObject::operator delete[](void* ptr)
voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
TProfile3D&operator=(const TProfile3D&)
Double_t&TArrayD::operator[](Int_t i)
Double_tTArrayD::operator[](Int_t i) const
virtual voidTH1::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTH1::Print(Option_t* option = "") const
TH1*TH3::Project3D(Option_t* option = "x") constMENU
virtual TProfile2D*Project3DProfile(Option_t* option = "xy") constMENU
TH1D*TH3::ProjectionX(const char* name = "_px", Int_t iymin = 0, Int_t iymax = -1, Int_t izmin = 0, Int_t izmax = -1, Option_t* option = "") constMENU
virtual TH3D*ProjectionXYZ(const char* name = "_pxyz", Option_t* option = "e") const
TH1D*TH3::ProjectionY(const char* name = "_py", Int_t ixmin = 0, Int_t ixmax = -1, Int_t izmin = 0, Int_t izmax = -1, Option_t* option = "") constMENU
TH1D*TH3::ProjectionZ(const char* name = "_pz", Int_t ixmin = 0, Int_t ixmax = -1, Int_t iymin = 0, Int_t iymax = -1, Option_t* option = "") constMENU
virtual voidPutStats(Double_t* stats)
virtual Int_tTObject::Read(const char* name)
static TArray*TArray::ReadArray(TBuffer& b, const TClass* clReq)
virtual TH1*TH1::Rebin(Int_t ngroup = 2, const char* newname = "", const Double_t* xbins = 0)MENU
virtual TH3*TH3::Rebin3D(Int_t nxgroup = 2, Int_t nygroup = 2, Int_t nzgroup = 2, const char* newname = "")
virtual voidTH1::RebinAxis(Double_t x, TAxis* axis)
virtual TH3*TH3::RebinX(Int_t ngroup = 2, const char* newname = "")
virtual TH3*TH3::RebinY(Int_t ngroup = 2, const char* newname = "")
virtual TH3*TH3::RebinZ(Int_t ngroup = 2, const char* newname = "")
virtual voidTH1::Rebuild(Option_t* option = "")
virtual voidTH1::RecursiveRemove(TObject* obj)
virtual voidReset(Option_t* option = "")
virtual voidTAttFill::ResetAttFill(Option_t* option = "")
virtual voidTAttLine::ResetAttLine(Option_t* option = "")
virtual voidTAttMarker::ResetAttMarker(Option_t* toption = "")
voidTObject::ResetBit(UInt_t f)
virtual voidTH1::ResetStats()
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTAttFill::SaveFillAttributes(ostream& out, const char* name, Int_t coldef = 1, Int_t stydef = 1001)
virtual voidTAttLine::SaveLineAttributes(ostream& out, const char* name, Int_t coldef = 1, Int_t stydef = 1, Int_t widdef = 1)
virtual voidTAttMarker::SaveMarkerAttributes(ostream& out, const char* name, Int_t coldef = 1, Int_t stydef = 1, Int_t sizdef = 1)
virtual voidSavePrimitive(ostream& out, Option_t* option = "")
virtual voidScale(Double_t c1 = 1, Option_t* option = "")
virtual voidTArrayD::Set(Int_t n)
voidTArrayD::Set(Int_t n, const Double_t* array)
virtual voidTArrayD::SetAt(Double_t v, Int_t i)
virtual voidTH1::SetAxisColor(Color_t color = 1, Option_t* axis = "X")
virtual voidTH1::SetAxisRange(Double_t xmin, Double_t xmax, Option_t* axis = "X")
virtual voidTH1::SetBarOffset(Float_t offset = 0.25)
virtual voidTH1::SetBarWidth(Float_t width = 0.5)
virtual voidTH3::SetBinContent(Int_t bin, Double_t content)
virtual voidTH3::SetBinContent(Int_t bin, Int_t, Double_t content)
virtual voidTH3::SetBinContent(Int_t binx, Int_t biny, Int_t binz, Double_t content)
virtual voidSetBinEntries(Int_t bin, Double_t w)
virtual voidTH1::SetBinError(Int_t bin, Double_t error)
virtual voidTH1::SetBinError(Int_t binx, Int_t biny, Double_t error)
virtual voidTH1::SetBinError(Int_t binx, Int_t biny, Int_t binz, Double_t error)
virtual voidTH1::SetBinErrorOption(TH1::EBinErrorOpt type)
virtual voidSetBins(Int_t nx, const Double_t* xBins, Int_t ny, const Double_t* yBins, Int_t nz, const Double_t* zBins)
virtual voidSetBins(Int_t nbinsx, Double_t xmin, Double_t xmax, Int_t nbinsy, Double_t ymin, Double_t ymax, Int_t nbinsz, Double_t zmin, Double_t zmax)
virtual voidSetBinsLength(Int_t n = -1)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidSetBuffer(Int_t buffersize, Option_t* opt = "")
virtual UInt_tTH1::SetCanExtend(UInt_t extendBitMask)
virtual voidTH1::SetCellContent(Int_t binx, Int_t biny, Double_t content)
virtual voidTH1::SetCellError(Int_t binx, Int_t biny, Double_t content)
virtual voidTH1::SetContent(const Double_t* content)
virtual voidTH1::SetContour(Int_t nlevels, const Double_t* levels = 0)
virtual voidTH1::SetContourLevel(Int_t level, Double_t value)
static voidTH1::SetDefaultBufferSize(Int_t buffersize = 1000)
static voidTH1::SetDefaultSumw2(Bool_t sumw2 = kTRUE)
virtual voidTH1::SetDirectory(TDirectory* dir)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
virtual voidTH1::SetEntries(Double_t n)
virtual voidTH1::SetError(const Double_t* error)
virtual voidSetErrorOption(Option_t* option = "")MENU
virtual voidTAttFill::SetFillAttributes()MENU
virtual voidTAttFill::SetFillColor(Color_t fcolor)
virtual voidTAttFill::SetFillColorAlpha(Color_t fcolor, Float_t falpha)
virtual voidTAttFill::SetFillStyle(Style_t fstyle)
virtual voidTH1::SetLabelColor(Color_t color = 1, Option_t* axis = "X")
virtual voidTH1::SetLabelFont(Style_t font = 62, Option_t* axis = "X")
virtual voidTH1::SetLabelOffset(Float_t offset = 0.0050000000000000001, Option_t* axis = "X")
virtual voidTH1::SetLabelSize(Float_t size = 0.02, Option_t* axis = "X")
virtual voidTAttLine::SetLineAttributes()MENU
virtual voidTAttLine::SetLineColor(Color_t lcolor)
virtual voidTAttLine::SetLineColorAlpha(Color_t lcolor, Float_t lalpha)
virtual voidTAttLine::SetLineStyle(Style_t lstyle)
virtual voidTAttLine::SetLineWidth(Width_t lwidth)
virtual voidTAttMarker::SetMarkerAttributes()MENU
virtual voidTAttMarker::SetMarkerColor(Color_t mcolor = 1)
virtual voidTAttMarker::SetMarkerColorAlpha(Color_t mcolor, Float_t malpha)
virtual voidTAttMarker::SetMarkerSize(Size_t msize = 1)
virtual voidTAttMarker::SetMarkerStyle(Style_t mstyle = 1)
virtual voidTH1::SetMaximum(Double_t maximum = -1111)MENU
virtual voidTH1::SetMinimum(Double_t minimum = -1111)MENU
virtual voidTH1::SetName(const char* name)MENU
virtual voidTH1::SetNameTitle(const char* name, const char* title)
virtual voidTH1::SetNdivisions(Int_t n = 510, Option_t* axis = "X")
virtual voidTH1::SetNormFactor(Double_t factor = 1)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTH1::SetOption(Option_t* option = " ")
virtual voidTH3::SetShowProjection(const char* option = "xy", Int_t nbins = 1)MENU
virtual voidTH1::SetStats(Bool_t stats = kTRUE)MENU
virtual voidTH1::SetTickLength(Float_t length = 0.02, Option_t* axis = "X")
virtual voidTH1::SetTitle(const char* title)MENU
virtual voidTH1::SetTitleFont(Style_t font = 62, Option_t* axis = "X")
virtual voidTH1::SetTitleOffset(Float_t offset = 1, Option_t* axis = "X")
virtual voidTH1::SetTitleSize(Float_t size = 0.02, Option_t* axis = "X")
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidTH1::SetXTitle(const char* title)
virtual voidTH1::SetYTitle(const char* title)
virtual voidTH1::SetZTitle(const char* title)
virtual TH1*TH1::ShowBackground(Int_t niter = 20, Option_t* option = "same")MENU
virtual voidShowMembers(TMemberInspector& insp) const
virtual Int_tTH1::ShowPeaks(Double_t sigma = 2, Option_t* option = "", Double_t threshold = 0.050000000000000003)MENU
virtual Int_tTNamed::Sizeof() const
virtual voidTAtt3D::Sizeof3D() const
virtual voidTH1::Smooth(Int_t ntimes = 1, Option_t* option = "")MENU
static voidTH1::SmoothArray(Int_t NN, Double_t* XX, Int_t ntimes = 1)
static voidTH1::StatOverflows(Bool_t flag = kTRUE)
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_b)
virtual voidSumw2(Bool_t flag = kTRUE)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
TProfile3D()
TProfile3D(const TProfile3D& profile)
TProfile3D(const char* name, const char* title, Int_t nbinsx, const Double_t* xbins, Int_t nbinsy, const Double_t* ybins, Int_t nbinsz, const Double_t* zbins, Option_t* option = "")
TProfile3D(const char* name, const char* title, Int_t nbinsx, Double_t xlow, Double_t xup, Int_t nbinsy, Double_t ylow, Double_t yup, Int_t nbinsz, Double_t zlow, Double_t zup, Option_t* option = "")
static TH1*TH1::TransformHisto(TVirtualFFT* fft, TH1* h_output, Option_t* option)
virtual voidTH1::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
static voidTArray::WriteArray(TBuffer& b, const TArray* a)
protected:
Bool_tTArray::BoundsOk(const char* where, Int_t at) const
virtual Int_tBufferFill(Double_t, Double_t)
virtual Int_tBufferFill(Double_t, Double_t, Double_t)
virtual Int_tBufferFill(Double_t, Double_t, Double_t, Double_t)
virtual Int_tBufferFill(Double_t x, Double_t y, Double_t z, Double_t t, Double_t w)
static boolTH1::CheckAxisLimits(const TAxis* a1, const TAxis* a2)
static boolTH1::CheckBinLabels(const TAxis* a1, const TAxis* a2)
static boolTH1::CheckBinLimits(const TAxis* a1, const TAxis* a2)
static boolTH1::CheckConsistency(const TH1* h1, const TH1* h2)
static boolTH1::CheckConsistentSubAxes(const TAxis* a1, Int_t firstBin1, Int_t lastBin1, const TAxis* a2, Int_t firstBin2 = 0, Int_t lastBin2 = 0)
static boolTH1::CheckEqualAxes(const TAxis* a1, const TAxis* a2)
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
virtual voidTH1::DoFillN(Int_t ntimes, const Double_t* x, const Double_t* w, Int_t stride = 1)
voidTH3::DoFillProfileProjection(TProfile2D* p2, const TAxis& a1, const TAxis& a2, const TAxis& a3, Int_t bin1, Int_t bin2, Int_t bin3, Int_t inBin, Bool_t useWeights) const
virtual Double_tTH1::DoIntegral(Int_t ix1, Int_t ix2, Int_t iy1, Int_t iy2, Int_t iz1, Int_t iz2, Double_t& err, Option_t* opt, Bool_t doerr = kFALSE) const
virtual TH1D*TH3::DoProject1D(const char* name, const char* title, const TAxis* projAxis, bool computeErrors, bool originalRange, bool useUF, bool useOF) const
static TH1D*TH3::DoProject1D(const TH3& h, const char* name, const char* title, const TAxis* projX, bool computeErrors, bool originalRange, bool useUF, bool useOF)
virtual TH1D*TH3::DoProject1D(const char* name, const char* title, int imin1, int imax1, int imin2, int imax2, const TAxis* projAxis, const TAxis* axis1, const TAxis* axis2, Option_t* option) const
virtual TH2D*TH3::DoProject2D(const char* name, const char* title, const TAxis* projX, const TAxis* projY, bool computeErrors, bool originalRange, bool useUF, bool useOF) const
static TH2D*TH3::DoProject2D(const TH3& h, const char* name, const char* title, const TAxis* projX, const TAxis* projY, bool computeErrors, bool originalRange, bool useUF, bool useOF)
virtual TProfile2D*DoProjectProfile2D(const char* name, const char* title, const TAxis* projX, const TAxis* projY, bool originalRange, bool useUF, bool useOF) const
Int_tFill(const Double_t* v)
virtual Int_tFill(Double_t, Double_t, Double_t)
virtual Int_tFill(const char*, const char*, const char*, Double_t)
virtual Int_tFill(const char*, Double_t, const char*, Double_t)
virtual Int_tFill(const char*, const char*, Double_t, Double_t)
virtual Int_tFill(Double_t, const char*, const char*, Double_t)
virtual Int_tFill(Double_t, const char*, Double_t, Double_t)
virtual Int_tFill(Double_t, Double_t, const char*, Double_t)
virtual Bool_tTH1::FindNewAxisLimits(const TAxis* axis, const Double_t point, Double_t& newMin, Double_t& newMax)
virtual Double_tGetBinErrorSqUnchecked(Int_t bin) const
voidTObject::MakeZombie()
Bool_tTArray::OutOfBoundsError(const char* where, Int_t i) const
static Bool_tTH1::RecomputeAxisLimits(TAxis& destAxis, const TAxis& anAxis)
virtual Double_tRetrieveBinContent(Int_t bin) const
static Bool_tTH1::SameLimitsAndNBins(const TAxis& axis1, const TAxis& axis2)
virtual voidTH1::SavePrimitiveHelp(ostream& out, const char* hname, Option_t* option = "")
voidSetBins(const Int_t* nbins, const Double_t* range)
virtual voidTH3D::UpdateBinContent(Int_t bin, Double_t content)
private:
Double_t*GetB()
Double_t*GetB2()
Double_t*GetW()
Double_t*GetW2()
virtual voidSetBins(Int_t, const Double_t*)
virtual voidSetBins(Int_t, Double_t, Double_t)
virtual voidSetBins(Int_t, const Double_t*, Int_t, const Double_t*)
virtual voidSetBins(Int_t, Double_t, Double_t, Int_t, Double_t, Double_t)

Data Members

public:
Double_t*TArrayD::fArray[fN] Array of fN doubles
Int_tTArray::fNNumber of array elements
static TH1::(anonymous)TH1::kAllAxes
static TObject::(anonymous)TObject::kBitMask
static TObject::EStatusBitsTObject::kCanDelete
static TH1::(anonymous)TH1::kCanRebin
static TObject::EStatusBitsTObject::kCannotPick
static TObject::EStatusBitsTObject::kHasUUID
static TObject::EStatusBitsTObject::kInvalidObject
static TH1::(anonymous)TH1::kIsAverage
static TH1::(anonymous)TH1::kIsNotW
static TObject::(anonymous)TObject::kIsOnHeap
static TObject::EStatusBitsTObject::kIsReferenced
static TH1::(anonymous)TH1::kIsZoomed
static TH1::(anonymous)TH1::kLogX
static TObject::EStatusBitsTObject::kMustCleanup
static TH1::(anonymous)TH1::kNoAxis
static TObject::EStatusBitsTObject::kNoContextMenu
static TH1::(anonymous)TH1::kNoStats
static TH1::(anonymous)TH1::kNoTitle
static TH1::EBinErrorOptTH1::kNormal
static TObject::(anonymous)TObject::kNotDeleted
static TH1::(anonymous)TH1::kNstat
static TObject::EStatusBitsTObject::kObjInCanvas
static TObject::(anonymous)TObject::kOverwrite
static TH1::EBinErrorOptTH1::kPoisson
static TH1::EBinErrorOptTH1::kPoisson2
static TObject::(anonymous)TObject::kSingleKey
static TH1::(anonymous)TH1::kUserContour
static TObject::(anonymous)TObject::kWriteDelete
static TH1::(anonymous)TH1::kXaxis
static TH1::(anonymous)TH1::kYaxis
static TH1::(anonymous)TH1::kZaxis
static TObject::(anonymous)TObject::kZombie
protected:
Short_tTH1::fBarOffset(1000*offset) for bar charts or legos
Short_tTH1::fBarWidth(1000*width) for bar charts or legos
TArrayDfBinEntriesnumber of entries per bin
TH1::EBinErrorOptTH1::fBinStatErrOptoption for bin statistical errors
TArrayDfBinSumw2Array of sum of squares of weights per bin
Double_t*TH1::fBuffer[fBufferSize] entry buffer
Int_tTH1::fBufferSizefBuffer size
TArrayDTH1::fContourArray to display contour levels
Int_tTH1::fDimension!Histogram dimension (1, 2 or 3 dim)
TDirectory*TH1::fDirectory!Pointer to directory holding this histogram
Double_tTH1::fEntriesNumber of entries
EErrorTypefErrorModeOption to compute errors
Color_tTAttFill::fFillColorfill area color
Style_tTAttFill::fFillStylefill area style
TList*TH1::fFunctions->Pointer to list of functions (fits and user)
Double_t*TH1::fIntegral!Integral of bins used by GetRandom
Color_tTAttLine::fLineColorline color
Style_tTAttLine::fLineStyleline style
Width_tTAttLine::fLineWidthline width
Color_tTAttMarker::fMarkerColorMarker color index
Size_tTAttMarker::fMarkerSizeMarker size
Style_tTAttMarker::fMarkerStyleMarker style
Double_tTH1::fMaximumMaximum value for plotting
Double_tTH1::fMinimumMinimum value for plotting
TStringTNamed::fNameobject identifier
Int_tTH1::fNcellsnumber of bins(1D), cells (2D) +U/Overflows
Double_tTH1::fNormFactorNormalization factor
TStringTH1::fOptionhistogram options
TVirtualHistPainter*TH1::fPainter!pointer to histogram painter
Bool_tfScaling!True when TProfile3D::Scale is called
TArrayDTH1::fSumw2Array of sum of squares of weights
TStringTNamed::fTitleobject title
Double_tfTmaxUpper limit in T (if set)
Double_tfTminLower limit in T (if set)
Double_tTH1::fTsumwTotal Sum of weights
Double_tTH1::fTsumw2Total Sum of squares of weights
Double_tfTsumwtTotal Sum of weight*T
Double_tfTsumwt2Total Sum of weight*T*T
Double_tTH1::fTsumwxTotal Sum of weight*X
Double_tTH1::fTsumwx2Total Sum of weight*X*X
Double_tTH3::fTsumwxyTotal Sum of weight*X*Y
Double_tTH3::fTsumwxzTotal Sum of weight*X*Z
Double_tTH3::fTsumwyTotal Sum of weight*Y
Double_tTH3::fTsumwy2Total Sum of weight*Y*Y
Double_tTH3::fTsumwyzTotal Sum of weight*Y*Z
Double_tTH3::fTsumwzTotal Sum of weight*Z
Double_tTH3::fTsumwz2Total Sum of weight*Z*Z
TAxisTH1::fXaxisX axis descriptor
TAxisTH1::fYaxisY axis descriptor
TAxisTH1::fZaxisZ axis descriptor
static Bool_tTH1::fgAddDirectory!flag to add histograms to the directory
static Bool_tfgApproximatebin error approximation option
static Int_tTH1::fgBufferSize!default buffer size for automatic histograms
static Bool_tTH1::fgDefaultSumw2!flag to call TH1::Sumw2 automatically at histogram creation time
static Bool_tTH1::fgStatOverflows!flag to use under/overflows in statistics

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

TProfile3D()
Default constructor for Profile3D histograms*-*-*-
*-*        ============================================
~TProfile3D()
Default destructor for Profile3D histograms*-*-*-
*-*        ===========================================
TProfile3D(const char* name, const char* title, Int_t nbinsx, Double_t xlow, Double_t xup, Int_t nbinsy, Double_t ylow, Double_t yup, Int_t nbinsz, Double_t zlow, Double_t zup, Option_t* option = "")
Normal Constructor for Profile histograms*-*-*-*-
*-*        ==========================================

  The first eleven parameters are similar to TH3D::TH3D.
  All values of t are accepted at filling time.
  To fill a profile3D histogram, one must use TProfile3D::Fill function.

  Note that when filling the profile histogram the function Fill
  checks if the variable t is betyween fTmin and fTmax.
  If a minimum or maximum value is set for the T scale before filling,
  then all values below tmin or above tmax will be discarded.
  Setting the minimum or maximum value for the T scale before filling
  has the same effect as calling the special TProfile3D constructor below
  where tmin and tmax are specified.

  H(I,J,K) is printed as the cell contents. The errors computed are s(I,J,K) if CHOPT='S'
  (spread option), or e(I,J,K) if CHOPT=' ' (error on mean).

        See TProfile3D::BuildOptions for explanation of parameters

   see other constructors below with all possible combinations of
   fix and variable bin size like in TH3D.
TProfile3D(const char* name, const char* title, Int_t nbinsx, const Double_t* xbins, Int_t nbinsy, const Double_t* ybins, Int_t nbinsz, const Double_t* zbins, Option_t* option = "")
  Create a 3-D Profile with variable bins in X , Y and Z
void BuildOptions(Double_t tmin, Double_t tmax, Option_t* option)
Set Profile3D histogram structure and options*-*-
*-*          =============================================

    tmin:  minimum value allowed for t
    tmax:  maximum value allowed for t
            if (tmin = tmax = 0) there are no limits on the allowed t values (tmin = -inf, tmax = +inf)

    option:  this is the option for the computation of the t error of the profile ( TProfile3D::GetBinError )
             possible values for the options are documented in TProfile3D::SetErrorOption

    see also TProfile::BuildOptions for a detailed description
TProfile3D(const TProfile3D& profile)
copy constructor
Bool_t Add(TF1* h1, Double_t c1 = 1, Option_t* option = "")
 Performs the operation: this = this + c1*f1
Bool_t Add(const TH1* h1, Double_t c1 = 1)
 Performs the operation: this = this + c1*h1
Bool_t Add(const TH1* h1, const TH1* h2, Double_t c1 = 1, Double_t c2 = 1)
-*-*Replace contents of this profile3D by the addition of h1 and h2
*-*      ===============================================================

   this = c1*h1 + c2*h2

void Approximate(Bool_t approx = kTRUE)
     static function
 set the fgApproximate flag. When the flag is true, the function GetBinError
 will approximate the bin error with the average profile error on all bins
 in the following situation only
  - the number of bins in the profile3D is less than 10404 (eg 100x100x100)
  - the bin number of entries is small ( <5)
  - the estimated bin error is extremely small compared to the bin content
  (see TProfile3D::GetBinError)
Int_t BufferEmpty(Int_t action = 0)
 Fill histogram with all entries in the buffer.
 action = -1 histogram is reset and refilled from the buffer (called by THistPainter::Paint)
 action =  0 histogram is filled from the buffer
 action =  1 histogram is filled and buffer is deleted
             The buffer is automatically deleted when the number of entries
             in the buffer is greater than the number of entries in the histogram
Int_t BufferFill(Double_t x, Double_t y, Double_t z, Double_t t, Double_t w)
 accumulate arguments in buffer. When buffer is full, empty the buffer
 fBuffer[0] = number of entries in buffer
 fBuffer[1] = w of first entry
 fBuffer[2] = x of first entry
 fBuffer[3] = y of first entry
 fBuffer[4] = z of first entry
 fBuffer[5] = t of first entry
void Copy(TObject& hnew) const
-*-*-*-*Copy a Profile3D histogram to a new profile2D histogram
*-*            =======================================================
Bool_t Divide(TF1* h1, Double_t c1 = 1)
 Performs the operation: this = this/(c1*f1)
 This function is not implemented
Bool_t Divide(const TH1* h1)
Divide this profile2D by h1*-*-
*-*                  ===========================

   this = this/h1

   This function return kFALSE if the divide operation failed
Bool_t Divide(const TH1* h1, const TH1* h2, Double_t c1 = 1, Double_t c2 = 1, Option_t* option = "")
-*-*Replace contents of this profile2D by the division of h1 by h2
*-*      ==============================================================

   this = c1*h1/(c2*h2)

   This function return kFALSE if the divide operation failed
Int_t Fill(Double_t x, Double_t y, Double_t z, Double_t t)
-*-*-*Fill a Profile3D histogram (no weights)
*-*                  =======================================
Int_t Fill(Double_t x, Double_t y, Double_t z, Double_t t, Double_t w)
-*-*-*Fill a Profile3D histogram with weights
*-*                  =======================================
Double_t GetBinContent(Int_t bin) const
Return bin content of a Profile3D histogram*-*-
*-*          ===========================================
Double_t GetBinEntries(Int_t bin) const
Return bin entries of a Profile3D histogram*-*-
*-*          ===========================================
Double_t GetBinEffectiveEntries(Int_t bin)
            Return bin effective entries for a weighted filled Profile histogram.
            In case of an unweighted profile, it is equivalent to the number of entries per bin
            The effective entries is defined as the square of the sum of the weights divided by the
            sum of the weights square.
            TProfile::Sumw2() must be called before filling the profile with weights.
            Only by calling this method the  sum of the square of the weights per bin is stored.

*-*          =========================================
Double_t GetBinError(Int_t bin) const
 *-*-*-*-*-*-*Return bin error of a Profile3D histogram*-*-*-*-*-*-*-*-*

 Computing errors: A moving field

 The computation of errors for a TProfile3D has evolved with the versions
 of ROOT. The difficulty is in computing errors for bins with low statistics.
 - prior to version 3.10, we had no special treatment of low statistic bins.
   As a result, these bins had huge errors. The reason is that the
   expression eprim2 is very close to 0 (rounding problems) or 0.
 - The algorithm is modified/protected for the case
   when a TProfile3D is projected (ProjectionX). The previous algorithm
   generated a N^2 problem when projecting a TProfile3D with a large number of
   bins (eg 100000).
 - in version 3.10/02, a new static function TProfile::Approximate
   is introduced to enable or disable (default) the approximation.
   (see also comments in TProfile::GetBinError)
Option_t * GetErrorOption() const
-*-*Return option to compute profile2D errors
*-*                =========================================
void GetStats(Double_t* stats) const
 fill the array stats from the contents of this profile
 The array stats must be correctly dimensionned in the calling program.
 stats[0] = sumw
 stats[1] = sumw2
 stats[2] = sumwx
 stats[3] = sumwx2
 stats[4] = sumwy
 stats[5] = sumwy2
 stats[6] = sumwxy
 stats[7] = sumwz
 stats[8] = sumwz2
 stats[9] = sumwxz
 stats[10]= sumwyz
 stats[11]= sumwt
 stats[12]= sumwt2

 If no axis-subrange is specified (via TAxis::SetRange), the array stats
 is simply a copy of the statistics quantities computed at filling time.
 If a sub-range is specified, the function recomputes these quantities
 from the bin contents in the current axis range.
Long64_t Merge(TCollection* list)
Merge all histograms in the collection in this histogram.
This function computes the min/max for the axes,
compute a new number of bins, if necessary,
add bin contents, errors and statistics.
If overflows are present and limits are different the function will fail.
The function returns the total number of entries in the result histogram
if the merge is successfull, -1 otherwise.

IMPORTANT remark. The 2 axis x and y may have different number
of bins and different limits, BUT the largest bin width must be
a multiple of the smallest bin width and the upper limit must also
be a multiple of the bin width.
Bool_t Multiply(TF1* h1, Double_t c1 = 1)
 Performs the operation: this = this*c1*f1
Bool_t Multiply(const TH1* h1)
Multiply this profile2D by h1*-
*-*                  =============================

   this = this*h1

Bool_t Multiply(const TH1* h1, const TH1* h2, Double_t c1 = 1, Double_t c2 = 1, Option_t* option = "")
-*-*-*Replace contents of this profile2D by multiplication of h1 by h2
*-*      ================================================================

   this = (c1*h1)*(c2*h2)

TH3D * ProjectionXYZ(const char* name = "_pxyz", Option_t* option = "e") const
Project this profile3D into a 3-D histogram along X,Y,Z*-*-
*-*      =====================================================

   The projection is always of the type TH3D.

   if option "E" is specified, the errors are computed. (default)
   if option "B" is specified, the content of bin of the returned histogram
      will be equal to the GetBinEntries(bin) of the profile,
   if option "C=E" the bin contents of the projection are set to the
       bin errors of the profile
   if option "E" is specified  the errors of the projected histogram are computed and set
      to be equal to the errors of the profile.
      Option "E" is defined as the default one in the header file.
   if option "" is specified the histogram errors are simply the sqrt of its content
   if option "B" is specified, the content of bin of the returned histogram
      will be equal to the GetBinEntries(bin) of the profile,
   if option "C=E" the bin contents of the projection are set to the
       bin errors of the profile
   if option "W" is specified the bin content of the projected histogram  is set to the
       product of the bin content of the profile and the entries.
       With this option the returned histogram will be equivalent to the one obtained by
       filling directly a TH2D using the 3-rd value as a weight.
       This option makes sense only for profile filled with all weights =1.
       When the profile is weighted (filled with weights different than 1) the
       bin error of the projected histogram (obtained using this option "W") cannot be
       correctly computed from the information stored in the profile. In that case the
       obtained histogram contains as bin error square the weighted sum of the square of the
       profiled observable (TProfile2D::fSumw2[bin] )
TProfile2D * Project3DProfile(Option_t* option = "xy") const
 *-*-*-*-*Project a 3-D profile into a 2D-profile histogram depending
 on the option parameter
 option may contain a combination of the characters x,y,z
 option = "xy" return the x versus y projection into a TProfile2D histogram
 option = "yx" return the y versus x projection into a TProfile2D histogram
 option = "xz" return the x versus z projection into a TProfile2D histogram
 option = "zx" return the z versus x projection into a TProfile2D histogram
 option = "yz" return the y versus z projection into a TProfile2D histogram
 option = "zy" return the z versus y projection into a TProfile2D histogram
 NB: the notation "a vs b" means "a" vertical and "b" horizontalalong X*-*-*-*-*-*

   The resulting profile contains the combination of all the considered bins along X
   By default, all bins are included considering also underflow/overflows

   The option can also be used to specify the projected profile error type.
   Values which can be used are 's', 'i', or 'g'. See TProfile::BuildOptions for details

   To select a bin range along an axis, use TAxis::SetRange, eg
     h3.GetYaxis()->SetRange(23,56);


TProfile2D * DoProjectProfile2D(const char* name, const char* title, const TAxis* projX, const TAxis* projY, bool originalRange, bool useUF, bool useOF) const
 internal method to project to a 2D Profile
 called from TH3::Project3DProfile but re-implemented in case of the TPRofile3D since what is done is different
void PutStats(Double_t* stats)
 Replace current statistics with the values in array stats
void Reset(Option_t* option = "")
-*-*Reset contents of a Profile3D histogram
*-*                =======================================
void ExtendAxis(Double_t x, TAxis* axis)
 Profile histogram is resized along axis such that x is in the axis range.
 The new axis limits are recomputed by doubling iteratively
 the current axis range until the specified value x is within the limits.
 The algorithm makes a copy of the histogram, then loops on all bins
 of the old histogram to fill the rebinned histogram.
 Takes into account errors (Sumw2) if any.
 The axis must be rebinnable before invoking this function.
 Ex: h->GetXaxis()->SetCanExtend(kTRUE)
void SavePrimitive(ostream& out, Option_t* option = "")
 Save primitive as a C++ statement(s) on output stream out
void Scale(Double_t c1 = 1, Option_t* option = "")
 *-*-*-*-*Multiply this profile2D by a constant c1*-*-*-*-*-*-*-*-*
 *-*      ========================================

   this = c1*this

 This function uses the services of TProfile3D::Add

void SetBinEntries(Int_t bin, Double_t w)
Set the number of entries in bin*-*-*-
*-*              ================================
void SetBins(Int_t nbinsx, Double_t xmin, Double_t xmax, Int_t nbinsy, Double_t ymin, Double_t ymax, Int_t nbinsz, Double_t zmin, Double_t zmax)
   -*-*-*-*-*-*-*Redefine  x, y and z axis parameters*-*-*-*-*-*-*-*-*-*-*-*
*-*              ===========================
void SetBins(Int_t nx, const Double_t* xBins, Int_t ny, const Double_t* yBins, Int_t nz, const Double_t* zBins)
   -*-*-*-*-*-*-*Redefine  x, y and z axis parameters with variable bin sizes *-*-*-*-*-*-*-*-*

void SetBinsLength(Int_t n = -1)
 Set total number of bins including under/overflow
 Reallocate bin contents array
void SetBuffer(Int_t buffersize, Option_t* opt = "")
 set the buffer size in units of 8 bytes (double)
void SetErrorOption(Option_t* option = "")
-*-*Set option to compute profile3D errors
*-*                =======================================

    The computation of the bin errors is based on the parameter option:
    option:
     ' '  (Default) The bin errors are the standard error on the mean of the bin profiled values (T),
                    i.e. the standard error of the bin contents.
                    Note that if TProfile3D::Approximate()  is called, an approximation is used when
                    the spread in T is 0 and the number of bin entries  is > 0

     's'            The bin errors are the standard deviations of the T bin values
                    Note that if TProfile3D::Approximate()  is called, an approximation is used when
                    the spread in T is 0 and the number of bin entries is > 0

     'i'            Errors are as in default case (standard errors of the bin contents)
                    The only difference is for the case when the spread in T is zero.
                    In this case for N > 0 the error is  1./SQRT(12.*N)

     'g'            Errors are 1./SQRT(W)  for W not equal to 0 and 0 for W = 0.
                    W is the sum in the bin of the weights of the profile.
                    This option is for combining measurements t +/- dt,
                    and  the profile is filled with values t and weights w = 1/dt**2

   See TProfile::BuildOptions for explanation of all options
void Sumw2(Bool_t flag = kTRUE)
 Create/Delete structure to store sum of squares of weights per bin  *-*-*-*-*-*-*-*
   This is needed to compute  the correct statistical quantities
    of a profile filled with weights


  This function is automatically called when the histogram is created
  if the static function TH1::SetDefaultSumw2 has been called before.
  If flag = false the structure is deleted
Int_t BufferFill(Double_t , Double_t )
{return -2;}
Int_t BufferFill(Double_t , Double_t , Double_t )
{return -2;}
Int_t BufferFill(Double_t , Double_t , Double_t , Double_t )
{return -2;}
void SetBins(const Int_t* nbins, const Double_t* range)
 helper methods for the Merge unification in TProfileHelper
Int_t Fill(const Double_t* v)
{ return Fill(v[0], v[1], v[2], v[3], v[4]); }
Int_t Fill(Double_t , Double_t , Double_t )
{return TH3::Fill(0); }
Int_t Fill(const char* , const char* , const char* , Double_t )
{return TH3::Fill(0); }
Int_t Fill(const char* , Double_t , const char* , Double_t )
{return TH3::Fill(0); }
Int_t Fill(const char* , const char* , Double_t , Double_t )
{return TH3::Fill(0); }
Int_t Fill(Double_t , const char* , const char* , Double_t )
{return TH3::Fill(0); }
Int_t Fill(Double_t , const char* , Double_t , Double_t )
{return TH3::Fill(0); }
Int_t Fill(Double_t , Double_t , const char* , Double_t )
{return TH3::Fill(0); }
Double_t RetrieveBinContent(Int_t bin) const
virtual void     UpdateBinContent(Int_t bin, Double_t content);
{ return (fBinEntries.fArray[bin] > 0) ? fArray[bin]/fBinEntries.fArray[bin] : 0; }
Double_t GetBinErrorSqUnchecked(Int_t bin) const
{ Double_t err = GetBinError(bin); return err*err; }
Double_t * GetB()
{return &fBinEntries.fArray[0];}
Double_t * GetB2()
{return (fBinSumw2.fN ? &fBinSumw2.fArray[0] : 0 ); }
Double_t * GetW()
{return &fArray[0];}
Double_t * GetW2()
{return &fSumw2.fArray[0];}
void SetBins(Int_t , Double_t , Double_t )
{ MayNotUse("SetBins(Int_t, Double_t, Double_t"); }
void SetBins(Int_t , const Double_t* )
{ MayNotUse("SetBins(Int_t, const Double_t*"); }
void SetBins(Int_t , Double_t , Double_t , Int_t , Double_t , Double_t )
{ MayNotUse("SetBins(Int_t, Double_t, Double_t, Int_t, Double_t, Double_t"); }
void SetBins(Int_t , const Double_t* , Int_t , const Double_t* )
{ MayNotUse("SetBins(Int_t, const Double_t*, Int_t, const Double_t*"); }
Double_t GetBinContent(Int_t bin) const
Double_t GetBinContent(Int_t , Int_t ) const
{ MayNotUse("GetBinContent(Int_t, Int_t"); return -1; }
Double_t GetBinError(Int_t bin) const
Double_t GetBinError(Int_t , Int_t ) const
{ MayNotUse("GetBinError(Int_t, Int_t"); return -1; }
TArrayD * GetBinSumw2()
{return &fBinSumw2;}
const TArrayD * GetBinSumw2() const
{return &fBinSumw2;}
Double_t GetTmin() const
{return fTmin;}
Double_t GetTmax() const
{return fTmax;}