113TProfile3D::TProfile3D(
const char *
name,
const char *title,
Int_t nx,
Double_t xlow,
Double_t xup,
Int_t ny,
Double_t ylow,
Double_t yup,
Int_t nz, 
Double_t zlow,
Double_t zup,
Option_t *
option)
 
  114    : 
TH3D(
name,title,
nx,xlow,xup,
ny,ylow,yup,
nz,
zlow,
zup)
 
 
  174   Error(
"Add",
"Function not implemented for TProfile3D");
 
 
  184      Error(
"Add",
"Attempt to add a non-existing profile");
 
  188      Error(
"Add",
"Attempt to add a non-profile2D object");
 
 
  203      Error(
"Add",
"Attempt to add a non-existing profile");
 
  207      Error(
"Add",
"Attempt to add a non-profile3D object");
 
  211      Error(
"Add",
"Attempt to add a non-profile3D object");
 
 
  254      if (
action == 0) 
return 0;
 
  276         if (z < zmin) zmin = z;
 
  277         if (z > zmax) zmax = z;
 
  297      Fill(buffer[5*i+2],buffer[5*i+3],buffer[5*i+4],buffer[5*i+5],buffer[5*i+1]);
 
 
  358      for (
int bin=0;bin<
fNcells;bin++) {
 
  370      Fatal(
"Copy",
"Cannot copy a TProfile3D in a %s",obj.
IsA()->GetName());
 
 
  381   Error(
"Divide",
"Function not implemented for TProfile3D");
 
 
  395      Error(
"Divide",
"Attempt to divide a non-existing profile2D");
 
  399      Error(
"Divide",
"Attempt to divide a non-profile3D object");
 
  409   if (
nx != 
p1->GetNbinsX()) {
 
  410      Error(
"Divide",
"Attempt to divide profiles with different number of bins");
 
  414   if (
ny != 
p1->GetNbinsY()) {
 
  415      Error(
"Divide",
"Attempt to divide profiles with different number of bins");
 
  419   if (
nz != 
p1->GetNbinsZ()) {
 
  420      Error(
"Divide",
"Attempt to divide profiles with different number of bins");
 
  473      Warning(
"Divide",
"Cannot preserve during the division of profiles the sum of bin weight square");
 
 
  493      Error(
"Divide",
"Attempt to divide a non-existing profile2D");
 
  497      Error(
"Divide",
"Attempt to divide a non-profile2D object");
 
  502      Error(
"Divide",
"Attempt to divide a non-profile2D object");
 
  509   if (
nx != 
p1->GetNbinsX() || 
nx != 
p2->GetNbinsX()) {
 
  510      Error(
"Divide",
"Attempt to divide profiles with different number of bins");
 
  514   if (
ny != 
p1->GetNbinsY() || 
ny != 
p2->GetNbinsY()) {
 
  515      Error(
"Divide",
"Attempt to divide profiles with different number of bins");
 
  519   if (
nz != 
p1->GetNbinsZ() || 
nz != 
p2->GetNbinsZ()) {
 
  520      Error(
"Divide",
"Attempt to divide profiles with different number of bins");
 
  524      Error(
"Divide",
"Coefficient of dividing profile cannot be zero");
 
  548            if (b2) 
w = 
c1*b1/(
c2*b2);
 
 
  877   Error(
"LabelsOption",
"Labels option function is not implemented for a TProfile3D");
 
 
  904   Error(
"Multiply",
"Function not implemented for TProfile3D");
 
 
  915   Error(
"Multiply",
"Multiplication of profile2D histograms not implemented");
 
 
  926   Error(
"Multiply",
"Multiplication of profile2D histograms not implemented");
 
 
  975   if (
pname == 
"_px") {
 
  979   if (xbins->fN == 0 && 
ybins->fN == 0 && 
zbins->fN == 0)
 
  980      h1 = 
new TH3D(
pname,
GetTitle(),
nx,
fXaxis.
GetXmin(),
fXaxis.
GetXmax(),
ny,
fYaxis.
GetXmin(),
fYaxis.
GetXmax(),
nz,
fZaxis.
GetXmin(),
fZaxis.
GetXmax());
 
  981   else if ( xbins->fN != 0 && 
ybins->fN != 0 && 
zbins->fN != 0)
 
  984      Error(
"ProjectionXYZ",
"Histogram has an axis with variable bins and an axis with fixed bins. This case is not supported - return a null pointer");
 
 
 1090      if (xbins->fN == 0 && 
ybins->fN == 0) {
 
 1097      if (xbins->fN == 0 && 
ybins->fN == 0) {
 
 1113   h3dW->SetDirectory(
nullptr); 
h3dN->SetDirectory(
nullptr);
 
 1144   h2W->SetDirectory(
nullptr); 
h2N->SetDirectory(
nullptr);
 
 1151   for (
int i = 0; i < 
p2->fN ; ++i) {
 
 1153      p2->fArray[i] = 
h2W->fArray[i];   
 
 1154      p2->GetSumw2()->fArray[i]  = 
h2W->GetSumw2()->fArray[i];   
 
 1155      p2->SetBinEntries(i, 
h2N->fArray[i] );
 
 1156      if (
useWeights) 
p2->GetBinSumw2()->fArray[i] = 
h2N->GetSumw2()->fArray[i];    
 
 1166   p2->SetEntries( 
p2->GetEffectiveEntries() );
 
 
 1238      out << 
sxaxis << 
".data()";
 
 1244      out << 
syaxis << 
".data()";
 
 1250      out << 
szaxis << 
".data()";
 
 1278            out << 
"   " << 
hname << 
"->SetBinEntries(" << bin << 
"," << entries[bin] << 
");\n";
 
 1282            out << 
"   " << 
hname << 
"->SetBinContent(" << bin << 
"," << 
content[bin] << 
");\n";
 
 1287               out << 
"   " << 
hname << 
"->SetBinError(" << bin << 
"," << 
errors[bin] << 
");\n";
 
 1292         out << 
"   for (Int_t bin = 0; bin < " << 
fNcells << 
"; bin++)\n";
 
 1293         out << 
"      if (" << 
vect << 
"[bin])\n";
 
 1294         out << 
"         " << 
hname << 
"->SetBinEntries(bin, " << 
vect << 
"[bin]);\n";
 
 1298         out << 
"   for (Int_t bin = 0; bin < " << 
fNcells << 
"; bin++)\n";
 
 1299         out << 
"      if (" << 
vect << 
"[bin])\n";
 
 1300         out << 
"         " << 
hname << 
"->SetBinContent(bin, " << 
vect << 
"[bin]);\n";
 
 1304         out << 
"   for (Int_t bin = 0; bin < " << 
fNcells << 
"; bin++)\n";
 
 1305         out << 
"      if (" << 
vect << 
"[bin])\n";
 
 1306         out << 
"         " << 
hname << 
"->SetBinError(bin, " << 
vect << 
"[bin]);\n";
 
 
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
 
#define R__ASSERT(e)
Checks condition e and reports a fatal error if it's false.
 
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
 
void Warning(const char *location, const char *msgfmt,...)
Use this function in warning situations.
 
void Fatal(const char *location, const char *msgfmt,...)
Use this function in case of a fatal error. It will abort the program.
 
Array of doubles (64 bits per element).
 
void Copy(TArrayD &array) const
 
void Set(Int_t n) override
Set size of this array to n doubles.
 
TArrayD()
Default TArrayD ctor.
 
Class to manage histogram axis.
 
virtual Double_t GetBinCenter(Int_t bin) const
Return center of bin.
 
const TArrayD * GetXbins() const
 
virtual Int_t FindBin(Double_t x)
Find bin number corresponding to abscissa x.
 
Int_t GetLast() const
Return last bin on the axis i.e.
 
Int_t GetFirst() const
Return first bin on the axis i.e.
 
Collection abstract base class.
 
TH1 is the base class of all histogram classes in ROOT.
 
Double_t * fBuffer
[fBufferSize] entry buffer
 
Int_t fNcells
Number of bins(1D), cells (2D) +U/Overflows.
 
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.
 
virtual Int_t GetNbinsY() const
 
virtual Int_t GetNbinsZ() const
 
@ kIsNotW
Histogram is forced to be not weighted even when the histogram is filled with weighted.
 
virtual Bool_t CanExtendAllAxes() const
Returns true if all axes are extendable.
 
virtual Int_t GetNbinsX() const
 
Int_t fBufferSize
fBuffer size
 
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...
 
virtual void SetBinError(Int_t bin, Double_t error)
Set the bin Error Note that this resets the bin eror option to be of Normal Type and for the non-empt...
 
static Int_t fgBufferSize
! Default buffer size for automatic histograms
 
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,...
 
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
 
@ kNstat
Size of statistics data (up to TProfile3D)
 
Double_t fEntries
Number of entries.
 
TAxis fZaxis
Z axis descriptor.
 
virtual TArrayD * GetSumw2()
 
TAxis fXaxis
X axis descriptor.
 
TArrayD fSumw2
Array of sum of squares of weights.
 
Bool_t GetStatOverflowsBehaviour() const
 
TAxis fYaxis
Y axis descriptor.
 
virtual void SetBins(Int_t nx, Double_t xmin, Double_t xmax)
Redefine x axis parameters.
 
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.
 
2-D histogram with a double per channel (see TH1 documentation)
 
3-D histogram with a double per channel (see TH1 documentation)
 
void SetBinsLength(Int_t n=-1) override
Set total number of bins including under/overflow Reallocate bin contents array.
 
void Copy(TObject &hnew) const override
Copy this 3-D histogram structure to newth3.
 
void AddBinContent(Int_t bin) override
Increment bin content by 1.
 
Double_t fTsumwy
Total Sum of weight*Y.
 
Double_t fTsumwy2
Total Sum of weight*Y*Y.
 
virtual TH2D * DoProject2D(const char *name, const char *title, const TAxis *projX, const TAxis *projY, bool computeErrors, bool originalRange, bool useUF, bool useOF) const
internal method performing the projection to a 2D histogram called from TH3::Project3D
 
Double_t fTsumwxz
Total Sum of weight*X*Z.
 
virtual TProfile2D * Project3DProfile(Option_t *option="xy") const
Project a 3-d histogram into a 2-d profile histograms depending on the option parameter option may co...
 
Double_t fTsumwz2
Total Sum of weight*Z*Z.
 
Double_t fTsumwxy
Total Sum of weight*X*Y.
 
Double_t fTsumwz
Total Sum of weight*Z.
 
Double_t fTsumwyz
Total Sum of weight*Y*Z.
 
Int_t GetBin(Int_t binx, Int_t biny, Int_t binz) const override
See comments in TH1::GetBin.
 
void PutStats(Double_t *stats) override
Replace current statistics with the values in array stats.
 
static THLimitsFinder * GetLimitsFinder()
Return pointer to the current finder.
 
const char * GetName() const override
Returns name of object.
 
const char * GetTitle() const override
Returns title of object.
 
Mother of all ROOT objects.
 
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
 
static TString SavePrimitiveVector(std::ostream &out, const char *prefix, Int_t len, Double_t *arr, Bool_t empty_line=kFALSE)
Save array in the output stream "out" as vector.
 
virtual const char * ClassName() const
Returns name of class to which the object belongs.
 
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
 
virtual TClass * IsA() const
 
Profile2D histograms are used to display the mean value of Z and its error for each cell in X,...
 
Profile3D histograms are used to display the mean value of T and its RMS for each cell in X,...
 
TProfile3D & operator=(const TProfile3D &profile)
 
TProfile2D * DoProjectProfile2D(const char *name, const char *title, const TAxis *projX, const TAxis *projY, bool originalRange, bool useUF, bool useOF) const override
Internal method to project to a 2D Profile.
 
Long64_t Merge(TCollection *list) override
Merge all histograms in the collection in this histogram.
 
static Bool_t fgApproximate
Bin error approximation option.
 
Option_t * GetErrorOption() const
Return option to compute profile2D errors.
 
Bool_t fScaling
! True when TProfile3D::Scale is called
 
void SetBins(const Int_t *nbins, const Double_t *range)
 
void PutStats(Double_t *stats) override
Replace current statistics with the values in array stats.
 
void Copy(TObject &hnew) const override
Copy a Profile3D histogram to a new profile2D histogram.
 
Int_t BufferFill(Double_t, Double_t) override
accumulate arguments in buffer.
 
void SetBuffer(Int_t bufsize, Option_t *opt="") override
Set the buffer size in units of 8 bytes (double).
 
Double_t fTsumwt2
Total Sum of weight*T*T.
 
virtual Double_t GetBinEffectiveEntries(Int_t bin)
Return bin effective entries for a weighted filled Profile histogram.
 
void GetStats(Double_t *stats) const override
fill the array stats from the contents of this profile.
 
Bool_t Multiply(TF1 *h1, Double_t c1=1) override
Performs the operation: this = this*c1*f1 .
 
void LabelsOption(Option_t *option="h", Option_t *axis="X") override
Set option(s) to draw axis with labels.
 
TProfile3D()
Default constructor for Profile3D histograms.
 
TArrayD fBinEntries
Number of entries per bin.
 
void LabelsDeflate(Option_t *axis="X") override
Reduce the number of bins for this axis to the number of bins having a label.
 
~TProfile3D() override
Default destructor for Profile3D histograms.
 
void ExtendAxis(Double_t x, TAxis *axis) override
Profile histogram is resized along axis such that x is in the axis range.
 
Double_t fTmin
Lower limit in T (if set)
 
void Scale(Double_t c1=1, Option_t *option="") override
Multiply this profile2D by a constant c1.
 
void Sumw2(Bool_t flag=kTRUE) override
Create/Delete structure to store sum of squares of weights per bin This is needed to compute the corr...
 
void LabelsInflate(Option_t *axis="X") override
Double the number of bins for axis.
 
TProfile2D * Project3DProfile(Option_t *option="xy") const override
Project a 3-D profile into a 2D-profile histogram depending on the option parameter.
 
virtual void SetBinEntries(Int_t bin, Double_t w)
Set the number of entries in bin.
 
void BuildOptions(Double_t tmin, Double_t tmax, Option_t *option)
Set Profile3D histogram structure and options.
 
Int_t Fill(const Double_t *v)
 
TArrayD fBinSumw2
Array of sum of squares of weights per bin.
 
Int_t BufferEmpty(Int_t action=0) override
Fill histogram with all entries in the buffer.
 
void SavePrimitive(std::ostream &out, Option_t *option="") override
Save primitive as a C++ statement(s) on output stream out.
 
virtual void SetErrorOption(Option_t *option="")
Set option to compute profile3D errors.
 
virtual TH3D * ProjectionXYZ(const char *name="_pxyz", Option_t *option="e") const
Project this profile3D into a 3-D histogram along X,Y,Z.
 
Bool_t Add(TF1 *h1, Double_t c1=1, Option_t *option="") override
Performs the operation: this = this + c1*f1 .
 
Double_t GetBinContent(Int_t bin) const override
Return bin content of a Profile3D histogram.
 
EErrorType fErrorMode
Option to compute errors.
 
void SetBinsLength(Int_t n=-1) override
Set total number of bins including under/overflow.
 
virtual Double_t GetBinEntries(Int_t bin) const
Return bin entries of a Profile3D histogram.
 
Bool_t Divide(TF1 *h1, Double_t c1=1) override
Performs the operation: this = this/(c1*f1) .
 
Double_t fTsumwt
Total Sum of weight*T.
 
static void Approximate(Bool_t approx=kTRUE)
Set the fgApproximate flag.
 
Double_t fTmax
Upper limit in T (if set)
 
Double_t GetBinError(Int_t bin) const override
Return bin error of a Profile3D histogram.
 
static void LabelsInflate(T *p, Option_t *)
 
static Double_t GetBinError(T *p, Int_t bin)
 
static T * ExtendAxis(T *p, Double_t x, TAxis *axis)
 
static void Sumw2(T *p, Bool_t flag)
 
static void SetBinEntries(T *p, Int_t bin, Double_t w)
 
static void Scale(T *p, Double_t c1, Option_t *option)
 
static void SetErrorOption(T *p, Option_t *opt)
 
static Long64_t Merge(T *p, TCollection *list)
 
static void BuildArray(T *p)
 
static Bool_t Add(T *p, const TH1 *h1, const TH1 *h2, Double_t c1, Double_t c2=1)
 
static Double_t GetBinEffectiveEntries(T *p, Int_t bin)
 
static void LabelsDeflate(T *p, Option_t *)
 
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...
 
void ToUpper()
Change string to upper case.
 
TString & Append(const char *cs)
 
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
 
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.