// @(#)root/histpainter:$Id$
// Author: Rene Brun   26/08/99

/*************************************************************************
 * 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.             *
 *************************************************************************/

#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <ctype.h>

#include "Riostream.h"
#include "TROOT.h"
#include "TClass.h"
#include "TSystem.h"
#include "THistPainter.h"
#include "TH2.h"
#include "TH2Poly.h"
#include "TH3.h"
#include "TProfile.h"
#include "TProfile2D.h"
#include "THStack.h"
#include "TF2.h"
#include "TF3.h"
#include "TCutG.h"
#include "TMatrixDBase.h"
#include "TMatrixFBase.h"
#include "TVectorD.h"
#include "TVectorF.h"
#include "TCanvas.h"
#include "TPad.h"
#include "TPaveStats.h"
#include "TFrame.h"
#include "TLatex.h"
#include "TLine.h"
#include "TPolyLine.h"
#include "TPoints.h"
#include "TStyle.h"
#include "TGraph.h"
#include "TMultiGraph.h"
#include "TPie.h"
#include "TGaxis.h"
#include "TColor.h"
#include "TPainter3dAlgorithms.h"
#include "TGraph2DPainter.h"
#include "TGraphDelaunay.h"
#include "TView.h"
#include "TMath.h"
#include "TRandom2.h"
#include "TObjArray.h"
#include "TVectorD.h"
#include "Hoption.h"
#include "Hparam.h"
#include "TPluginManager.h"
#include "TPaletteAxis.h"
#include "TCrown.h"
#include "TVirtualPadEditor.h"
#include "TEnv.h"
#include "TPoint.h"


//______________________________________________________________________________
/* Begin_Html
<center><h2>The histogram painter class</h2></center>

<ul>
<li><a href="#HP00">Introduction</li></a>
<li><a href="#HP01">Histograms' plotting options</li></a>
<ul>
<li><a href="#HP01a">Options supported for 1D and 2D histograms</li></a>
<li><a href="#HP01b">Options supported for 1D histograms</li></a>
<li><a href="#HP01c">Options supported for 2D histograms</li></a>
<li><a href="#HP01d">Options supported for 3D histograms</li></a>
<li><a href="#HP01e">Options supported for histograms' stacks (<tt>THStack</tt>)</li></a>
</ul>
<li><a href="#HP02">Setting the Style</li></a>
<li><a href="#HP03">Setting line, fill, marker, and text attributes</li></a>
<li><a href="#HP04">Setting Tick marks on the histogram axis</li></a>
<li><a href="#HP05">Giving titles to the X, Y and Z axis</li></a>
<li><a href="#HP060">The option "SAME"</li></a>
<ul>
<li><a href="#HP060a">Limitations</li></a>
</ul>
<li><a href="#HP06">Superimposing two histograms with different scales in the same pad</li></a>
<li><a href="#HP07">Statistics Display</li></a>
<li><a href="#HP08">Fit Statistics</li></a>
<li><a href="#HP09">The error bars options</li></a>
<li><a href="#HP100">The bar chart option</li></a>
<li><a href="#HP10">The "BAR" and "HBAR" options</li></a>
<li><a href="#HP11">The SCATter plot option (default for 2D histograms)</li></a>
<li><a href="#HP12">The ARRow option</li></a>
<li><a href="#HP13">The BOX option</li></a>
<li><a href="#HP14">The COLor option</li></a>
<li><a href="#HP140">The CANDLE option</li></a>
<li><a href="#HP15">The TEXT and TEXTnn Option</li></a>
<li><a href="#HP16">The CONTour options</li></a>
<ul>
<li><a href="#HP16a">The LIST option</li></a>
</ul>
<li><a href="#HP17">The LEGO options</li></a>
<li><a href="#HP18">The "SURFace" options</li></a>
<li><a href="#HP19">Cylindrical, Polar, Spherical and PseudoRapidity/Phi options</li></a>
<li><a href="#HP20">Base line for bar-charts and lego plots</li></a>
<li><a href="#HP20a">TH2Poly Drawing</li></a>
<li><a href="#HP21">The SPEC option</li></a>
<li><a href="#HP22">Option "Z" : Adding the color palette on the right side of the pad</li></a>
<li><a href="#HP23">Setting the color palette</li></a>
<li><a href="#HP24">Drawing a sub-range of a 2-D histogram; the [cutg] option</li></a>
<li><a href="#HP25">Drawing options for 3D histograms</li></a>
<li><a href="#HP26">Drawing option for histograms' stacks</li></a>
<li><a href="#HP27">Drawing of 3D implicit functions</li></a>
<li><a href="#HP28">Associated functions drawing</li></a>
<li><a href="#HP29">Drawing using OpenGL</li></a>
<ul>
<li><a href="#HP29a">General information: plot types and supported options</li></a>
<li><a href="#HP29b">TH3 as boxes (spheres)</li></a>
<li><a href="#HP29c">TH3 as iso-surface(s)</li></a>
<li><a href="#HP29d">TF3 (implicit function)</li></a>
<li><a href="#HP29e">Parametric surfaces</li></a>
<li><a href="#HP29f">Interaction with the plots</li></a>
<li><a href="#HP29g">Selectable parts</li></a>
<li><a href="#HP29h">Rotation and zooming</li></a>
<li><a href="#HP29i">Panning</li></a>
<li><a href="#HP29j">Box cut</li></a>
<li><a href="#HP29k">Plot specific interactions (dynamic slicing etc.)</li></a>
<li><a href="#HP29l">Surface with option "GLSURF"</li></a>
<li><a href="#HP29m">TF3</li></a>
<li><a href="#HP29n">Box</li></a>
<li><a href="#HP29o">Iso</li></a>
<li><a href="#HP29p">Parametric plot</li></a>
</ul>
</ul>


<a name="HP00"></a><h3>Introduction</h3>


Histograms are drawn via the <tt>THistPainter</tt> class. Each histogram has a
pointer to its own painter (to be usable in a multithreaded program). When the
canvas has to be redrawn, the <tt>Paint</tt> function of each objects in the
pad is called. In case of histograms, <tt>TH1::Paint</tt> invokes directly
<tt>THistPainter::Paint</tt>.

<p>To draw a histogram "<tt>h</tt>" is enough to do:
<pre>
      h->Draw();
</pre>
"<tt>h</tt>" can be of any kind: 1D, 2D or 3D. To choose how the histogram will
be drawn, the <tt>Draw()</tt> method can be invoked with an option. For instance
to draw a 2D histogram as a lego plot it is enough to do:
<pre>
      h->Draw("lego");
</pre>
<tt>THistPainter</tt> offers many options to paint 1D, 2D and 3D histograms.

<p>When the <tt>Draw()</tt> method of a histogram is called for the first time
(<tt>TH1::Draw</tt>), it creates a <tt>THistPainter</tt> object and saves a
pointer to this "painter" as a data member of the histogram. The
<tt>THistPainter</tt> class specializes in the drawing of histograms. It is
separated from the histogram so that one can have histograms without the
graphics overhead, for example in a batch program. Each histogram have its own
painter rather than a central singleton painter painting all histograms, allows
two histograms to be drawn in two threads without overwriting the painter's
values.

<p>When a displayed histogram is filled again, there is not need to call the
<tt>Draw()</tt> method again; the image will be refreshed the next time the
pad will be updated.

<p>A pad is updated after one of these three actions:
<ol>
<li>  a carriage control on the ROOT command line,
<li>  a click inside the pad,
<li>  a call to <tt>TPad::Update</tt>.
</ol>

<p>By default a call to <tt>TH1::Draw()</tt> clears the pad of all objects
before drawing the new image of the histogram. One can use the <tt>"SAME"</tt>
option to leave the previous display intact and superimpose the new histogram.
The same histogram can be drawn with different graphics options in different
pads.

<p>When a displayed histogram is deleted, its image is automatically removed
from the pad.

<p> To create a copy of the histogram when drawing it, one can use
<tt>TH1::DrawClone()</tt>. This will clone the histogram and allow to change
and delete the original one without affecting the clone.


<a name="HP01"></a><h3>Histograms' plotting options</h3>


Most options can be concatenated with or without spaces or commas, for example:
<pre>
      h->Draw("E1 SAME");
</pre>
The options are not case sensitive:
<pre>
      h->Draw("e1 same");
</pre>

The default drawing option can be set with <tt>TH1::SetOption</tt> and retrieve
using <tt>TH1::GetOption</tt>:
<pre>
      root [0] h->Draw();          // Draw "h" using the standard histogram representation.
      root [1] h->Draw("E");       // Draw "h" using error bars
      root [3] h->SetOption("E");  // Change the default drawing option for "h"
      root [4] h->Draw();          // Draw "h" using error bars
      root [5] h->GetOption();     // Retrieve the default drawing option for "h"
      (const Option_t* 0xa3ff948)"E"
</pre>

<a name="HP01a"></a><h4><u>Options supported for 1D and 2D histograms</u></h4>

<table border=0>

<tr><th valign=top>"E"</th><td>
Draw error bars.
</td></tr>

<tr><th valign=top>"AXIS"</th><td>
Draw only axis.
</td></tr>

<tr><th valign=top>"AXIG"</th><td>
Draw only grid (if the grid is requested).
</td></tr>

<tr><th valign=top>"HIST"</th><td>
When an histogram has errors it is visualized by default with error bars. To
visualize it without errors use the option "HIST" together with the required
option (eg "hist same c").  The "HIST" option can also be used to plot only the
histogram and not the associated function(s).
</td></tr>

<tr><th valign=top>"FUNC"</th><td>
When an histogram has a fitted function, this option allows to draw the fit
result only.
</td></tr>

<tr><th valign=top>"SAME"</th><td>
Superimpose on previous picture in the same pad.
</td></tr>

<tr><th valign=top>"LEGO"</th><td>
Draw a lego plot with hidden line removal.
</td></tr>

<tr><th valign=top>"LEGO1"</th><td>
Draw a lego plot with hidden surface removal.
</td></tr>

<tr><th valign=top>"LEGO2"</th><td>
Draw a lego plot using colors to show the cell contents When the option "0" is
used with any LEGO option, the empty bins are not drawn.
</td></tr>

<tr><th valign=top>"LEGO3"</th><td>
Draw a lego plot with hidden surface removal, like LEGO1 but the border lines
of each lego-bar are not drawn.
</td></tr>

<tr><th valign=top>"LEGO4"</th><td>
Draw a lego plot with hidden surface removal, like LEGO1 but without the
shadow effect on each lego-bar.
</td></tr>

<tr><th valign=top>"TEXT"</th><td>
Draw bin contents as text (format set via <tt>gStyle->SetPaintTextFormat</tt>).
</td></tr>

<tr><th valign=top>"TEXTnn"</th><td>
Draw bin contents as text at angle nn (0 < nn < 90).
</td></tr>

<tr><th valign=top>"X+"</th><td>
The X-axis is drawn on the top side of the plot.
</td></tr>

<tr><th valign=top>"Y+"</th><td>
The Y-axis is drawn on the right side of the plot.
</td></tr>

</table>

<a name="HP01b"></a><h4><u>Options supported for 1D histograms</u></h4>

<table border=0>

<tr><th valign=top>" "</th><td>
Default.
</td></tr>

<tr><th valign=top>"AH"</th><td>
Draw histogram without axis. "A" can be combined with any drawing option. For
instance, "AC" draws the histogram as a smooth Curve without axis.
</td></tr>

<tr><th valign=top>"]["</th><td>
When this option is selected the first and last vertical lines of the histogram
are not drawn.
</td></tr>

<tr><th valign=top>"B"</th><td>
Bar chart option.
</td></tr>

<tr><th valign=top>"BAR"</th><td>
Like option "B", but bars can be drawn with a 3D effect.
</td></tr>

<tr><th valign=top>"HBAR"</th><td>
Like option "BAR", but bars are drawn horizontally.
</td></tr>

<tr><th valign=top>"C"</th><td>
Draw a smooth Curve through the histogram bins.
</td></tr>

<tr><th valign=top>"E0"</th><td>
Draw error bars. Markers are drawn for bins with 0 contents.
</td></tr>

<tr><th valign=top>"E1"</th><td>
Draw error bars with perpendicular lines at the edges.
</td></tr>

<tr><th valign=top>"E2"</th><td>
Draw error bars with rectangles.
</td></tr>

<tr><th valign=top>"E3"</th><td>
Draw a fill area through the end points of the vertical error bars.
</td></tr>

<tr><th valign=top>"E4"</th><td>
Draw a smoothed filled area through the end points of the error bars.
</td></tr>

<tr><th valign=top>"E5"</th><td>
Like E3 but ignore the bins with 0 contents.
</td></tr>

<tr><th valign=top>"E6"</th><td>
Like E4 but ignore the bins with 0 contents.
</td></tr>

<tr><th valign=top>"X0"</th><td>
When used with one of the "E" option, it suppress the error bar along
X as <tt>gStyle->SetErrorX(0)</tt> would do.
</td></tr>

<tr><th valign=top>"L"</th><td>
Draw a line through the bin contents.
</td></tr>

<tr><th valign=top>"P"</th><td>
Draw current marker at each bin except empty bins.
</td></tr>

<tr><th valign=top>"P0"</th><td>
Draw current marker at each bin including empty bins.
</td></tr>

<tr><th valign=top>"PIE"</th><td>
Draw histogram as a Pie Chart.
</td></tr>

<tr><th valign=top>"*H"</th><td>
Draw histogram with a * at each bin.
</td></tr>

<tr><th valign=top>"LF2"</th><td>
Draw histogram like with option "L" but with a fill area. Note that "L" draws
also a fill area if the hist fill color is set but the fill area corresponds to
the histogram contour.
</td></tr>

</table>

<a name="HP01c"></a><h4><u>Options supported for 2D histograms</u></h4>

<table border=0>

<tr><th valign=top>" "</th><td>
Default (scatter plot).
</td></tr>

<tr><th valign=top>"ARR"</th><td>
Arrow mode. Shows gradient between adjacent cells.
</td></tr>

<tr><th valign=top>"BOX"</th><td>
A box is drawn for each cell with surface proportional to the content's
absolute value. A negative content is marked with a X.
</td></tr>

<tr><th valign=top>"BOX1"</th><td>
A button is drawn for each cell with surface proportional to content's absolute
value. A sunken button is drawn for negative values a raised one for positive.
</td></tr>

<tr><th valign=top>"COL"</th><td>
A box is drawn for each cell with a color scale varying with contents. All the
none empty bins are painted. Empty bins are not painted unless some bins have
a negative content because in that case the null bins might be not empty.
<tt>TProfile2D</tt> histograms are handled differently because, for this type of 2D
histograms, it is possible to know if an empty bin has been filled or not. So even
if all the bins' contents are positive some empty bins might be painted. And vice versa,
if some bins have a negative content some empty bins might be not painted.
</td></tr>

<tr><th valign=top>"COLZ"</th><td>
Same as "COL". In addition the color palette is also drawn.
</td></tr>

<tr><th valign=top>"CANDLE"</th><td>
Draw a candle plot along X axis.
</td></tr>

<tr><th valign=top>"CANDLEX"</th><td>
Same as "CANDLE".
</td></tr>

<tr><th valign=top>"CANDLEY"</th><td>
Draw a candle plot along Y axis.
</td></tr>

<tr><th valign=top>"CONT"</th><td>
Draw a contour plot (same as CONT0).
</td></tr>

<tr><th valign=top>"CONT0"</th><td>
Draw a contour plot using surface colors to distinguish contours.
</td></tr>

<tr><th valign=top>"CONT1"</th><td>
Draw a contour plot using line styles to distinguish contours.
</td></tr>

<tr><th valign=top>"CONT2"</th><td>
Draw a contour plot using the same line style for all contours.
</td></tr>

<tr><th valign=top>"CONT3"</th><td>
Draw a contour plot using fill area colors.
</td></tr>

<tr><th valign=top>"CONT4"</th><td>
Draw a contour plot using surface colors (SURF option at theta = 0).
</td></tr>

<tr><th valign=top>"CONT5"</th><td>
(TGraph2D only) Draw a contour plot using Delaunay triangles.
</td></tr>

<tr><th valign=top>"LIST"</th><td>
Generate a list of TGraph objects for each contour.
</td></tr>

<tr><th valign=top>"CYL"</th><td>
Use Cylindrical coordinates. The X coordinate is mapped on the angle and the Y
coordinate on the cylinder length.
</td></tr>

<tr><th valign=top>"POL"</th><td>
Use Polar coordinates. The X coordinate is mapped on the angle and the Y
coordinate on the radius.
</td></tr>

<tr><th valign=top>"SPH"</th><td>
Use Spherical coordinates. The X coordinate is mapped on the latitude and the Y
coordinate on the longitude.
</td></tr>

<tr><th valign=top>"PSR"</th><td>
Use PseudoRapidity/Phi coordinates. The X coordinate is mapped on Phi.
</td></tr>

<tr><th valign=top>"SURF"</th><td>
Draw a surface plot with hidden line removal.
</td></tr>

<tr><th valign=top>"SURF1"</th><td>
Draw a surface plot with hidden surface removal.
</td></tr>

<tr><th valign=top>"SURF2"</th><td>
Draw a surface plot using colors to show the cell contents.
</td></tr>

<tr><th valign=top>"SURF3"</th><td>
Same as SURF with in addition a contour view drawn on the top.
</td></tr>

<tr><th valign=top>"SURF4"</th><td>
Draw a surface using Gouraud shading.
</td></tr>

<tr><th valign=top>"SURF5"</th><td>
Same as SURF3 but only the colored contour is drawn. Used with option CYL, SPH
or PSR it allows to draw colored contours on a sphere, a cylinder or a in
pseudo rapidity space. In cartesian or polar coordinates, option SURF3 is used.
</td></tr>

<tr><th valign=top>"FB"</th><td>
With LEGO or SURFACE, suppress the Front-Box.
</td></tr>

<tr><th valign=top>"BB"</th><td>
With LEGO or SURFACE, suppress the Back-Box.
</td></tr>

<tr><th valign=top>"A"</th><td>
With LEGO or SURFACE, suppress the axis.
</td></tr>

<tr><th valign=top>"SCAT"</th><td>
Draw a scatter-plot (default).
</td></tr>

<tr><th valign=top>"[cutg]"</th><td>
Draw only the sub-range selected by the TCutG named "cutg".
</td></tr>

</table>

<a name="HP01d"></a><h4><u>Options supported for 3D histograms</u></h4>

<table border=0>

<tr><th valign=top>" "</th><td>
Default (scatter plot).
</td></tr>

<tr><th valign=top>"ISO"</th><td>
Draw a Gouraud shaded 3d iso surface through a 3d histogram. It paints one
surface at the value computed as follow:
<tt>SumOfWeights/(NbinsX*NbinsY*NbinsZ)</tt>.
</td></tr>

<tr><th valign=top>"BOX"</th><td>
Draw a for each cell with volume proportional to the content's absolute value.
</td></tr>

<tr><th valign=top>"LEGO"</th><td>
Same as <tt>BOX</tt>.
</td></tr>

</table>

<a name="HP01e"></a><h4><u>Options supported for histograms' stacks (<tt>THStack</tt>)</u></h4>

<table border=0>

<tr><th valign=top>" "</th><td>
Default, the histograms are drawn on top of each other (as lego plots for 2D
histograms).
</td></tr>

<tr><th valign=top>"NOSTACK"</th><td>
Histograms in the stack are all paint in the same pad as if the option
<tt>"SAME"</tt> had been specified.
</td></tr>

<tr><th valign=top>"PADS"</th><td>
The current pad/canvas is subdivided into a number of pads equal to the number
of histograms in the stack and each histogram is paint into a separate pad.
</td></tr>

</table>


<a name="HP02"></a><h3>Setting the Style</h3>


Histograms use the current style (<tt>gStyle</tt>). When one changes the current
style and would like to propagate the changes to the histogram,
<tt>TH1::UseCurrentStyle</tt> should be called. Call <tt>UseCurrentStyle</tt> on
each histogram is needed.
<br>
To force all the histogram to use the current style use:
<pre>
      gROOT->ForceStyle();
</pre>
All the histograms read after this call will use the current style.


<a name="HP03"></a><h3>Setting line, fill, marker, and text attributes</h3>


The histogram classes inherit from the attribute classes:
<tt>TAttLine</tt>, <tt>TAttFill</tt> and <tt>TAttMarker</tt>.
See the description of these classes for the list of options.


<a name="HP04"></a><h3>Setting Tick marks on the histogram axis</h3>


The <tt>TPad::SetTicks</tt> method specifies the type of tick marks on the axis.
If <tt> tx = gPad->GetTickx()</tt> and <tt>ty = gPad->GetTicky()</tt> then:
<pre>
      tx = 1;   tick marks on top side are drawn (inside)
      tx = 2;   tick marks and labels on top side are drawn
      ty = 1;   tick marks on right side are drawn (inside)
      ty = 2;   tick marks and labels on right side are drawn
</pre>
By default only the left Y axis and X bottom axis are drawn
(<tt>tx = ty = 0</tt>)

<p><tt>TPad::SetTicks(tx,ty)</tt> allows to set these options.
See also The <tt>TAxis</tt> functions to set specific axis attributes.

<p>In case multiple color filled histograms are drawn on the same pad, the fill
area may hide the axis tick marks. One can force a redraw of the axis over all
the histograms by calling:
<pre>
      gPad->RedrawAxis();
</pre>


<a name="HP05"></a><h3>Giving titles to the X, Y and Z axis</h3>


<pre>
      h->GetXaxis()->SetTitle("X axis title");
      h->GetYaxis()->SetTitle("Y axis title");
</pre>
The histogram title and the axis titles can be any <tt>TLatex</tt> string.
The titles are part of the persistent histogram.


<a name="HP060"></a><h3>The option "SAME"</h3>


By default, when an histogram is drawn, the current pad is cleared before
drawing. In order to keep the previous drawing and draw on top of it the
option <tt>"SAME"</tt> should be use. The histogram drawn with the option
<tt>"SAME"</tt> uses the coordinates system available in the current pad.
<p>
This option can be used alone or combined with any valid drawing option but
some combinations must be use with care.

<a name="HP060a"></a><h4><u>Limitations</u></h4>
<ul>
<li>It does not work when
combined with the <tt>"LEGO"</tt> and <tt>"SURF"</tt> options unless the
histogram plotted with the option <tt>"SAME"</tt> has <u>exactly</u> the same
ranges on the X, Y and Z axis as the currently drawn histogram. To superimpose
lego plots <a href="#HP26">histograms' stacks</a> should be used.</li>
</ul>

<a name="HP06"></a><h3>Superimposing two histograms with different scales in the same pad</h3>


The following example creates two histograms, the second histogram is the bins
integral of the first one. It shows a procedure to draw the two histograms in
the same pad and it draws the scale of the second histogram using a new vertical
axis on the right side. See also the tutorial <tt>transpad.C</tt> for a variant
of this example.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   // create/fill draw h1
   gStyle->SetOptStat(kFALSE);
   TH1F *h1 = new TH1F("h1","Superimposing two histograms with different scales",100,-3,3);
   Int_t i;
   for (i=0;i<10000;i++) h1->Fill(gRandom->Gaus(0,1));
   h1->Draw();
   c1->Update();

   // create hint1 filled with the bins integral of h1
   TH1F *hint1 = new TH1F("hint1","h1 bins integral",100,-3,3);
   Float_t sum = 0;
   for (i=1;i<=100;i++) {
      sum += h1->GetBinContent(i);
      hint1->SetBinContent(i,sum);
   }

   // scale hint1 to the pad coordinates
   Float_t rightmax = 1.1*hint1->GetMaximum();
   Float_t scale = gPad->GetUymax()/rightmax;
   hint1->SetLineColor(kRed);
   hint1->Scale(scale);
   hint1->Draw("same");

   // draw an axis on the right side
   TGaxis *axis = new TGaxis(gPad->GetUxmax(),gPad->GetUymin(),
   gPad->GetUxmax(), gPad->GetUymax(),0,rightmax,510,"+L");
   axis->SetLineColor(kRed);
   axis->SetTextColor(kRed);
   axis->Draw();
   return c1;
}
End_Macro
Begin_Html


<a name="HP07"></a><h3>Statistics Display</h3>


The type of information shown in the histogram statistics box can be selected
with:
<pre>
      gStyle->SetOptStat(mode);
</pre>
The "<tt>mode</tt>" has up to nine digits that can be set to on(1 or 2), off(0).
<pre>
      mode = iourmen  (default = 000001111)
      k = 1;  kurtosis printed
      k = 2;  kurtosis and kurtosis error printed
      s = 1;  skewness printed
      s = 2;  skewness and skewness error printed
      i = 1;  integral of bins printed
      i = 2;  integral of bins with option "width" printed
      o = 1;  number of overflows printed
      u = 1;  number of underflows printed
      r = 1;  rms printed
      r = 2;  rms and rms error printed
      m = 1;  mean value printed
      m = 2;  mean and mean error values printed
      e = 1;  number of entries printed
      n = 1;  name of histogram is printed
</pre>
For example:
<pre>
      gStyle->SetOptStat(11);
</pre>
displays only the name of histogram and the number of entries, whereas:
<pre>
      gStyle->SetOptStat(1101);
</pre>
displays the name of histogram, mean value and RMS.

<p><b>WARNING 1:</b> never do:
<pre>
      <s>gStyle->SetOptStat(000111);</s>
</pre>
but instead do:
<pre>
      gStyle->SetOptStat(1111);
</pre>
because <tt>0001111</tt> will be taken as an octal number!

<p><b>WARNING 2:</b> for backward compatibility with older versions
<pre>
      gStyle->SetOptStat(1);
</pre>
is taken as:
<pre>
      gStyle->SetOptStat(1111)
</pre>
To print only the name of the histogram do:
<pre>
      gStyle->SetOptStat(1000000001);
</pre>
<b>NOTE</b> that in case of 2D histograms, when selecting only underflow
(10000) or overflow (100000), the statistics box will show all combinations
of underflow/overflows and not just one single number.

<p>The parameter mode can be any combination of the letters
<tt>kKsSiIourRmMen</tt>
<pre>
      k :  kurtosis printed
      K :  kurtosis and kurtosis error printed
      s :  skewness printed
      S :  skewness and skewness error printed
      i :  integral of bins printed
      I :  integral of bins with option "width" printed
      o :  number of overflows printed
      u :  number of underflows printed
      r :  rms printed
      R :  rms and rms error printed
      m :  mean value printed
      M :  mean value mean error values printed
      e :  number of entries printed
      n :  name of histogram is printed
</pre>
For example, to print only name of histogram and number of entries do:
<pre>
      gStyle->SetOptStat("ne");
</pre>
To print only the name of the histogram do:
<pre>
      gStyle->SetOptStat("n");
</pre>
The default value is:
<pre>
      gStyle->SetOptStat("nemr");
</pre>

<p>When a histogram is painted, a <tt>TPaveStats</tt> object is created and added
to the list of functions of the histogram. If a <tt>TPaveStats</tt> object
already exists in the histogram list of functions, the existing object is just
updated with the current histogram parameters.

<p>Once a histogram is painted, the statistics box can be accessed using
<tt>h->FindObject("stats")</tt>. In the command line it is enough to do:
<pre>
      Root > h->Draw()
      Root > TPaveStats *st = (TPaveStats*)h->FindObject("stats")
</pre>
because after <tt>h->Draw()</tt> the histogram is automatically painted. But
in a script file the painting should be forced using <tt>gPad->Update()</tt>
in order to make sure the statistics box is created:
<pre>
      h->Draw();
      gPad->Update();
      TPaveStats *st = (TPaveStats*)h->FindObject("stats");
</pre>

<p>Without <tt>gPad->Update()</tt> the line <tt>h->FindObject("stats")</tt>
returns a null pointer.

<p>When a histogram is drawn with the option "<tt>SAME</tt>", the statistics box
is not drawn. To force the statistics box drawing with the option
"<tt>SAME</tt>", the option "<tt>SAMES</tt>" must be used.
If the new statistics box hides the previous statistics box, one can change
its position with these lines ("<tt>h</tt>" being the pointer to the histogram):
<pre>
      Root > TPaveStats *st = (TPaveStats*)h->FindObject("stats")
      Root > st->SetX1NDC(newx1); //new x start position
      Root > st->SetX2NDC(newx2); //new x end position
</pre>
To change the type of information for an histogram with an existing
<tt>TPaveStats</tt> one should do:
<pre>
      st->SetOptStat(mode);
</pre>
Where "<tt>mode</tt>" has the same meaning than when calling
<tt>gStyle->SetOptStat(mode)</tt> (see above).

<p>One can delete the statistics box for a histogram <tt>TH1* h</tt> with:
<pre>
      h->SetStats(0)
</pre>
and activate it again with:
<pre>
      h->SetStats(1).
</pre>

<p>Labels used in the statistics box ("Mean", "RMS", ...) can be changed from
<a href="http://root.cern.ch/download/doc/primer/ROOTPrimer.html#configure-root-at-start-up">$ROOTSYS/etc/system.rootrc</a> or
<a href="http://root.cern.ch/download/doc/primer/ROOTPrimer.html#configure-root-at-start-up">.rootrc</a>
(look for the string <tt>"Hist.Stats."</tt>).
</p>


<a name="HP08"></a><h3>Fit Statistics</h3>


The type of information about fit parameters printed in the histogram statistics
box can be selected via the parameter mode. The parameter mode can be
<tt>= pcev</tt>  (default <tt>= 0111</tt>)
<pre>
      p = 1;  print Probability
      c = 1;  print Chisquare/Number of degrees of freedom
      e = 1;  print errors (if e=1, v must be 1)
      v = 1;  print name/values of parameters
</pre>
Example:
<pre>
      gStyle->SetOptFit(1011);
</pre>
print fit probability, parameter names/values and errors.
<ol>
<li> When <tt>"v" = 1</tt> is specified, only the non-fixed parameters are
     shown.
<li> When <tt>"v" = 2</tt> all parameters are shown.
</ol>
Note: <tt>gStyle->SetOptFit(1)</tt> means "default value", so it is equivalent
to <tt>gStyle->SetOptFit(111)</tt>


<a name="HP09"></a><h3>The error bars options</h3>


<table border=0>

<tr><th valign=top>"E"</th><td>
Default. Shows only the error bars, not a marker.
</td></tr>

<tr><th valign=top>"E1"</th><td>
Small lines are drawn at the end of the error bars.
</td></tr>

<tr><th valign=top>"E2"</th><td>
Error rectangles are drawn.
</td></tr>

<tr><th valign=top>"E3"</th><td>
A filled area is drawn through the end points of the vertical error bars.
</td></tr>

<tr><th valign=top>"E4"</th><td>
A smoothed filled area is drawn through the end points of the vertical error
bars.
</td></tr>

<tr><th valign=top>"E0"</th><td>
Draw also bins with null contents.
</td></tr>

</table>

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH1F *he = new TH1F("he","Distribution drawn with error bars (option E1)  ",100,-3,3);
   Int_t i;
   for (i=0;i<10000;i++) he->Fill(gRandom->Gaus(0,1));
   gStyle->SetEndErrorSize(3);
   gStyle->SetErrorX(1.);
   he->SetMarkerStyle(20);
   he->Draw("E1");
   return c1;
}
End_Macro
Begin_Html

<p>The options "E3" and "E4" draw an error band through the end points of the
vertical error bars. With "E4" the error band is smoothed. Because of the
smoothing algorithm used some artefacts may appear at the end of the band
like in the following example. In such cases "E3" should be used instead
of "E4".

End_Html
Begin_Macro(source)
{
   TCanvas *ce4 = new TCanvas("ce4","ce4",600,400);
   ce4->Divide(2,1);
   TH1F *he4 = new TH1F("he4","Distribution drawn with option E4",100,-3,3);
   Int_t i;
   for (i=0;i<10000;i++) he4->Fill(gRandom->Gaus(0,1));
   he4->SetFillColor(kRed);
   he4->GetXaxis()->SetRange(40,48);
   ce4->cd(1);
   he4->Draw("E4");
   ce4->cd(2);
   TH1F *he3 = (TH1F*)he4->DrawClone("E3");
   he3->SetTitle("Distribution drawn option E3");
   return ce4;
}
End_Macro
Begin_Html

<p>2D histograms can be drawn with error bars as shown is the following example:

End_Html
Begin_Macro(source)
{
   TCanvas *c2e = new TCanvas("c2e","c2e",600,400);
   TH2F *h2e = new TH2F("h2e","TH2 drawn with option E",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      h2e->Fill(px,5*py);
   }
   h2e->Draw("E");
   return c2e;
}
End_Macro
Begin_Html


<a name="HP100"></a><h3>The bar chart option</h3>


The option "B" allows to draw simple vertical bar charts.
The bar width is controlled with <tt>TH1::SetBarWidth()</tt>,
and the bar offset wihtin the bin, with <tt>TH1::SetBarOffset()</tt>.
These two settings are useful to draw several histograms on the
same plot as shown in the following example:

End_Html
Begin_Macro(source)
{
   int i;
   const Int_t nx = 8;
   char *os_X[nx]   = {"8","32","128","512","2048","8192","32768","131072"};
   float d_35_0[nx] = {0.75, -3.30, -0.92, 0.10, 0.08, -1.69, -1.29, -2.37};
   float d_35_1[nx] = {1.01, -3.02, -0.65, 0.37, 0.34, -1.42, -1.02, -2.10};

   TCanvas *cb = new TCanvas("cb","cb",600,400);
   cb->SetGrid();

   gStyle->SetHistMinimumZero();

   TH1F *h1b = new TH1F("h1b","Option B example",nx,0,nx);
   h1b->SetFillColor(4);
   h1b->SetBarWidth(0.4);
   h1b->SetBarOffset(0.1);
   h1b->SetStats(0);
   h1b->SetMinimum(-5);
   h1b->SetMaximum(5);

   for (i=1; i<=nx; i++) {
      h1b->Fill(os_X[i-1], d_35_0[i-1]);
      h1b->GetXaxis()->SetBinLabel(i,os_X[i-1]);
   }

   h1b->Draw("b");

   TH1F *h2b = new TH1F("h2b","h2b",nx,0,nx);
   h2b->SetFillColor(38);
   h2b->SetBarWidth(0.4);
   h2b->SetBarOffset(0.5);
   h2b->SetStats(0);
   for (i=1;i<=nx;i++) h2b->Fill(os_X[i-1], d_35_1[i-1]);

   h2b->Draw("b same");

   return cb;
}
End_Macro
Begin_Html


<a name="HP10"></a><h3>The "BAR" and "HBAR" options</h3>


When the option "bar" or "hbar" is specified, a bar chart is drawn. A vertical
bar-chart is drawn with the options <tt>"bar"</tt>, <tt>"bar0"</tt>,
<tt>"bar1"</tt>, <tt>"bar2"</tt>, <tt>"bar3"</tt>, <tt>"bar4"</tt>.
An horizontal bar-chart is drawn with the options <tt>"hbar"</tt>,
<tt>"hbar0"</tt>, <tt>"hbar1"</tt>, <tt>"hbar2"</tt></tt>, <tt>"hbar3"</tt>,
<tt>"hbar4"</tt>.
<ul>
<li> The bar is filled with the histogram fill color.
<li> The left side of the bar is drawn with a light fill color.
<li> The right side of the bar is drawn with a dark fill color.
<li> The percentage of the bar drawn with either the light or dark color is:
<ul>
<li>    0% for option "(h)bar" or "(h)bar0"
<li>   10% for option "(h)bar1"
<li>   20% for option "(h)bar2"
<li>   30% for option "(h)bar3"
<li>   40% for option "(h)bar4"
</ul>
</ul>

End_Html
Begin_Macro(source)
../../../tutorials/hist/hbars.C
End_Macro
Begin_Html

<p>To control the bar width (default is the bin width) <tt>TH1::SetBarWidth()</tt>
should be used.
<br>
To control the bar offset (default is 0) <tt>TH1::SetBarOffset()</tt> should
be used.
<br>
These two parameters are useful when several histograms are plotted using
the option <tt>SAME</tt>. They allow to plot the histograms next to each other.


<a name="HP11"></a><h3>The SCATter plot option (default for 2D histograms)</h3>


For each cell (i,j) a number of points proportional to the cell content is
drawn. A maximum of <tt>kNMAX</tt> points per cell is drawn. If the maximum is above
<tt>kNMAX</tt> contents are normalized to <tt>kNMAX</tt> (<tt>kNMAX=2000</tt>).
If option is of the form <tt>"scat=ff"</tt>, (eg <tt>scat=1.8</tt>,
<tt>scat=1e-3</tt>), then <tt>ff</tt> is used as a scale factor to compute the
number of dots. <tt>"scat=1"</tt> is the default.
<p>
By default the scatter plot is painted with a "dot marker" which not scalable
(see the <a href="http://root.cern.ch/root/html/TAttMarker.html#M3">TAttMarker
documentation</a>). To change the marker size, a scalable marker type should be
used. For instance a circle (marker style 20).


End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hscat = new TH2F("hscat","Option SCATter example (default for 2D histograms)  ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hscat->Fill(px,5*py);
      hscat->Fill(3+0.5*px,2*py-10.);
   }
   hscat->Draw("scat=0.5");
   return c1;
}
End_Macro
Begin_Html


<a name="HP12"></a><h3>The ARRow option</h3>


Shows gradient between adjacent cells. For each cell (i,j) an arrow is drawn
The orientation of the arrow follows the cell gradient.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *harr = new TH2F("harr","Option ARRow example",20,-4,4,20,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      harr->Fill(px,5*py);
      harr->Fill(3+0.5*px,2*py-10.,0.1);
   }
   harr->Draw("ARR");
   return c1;
}
End_Macro
Begin_Html


<a name="HP13"></a><h3>The BOX option</h3>


For each cell (i,j) a box is drawn. The size (surface) of the box is
proportional to the absolute value of the cell content.
The cells with a negative content draw with a <tt>X</tt> on top of the boxes.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   hbox  = new TH2F("hbox","Option BOX example",3,0,3,3,0,3);
   hbox->SetFillColor(42);
   hbox->Fill(0.5, 0.5,  1.);
   hbox->Fill(0.5, 1.5,  4.);
   hbox->Fill(0.5, 2.5,  3.);
   hbox->Fill(1.5, 0.5,  2.);
   hbox->Fill(1.5, 1.5, 12.);
   hbox->Fill(1.5, 2.5, -6.);
   hbox->Fill(2.5, 0.5, -4.);
   hbox->Fill(2.5, 1.5,  6.);
   hbox->Fill(2.5, 2.5,  0.5);
   hbox->Draw("BOX");
   return c1;
}
End_Macro
Begin_Html

<p>With option <tt>"BOX1"</tt> a button is drawn for each cell with surface
proportional to content's absolute value. A sunken button is drawn for
negative values a raised one for positive.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   hbox1  = new TH2F("hbox1","Option BOX1 example",3,0,3,3,0,3);
   hbox1->SetFillColor(42);
   hbox1->Fill(0.5, 0.5,  1.);
   hbox1->Fill(0.5, 1.5,  4.);
   hbox1->Fill(0.5, 2.5,  3.);
   hbox1->Fill(1.5, 0.5,  2.);
   hbox1->Fill(1.5, 1.5, 12.);
   hbox1->Fill(1.5, 2.5, -6.);
   hbox1->Fill(2.5, 0.5, -4.);
   hbox1->Fill(2.5, 1.5,  6.);
   hbox1->Fill(2.5, 2.5,  0.5);
   hbox1->Draw("BOX1");
   return c1;
}
End_Macro
Begin_Html

<p>When the option <tt>"SAME"</tt> (or "SAMES") is used with the option <tt>"BOX"</tt>,
the boxes' sizes are computing taking the previous plots into account. The range
along the Z axis is imposed by the first plot (the one without option
<tt>"SAME"</tt>); therefore the order in which the plots are done is relevant.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hb1 = new TH2F("hb1","Example of BOX plots with option SAME ",40,-3,3,40,-3,3);
   TH2F *hb2 = new TH2F("hb2","hb2",40,-3,3,40,-3,3);
   TH2F *hb3 = new TH2F("hb3","hb3",40,-3,3,40,-3,3);
   TH2F *hb4 = new TH2F("hb4","hb4",40,-3,3,40,-3,3);
   for (Int_t i=0;i<1000;i++) {
      double x,y;
      gRandom->Rannor(x,y);
      if (x>0 && y>0) hb1->Fill(x,y,4);
      if (x<0 && y<0) hb2->Fill(x,y,3);
      if (x>0 && y<0) hb3->Fill(x,y,2);
      if (x<0 && y>0) hb4->Fill(x,y,1);
   }
   hb1->SetFillColor(1);
   hb2->SetFillColor(2);
   hb3->SetFillColor(3);
   hb4->SetFillColor(4);
   hb1->Draw("box");
   hb2->Draw("box same");
   hb3->Draw("box same");
   hb4->Draw("box same");
   return c1;
}
End_Macro
Begin_Html


<a name="HP14"></a><h3>The COLor option</h3>


For each cell (i,j) a box is drawn with a color proportional to the cell
content.

<p>The color table used is defined in the current style.

<p>If the histogram's minimum and maximum are the same (flat histogram), the
mapping on colors is not possible, therefore nothing is painted. To paint a
flat histogram it is enough to set the histogram minimum
(<tt>TH1::SetMinimum()</tt>) different from the bins' content.

<p>The default number of color levels used to paint the cells is 20.
It can be changed with <tt>TH1::SetContour()</tt> or
<tt>TStyle::SetNumberContours()</tt>. The higher this number is, the smoother
is the color change between cells.

<p>The color palette in TStyle can be modified via <tt>gStyle->SetPalette()</tt>.

<p>All the none empty bins are painted. Empty bins are not painted unless
some bins have a negative content because in that case the null bins
might be not empty.

<p><tt>TProfile2D</tt> histograms are handled differently because, for this type of 2D
histograms, it is possible to know if an empty bin has been filled or not. So even
if all the bins' contents are positive some empty bins might be painted. And vice versa,
if some bins have a negative content some empty bins might be not painted.

<p>Combined with the option <tt>"COL"</tt>, the option <tt>"Z"</tt> allows to
display the color palette defined by <tt>gStyle->SetPalette()</tt>.

<p>In the following example, the histogram has only positive bins; the empty
bins (containing 0) <u>are not drawn</u>.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcol1 = new TH2F("hcol1","Option COLor example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcol1->Fill(px,5*py);
   }
   gStyle->SetPalette(1);
   hcol1->Draw("COLZ");
   return c1;
}
End_Macro
Begin_Html

<p>In the following example, the histogram has some negative bins; the empty
bins (containing 0) <u>are drawn</u>.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcol2 = new TH2F("hcol2","Option COLor example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcol2->Fill(px,5*py);
   }
   hcol2->Fill(0.,0.,-200.);
   gStyle->SetPalette(1);
   hcol2->Draw("COLZ");
   return c1;
}
End_Macro
Begin_Html


<a name="HP140"></a><h3>The CANDLE option</h3>


A Candle plot (also known as a "box-and whisker plot" or simply "box plot")
is a convenient way to describe graphically a data distribution (D) with
only the five numbers. It was invented in 1977 by John Tukey.
<p>
With the option CANDLEX five numbers are:
<ol>
<li> The minimum value of the distribution D (bottom dashed line).
<li> The lower quartile (Q1): 25% of the data points in D are less than
     Q1 (bottom of the box).
<li> The median (M): 50% of the data points in D are less than M
     (thick line segment inside the box).
<li> The upper quartile (Q3): 75% of the data points in D are less
     than Q3 (top of the box).
<li> The maximum value of the distribution D (top dashed line).
</ol>

The mean value of the distribution D is also represented as a circle.
<p>
In this implementation a TH2 is considered as a collection of TH1 along
X (option <tt>CANDLE</tt> or <tt>CANDLEX</tt>) or Y (option <tt>CANDLEY</tt>).
Each TH1 is represented as a candle plot.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcandle = new TH2F("hcandle","Option CANDLE example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcandle->Fill(px,5*py);
   }
   hcandle->SetMarkerSize(0.5);
   hcandle->Draw("CANDLE");
   return c1;
}
End_Macro
Begin_Html


<a name="HP15"></a><h3>The TEXT and TEXTnn Option</h3>


For each bin the content is printed. The text attributes are:
<ul>
<li> text font = current TStyle font (<tt>gStyle->SetTextFont()</tt>).
<li> text size = 0.02*padheight*markersize (if <tt>h</tt> is the histogram drawn
     with the option <tt>"TEXT"</tt> the marker size can be changed with
     <tt>h->SetMarkerSize(markersize)</tt>).
<li> text color = marker color.
</ul>
By default the format <tt>"g"</tt> is used. This format can be redefined
by calling <tt>gStyle->SetPaintTextFormat()</tt>.

<p>It is also possible to use <tt>"TEXTnn"</tt> in order to draw the text with
the angle <tt>nn</tt> (<tt>0 < nn < 90</tt>).

<p>For 2D histograms the text is plotted in the center of each non empty cells.
It is possible to plot empty cells by calling gStyle->SetHistMinimumZero().
For 1D histogram the text is plotted at a y position equal to the bin content.

<p>For 2D histograms when the option "E" (errors) is combined with the option
text ("TEXTE"), the error for each bin is also printed.

End_Html
Begin_Macro(source)
{
   TCanvas *c01 = new TCanvas("c01","c01",700,400);
   c01->Divide(2,1);
   TH1F *htext1 = new TH1F("htext1","Option TEXT on 1D histograms ",10,-4,4);
   TH2F *htext2 = new TH2F("htext2","Option TEXT on 2D histograms ",10,-4,4,10,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
        htext1->Fill(px,0.1);
      htext2->Fill(px,5*py,0.1);
   }
   gStyle->SetPaintTextFormat("4.1f m");
   htext2->SetMarkerSize(1.8);
   c01->cd(1);
   htext2->Draw("TEXT45");
   c01->cd(2);
   htext1->Draw();
   htext1->Draw("TEXT0 SAME");
   return c01;
}
End_Macro
Begin_Html

<p>In the case of profile histograms it is possible to print the number
of entries instead of the bin content. It is enough to combine the
option "E" (for entries) with the option "TEXT".

End_Html
Begin_Macro(source)
{
   TCanvas *c02 = new TCanvas("c02","c02",700,400);
   c02->Divide(2,1);
   gStyle->SetPaintTextFormat("g");

   TProfile *profile = new TProfile("profile","profile",10,0,10);
   profile->SetMarkerSize(2.2);
   profile->Fill(0.5,1);
   profile->Fill(1.5,2);
   profile->Fill(2.5,3);
   profile->Fill(3.5,4);
   profile->Fill(4.5,5);
   profile->Fill(5.5,5);
   profile->Fill(6.5,4);
   profile->Fill(7.5,3);
   profile->Fill(8.5,2);
   profile->Fill(9.5,1);
   c02->cd(1); profile->Draw("HIST TEXT0");
   c02->cd(2); profile->Draw("HIST TEXT0E");

   return c02;
}
End_Macro
Begin_Html

<a name="HP16"></a><h3>The CONTour options</h3>


The following contour options are supported:

<table border=0>

<tr><th valign=top>"CONT"</th><td>
Draw a contour plot (same as CONT0).
</td></tr>

<tr><th valign=top>"CONT0"</th><td>
Draw a contour plot using surface colors to distinguish contours.
</td></tr>

<tr><th valign=top>"CONT1"</th><td>
Draw a contour plot using the line colors to distinguish contours.
</td></tr>

<tr><th valign=top>"CONT2"</th><td>
Draw a contour plot using the line styles to distinguish contours.
</td></tr>

<tr><th valign=top>"CONT3"</th><td>
Draw a contour plot solid lines for all contours.
</td></tr>

<tr><th valign=top>"CONT4"</th><td>
Draw a contour plot using surface colors (<tt>"SURF"</tt> option at theta = 0).
</td></tr>

<tr><th valign=top>"CONT5"</th><td>
Draw a contour plot using Delaunay triangles.
</td></tr>

</table>

The following example shows a 2D histogram plotted with the option
<tt>"CONTZ"</tt>. The option <tt>"CONT"</tt> draws a contour plot using surface
colors to distinguish contours.  Combined with the option <tt>"CONT"</tt> (or
<tt>"CONT0"</tt>), the option <tt>"Z"</tt> allows to display the color palette
defined by <tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcontz = new TH2F("hcontz","Option CONTZ example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcontz->Fill(px-1,5*py);
      hcontz->Fill(2+0.5*px,2*py-10.,0.1);
   }
   gStyle->SetPalette(1);
   hcontz->Draw("CONTZ");
   return c1;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"CONT1Z"</tt>. The option <tt>"CONT1"</tt> draws a contour plot using the
line colors to distinguish contours. Combined with the option <tt>"CONT1"</tt>,
the option <tt>"Z"</tt> allows to display the color palette defined by
<tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcont1 = new TH2F("hcont1","Option CONT1Z example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcont1->Fill(px-1,5*py);
      hcont1->Fill(2+0.5*px,2*py-10.,0.1);
   }
   gStyle->SetPalette(1);
   hcont1->Draw("CONT1Z");
   return c1;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"CONT2"</tt>. The option <tt>"CONT2"</tt> draws a contour plot using the
line styles to distinguish contours.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcont2 = new TH2F("hcont2","Option CONT2 example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcont2->Fill(px-1,5*py);
      hcont2->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hcont2->Draw("CONT2");
   return c1;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"CONT3"</tt>. The option <tt>"CONT3"</tt> draws contour plot solid lines for
all contours.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcont3 = new TH2F("hcont3","Option CONT3 example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcont3->Fill(px-1,5*py);
      hcont3->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hcont3->Draw("CONT3");
   return c1;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"CONT4"</tt>. The option <tt>"CONT4"</tt> draws a contour plot using surface
colors to distinguish contours (<tt>"SURF"</tt> option at theta = 0). Combined
with the option <tt>"CONT"</tt> (or <tt>"CONT0"</tt>), the option <tt>"Z"</tt>
allows to display the color palette defined by <tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c1 = new TCanvas("c1","c1",600,400);
   TH2F *hcont4 = new TH2F("hcont4","Option CONT4Z example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hcont4->Fill(px-1,5*py);
      hcont4->Fill(2+0.5*px,2*py-10.,0.1);
   }
   gStyle->SetPalette(1);
   hcont4->Draw("CONT4Z");
   return c1;
}
End_Macro
Begin_Html

<p>The default number of contour levels is 20 equidistant levels and can be changed
with <tt>TH1::SetContour()</tt> or <tt>TStyle::SetNumberContours()</tt>.

<a name="HP16a"></a><h4><u>The LIST option</u></h4>

<p>When option <tt>"LIST"</tt> is specified together with option
<tt>"CONT"</tt>, the points used to draw the contours are saved in
<tt>TGraph</tt> objects:
<pre>
      h->Draw("CONT LIST");
      gPad->Update();
</pre>
The contour are saved in <tt>TGraph</tt> objects once the pad is painted.
Therefore to use this functionnality in a macro, <tt>gPad->Update()</tt>
should be performed after the histogram drawing. Once the list is
built, the contours are accessible in the following way:
<pre>
      TObjArray *contours = gROOT->GetListOfSpecials()->FindObject("contours")
      Int_t ncontours     = contours->GetSize();
      TList *list         = (TList*)contours->At(i);
</pre>
Where <tt>i</tt> is a contour number, and list contains a list of
<tt>TGraph</tt> objects.
For one given contour, more than one disjoint polyline may be generated.
The number of TGraphs per contour is given by:
<pre>
      list->GetSize();
</pre>
To access the first graph in the list one should do:
<pre>
      TGraph *gr1 = (TGraph*)list->First();
</pre>

The following example shows how to use this functionality.

End_Html
Begin_Macro(source)
../../../tutorials/hist/ContourList.C
End_Macro
Begin_Html

<p>The following options select the <tt>"CONT4"</tt> option and are useful for
sky maps or exposure maps.

<table border=0>

<tr><th valign=top>"AITOFF"</th><td>
Draw a contour via an AITOFF projection.
</td></tr>

<tr><th valign=top>"MERCATOR"</th><td>
Draw a contour via an Mercator projection.
</td></tr>

<tr><th valign=top>"SINUSOIDAL"</th><td>
Draw a contour via an Sinusoidal projection.
</td></tr>

<tr><th valign=top>"PARABOLIC"</th><td>
Draw a contour via an Parabolic projection.
</td></tr>

</table>

End_Html
Begin_Macro(source)
../../../tutorials/graphics/earth.C
End_Macro
Begin_Html


<a name="HP17"></a><h3>The LEGO options</h3>


In a lego plot the cell contents are drawn as 3-d boxes. The height of each box
is proportional to the cell content. The lego aspect is control with the
following options:

<table border=0>

<tr><th valign=top>"LEGO" </th><td>
Draw a lego plot using the hidden lines removal technique.
</td></tr>

<tr><th valign=top>"LEGO1"</th><td>
Draw a lego plot using the hidden surface removal technique.
</td></tr>

<tr><th valign=top>"LEGO2"</th><td>
Draw a lego plot using colors to show the cell contents.
</td></tr>

<tr><th valign=top>"LEGO3"</th><td>
Draw a lego plot with hidden surface removal, like LEGO1 but the border lines
of each lego-bar are not drawn.
</td></tr>

<tr><th valign=top>"LEGO4"</th><td>
Draw a lego plot with hidden surface removal, like LEGO1 but without the
shadow effect on each lego-bar.
</td></tr>

<tr><th valign=top>"0"</th><td>
When used with any LEGO option, the empty bins are not drawn.
</td></tr>

</table>
See the limitations with <a href="#HP060a">the option "SAME"</a>.

<p>Line attributes can be used in lego plots to change the edges' style.

<p>The following example shows a 2D histogram plotted with the option
<tt>"LEGO"</tt>. The option <tt>"LEGO"</tt> draws a lego plot using the hidden
lines removal technique.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hlego = new TH2F("hlego","Option LEGO example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hlego->Fill(px-1,5*py);
      hlego->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hlego->Draw("LEGO");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"LEGO1"</tt>. The option <tt>"LEGO1"</tt> draws a lego plot using the
hidden surface removal technique. Combined with any <tt>"LEGOn"</tt> option, the
option <tt>"0"</tt> allows to not drawn the empty bins.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hlego1 = new TH2F("hlego1","Option LEGO1 example (with option 0)  ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hlego1->Fill(px-1,5*py);
      hlego1->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hlego1->SetFillColor(kYellow);
   hlego1->Draw("LEGO1 0");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"LEGO3"</tt>. Like the option <tt>"LEGO1"</tt>, the option <tt>"LEGO3"</tt>
draws a lego plot using the hidden surface removal technique but doesn't draw
the border lines of each individual lego-bar. This is very useful for histograms
having many bins. With such histograms the option <tt>"LEGO1"</tt> gives a black
image because of the border lines. This option also works with stacked legos.
End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hlego3 = new TH2F("hlego3","Option LEGO3 example",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hlego3->Fill(px-1,5*py);
      hlego3->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hlego3->SetFillColor(kRed);
   hlego3->Draw("LEGO3");
   return c2;
 }
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"LEGO2"</tt>. The option <tt>"LEGO2"</tt> draws a lego plot using colors to
show the cell contents.  Combined with the option <tt>"LEGO2"</tt>, the option
<tt>"Z"</tt> allows to display the color palette defined by
<tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hlego2 = new TH2F("hlego2","Option LEGO2Z example ",40,-4,4,40,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hlego2->Fill(px-1,5*py);
      hlego2->Fill(2+0.5*px,2*py-10.,0.1);
   }
   gStyle->SetPalette(1);
   hlego2->Draw("LEGO2Z");
   return c2;
}
End_Macro
Begin_Html



<a name="HP18"></a><h3>The "SURFace" options</h3>


In a surface plot, cell contents are represented as a mesh.
The height of the mesh is proportional to the cell content.

<table border=0>

<tr><th valign=top>"SURF"</th><td>
Draw a surface plot using the hidden line removal technique.
</td></tr>

<tr><th valign=top>"SURF1"</th><td>
Draw a surface plot using the hidden surface removal technique.
</td></tr>

<tr><th valign=top>"SURF2"</th><td>
Draw a surface plot using colors to show the cell contents.
</td></tr>

<tr><th valign=top>"SURF3"</th><td>
Same as <tt>SURF</tt> with an additionial filled contour plot on top.
</td></tr>

<tr><th valign=top>"SURF4"</th><td>
Draw a surface using the Gouraud shading technique.
</td></tr>

<tr><th valign=top>"SURF5"</th><td>
Used with one of the options CYL, PSR and CYL this option allows to draw a
a filled contour plot.
</td></tr>

<tr><th valign=top>"SURF6"</th><td>
This option should not be used directly. It is used internally when the
CONT is used with option the option SAME on a 3D plot.
</td></tr>

<tr><th valign=top>"SURF7"</th><td>
Same as <tt>SURF2</tt> with an additionial line contour plot on top.
</td></tr>

</table>

See the limitations with <a href="#HP060a">the option "SAME"</a>.
<p>
The following example shows a 2D histogram plotted with the option
<tt>"SURF"</tt>. The option <tt>"SURF"</tt> draws a lego plot using the hidden
lines removal technique.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hsurf = new TH2F("hsurf","Option SURF example ",30,-4,4,30,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hsurf->Fill(px-1,5*py);
      hsurf->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hsurf->Draw("SURF");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"SURF1"</tt>. The option <tt>"SURF1"</tt> draws a surface plot using the
hidden surface removal technique.  Combined with the option <tt>"SURF1"</tt>,
the option <tt>"Z"</tt> allows to display the color palette defined by
<tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hsurf1 = new TH2F("hsurf1","Option SURF1 example ",30,-4,4,30,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hsurf1->Fill(px-1,5*py);
      hsurf1->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hsurf1->Draw("SURF1");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"SURF2"</tt>. The option <tt>"SURF2"</tt> draws a surface plot using colors
to show the cell contents. Combined with the option <tt>"SURF2"</tt>, the option
<tt>"Z"</tt> allows to display the color palette defined by
<tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hsurf2 = new TH2F("hsurf2","Option SURF2 example ",30,-4,4,30,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hsurf2->Fill(px-1,5*py);
      hsurf2->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hsurf2->Draw("SURF2");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"SURF3"</tt>. The option <tt>"SURF3"</tt> draws a surface plot using the
hidden line removal technique with, in addition, a filled contour view drawn on the
top.  Combined with the option <tt>"SURF3"</tt>, the option <tt>"Z"</tt> allows
to display the color palette defined by <tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hsurf3 = new TH2F("hsurf3","Option SURF3 example ",30,-4,4,30,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hsurf3->Fill(px-1,5*py);
      hsurf3->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hsurf3->Draw("SURF3");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"SURF4"</tt>. The option <tt>"SURF4"</tt> draws a surface using the Gouraud
shading technique.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hsurf4 = new TH2F("hsurf4","Option SURF4 example ",30,-4,4,30,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hsurf4->Fill(px-1,5*py);
      hsurf4->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hsurf4->SetFillColor(kOrange);
   hsurf4->Draw("SURF4");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"SURF5 CYL"</tt>.  Combined with the option <tt>"SURF5"</tt>, the option
<tt>"Z"</tt> allows to display the color palette defined by <tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hsurf5 = new TH2F("hsurf4","Option SURF5 example ",30,-4,4,30,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hsurf5->Fill(px-1,5*py);
      hsurf5->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hsurf5->SetFillColor(kOrange);
   hsurf5->Draw("SURF5 CYL");
   return c2;
}
End_Macro
Begin_Html

<p>The following example shows a 2D histogram plotted with the option
<tt>"SURF7"</tt>. The option <tt>"SURF7"</tt> draws a surface plot using the
hidden surfaces removal technique with, in addition, a line contour view drawn on the
top.  Combined with the option <tt>"SURF7"</tt>, the option <tt>"Z"</tt> allows
to display the color palette defined by <tt>gStyle->SetPalette()</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TH2F *hsurf7 = new TH2F("hsurf3","Option SURF7 example ",30,-4,4,30,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hsurf7->Fill(px-1,5*py);
      hsurf7->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hsurf7->Draw("SURF7");
   return c2;
}
End_Macro
Begin_Html

<p>As shown in the following example, when a contour plot is painted on top of a
surface plot using the option <tt>SAME</tt>, the contours appear in 3D on the
surface.

End_Html
Begin_Macro(source)
{
   TCanvas *c20=new TCanvas("c20","c20",600,400);
   int NBins = 50;
   double d = 2;
   TH2F* hsc = new TH2F("hsc", "Surface and contour with option SAME ", NBins, -d, d, NBins, -d, d);
   for (int bx = 1;  bx <= NBins; ++bx) {
      for (int by = 1;  by <= NBins; ++by) {
         double x = hsc->GetXaxis()->GetBinCenter(bx);
         double y = hsc->GetYaxis()->GetBinCenter(by);
         hsc->SetBinContent(bx, by, exp(-x*x)*exp(-y*y));
      }
   }
   gStyle->SetPalette(1);
   hsc->Draw("surf2");
   hsc->Draw("CONT1 SAME");
   return c20;
}
End_Macro
Begin_Html


<a name="HP19"></a><h3>Cylindrical, Polar, Spherical and PseudoRapidity/Phi options</h3>


Legos and surfaces plots are represented by default in Cartesian coordinates.
Combined with any <tt>"LEGOn"</tt> or <tt>"SURFn"</tt> options the following
options allow to draw a lego or a surface in other coordinates systems.

<table border=0>

<tr><th valign=top>"CYL"</th><td>
Use Cylindrical coordinates. The X coordinate is mapped on the angle and the Y
coordinate on the cylinder length.
</td></tr>

<tr><th valign=top>"POL"</th><td>
Use Polar coordinates. The X coordinate is mapped on the angle and the Y
coordinate on the radius.
</td></tr>

<tr><th valign=top>"SPH"</th><td>
Use Spherical coordinates. The X coordinate is mapped on the latitude and the
Y coordinate on the longitude.
</td></tr>

<tr><th valign=top>"PSR"</th><td>
Use PseudoRapidity/Phi coordinates. The X coordinate is mapped on Phi.
</td></tr>

</table>

<b>WARNING:</b> Axis are not drawn with these options.

<p>The following example shows the same histogram as a lego plot is the four
different coordinates systems.

End_Html
Begin_Macro(source)
{
   TCanvas *c3 = new TCanvas("c3","c3",600,400);
   c3->Divide(2,2);
   TH2F *hlcc = new TH2F("hlcc","Cylindrical coordinates",20,-4,4,20,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hlcc->Fill(px-1,5*py);
      hlcc->Fill(2+0.5*px,2*py-10.,0.1);
   }
   hlcc->SetFillColor(kYellow);
   c3->cd(1); hlcc->Draw("LEGO1 CYL");
   c3->cd(2); TH2F *hlpc = (TH2F*) hlcc->DrawClone("LEGO1 POL");
   hlpc->SetTitle("Polar coordinates");
   c3->cd(3); TH2F *hlsc = (TH2F*) hlcc->DrawClone("LEGO1 SPH");
   hlsc->SetTitle("Spherical coordinates");
   c3->cd(4); TH2F *hlprpc = (TH2F*) hlcc->DrawClone("LEGO1 PSR");
   hlprpc->SetTitle("PseudoRapidity/Phi coordinates");
   return c3;
}
End_Macro
Begin_Html

<p>The following example shows the same histogram as a surface plot is the four
different coordinates systems.

End_Html
Begin_Macro(source)
{
   TCanvas *c4 = new TCanvas("c4","c4",600,400);
   c4->Divide(2,2);
   TH2F *hscc = new TH2F("hscc","Cylindrical coordinates",20,-4,4,20,-20,20);
   Float_t px, py;
   for (Int_t i = 0; i < 25000; i++) {
      gRandom->Rannor(px,py);
      hscc->Fill(px-1,5*py);
      hscc->Fill(2+0.5*px,2*py-10.,0.1);
   }
   gStyle->SetPalette(1);
   c4->cd(1); hscc->Draw("SURF1 CYL");
   c4->cd(2); TH2F *hspc = (TH2F*) hscc->DrawClone("SURF1 POL");
   hspc->SetTitle("Polar coordinates");
   c4->cd(3); TH2F *hssc = (TH2F*) hscc->DrawClone("SURF1 SPH");
   hssc->SetTitle("Spherical coordinates");
   c4->cd(4); TH2F *hsprpc = (TH2F*) hscc->DrawClone("SURF1 PSR");
   hsprpc->SetTitle("PseudoRapidity/Phi coordinates");
   return c4;
}
End_Macro
Begin_Html


<a name="HP20"></a><h3>Base line for bar-charts and lego plots</h3>


By default the base line used to draw the boxes for bar-charts and lego plots is
the histogram minimum. It is possible to force this base line to be 0 with the
command:
<pre>
      gStyle->SetHistMinimumZero();
</pre>

End_Html
Begin_Macro(source)
{
   TCanvas *c5 = new TCanvas("c5","c5",700,400);
   c5->Divide(2,1);
   gStyle->SetHistMinimumZero(1);
   TH1F *hz1 = new TH1F("hz1","Bar-chart drawn from 0",20,-3,3);
   TH2F *hz2 = new TH2F("hz2","Lego plot drawn from 0",20,-3,3,20,-3,3);
   Int_t i;
   Double_t x,y;
   hz1->SetFillColor(kBlue);
   hz2->SetFillColor(kBlue);
   for (i=0;i<10000;i++) {
      x = gRandom->Gaus(0,1);
      y = gRandom->Gaus(0,1);
      if (x>0) {
         hz1->Fill(x,1);
         hz2->Fill(x,y,1);
      } else {
         hz1->Fill(x,-1);
         hz2->Fill(x,y,-2);
      }
   }
   c5->cd(1); hz1->Draw("bar2");
   c5->cd(2); hz2->Draw("lego1");
   return c5;
}
End_Macro
Begin_Html

<p>This option also works for horizontal plots. The example given in the section
<a href="http://root.cern.ch/root/html/THistPainter.html#HP100">
"The bar chart option"</a> appears as follow:

End_Html
Begin_Macro(source)
{
   int i;
   const Int_t nx = 8;
   char *os_X[nx]   = {"8","32","128","512","2048","8192","32768","131072"};
   float d_35_0[nx] = {0.75, -3.30, -0.92, 0.10, 0.08, -1.69, -1.29, -2.37};
   float d_35_1[nx] = {1.01, -3.02, -0.65, 0.37, 0.34, -1.42, -1.02, -2.10};

   TCanvas *cbh = new TCanvas("cbh","cbh",400,600);
   cbh->SetGrid();

   gStyle->SetHistMinimumZero();

   TH1F *h1bh = new TH1F("h1bh","Option HBAR centered on 0",nx,0,nx);
   h1bh->SetFillColor(4);
   h1bh->SetBarWidth(0.4);
   h1bh->SetBarOffset(0.1);
   h1bh->SetStats(0);
   h1bh->SetMinimum(-5);
   h1bh->SetMaximum(5);

   for (i=1; i<=nx; i++) {
      h1bh->Fill(os_X[i-1], d_35_0[i-1]);
      h1bh->GetXaxis()->SetBinLabel(i,os_X[i-1]);
   }

   h1bh->Draw("hbar");

   TH1F *h2bh = new TH1F("h2bh","h2bh",nx,0,nx);
   h2bh->SetFillColor(38);
   h2bh->SetBarWidth(0.4);
   h2bh->SetBarOffset(0.5);
   h2bh->SetStats(0);
   for (i=1;i<=nx;i++) h2bh->Fill(os_X[i-1], d_35_1[i-1]);

   h2bh->Draw("hbar same");

   return cbh;
}
End_Macro
Begin_Html


<a name="HP20a"></a><h3>TH2Poly Drawing</h3>


The following options are supported:

<table border=0>

<tr><th valign=top>"SCAT"</th><td>
Draw a scatter plot (default).
</td></tr>

<tr><th valign=top>"COL"</th><td>
Draw a color plot. All the none empty bins are painted. Empty bins are not
painted.
</td></tr>

<tr><th valign=top>"COLZ"</th><td>
Same as "COL". In addition the color palette is also drawn.
</td></tr>

<tr><th valign=top>"TEXT"</th><td>
Draw bin contents as text (format set via <tt>gStyle->SetPaintTextFormat</tt>).
</td></tr>

<tr><th valign=top>"TEXTN"</th><td>
Draw bin names as text.
</td></tr>

<tr><th valign=top>"TEXTnn"</th><td>
Draw bin contents as text at angle nn (0 < nn < 90).
</td></tr>

<tr><th valign=top>"L"</th><td>
Draw the bins boundaries as lines.
The lines attibutes are the TGraphs ones.
</td></tr>

<tr><th valign=top>"P"</th><td>
Draw the bins boundaries as markers.
The markers attibutes are the TGraphs ones.
</td></tr>

<tr><th valign=top>"F"</th><td>
Draw the bins boundaries as filled polygons.
The filled polygons attibutes are the TGraphs ones.
</td></tr>

</table>

<p><a href="http://root.cern.ch/root/html/TH2Poly.html"><tt>TH2Poly</tt></a> can
be drawn as a color plot (option COL). <tt>TH2Poly</tt> bins can have any
shapes. The bins are defined as graphs. The following macro is a very simple
example showing how to book a TH2Poly and draw it.
End_Html
Begin_Macro(source)
{
   TCanvas *ch2p1 = new TCanvas("ch2p1","ch2p1",600,400);
   TH2Poly *h2p = new TH2Poly();
   h2p->SetName("h2poly_name");
   h2p->SetTitle("h2poly_title");
   Double_t px1[] = {0, 5, 6};
   Double_t py1[] = {0, 0, 5};
   Double_t px2[] = {0, -1, -1, 0};
   Double_t py2[] = {0, 0, -1, 3};
   Double_t px3[] = {4, 3, 0, 1, 2.4};
   Double_t py3[] = {4, 3.7, 1, 3.7, 2.5};
   h2p->AddBin(3, px1, py1);
   h2p->AddBin(4, px2, py2);
   h2p->AddBin(5, px3, py3);
   h2p->Fill(0.1, 0.01, 3);
   h2p->Fill(-0.5, -0.5, 7);
   h2p->Fill(-0.7, -0.5, 1);
   h2p->Fill(1, 3, 1.5);
   Double_t fx[] = {0.1, -0.5, -0.7, 1};
   Double_t fy[] = {0.01, -0.5, -0.5, 3};
   Double_t fw[] = {3, 1, 1, 1.5};
   h2p->FillN(4, fx, fy, fw);
   gStyle->SetPalette(1);
   h2p->Draw("col");
   return ch2p1;
}
End_Macro
Begin_Html

<p>Rectangular bins are a frequent case. The special version of
the <tt>AddBin</tt> method allows to define them more easily like
shown in the following example.

End_Html
Begin_Macro(source)
../../../tutorials/hist/th2polyBoxes.C
End_Macro
Begin_Html

<p>One <tt>TH2Poly</tt> bin can be a list of polygons. Such bins are defined
by calling <tt>AddBin</tt> with a <tt>TMultiGraph</tt>. The following example
shows a such case:
End_Html
Begin_Macro(source)
{
   TCanvas *ch2p2 = new TCanvas("ch2p2","ch2p2",600,400);

   Int_t i, bin;
   const Int_t nx = 48;
   const char *states [nx] = {
      "alabama",      "arizona",        "arkansas",       "california",
      "colorado",     "connecticut",    "delaware",       "florida",
      "georgia",      "idaho",          "illinois",       "indiana",
      "iowa",         "kansas",         "kentucky",       "louisiana",
      "maine",        "maryland",       "massachusetts",  "michigan",
      "minnesota",    "mississippi",    "missouri",       "montana",
      "nebraska",     "nevada",         "new_hampshire",  "new_jersey",
      "new_mexico",   "new_york",       "north_carolina", "north_dakota",
      "ohio",         "oklahoma",       "oregon",         "pennsylvania",
      "rhode_island", "south_carolina", "south_dakota",   "tennessee",
      "texas",        "utah",           "vermont",        "virginia",
      "washington",   "west_virginia",  "wisconsin",      "wyoming"
   };
   Double_t pop[nx] = {
    4708708, 6595778,  2889450, 36961664, 5024748,  3518288,  885122, 18537969,
    9829211, 1545801, 12910409,  6423113, 3007856,  2818747, 4314113,  4492076,
    1318301, 5699478,  6593587,  9969727, 5266214,  2951996, 5987580,   974989,
    1796619, 2643085,  1324575,  8707739, 2009671, 19541453, 9380884,   646844,
   11542645, 3687050,  3825657, 12604767, 1053209,  4561242,  812383,  6296254,
   24782302, 2784572,   621760,  7882590, 6664195,  1819777, 5654774,   544270
   };

   Double_t lon1 = -130;
   Double_t lon2 = -65;
   Double_t lat1 = 24;
   Double_t lat2 = 50;
   TH2Poly *p = new TH2Poly("USA","USA Population",lon1,lon2,lat1,lat2);

   TFile *f;
   f = TFile::Open("http://root.cern.ch/files/usa.root");

   TMultiGraph *mg;
   TKey *key;
   TIter nextkey(gDirectory->GetListOfKeys());
   while ((key = (TKey*)nextkey())) {
      TObject *obj = key->ReadObj();
      if (obj->InheritsFrom("TMultiGraph")) {
         mg = (TMultiGraph*)obj;
         bin = p->AddBin(mg);
      }
   }

   for (i=0; i<nx; i++) p->Fill(states[i], pop[i]);

   gStyle->SetOptStat(11);
   gStyle->SetPalette(1);
   p->Draw("COLZ L");
   return ch2p2;
}
End_Macro
Begin_Html

<p> <tt>TH2Poly</tt> histograms can also be plotted using the GL interface using
the option "GLLEGO".

<a name="HP21"></a><h3>The SPEC option</h3>


This option allows to use the <tt>TSpectrum2Painter</tt> tools. See the full
documentation in <tt>TSpectrum2Painter::PaintSpectrum</tt>.


<a name="HP22"></a><h3>Option "Z" : Adding the color palette on the right side of the pad</h3>


When this option is specified, a color palette with an axis indicating the value
of the corresponding color is drawn on the right side of the picture. In case,
not enough space is left, one can increase the size of the right margin by
calling <tt>TPad::SetRightMargin()</tt>. The attributes used to display the
palette axis values are taken from the Z axis of the object. For example, to
set the labels size on the palette axis do:
<pre>
      hist->GetZaxis()->SetLabelSize().
</pre>
<b>WARNING:</b> The palette axis is always drawn vertically.


<a name="HP23"></a><h3>Setting the color palette</h3>


To change the color palette <tt>TStyle::SetPalette</tt> should be used, eg:
<pre>
      gStyle->SetPalette(ncolors,colors);
</pre>
For example the option <tt>"COL"</tt> draws a 2D histogram with cells
represented by a box filled with a color index which is a function
of the cell content.
If the cell content is N, the color index used will be the color number
in <tt>colors[N]</tt>, etc. If the maximum cell content is greater than
<tt>ncolors</tt>, all cell contents are scaled to <tt>ncolors</tt>.

<p>If <tt> ncolors <= 0</tt>, a default palette (see below) of 50 colors is
defined. This palette is recommended for pads, labels ...

<tt>if ncolors == 1 && colors == 0</tt>, then a Pretty Palette with a
Spectrum Violet->Red is created with 50 colors. That's the default rain bow
palette.
<p>
Other prefined palettes with 255 colors are available when <tt>colors == 0</tt>.
The following value of <tt>ncolors</tt> give access to:
<p>
<pre>
if ncolors = 51 and colors=0, a Deep Sea palette is used.
if ncolors = 52 and colors=0, a Grey Scale palette is used.
if ncolors = 53 and colors=0, a Dark Body Radiator palette is used.
if ncolors = 54 and colors=0, a two-color hue palette palette is used.(dark blue through neutral gray to bright yellow)
if ncolors = 55 and colors=0, a Rain Bow palette is used.
if ncolors = 56 and colors=0, an inverted Dark Body Radiator palette is used.
</pre>

<p> If <tt>ncolors > 0 && colors == 0</tt>, the default palette is used
with a maximum of ncolors.

<p> The default palette defines:
<ul>
<li> index  0  to  9 : shades of grey
<li> index 10  to 19 : shades of brown
<li> index 20  to 29 : shades of blue
<li> index 30  to 39 : shades of red
<li> index 40  to 49 : basic colors
</ul>
The color numbers specified in the palette can be viewed by selecting
the item <tt>"colors"</tt> in the <tt>"VIEW"</tt> menu of the canvas tool bar.
The red, green, and blue components of a color can be changed thanks to
<tt>TColor::SetRGB()</tt>.


<a name="HP24"></a><h3>Drawing a sub-range of a 2D histogram; the [cutg] option</h3>


Using a <tt>TCutG</tt> object, it is possible to draw a sub-range of a 2D
histogram. One must create a graphical cut (mouse or C++) and specify the name
of the cut between <tt>[]</tt> in the <tt>Draw()</tt> option.
For example, with a <tt>TCutG</tt> named <tt>"cutg"</tt>, one can call:
<pre>
      myhist->Draw("surf1 [cutg]");
</pre>
To invert the cut, it is enough to put a <tt>"-"</tt> in front of its name:
<pre>
      myhist->Draw("surf1 [-cutg]");
</pre>
It is possible to apply several cuts (<tt>","</tt> means logical AND):
<pre>
      myhist->Draw("surf1 [cutg1,cutg2]");
</pre>

End_Html
Begin_Macro(source)
../../../tutorials/fit/fit2a.C
End_Macro
Begin_Html


<a name="HP25"></a><h3>Drawing options for 3D histograms</h3>


<table border=0>

<tr><th valign=top>"ISO"</th><td>
Draw a Gouraud shaded 3d iso surface through a 3d histogram. It paints one
surface at the value computed as follow:
<tt>SumOfWeights/(NbinsX*NbinsY*NbinsZ)</tt>
</td></tr>

<tr><th valign=top>"BOX"</th><td>
Draw a for each cell with volume proportional to the content's absolute value.
</td></tr>

</table>

By default, like 2D histograms, 3D histograms are drawn as scatter plots.

<p>The following example shows a 3D histogram plotted as a scatter plot.

End_Html
Begin_Macro(source)
{
   TCanvas *c06 = new TCanvas("c06","c06",600,400);
   gStyle->SetOptStat(kFALSE);
   TH3F *h3scat = new TH3F("h3scat","Option SCAT (default) ",15,-2,2,15,-2,2,15,0,4);
   Double_t x, y, z;
   for (Int_t i=0;i<10000;i++) {
      gRandom->Rannor(x, y);
      z = x*x + y*y;
      h3scat->Fill(x,y,z);
   }
   h3scat->Draw();
   return c06;
}
End_Macro
Begin_Html

<p>The following example shows a 3D histogram plotted with the option <tt>"BOX"</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c16 = new TCanvas("c16","c16",600,400);
   gStyle->SetOptStat(kFALSE);
   TH3F *h3box = new TH3F("h3box","Option BOX",15,-2,2,15,-2,2,15,0,4);
   Double_t x, y, z;
   for (Int_t i=0;i<10000;i++) {
      gRandom->Rannor(x, y);
      z = x*x + y*y;
      h3box->Fill(x,y,z);
   }
   h3box->Draw("BOX");
   return c16;
}
End_Macro
Begin_Html

<p>The following example shows a 3D histogram plotted with the option <tt>"ISO"</tt>.

End_Html
Begin_Macro(source)
{
   TCanvas *c26 = new TCanvas("c26","c26",600,400);
   gStyle->SetOptStat(kFALSE);
   TH3F *h3iso = new TH3F("h3iso","Option ISO",15,-2,2,15,-2,2,15,0,4);
   Double_t x, y, z;
   for (Int_t i=0;i<10000;i++) {
      gRandom->Rannor(x, y);
      z = x*x + y*y;
      h3iso->Fill(x,y,z);
   }
   h3iso->SetFillColor(kCyan);
   h3iso->Draw("ISO");
   return c26;
}
End_Macro
Begin_Html


<a name="HP26"></a><h3>Drawing option for histograms' stacks</h3>


Stacks of histograms are managed with the <tt>THStack</tt>. A <tt>THStack</tt>
is a collection of <tt>TH1</tt> (or derived) objects. For painting only the
<tt>THStack</tt> containing <tt>TH1</tt> only or
<tt>THStack</tt> containing <tt>TH2</tt> only will be considered.

<p>By default, histograms are shown stacked:
<ol>
<li> The first histogram is paint.
<li> The the sum of the first and second, etc...
</ol>
If the option <tt>"NOSTACK"</tt> is specified, the histograms are all paint in
the same pad as if the option <tt>"SAME"</tt> had been specified. This allows to
compute X and Y scales common to all the histograms, like
<tt>TMultiGraph</tt> does for graphs.

<p>If the option <tt>"PADS"</tt> is specified, the current pad/canvas is
subdivided into a number of pads equal to the number of histograms and each
histogram is paint into a separate pad.

<p>The following example shows various types of stacks.

End_Html
Begin_Macro(source)
../../../tutorials/hist/hstack.C
End_Macro
Begin_Html

<p>If at least one of the histograms in the stack has errors, the whole stack is
visualized by default with error bars. To visualize it without errors the
option <tt>"HIST"</tt> should be used.

End_Html
Begin_Macro(source)
{
   TCanvas *cst1 = new TCanvas("cst1","cst1",700,400);
   cst1->Divide(2,1);

   TH1F * hst11 = new TH1F("hst11", "", 20, -10, 10);
   hst11->Sumw2();
   hst11->FillRandom("gaus", 1000);
   hst11->SetFillColor(kViolet);
   hst11->SetLineColor(kViolet);

   TH1F * hst12 = new TH1F("hst12", "", 20, -10, 10);
   hst12->FillRandom("gaus", 500);
   hst12->SetFillColor(kBlue);
   hst12->SetLineColor(kBlue);

   THStack st1("st1", "st1");
   st1.Add(hst11);
   st1.Add(hst12);

   cst1->cd(1); st1.Draw();
   cst1->cd(2); st1.Draw("hist");

   return cst1;
}
End_Macro
Begin_Html

<a name="HP27"></a><h3>Drawing of 3D implicit functions</h3>


3D implicit functions (<tt>TF3</tt>) can be drawn as iso-surfaces.
The implicit function f(x,y,z) = 0 is drawn in cartesian coordinates.
In the following example the options "FB" and "BB" suppress the
"Front Box" and "Back Box" around the plot.

End_Html
Begin_Macro(source)
{
   TCanvas *c2 = new TCanvas("c2","c2",600,400);
   TF3 *f3 = new TF3("f3","sin(x*x+y*y+z*z-36)",-2,2,-2,2,-2,2);
   f3->SetClippingBoxOn(0,0,0);
   f3->SetFillColor(30);
   f3->SetLineColor(15);
   f3->Draw("FBBB");
   return c2;
}
End_Macro
Begin_Html


<a name="HP28"></a><h3>Associated functions drawing</h3>


An associated function is created by <tt>TH1::Fit</tt>. More than on fitted
function can be associated with one histogram (see <tt>TH1::Fit</tt>).

<p>A <tt>TF1</tt> object <tt>f1</tt> can be added to the list of associated
functions of an histogram <tt>h</tt> without calling <tt>TH1::Fit</tt>
simply doing:
<pre>
      h->GetListOfFunctions()->Add(f1);
</pre>
or
<pre>
      h->GetListOfFunctions()->Add(f1,someoption);
</pre>
To retrieve a function by name from this list, do:
<pre>
      TF1 *f1 = (TF1*)h->GetListOfFunctions()->FindObject(name);
</pre>
or
<pre>
      TF1 *f1 = h->GetFunction(name);
</pre>
Associated functions are automatically painted when an histogram is drawn.
To avoid the painting of the associated functions the option <tt>HIST</tt>
should be added to the list of the options used to paint the histogram.


<a name="HP29"></a><h3>Drawing using OpenGL</h3>


The class <tt>TGLHistPainter</tt> allows to paint data set using the OpenGL 3D
graphics library. The plotting options start with <tt>GL</tt> keyword.
In addition, in order to inform canvases that OpenGL should be used to render
3D representations, the following option should be set:
<pre>
      gStyle->SetCanvasPreferGL(true);
</pre>

<a name="HP29a"></a><h4><u>General information: plot types and supported options</u></h4>

The following types of plots are provided:

<p>For lego plots the supported options are:

<table border=0>

<tr><th valign=top>"GLLEGO"</th><td>
Draw a lego plot. It works also for <tt>TH2Poly</tt>.
</td></tr>

<tr><th valign=top>"GLLEGO2</th><td>
Bins with color levels.
</td></tr>

<tr><th valign=top>"GLLEGO3</th><td>
Cylindrical bars.
</td></tr>

</table>

<p>Lego painter in cartesian supports logarithmic scales for X, Y, Z.
In polar only Z axis can be logarithmic, in cylindrical only Y.

<p>For surface plots (<tt>TF2</tt> and <tt>TH2</tt>) the supported options are:

<table border=0>

<tr><th valign=top>"GLSURF" </th><td>
Draw a surface.
</td></tr>

<tr><th valign=top>"GLSURF1"</th><td>
Surface with color levels
</td></tr>

<tr><th valign=top>"GLSURF2"</th><td>
The same as "GLSURF1" but without polygon outlines.
</td></tr>

<tr><th valign=top>"GLSURF3"</th><td>
Color level projection on top of plot (works only in cartesian coordinate
system).
</td></tr>

<tr><th valign=top>"GLSURF4"</th><td>
Same as "GLSURF" but without polygon outlines.
</td></tr>

</table>

The surface painting in cartesian coordinates supports logarithmic scales along
X, Y, Z axis. In polar coordinates only the Z axis can be logarithmic,
in cylindrical coordinates only the Y axis.

<p>Additional options to SURF and LEGO - Coordinate systems:

<table border=0>

<tr><th valign=top>" "</th><td>
Default, cartesian coordinates system.
</td></tr>

<tr><th valign=top>"POL"</th><td>
Polar coordinates system.
</td></tr>

<tr><th valign=top>"CYL"</th><td>
Cylindrical coordinates system.
</td></tr>

<tr><th valign=top>"SPH"</th><td>
Spherical coordinates system.
</td></tr>

</table>

<a name="HP29b"></a><h4><u>TH3 as boxes (spheres)</u></h4>

The supported options are:

<table border=0>

<tr><th valign=top>GLBOX" </th><td>
TH3 as a set of boxes, size of box is proportional to bin content.
</td></tr>

<tr><th valign=top>GLBOX1"</th><td>
The same as "glbox", but spheres are drawn instead of boxes.
</td></tr>

</table>

<a name="HP29c"></a><h4><u>TH3 as iso-surface(s)</u></h4>

The supported option is:

<table border=0>

<tr><th valign=top>"GLISO" </th><td>
TH3 is drawn using iso-surfaces.
</td></tr>

</table>

<a name="HP29d"></a><h4><u>TF3 (implicit function)</u></h4>

The supported option is:

<table border=0>

<tr><th valign=top>GLTF3" </th><td>
Draw a TF3.
</td></tr>

</table>

<a name="HP29e"></a><h4><u>Parametric surfaces</u></h4>

<tt>$ROOTSYS/tutorials/gl/glparametric.C</tt> shows how to create parametric
equations and visualize the surface.

<a name="HP29f"></a><h4><u>Interaction with the plots</u></h4>

All the interactions are implemented via standard methods
<tt>DistancetoPrimitive()</tt> and <tt>ExecuteEvent()</tt>. That's why all the
interactions with the OpenGL plots are possible only when the mouse cursor is
in the plot's area (the plot's area is the part of a the pad occupied by
gl-produced picture). If the mouse cursor is not above gl-picture, the standard
pad interaction is performed.

<a name="HP29g"></a><h4><u>Selectable parts</u></h4>

Different parts of the plot can be selected:
<ul>
<li> xoz, yoz, xoy back planes:
When such a plane selected, it's highlighted in green if the
dynamic slicing by this plane is supported, and it's
highlighted in red, if the dynamic slicing is not supported.
<li> The plot itself:
On surfaces, the selected surface is outlined in red. (TF3 and
ISO are not outlined). On lego plots, the selected bin is
highlighted. The bin number and content are displayed in pad's
status bar. In box plots, the box or sphere is highlighted and
the bin info is displayed in pad's status bar.
</ul>

<a name="HP29h"></a><h4><u>Rotation and zooming</u></h4>

<ul>
<li>Rotation:
When the plot is selected, it can be rotated by pressing and
holding the left mouse button and move the cursor.
<li>Zoom/Unzoom:
Mouse wheel or 'j', 'J', 'k', 'K' keys.
</ul>

<a name="HP29i"></a><h4><u>Panning</u></h4>

The selected plot can be moved in a pad's area by pressing and
holding the left mouse button and the shift key.

<a name="HP29j"></a><h4><u>Box cut</u></h4>

Surface, iso, box, TF3 and parametric painters support box cut by
pressing the 'c' or 'C' key when the mouse cursor is in a plot's
area. That will display a transparent box, cutting away part of the
surface (or boxes) in order to show internal part of plot. This box
can be moved inside the plot's area (the full size of the box is
equal to the plot's surrounding box) by selecting one of the box
cut axes and pressing the left mouse button to move it.

<a name="HP29k"></a><h4><u>Plot specific interactions (dynamic slicing etc.)</u></h4>

Currently, all gl-plots support some form of slicing. When back plane
is selected (and if it's highlighted in green) you can press and hold
left mouse button and shift key and move this back plane inside
plot's area, creating the slice. During this "slicing" plot becomes
semi-transparent. To remove all slices (and projected curves for
surfaces) double click with left mouse button in a plot's area.

<a name="HP29l"></a><h4><u>Surface with option "GLSURF"</u></h4>

The surface profile is displayed on the slicing plane.
The profile projection is drawn on the back plane
by pressing <tt>'p'</tt> or <tt>'P'</tt> key.

<a name="HP29m"></a><h4><u>TF3</u></h4>

The contour plot is drawn on the slicing plane. For TF3 the color
scheme can be changed by pressing 's' or 'S'.

<a name="HP29n"></a><h4><u>Box</u></h4>

The contour plot corresponding to slice plane position is drawn in real time.

<a name="HP29o"></a><h4><u>Iso</u></h4>

Slicing is similar to "GLBOX" option.

<a name="HP29p"></a><h4><u>Parametric plot</u></h4>

No slicing. Additional keys: 's' or 'S' to change color scheme -
about 20 color schemes supported ('s' for "scheme"); 'l' or 'L' to
increase number of polygons ('l' for "level" of details), 'w' or 'W'
to show outlines ('w' for "wireframe").

End_Html */

TH1 *gCurrentHist = 0;

Hoption_t Hoption;
Hparam_t  Hparam;

const Int_t kNMAX = 2000;

const Int_t kMAXCONTOUR  = 104;
const UInt_t kCannotRotate = BIT(11);

static TString gStringEntries;
static TString gStringMean;
static TString gStringMeanX;
static TString gStringMeanY;
static TString gStringMeanZ;
static TString gStringRMS;
static TString gStringRMSX;
static TString gStringRMSY;
static TString gStringRMSZ;
static TString gStringUnderflow;
static TString gStringOverflow;
static TString gStringIntegral;
static TString gStringIntegralBinWidth;
static TString gStringSkewness;
static TString gStringSkewnessX;
static TString gStringSkewnessY;
static TString gStringSkewnessZ;
static TString gStringKurtosis;
static TString gStringKurtosisX;
static TString gStringKurtosisY;
static TString gStringKurtosisZ;

ClassImp(THistPainter)


//______________________________________________________________________________
THistPainter::THistPainter()
{
   /* Begin_html
   Default constructor.
   End_html */

   fH = 0;
   fXaxis = 0;
   fYaxis = 0;
   fZaxis = 0;
   fFunctions = 0;
   fXbuf  = 0;
   fYbuf  = 0;
   fNcuts = 0;
   fStack = 0;
   fLego  = 0;
   fPie   = 0;
   fGraph2DPainter = 0;
   fShowProjection = 0;
   fShowOption = "";
   for (int i=0; i<kMaxCuts; i++) {
      fCuts[i] = 0;
      fCutsOpt[i] = 0;
   }

   gStringEntries          = gEnv->GetValue("Hist.Stats.Entries",          "Entries");
   gStringMean             = gEnv->GetValue("Hist.Stats.Mean",             "Mean");
   gStringMeanX            = gEnv->GetValue("Hist.Stats.MeanX",            "Mean x");
   gStringMeanY            = gEnv->GetValue("Hist.Stats.MeanY",            "Mean y");
   gStringMeanZ            = gEnv->GetValue("Hist.Stats.MeanZ",            "Mean z");
   gStringRMS              = gEnv->GetValue("Hist.Stats.RMS",              "RMS");
   gStringRMSX             = gEnv->GetValue("Hist.Stats.RMSX",             "RMS x");
   gStringRMSY             = gEnv->GetValue("Hist.Stats.RMSY",             "RMS y");
   gStringRMSZ             = gEnv->GetValue("Hist.Stats.RMSZ",             "RMS z");
   gStringUnderflow        = gEnv->GetValue("Hist.Stats.Underflow",        "Underflow");
   gStringOverflow         = gEnv->GetValue("Hist.Stats.Overflow",         "Overflow");
   gStringIntegral         = gEnv->GetValue("Hist.Stats.Integral",         "Integral");
   gStringIntegralBinWidth = gEnv->GetValue("Hist.Stats.IntegralBinWidth", "Integral(w)");
   gStringSkewness         = gEnv->GetValue("Hist.Stats.Skewness",         "Skewness");
   gStringSkewnessX        = gEnv->GetValue("Hist.Stats.SkewnessX",        "Skewness x");
   gStringSkewnessY        = gEnv->GetValue("Hist.Stats.SkewnessY",        "Skewness y");
   gStringSkewnessZ        = gEnv->GetValue("Hist.Stats.SkewnessZ",        "Skewness z");
   gStringKurtosis         = gEnv->GetValue("Hist.Stats.Kurtosis",         "Kurtosis");
   gStringKurtosisX        = gEnv->GetValue("Hist.Stats.KurtosisX",        "Kurtosis x");
   gStringKurtosisY        = gEnv->GetValue("Hist.Stats.KurtosisY",        "Kurtosis y");
   gStringKurtosisZ        = gEnv->GetValue("Hist.Stats.KurtosisZ",        "Kurtosis z");
}


//______________________________________________________________________________
THistPainter::~THistPainter()
{
   /* Begin_html
   Default destructor.
   End_html */
}


//______________________________________________________________________________
Int_t THistPainter::DistancetoPrimitive(Int_t px, Int_t py)
{
   /* Begin_html
   Compute the distance from the point px,py to a line.
   <p>
   Compute the closest distance of approach from point px,py to elements of
   an histogram. The distance is computed in pixels units.
   <p>
   Algorithm:<br>
   Currently, this simple model computes the distance from the mouse to the
   histogram contour only.
   End_html */

   const Int_t big = 9999;
   const Int_t kMaxDiff = 7;

   if (fPie) return fPie->DistancetoPrimitive(px, py);

   Double_t x  = gPad->AbsPixeltoX(px);
   Double_t x1 = gPad->AbsPixeltoX(px+1);

   Int_t puxmin = gPad->XtoAbsPixel(gPad->GetUxmin());
   Int_t puymin = gPad->YtoAbsPixel(gPad->GetUymin());
   Int_t puxmax = gPad->XtoAbsPixel(gPad->GetUxmax());
   Int_t puymax = gPad->YtoAbsPixel(gPad->GetUymax());
   Int_t curdist = big;
   Int_t yxaxis, dyaxis,xyaxis, dxaxis;
   Bool_t dsame;
   TObject *PadPointer = gPad->GetPadPointer();
   if (!PadPointer) return 0;
   TString doption = PadPointer->GetDrawOption();
   Double_t factor = 1;
   if (fH->GetNormFactor() != 0) {
      factor = fH->GetNormFactor()/fH->GetSumOfWeights();
   }
   //     return if point is not in the histogram area

   //     If a 3D view exists, check distance to axis
   TView *view = gPad->GetView();
   Int_t d1,d2,d3;
   if (view && Hoption.Contour != 14) {
      Double_t ratio;
      d3 = view->GetDistancetoAxis(3, px, py, ratio);
      if (d3 <= kMaxDiff) {gPad->SetSelected(fZaxis); return 0;}
      d1 = view->GetDistancetoAxis(1, px, py, ratio);
      if (d1 <= kMaxDiff) {gPad->SetSelected(fXaxis); return 0;}
      d2 = view->GetDistancetoAxis(2, px, py, ratio);
      if (d2 <= kMaxDiff) {gPad->SetSelected(fYaxis); return 0;}
      if ( px > puxmin && px < puxmax && py > puymax && py < puymin) curdist = 1;
      goto FUNCTIONS;
   }
   //     check if point is close to an axis
   doption.ToLower();
   dsame = kFALSE;
   if (doption.Contains("same")) dsame = kTRUE;

   dyaxis = Int_t(2*(puymin-puymax)*fYaxis->GetLabelSize());
   if (doption.Contains("y+")) {
      xyaxis = puxmax + Int_t((puxmax-puxmin)*fYaxis->GetLabelOffset());
      if (px <= xyaxis+dyaxis && px >= xyaxis && py >puymax && py < puymin) {
         if (!dsame) {
            if (gPad->IsVertical()) gPad->SetSelected(fYaxis);
            else                    gPad->SetSelected(fXaxis);
            return 0;
         }
      }
   } else {
      xyaxis = puxmin - Int_t((puxmax-puxmin)*fYaxis->GetLabelOffset());
      if (px >= xyaxis-dyaxis && px <= xyaxis && py >puymax && py < puymin) {
         if (!dsame) {
            if (gPad->IsVertical()) gPad->SetSelected(fYaxis);
            else                    gPad->SetSelected(fXaxis);
            return 0;
         }
      }
   }

   dxaxis = Int_t((puymin-puymax)*fXaxis->GetLabelSize());
   if (doption.Contains("x+")) {
      yxaxis = puymax - Int_t((puymin-puymax)*fXaxis->GetLabelOffset());
      if (py >= yxaxis-dxaxis && py <= yxaxis && px <puxmax && px > puxmin) {
         if (!dsame) {
            if (gPad->IsVertical()) gPad->SetSelected(fXaxis);
            else                    gPad->SetSelected(fYaxis);
            return 0;
         }
      }
   } else {
      yxaxis = puymin + Int_t((puymin-puymax)*fXaxis->GetLabelOffset());
      if (yxaxis < puymin) yxaxis = puymin;
      if (py <= yxaxis+dxaxis && py >= yxaxis && px <puxmax && px > puxmin) {
         if (!dsame) {
            if (gPad->IsVertical()) gPad->SetSelected(fXaxis);
            else                    gPad->SetSelected(fYaxis);
            return 0;
         }
      }
   }

   //     if object is 2D or 3D return this object
   if (fH->GetDimension() == 2) {
      if (fH->InheritsFrom(TH2Poly::Class())) {
         TH2Poly *th2 = (TH2Poly*)fH;
         Double_t xmin, ymin, xmax, ymax;
         gPad->GetRangeAxis(xmin, ymin, xmax, ymax);
         Double_t pxu = gPad->AbsPixeltoX(px);
         Double_t pyu = gPad->AbsPixeltoY(py);
         if ((pxu>xmax) || (pxu < xmin) || (pyu>ymax) || (pyu < ymin)) {
            curdist = big;
            goto FUNCTIONS;
         } else {
            Int_t bin = th2->FindBin(pxu, pyu);
            if (bin>0) curdist = 1;
            else       curdist = big;
            goto FUNCTIONS;
         }
      }
      Int_t delta2 = 5; //Give a margin of delta2 pixels to be in the 2-d area
      if ( px > puxmin + delta2
        && px < puxmax - delta2
        && py > puymax + delta2
        && py < puymin - delta2) {curdist =1; goto FUNCTIONS;}
   }

   //     point is inside histogram area. Find channel number
   if (gPad->IsVertical()) {
      Int_t bin      = fXaxis->FindFixBin(gPad->PadtoX(x));
      Int_t binsup   = fXaxis->FindFixBin(gPad->PadtoX(x1));
      Double_t binval = factor*fH->GetBinContent(bin);
      Int_t pybin    = gPad->YtoAbsPixel(gPad->YtoPad(binval));
      if (binval == 0 && pybin < puymin) pybin = 10000;
      // special case if more than one bin for the pixel
      if (binsup-bin>1) {
         Double_t binvalmin, binvalmax;
         binvalmin=binval;
         binvalmax=binval;
         for (Int_t ibin=bin+1; ibin<binsup; ibin++) {
            Double_t binvaltmp = factor*fH->GetBinContent(ibin);
            if (binvalmin>binvaltmp) binvalmin=binvaltmp;
            if (binvalmax<binvaltmp) binvalmax=binvaltmp;
         }
         Int_t pybinmin = gPad->YtoAbsPixel(gPad->YtoPad(binvalmax));
         Int_t pybinmax = gPad->YtoAbsPixel(gPad->YtoPad(binvalmin));
         if (py<pybinmax+kMaxDiff/2 && py>pybinmin-kMaxDiff/2) pybin = py;
      }
      if (TMath::Abs(py - pybin) <= kMaxDiff) return TMath::Abs(py - pybin);
   } else {
      Double_t y  = gPad->AbsPixeltoY(py);
      Double_t y1 = gPad->AbsPixeltoY(py+1);
      Int_t bin      = fXaxis->FindFixBin(gPad->PadtoY(y));
      Int_t binsup   = fXaxis->FindFixBin(gPad->PadtoY(y1));
      Double_t binval = factor*fH->GetBinContent(bin);
      Int_t pxbin    = gPad->XtoAbsPixel(gPad->XtoPad(binval));
      if (binval == 0 && pxbin > puxmin) pxbin = 10000;
      // special case if more than one bin for the pixel
      if (binsup-bin>1) {
         Double_t binvalmin, binvalmax;
         binvalmin=binval;
         binvalmax=binval;
         for (Int_t ibin=bin+1; ibin<binsup; ibin++) {
            Double_t binvaltmp = factor*fH->GetBinContent(ibin);
            if (binvalmin>binvaltmp) binvalmin=binvaltmp;
            if (binvalmax<binvaltmp) binvalmax=binvaltmp;
         }
         Int_t pxbinmin = gPad->XtoAbsPixel(gPad->XtoPad(binvalmax));
         Int_t pxbinmax = gPad->XtoAbsPixel(gPad->XtoPad(binvalmin));
         if (px<pxbinmax+kMaxDiff/2 && px>pxbinmin-kMaxDiff/2) pxbin = px;
      }
      if (TMath::Abs(px - pxbin) <= kMaxDiff) return TMath::Abs(px - pxbin);
   }
   //     Loop on the list of associated functions and user objects
FUNCTIONS:
   TObject *f;
   TIter   next(fFunctions);
   while ((f = (TObject*) next())) {
      Int_t dist;
      if (f->InheritsFrom(TF1::Class())) dist = f->DistancetoPrimitive(-px,py);
      else                               dist = f->DistancetoPrimitive(px,py);
      if (dist < kMaxDiff) {gPad->SetSelected(f); return dist;}
   }
   return curdist;
}


//______________________________________________________________________________
void THistPainter::DrawPanel()
{
   /* Begin_html
   Display a panel with all histogram drawing options.
   End_html */

   gCurrentHist = fH;
   if (!gPad) {
      Error("DrawPanel", "need to draw histogram first");
      return;
   }
   TVirtualPadEditor *editor = TVirtualPadEditor::GetPadEditor();
   editor->Show();
   gROOT->ProcessLine(Form("((TCanvas*)0x%lx)->Selected((TVirtualPad*)0x%lx,(TObject*)0x%lx,1)",
                           (ULong_t)gPad->GetCanvas(), (ULong_t)gPad, (ULong_t)fH));
}


//______________________________________________________________________________
void THistPainter::ExecuteEvent(Int_t event, Int_t px, Int_t py)
{
   /* Begin_html
   Execute the actions corresponding to "event".
   <p>
   This function is called when a histogram is clicked with the locator at
   the pixel position px,py.
   End_html */

   static Int_t bin, px1, py1, px2, py2, pyold;
   static TBox *zoombox;

   Int_t bin1, bin2;
   Double_t xlow, xup, ylow, binval, x, baroffset, barwidth, binwidth;
   Bool_t opaque  = gPad->OpaqueMoving();

   if (!gPad->IsEditable()) return;

   if (fPie) {
      fPie->ExecuteEvent(event, px, py);
      return;
   }
   //     come here if we have a lego/surface in the pad
   TView *view = gPad->GetView();

   if (!fShowProjection && view && view->TestBit(kCannotRotate) == 0) {
      view->ExecuteRotateView(event, px, py);
      return;
   }

   TAxis *xaxis    = fH->GetXaxis();
   TAxis *yaxis    = fH->GetYaxis();
   Int_t dimension = fH->GetDimension();

   Double_t factor = 1;
   if (fH->GetNormFactor() != 0) {
      factor = fH->GetNormFactor()/fH->GetSumOfWeights();
   }

   switch (event) {

   case kButton1Down:

      if (!opaque) gVirtualX->SetLineColor(-1);
      fH->TAttLine::Modify();

      if (opaque && dimension ==2) {
         zoombox = new TBox(gPad->AbsPixeltoX(px), gPad->AbsPixeltoY(py),
                            gPad->AbsPixeltoX(px), gPad->AbsPixeltoY(py));
         Int_t ci = TColor::GetColor("#7d7dff");
         TColor *zoomcolor = gROOT->GetColor(ci);
         if (!TCanvas::SupportAlpha()) zoombox->SetFillStyle(3002);
         else                          zoomcolor->SetAlpha(0.5);
         zoombox->SetFillColor(ci);
         zoombox->Draw();
         gPad->Modified();
         gPad->Update();
      }
      // No break !!!

   case kMouseMotion:

      if (fShowProjection) {ShowProjection3(px,py); break;}

      gPad->SetCursor(kPointer);
      if (dimension ==1) {
         if (Hoption.Bar) {
            baroffset = fH->GetBarOffset();
            barwidth  = fH->GetBarWidth();
         } else {
            baroffset = 0;
            barwidth  = 1;
         }
         x        = gPad->AbsPixeltoX(px);
         bin      = fXaxis->FindFixBin(gPad->PadtoX(x));
         binwidth = fXaxis->GetBinWidth(bin);
         xlow     = gPad->XtoPad(fXaxis->GetBinLowEdge(bin) + baroffset*binwidth);
         xup      = gPad->XtoPad(xlow + barwidth*binwidth);
         ylow     = gPad->GetUymin();
         px1      = gPad->XtoAbsPixel(xlow);
         px2      = gPad->XtoAbsPixel(xup);
         py1      = gPad->YtoAbsPixel(ylow);
         py2      = py;
         pyold    = py;
         if (gROOT->GetEditHistograms()) gPad->SetCursor(kArrowVer);
      }

      break;

   case kButton1Motion:

      if (dimension ==1) {
         if (gROOT->GetEditHistograms()) {
            if (!opaque) {
               gVirtualX->DrawBox(px1, py1, px2, py2,TVirtualX::kHollow);  // Draw the old box
               py2 += py - pyold;
               gVirtualX->DrawBox(px1, py1, px2, py2,TVirtualX::kHollow);  // Draw the new box
               pyold = py;
            } else {
               py2 += py - pyold;
               pyold = py;
               binval = gPad->PadtoY(gPad->AbsPixeltoY(py2))/factor;
               fH->SetBinContent(bin,binval);
               gPad->Modified(kTRUE);
            }
         }
      }

      if (opaque && dimension ==2) {
         zoombox->SetX2(gPad->AbsPixeltoX(px));
         zoombox->SetY2(gPad->AbsPixeltoY(py));
         gPad->Modified();
         gPad->Update();
      }

      break;

   case kWheelUp:

      if (dimension ==2) {
         bin1 = xaxis->GetFirst()+1;
         bin2 = xaxis->GetLast()-1;
         if (bin2>bin1) xaxis->SetRange(bin1,bin2);
         bin1 = yaxis->GetFirst()+1;
         bin2 = yaxis->GetLast()-1;
         if (bin2>bin1) yaxis->SetRange(bin1,bin2);
      }
      gPad->Modified();
      gPad->Update();

      break;

   case kWheelDown:

      if (dimension == 2) {
         bin1 = xaxis->GetFirst()-1;
         bin2 = xaxis->GetLast()+1;
         if (bin2>bin1) xaxis->SetRange(bin1,bin2);
         bin1 = yaxis->GetFirst()-1;
         bin2 = yaxis->GetLast()+1;
         if (bin2>bin1) yaxis->SetRange(bin1,bin2);
      }
      gPad->Modified();
      gPad->Update();

      break;

   case kButton1Up:
      if (dimension ==1) {
         if (gROOT->GetEditHistograms()) {
            binval = gPad->PadtoY(gPad->AbsPixeltoY(py2))/factor;
            fH->SetBinContent(bin,binval);
            PaintInit();   // recalculate Hparam structure and recalculate range
         }

         // might resize pad pixmap so should be called before any paint routine
         RecalculateRange();
      }
      if (opaque && dimension ==2) {
         if (zoombox) {
            Double_t x1 = TMath::Min(zoombox->GetX1(), zoombox->GetX2());
            Double_t x2 = TMath::Max(zoombox->GetX1(), zoombox->GetX2());
            Double_t y1 = TMath::Min(zoombox->GetY1(), zoombox->GetY2());
            Double_t y2 = TMath::Max(zoombox->GetY1(), zoombox->GetY2());
            if (x1<x2 && y1<y2) {
               xaxis->SetRangeUser(x1, x2);
               yaxis->SetRangeUser(y1, y2);
            }
            zoombox->Delete();
            zoombox = 0;
         }
      }
      gPad->Modified(kTRUE);
      if (opaque) gVirtualX->SetLineColor(-1);

      break;

   case kButton1Locate:

      ExecuteEvent(kButton1Down, px, py);

      while (1) {
         px = py = 0;
         event = gVirtualX->RequestLocator(1, 1, px, py);

         ExecuteEvent(kButton1Motion, px, py);

         if (event != -1) {                     // button is released
            ExecuteEvent(kButton1Up, px, py);
            return;
         }
      }
   }
}


//______________________________________________________________________________
TList *THistPainter::GetContourList(Double_t contour) const
{
   /* Begin_html
   Get a contour (as a list of TGraphs) using the Delaunay triangulation.
   End_html */

   TGraphDelaunay *dt;

   // Check if fH contains a TGraphDelaunay
   TList *hl = fH->GetListOfFunctions();
   dt = (TGraphDelaunay*)hl->FindObject("TGraphDelaunay");
   if (!dt) return 0;

   gCurrentHist = fH;

   if (!fGraph2DPainter) ((THistPainter*)this)->fGraph2DPainter = new TGraph2DPainter(dt);

   return fGraph2DPainter->GetContourList(contour);
}


//______________________________________________________________________________
char *THistPainter::GetObjectInfo(Int_t px, Int_t py) const
{
   /* Begin_html
   Display the histogram info (bin number, contents, integral up to bin
   corresponding to cursor position px,py.
   End_html */

   if (!gPad) return (char*)"";
   static char info[200];
   Double_t x  = gPad->PadtoX(gPad->AbsPixeltoX(px));
   Double_t y  = gPad->PadtoY(gPad->AbsPixeltoY(py));
   Double_t x1 = gPad->PadtoX(gPad->AbsPixeltoX(px+1));
   const char *drawOption = fH->GetDrawOption();
   Double_t xmin, xmax, uxmin,uxmax;
   Double_t ymin, ymax, uymin,uymax;
   if (fH->GetDimension() == 2) {
      if (gPad->GetView() || strncmp(drawOption,"cont",4) == 0
                          || strncmp(drawOption,"CONT",4) == 0) {
         uxmin=gPad->GetUxmin();
         uxmax=gPad->GetUxmax();
         xmin = fXaxis->GetBinLowEdge(fXaxis->GetFirst());
         xmax = fXaxis->GetBinUpEdge(fXaxis->GetLast());
         x = xmin +(xmax-xmin)*(x-uxmin)/(uxmax-uxmin);
         uymin=gPad->GetUymin();
         uymax=gPad->GetUymax();
         ymin = fYaxis->GetBinLowEdge(fYaxis->GetFirst());
         ymax = fYaxis->GetBinUpEdge(fYaxis->GetLast());
         y = ymin +(ymax-ymin)*(y-uymin)/(uymax-uymin);
      }
   }
   Int_t binx,biny,binmin,binx1;
   if (gPad->IsVertical()) {
      binx   = fXaxis->FindFixBin(x);
      binmin = fXaxis->GetFirst();
      binx1  = fXaxis->FindFixBin(x1);
      // special case if more than 1 bin in x per pixel
      if (binx1-binx>1 && fH->GetDimension() == 1) {
         Double_t binval=fH->GetBinContent(binx);
         Int_t binnear=binx;
         for (Int_t ibin=binx+1; ibin<binx1; ibin++) {
            Double_t binvaltmp = fH->GetBinContent(ibin);
            if (TMath::Abs(y-binvaltmp) < TMath::Abs(y-binval)) {
               binval=binvaltmp;
               binnear=ibin;
            }
         }
         binx = binnear;
      }
   } else {
      x1 = gPad->PadtoY(gPad->AbsPixeltoY(py+1));
      binx   = fXaxis->FindFixBin(y);
      binmin = fXaxis->GetFirst();
      binx1  = fXaxis->FindFixBin(x1);
      // special case if more than 1 bin in x per pixel
      if (binx1-binx>1 && fH->GetDimension() == 1) {
         Double_t binval=fH->GetBinContent(binx);
         Int_t binnear=binx;
         for (Int_t ibin=binx+1; ibin<binx1; ibin++) {
            Double_t binvaltmp = fH->GetBinContent(ibin);
            if (TMath::Abs(x-binvaltmp) < TMath::Abs(x-binval)) {
               binval=binvaltmp;
               binnear=ibin;
            }
         }
         binx = binnear;
      }
   }
   if (fH->GetDimension() == 1) {
      if (fH->InheritsFrom(TProfile::Class())) {
         TProfile *tp = (TProfile*)fH;
         snprintf(info,200,"(x=%g, y=%g, binx=%d, binc=%g, bine=%g, binn=%d)",
                  x, y, binx, fH->GetBinContent(binx), fH->GetBinError(binx),
                  (Int_t) tp->GetBinEntries(binx));
      }
      else {
         Double_t integ = 0;
         for (Int_t bin=binmin;bin<=binx;bin++) {integ += fH->GetBinContent(bin);}
         snprintf(info,200,"(x=%g, y=%g, binx=%d, binc=%g, Sum=%g)",
                  x,y,binx,fH->GetBinContent(binx),integ);
      }
   } else if (fH->GetDimension() == 2) {
      if (fH->InheritsFrom(TH2Poly::Class())) {
         TH2Poly *th2 = (TH2Poly*)fH;
         biny = th2->FindBin(x,y);
         snprintf(info,200,"%s (x=%g, y=%g, bin=%d, binc=%g)",
                  th2->GetBinTitle(biny),x,y,biny,th2->GetBinContent(biny));
      }
      else if (fH->InheritsFrom(TProfile2D::Class())) {
         TProfile2D *tp = (TProfile2D*)fH;
         biny = fYaxis->FindFixBin(y);
         Int_t bin = fH->GetBin(binx,biny);
         snprintf(info,200,"(x=%g, y=%g, binx=%d, biny=%d, binc=%g, bine=%g, binn=%d)",
                  x, y, binx, biny, fH->GetBinContent(bin),
                  fH->GetBinError(bin), (Int_t) tp->GetBinEntries(bin));
      } else {
         biny = fYaxis->FindFixBin(y);
         snprintf(info,200,"(x=%g, y=%g, binx=%d, biny=%d, binc=%g bine=%g)",
                  x,y,binx,biny,fH->GetBinContent(binx,biny),
                  fH->GetBinError(binx,biny));
      }
   } else {
      // 3d case: retrieving the x,y,z bin is not yet implemented
      // print just the x,y info
      snprintf(info,200,"(x=%g, y=%g)",x,y);
   }
   return info;
}


//______________________________________________________________________________
Bool_t THistPainter::IsInside(Int_t ix, Int_t iy)
{
   /* Begin_html
   Return kTRUE if the cell ix, iy is inside one of the graphical cuts.
   End_html */

   for (Int_t i=0;i<fNcuts;i++) {
      Double_t x = fXaxis->GetBinCenter(ix);
      Double_t y = fYaxis->GetBinCenter(iy);
      if (fCutsOpt[i] > 0) {
         if (!fCuts[i]->IsInside(x,y)) return kFALSE;
      } else {
         if (fCuts[i]->IsInside(x,y))  return kFALSE;
      }
   }
   return kTRUE;
}


//______________________________________________________________________________
Bool_t THistPainter::IsInside(Double_t x, Double_t y)
{
   /* Begin_html
   Return kTRUE if the point x,y is inside one of the graphical cuts.
   End_html */

   for (Int_t i=0;i<fNcuts;i++) {
      if (fCutsOpt[i] > 0) {
         if (!fCuts[i]->IsInside(x,y)) return kFALSE;
      } else {
         if (fCuts[i]->IsInside(x,y))  return kFALSE;
      }
   }
   return kTRUE;
}


//______________________________________________________________________________
Int_t THistPainter::MakeChopt(Option_t *choptin)
{
   /* Begin_html
   Decode string "choptin" and fill Hoption structure.
   End_html */

   char *l;
   char chopt[128];
   Int_t nch = strlen(choptin);
   strlcpy(chopt,choptin,128);
   Int_t hdim = fH->GetDimension();

   Hoption.Axis = Hoption.Bar    = Hoption.Curve   = Hoption.Error = 0;
   Hoption.Hist = Hoption.Line   = Hoption.Mark    = Hoption.Fill  = 0;
   Hoption.Same = Hoption.Func   = Hoption.Scat    = 0;
   Hoption.Star = Hoption.Arrow  = Hoption.Box     = Hoption.Text  = 0;
   Hoption.Char = Hoption.Color  = Hoption.Contour = Hoption.Logx  = 0;
   Hoption.Logy = Hoption.Logz   = Hoption.Lego    = Hoption.Surf  = 0;
   Hoption.Off  = Hoption.Tri    = Hoption.Proj    = Hoption.AxisPos = 0;
   Hoption.Spec = Hoption.Pie    = Hoption.Candle  = 0;

   //    special 2D options
   Hoption.List     = 0;
   Hoption.Zscale   = 0;
   Hoption.FrontBox = 1;
   Hoption.BackBox  = 1;
   Hoption.System   = kCARTESIAN;

   Hoption.Zero     = 0;

   //check for graphical cuts
   MakeCuts(chopt);

   for (Int_t i=0;i<nch;i++) chopt[i] = toupper(chopt[i]);
   if (hdim > 1) Hoption.Scat = 1;
   if (!nch) Hoption.Hist = 1;
   if (fFunctions->First()) Hoption.Func = 2;
   if (fH->GetSumw2N() && hdim == 1) Hoption.Error = 2;

   l = strstr(chopt,"SPEC");
   if (l) {
      Hoption.Scat = 0;
      strncpy(l,"    ",4);
      Int_t bs=0;
      l = strstr(chopt,"BF(");
      if (l) {
         if (sscanf(&l[3],"%d",&bs) > 0) {
            Int_t i=0;
            while (l[i]!=')') {
               l[i] = ' ';
               i++;
            }
            l[i] = ' ';
         }
      }
      Hoption.Spec = TMath::Max(1600,bs);
      return 1;
   }

   l = strstr(chopt,"GL");
   if (l) {
      strncpy(l,"  ",2);
   }
   l = strstr(chopt,"X+");
   if (l) {
      Hoption.AxisPos = 10;
      strncpy(l,"  ",2);
   }
   l = strstr(chopt,"Y+");
   if (l) {
      Hoption.AxisPos += 1;
      strncpy(l,"  ",2);
   }
   if ((Hoption.AxisPos == 10 || Hoption.AxisPos == 1) && (nch == 2)) Hoption.Hist = 1;
   if (Hoption.AxisPos == 11 && nch == 4) Hoption.Hist = 1;

   l = strstr(chopt,"SAMES");
   if (l) {
      if (nch == 5) Hoption.Hist = 1;
      Hoption.Same = 2;
      strncpy(l,"     ",5);
   }
   l = strstr(chopt,"SAME");
   if (l) {
      if (nch == 4) Hoption.Hist = 1;
      Hoption.Same = 1;
      strncpy(l,"    ",4);
   }

   l = strstr(chopt,"PIE");
   if (l) {
      Hoption.Pie = 1;
      strncpy(l,"   ",3);
   }

   l = strstr(chopt,"CANDLE");
   if (l) {
      Hoption.Scat = 0;
      Hoption.Candle = 1;
      strncpy(l,"   ",6);
      if (l[6] == 'X') { Hoption.Candle = 1; l[6] = ' '; }
      if (l[6] == 'Y') { Hoption.Candle = 2; l[6] = ' '; }
   }

   l = strstr(chopt,"LEGO");
   if (l) {
      Hoption.Scat = 0;
      Hoption.Lego = 1; strncpy(l,"    ",4);
      if (l[4] == '1') { Hoption.Lego = 11; l[4] = ' '; }
      if (l[4] == '2') { Hoption.Lego = 12; l[4] = ' '; }
      if (l[4] == '3') { Hoption.Lego = 13; l[4] = ' '; }
      if (l[4] == '4') { Hoption.Lego = 14; l[4] = ' '; }
      l = strstr(chopt,"FB"); if (l) { Hoption.FrontBox = 0; strncpy(l,"  ",2); }
      l = strstr(chopt,"BB"); if (l) { Hoption.BackBox = 0;  strncpy(l,"  ",2); }
      l = strstr(chopt,"0");  if (l) { Hoption.Zero = 1;  strncpy(l," ",1); }
   }

   l = strstr(chopt,"SURF");
   if (l) {
      Hoption.Scat = 0;
      Hoption.Surf = 1; strncpy(l,"    ",4);
      if (l[4] == '1') { Hoption.Surf = 11; l[4] = ' '; }
      if (l[4] == '2') { Hoption.Surf = 12; l[4] = ' '; }
      if (l[4] == '3') { Hoption.Surf = 13; l[4] = ' '; }
      if (l[4] == '4') { Hoption.Surf = 14; l[4] = ' '; }
      if (l[4] == '5') { Hoption.Surf = 15; l[4] = ' '; }
      if (l[4] == '6') { Hoption.Surf = 16; l[4] = ' '; }
      if (l[4] == '7') { Hoption.Surf = 17; l[4] = ' '; }
      l = strstr(chopt,"FB");   if (l) { Hoption.FrontBox = 0; strncpy(l,"  ",2); }
      l = strstr(chopt,"BB");   if (l) { Hoption.BackBox = 0;  strncpy(l,"  ",2); }
   }

   l = strstr(chopt,"TF3");
   if (l) {
      l = strstr(chopt,"FB");   if (l) { Hoption.FrontBox = 0; strncpy(l,"  ",2); }
      l = strstr(chopt,"BB");   if (l) { Hoption.BackBox = 0;  strncpy(l,"  ",2); }
   }

   l = strstr(chopt,"ISO");
   if (l) {
      l = strstr(chopt,"FB");   if (l) { Hoption.FrontBox = 0; strncpy(l,"  ",2); }
      l = strstr(chopt,"BB");   if (l) { Hoption.BackBox = 0;  strncpy(l,"  ",2); }
   }

   l = strstr(chopt,"LIST");    if (l) { Hoption.List = 1;  strncpy(l,"    ",4);}

   l = strstr(chopt,"CONT");
   if (l) {
      strncpy(l,"    ",4);
      if (hdim>1) {
         Hoption.Scat = 0;
         Hoption.Contour = 1;
         if (l[4] == '1') { Hoption.Contour = 11; l[4] = ' '; }
         if (l[4] == '2') { Hoption.Contour = 12; l[4] = ' '; }
         if (l[4] == '3') { Hoption.Contour = 13; l[4] = ' '; }
         if (l[4] == '4') { Hoption.Contour = 14; l[4] = ' '; }
         if (l[4] == '5') { Hoption.Contour = 15; l[4] = ' '; }
      } else {
         Hoption.Hist = 1;
      }
   }
   l = strstr(chopt,"HBAR");
   if (l) {
      Hoption.Hist = 0;
      Hoption.Bar = 20; strncpy(l,"    ",4);
      if (l[4] == '1') { Hoption.Bar = 21; l[4] = ' '; }
      if (l[4] == '2') { Hoption.Bar = 22; l[4] = ' '; }
      if (l[4] == '3') { Hoption.Bar = 23; l[4] = ' '; }
      if (l[4] == '4') { Hoption.Bar = 24; l[4] = ' '; }
   }
   l = strstr(chopt,"BAR");
   if (l) {
      Hoption.Hist = 0;
      Hoption.Bar = 10; strncpy(l,"   ",3);
      if (l[3] == '1') { Hoption.Bar = 11; l[3] = ' '; }
      if (l[3] == '2') { Hoption.Bar = 12; l[3] = ' '; }
      if (l[3] == '3') { Hoption.Bar = 13; l[3] = ' '; }
      if (l[3] == '4') { Hoption.Bar = 14; l[3] = ' '; }
   }

   l = strstr(chopt,"ARR" );
   if (l) {
      strncpy(l,"   ", 3);
      if (hdim>1) {
         Hoption.Arrow  = 1;
         Hoption.Scat = 0;
      } else {
         Hoption.Hist = 1;
      }
   }
   l = strstr(chopt,"BOX" );
   if (l) {
      strncpy(l,"   ", 3);
      if (hdim>1) {
         Hoption.Scat = 0;
         Hoption.Box  = 1;
         if (l[3] == '1') { Hoption.Box = 11; l[3] = ' '; }
      } else {
         Hoption.Hist = 1;
      }
   }
   l = strstr(chopt,"COLZ");
   if (l) {
      strncpy(l,"    ",4);
      if (hdim>1) {
         Hoption.Color  = 2;
         Hoption.Scat   = 0;
         Hoption.Zscale = 1;
      } else {
         Hoption.Hist = 1;
      }
   }
   l = strstr(chopt,"COL" );
   if (l) {
      strncpy(l,"   ", 3);
      if (hdim>1) {
         Hoption.Color = 1;
         Hoption.Scat  = 0;
      } else {
         Hoption.Hist = 1;
      }
   }
   l = strstr(chopt,"CHAR"); if (l) { Hoption.Char   = 1; strncpy(l,"    ",4); Hoption.Scat = 0; }
   l = strstr(chopt,"FUNC"); if (l) { Hoption.Func   = 2; strncpy(l,"    ",4); Hoption.Hist = 0; }
   l = strstr(chopt,"HIST"); if (l) { Hoption.Hist   = 2; strncpy(l,"    ",4); Hoption.Func = 0; Hoption.Error = 0;}
   l = strstr(chopt,"AXIS"); if (l) { Hoption.Axis   = 1; strncpy(l,"    ",4); }
   l = strstr(chopt,"AXIG"); if (l) { Hoption.Axis   = 2; strncpy(l,"    ",4); }
   l = strstr(chopt,"SCAT"); if (l) { Hoption.Scat   = 1; strncpy(l,"    ",4); }
   l = strstr(chopt,"TEXT");
   if (l) {
      Int_t angle;
      if (sscanf(&l[4],"%d",&angle) > 0) {
         if (angle < 0)  angle=0;
         if (angle > 90) angle=90;
         Hoption.Text = 1000+angle;
      } else {
         Hoption.Text = 1;
      }
      strncpy(l,"    ", 4);
      l = strstr(chopt,"N");
      if (l && fH->InheritsFrom(TH2Poly::Class())) Hoption.Text += 3000;
      Hoption.Scat = 0;
   }
   l = strstr(chopt,"POL");  if (l) { Hoption.System = kPOLAR;       strncpy(l,"   ",3); }
   l = strstr(chopt,"CYL");  if (l) { Hoption.System = kCYLINDRICAL; strncpy(l,"   ",3); }
   l = strstr(chopt,"SPH");  if (l) { Hoption.System = kSPHERICAL;   strncpy(l,"   ",3); }
   l = strstr(chopt,"PSR");  if (l) { Hoption.System = kRAPIDITY;    strncpy(l,"   ",3); }

   l = strstr(chopt,"TRI");
   if (l) {
      Hoption.Scat = 0;
      Hoption.Color  = 0;
      Hoption.Tri = 1; strncpy(l,"   ",3);
      l = strstr(chopt,"FB");   if (l) { Hoption.FrontBox = 0; strncpy(l,"  ",2); }
      l = strstr(chopt,"BB");   if (l) { Hoption.BackBox = 0;  strncpy(l,"  ",2); }
      l = strstr(chopt,"ERR");  if (l) strncpy(l,"   ",3);
   }

   l = strstr(chopt,"AITOFF");
   if (l) {
      Hoption.Proj = 1; strncpy(l,"     ",6);       //Aitoff projection
   }
   l = strstr(chopt,"MERCATOR");
   if (l) {
      Hoption.Proj = 2; strncpy(l,"       ",8);     //Mercator projection
   }
   l = strstr(chopt,"SINUSOIDAL");
   if (l) {
      Hoption.Proj = 3; strncpy(l,"         ",10);  //Sinusoidal projection
   }
   l = strstr(chopt,"PARABOLIC");
   if (l) {
      Hoption.Proj = 4; strncpy(l,"        ",9);    //Parabolic projection
   }
   if (Hoption.Proj > 0) {
      Hoption.Scat = 0;
      Hoption.Contour = 14;
   }

   if (strstr(chopt,"A"))   Hoption.Axis = -1;
   if (strstr(chopt,"B"))   Hoption.Bar  = 1;
   if (strstr(chopt,"C")) { Hoption.Curve =1; Hoption.Hist = -1;}
   if (strstr(chopt,"F"))   Hoption.Fill =1;
   if (strstr(chopt,"][")) {Hoption.Off  =1; Hoption.Hist =1;}
   if (strstr(chopt,"F2"))  Hoption.Fill =2;
   if (strstr(chopt,"L")) { Hoption.Line =1; Hoption.Hist = -1;}
   if (strstr(chopt,"P")) { Hoption.Mark =1; Hoption.Hist = -1;}
   if (strstr(chopt,"Z"))   Hoption.Zscale =1;
   if (strstr(chopt,"*"))   Hoption.Star =1;
   if (strstr(chopt,"H"))   Hoption.Hist =2;
   if (strstr(chopt,"P0"))  Hoption.Mark =10;

   if (fH->InheritsFrom(TH2Poly::Class())) {
      if (Hoption.Fill+Hoption.Line+Hoption.Mark != 0 ) Hoption.Scat = 0;
   }

   if (strstr(chopt,"E")) {
      if (hdim == 1) {
         Hoption.Error = 1;
         if (strstr(chopt,"E0"))  Hoption.Error = 10;
         if (strstr(chopt,"E1"))  Hoption.Error = 11;
         if (strstr(chopt,"E2"))  Hoption.Error = 12;
         if (strstr(chopt,"E3"))  Hoption.Error = 13;
         if (strstr(chopt,"E4"))  Hoption.Error = 14;
         if (strstr(chopt,"E5"))  Hoption.Error = 15;
         if (strstr(chopt,"E6"))  Hoption.Error = 16;
         if (strstr(chopt,"X0")) {
            if (Hoption.Error == 1)  Hoption.Error += 20;
            Hoption.Error += 10;
         }
         if (Hoption.Text && fH->InheritsFrom(TProfile::Class())) {
            Hoption.Text += 2000;
            Hoption.Error = 0;
         }
      } else {
         if (Hoption.Error == 0) {
            Hoption.Error = 100;
            Hoption.Scat  = 0;
         }
         if (Hoption.Text) {
            Hoption.Text += 2000;
            Hoption.Error = 0;
         }
      }
   }

   if (Hoption.Surf == 15) {
      if (Hoption.System == kPOLAR || Hoption.System == kCARTESIAN) {
         Hoption.Surf = 13;
         Warning("MakeChopt","option SURF5 is not supported in Cartesian and Polar modes");
      }
   }

   //      Copy options from current style
   Hoption.Logx = gPad->GetLogx();
   Hoption.Logy = gPad->GetLogy();
   Hoption.Logz = gPad->GetLogz();

   //       Check options incompatibilities
   if (Hoption.Bar  == 1) Hoption.Hist = -1;
   return 1;
}


//______________________________________________________________________________
Int_t THistPainter::MakeCuts(char *choptin)
{
   /* Begin_html
   Decode string "choptin" and fill Graphical cuts structure.
   End_html */

   fNcuts = 0;
   char *left = (char*)strchr(choptin,'[');
   if (!left) return 0;
   char *right = (char*)strchr(choptin,']');
   if (!right) return 0;
   Int_t nch = right-left;
   if (nch < 2) return 0;
   char *cuts = left+1;
   *right = 0;
   char *comma, *minus;
   Int_t i;
   while (1) {
      comma = strchr(cuts,',');
      if (comma) *comma = 0;
      minus = strchr(cuts,'-');
      if (minus) cuts = minus+1;
      while (*cuts == ' ') cuts++;
      Int_t nc = strlen(cuts);
      while (cuts[nc-1] == ' ') {cuts[nc-1] = 0; nc--;}
      TIter next(gROOT->GetListOfSpecials());
      TCutG *cut=0;
      TObject *obj;
      while ((obj = next())) {
         if (!obj->InheritsFrom(TCutG::Class())) continue;
         if (strcmp(obj->GetName(),cuts)) continue;
         cut = (TCutG*)obj;
         break;
      }
      if (cut) {
         fCuts[fNcuts] = cut;
         fCutsOpt[fNcuts] = 1;
         if (minus) fCutsOpt[fNcuts] = -1;
         fNcuts++;
      }
      if (!comma) break;
      cuts = comma+1;
   }
   for (i=0;i<=nch;i++) left[i] = ' ';
   return fNcuts;
}


//______________________________________________________________________________
void THistPainter::Paint(Option_t *option)
{
   /* Begin_Html
   <a href="#HP00">Control routine to paint any kind of histograms.</a>
   End_html */

   if (fH->GetBuffer()) fH->BufferEmpty(-1);

   //For iOS: put the histogram on the top of stack of pickable objects.
   const TPickerStackGuard topPush(fH);

   gPad->SetVertical(kTRUE);

   TH1 *oldhist = gCurrentHist;
   gCurrentHist = fH;
   TH1 *hsave   = fH;
   Double_t minsav = fH->GetMinimumStored();

   if (!MakeChopt(option)) return; //check options and fill Hoption structure

   // Paint using TSpectrum2Painter
   if (Hoption.Spec) {
      if (!TableInit()) return;
      if (!TClass::GetClass("TSpectrum2Painter")) gSystem->Load("libSpectrumPainter");
      gROOT->ProcessLineFast(Form("TSpectrum2Painter::PaintSpectrum((TH2F*)0x%lx,\"%s\",%d)",
                                  (ULong_t)fH, option, Hoption.Spec));
      return;
   }

   if (Hoption.Pie) {
      if (fH->GetDimension() == 1) {
         if (!fPie) fPie = new TPie(fH);
         fPie->Paint(option);
      } else {
         Error("Paint", "Option PIE is for 1D histograms only");
      }
      return;
   } else {
      if (fPie) delete fPie;
      fPie = 0;
   }

   fXbuf  = new Double_t[kNMAX];
   fYbuf  = new Double_t[kNMAX];
   if (fH->GetDimension() > 2) {
      PaintH3(option);
      fH->SetMinimum(minsav);
      if (Hoption.Func) {
         Hoption_t hoptsave = Hoption;
         Hparam_t  hparsave = Hparam;
         PaintFunction(option);
         SetHistogram(hsave);
         Hoption = hoptsave;
         Hparam  = hparsave;
      }
      gCurrentHist = oldhist;
      delete [] fXbuf; delete [] fYbuf;
      return;
   }
   TView *view = gPad->GetView();
   if (view) {
      if (!Hoption.Lego && !Hoption.Surf && !Hoption.Tri) {
         delete view;
         gPad->SetView(0);
      }
   }
   if (fH->GetDimension() > 1 || Hoption.Lego || Hoption.Surf) {
      // In case of 1D histogram, Z axis becomes Y axis.
      Int_t logysav=0, logzsav=0;
      if (fH->GetDimension() == 1) {
         logysav = Hoption.Logy;
         logzsav = Hoption.Logz;
         Hoption.Logz = 0;
         if (Hoption.Logy) {
            Hoption.Logz = 1;
            Hoption.Logy = 0;
         }
      }
      PaintTable(option);
      fH->SetMinimum(minsav);
      if (Hoption.Func) {
         Hoption_t hoptsave = Hoption;
         Hparam_t  hparsave = Hparam;
         PaintFunction(option);
         SetHistogram(hsave);
         Hoption = hoptsave;
         Hparam  = hparsave;
      }
      gCurrentHist = oldhist;
      delete [] fXbuf; delete [] fYbuf;
      if (fH->GetDimension() == 1) {
         Hoption.Logy = logysav;
         Hoption.Logz = logzsav;
      }
      return;
   }

   if (Hoption.Bar >= 20) {PaintBarH(option);
      delete [] fXbuf; delete [] fYbuf;
      return;
   }

   // fill Hparam structure with histo parameters
   if (!PaintInit()) {
      delete [] fXbuf; delete [] fYbuf;
      return;
   }

   //          Picture surround (if new page) and page number (if requested).
   //          Histogram surround (if not option "Same").
   PaintFrame();

   //          Paint histogram axis only
   Bool_t gridx = gPad->GetGridx();
   Bool_t gridy = gPad->GetGridy();
   if (Hoption.Axis > 0) {
      if (Hoption.Axis > 1) PaintAxis(kTRUE);  //axis with grid
      else {
         if (gridx) gPad->SetGridx(0);
         if (gridy) gPad->SetGridy(0);
         PaintAxis(kFALSE);
         if (gridx) gPad->SetGridx(1);
         if (gridy) gPad->SetGridy(1);
      }
      if (Hoption.Same ==1) Hoption.Same = 2;
      goto paintstat;
   }
   if (gridx || gridy) PaintAxis(kTRUE); //    Draw the grid only

   //          test for options BAR or HBAR
   if (Hoption.Bar >= 10) {
      PaintBar(option);
   }

   //          do not draw histogram if error bars required
   if (!Hoption.Error) {
      if (Hoption.Hist && Hoption.Bar<10) PaintHist(option);
   }

   //         test for error bars or option E
   if (Hoption.Error) {
      PaintErrors(option);
      if (Hoption.Hist == 2) PaintHist(option);
   }

   if (Hoption.Text) PaintText(option);

   //         test for associated function
   if (Hoption.Func) {
      Hoption_t hoptsave = Hoption;
      Hparam_t  hparsave = Hparam;
      PaintFunction(option);
      SetHistogram(hsave);
      Hoption = hoptsave;
      Hparam  = hparsave;
   }

   if (gridx) gPad->SetGridx(0);
   if (gridy) gPad->SetGridy(0);
   PaintAxis(kFALSE);
   if (gridx) gPad->SetGridx(1);
   if (gridy) gPad->SetGridy(1);

   PaintTitle();  // Draw histogram title

   // Draw box with histogram statistics and/or fit parameters
paintstat:
   if (Hoption.Same != 1 && !fH->TestBit(TH1::kNoStats)) {  // bit set via TH1::SetStats
      TIter next(fFunctions);
      TObject *obj = 0;
      while ((obj = next())) {
         if (obj->InheritsFrom(TF1::Class())) break;
         obj = 0;
      }

      //Stat is painted twice (first, it will be in canvas' list of primitives),
      //second, it will be here, this is not required on iOS.
      //Condition is ALWAYS true on a platform different from iOS.
      if (!gPad->PadInSelectionMode() && !gPad->PadInHighlightMode())
         PaintStat(gStyle->GetOptStat(),(TF1*)obj);
   }
   fH->SetMinimum(minsav);
   gCurrentHist = oldhist;
   delete [] fXbuf; fXbuf = 0;
   delete [] fYbuf; fYbuf = 0;

}


//______________________________________________________________________________
void THistPainter::PaintArrows(Option_t *)
{
   /* Begin_html
   <a href="#HP12">Control function to draw a table as an arrow plot.</a>
   End_html */

   Style_t linesav   = fH->GetLineStyle();
   Width_t widthsav  = fH->GetLineWidth();
   fH->SetLineStyle(1);
   fH->SetLineWidth(1);
   fH->TAttLine::Modify();

   Double_t xk, xstep, yk, ystep;
   Double_t dx, dy, si, co, anr, x1, x2, y1, y2, xc, yc, dxn, dyn;
   Int_t   ncx  = Hparam.xlast - Hparam.xfirst + 1;
   Int_t   ncy  = Hparam.ylast - Hparam.yfirst + 1;
   Double_t xrg = gPad->GetUxmin();
   Double_t yrg = gPad->GetUymin();
   Double_t xln = gPad->GetUxmax() - xrg;
   Double_t yln = gPad->GetUymax() - yrg;
   Double_t cx  = (xln/Double_t(ncx) -0.03)/2;
   Double_t cy  = (yln/Double_t(ncy) -0.03)/2;
   Double_t dn  = 1.E-30;

   for (Int_t id=1;id<=2;id++) {
      for (Int_t j=Hparam.yfirst; j<=Hparam.ylast;j++) {
         yk    = fYaxis->GetBinLowEdge(j);
         ystep = fYaxis->GetBinWidth(j);
         for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
            xk    = fXaxis->GetBinLowEdge(i);
            xstep = fXaxis->GetBinWidth(i);
            if (!IsInside(xk+0.5*xstep,yk+0.5*ystep)) continue;
            if (i == Hparam.xfirst) {
               dx = fH->GetBinContent(i+1, j) - fH->GetBinContent(i, j);
            } else if (i == Hparam.xlast) {
               dx = fH->GetBinContent(i, j) - fH->GetBinContent(i-1, j);
            } else {
               dx = 0.5*(fH->GetBinContent(i+1, j) - fH->GetBinContent(i-1, j));
            }
            if (j == Hparam.yfirst) {
               dy = fH->GetBinContent(i, j+1) - fH->GetBinContent(i, j);
            } else if (j == Hparam.ylast) {
               dy = fH->GetBinContent(i, j) - fH->GetBinContent(i, j-1);
            } else {
               dy = 0.5*(fH->GetBinContent(i, j+1) - fH->GetBinContent(i, j-1));
            }
            if (id == 1) {
               dn = TMath::Max(dn, TMath::Abs(dx));
               dn = TMath::Max(dn, TMath::Abs(dy));
            } else if (id == 2) {
               xc  = xrg + xln*(Double_t(i - Hparam.xfirst+1)-0.5)/Double_t(ncx);
               dxn = cx*dx/dn;
               x1  = xc - dxn;
               x2  = xc + dxn;
               yc  = yrg + yln*(Double_t(j - Hparam.yfirst+1)-0.5)/Double_t(ncy);
               dyn = cy*dy/dn;
               y1  = yc - dyn;
               y2  = yc + dyn;
               fXbuf[0] = x1;
               fXbuf[1] = x2;
               fYbuf[0] = y1;
               fYbuf[1] = y2;
               if (TMath::Abs(x2-x1) > 0.01 || TMath::Abs(y2-y1) > 0.01) {
                  anr = 0.005*.5*TMath::Sqrt(2/(dxn*dxn + dyn*dyn));
                  si  = anr*(dxn + dyn);
                  co  = anr*(dxn - dyn);
                  fXbuf[2] = x2 - si;
                  fYbuf[2] = y2 + co;
                  gPad->PaintPolyLine(3, fXbuf, fYbuf);
                  fXbuf[0] = x2;
                  fXbuf[1] = x2 - co;
                  fYbuf[0] = y2;
                  fYbuf[1] = y2 - si;
                  gPad->PaintPolyLine(2, fXbuf, fYbuf);
               }
               else {
                  gPad->PaintPolyLine(2, fXbuf, fYbuf);
               }
            }
         }
      }
   }

   if (Hoption.Zscale) PaintPalette();
   fH->SetLineStyle(linesav);
   fH->SetLineWidth(widthsav);
   fH->TAttLine::Modify();
}


//______________________________________________________________________________
void THistPainter::PaintAxis(Bool_t drawGridOnly)
{
   /* Begin_html
   Draw axis (2D case) of an histogram.
   <p>
   If drawGridOnly is TRUE, only the grid is painted (if needed). This allows
   to draw the grid and the axis separately. In THistPainter::Paint this
   feature is used to make sure that the grid is drawn in the background and
   the axis tick marks in the foreground of the pad.
   End_html */

   //On iOS, grid should not be picable and can not be highlighted.
   //Condition is never true on a platform different from iOS.
   if (drawGridOnly && (gPad->PadInHighlightMode() || gPad->PadInSelectionMode()))
      return;

   if (Hoption.Axis == -1) return;
   if (Hoption.Same && Hoption.Axis <= 0) return;

   // Repainting alphanumeric labels axis on a plot done with
   // the option HBAR (horizontal) needs some adjustements.
   TAxis *xaxis = 0;
   TAxis *yaxis = 0;
   if (Hoption.Same && Hoption.Axis) { // Axis repainted (TPad::RedrawAxis)
      if (fXaxis->GetLabels() || fYaxis->GetLabels()) { // One axis has alphanumeric labels
         TIter next(gPad->GetListOfPrimitives());
         TObject *obj;
         // Check if the first TH1 of THStack in the pad is drawn with the option HBAR
         while ((obj = next())) {
            if (!obj->InheritsFrom(TH1::Class()) &&
                !obj->InheritsFrom(THStack::Class())) continue;
            TString opt = obj->GetDrawOption();
            opt.ToLower();
            // if drawn with HBAR, the axis should be inverted and the pad set to horizontal
            if (strstr(opt,"hbar")) {
               gPad->SetVertical(kFALSE);
               xaxis = fXaxis;
               yaxis = fYaxis;
               if (!strcmp(xaxis->GetName(),"xaxis")) {
                  fXaxis = yaxis;
                  fYaxis = xaxis;
               }
            }
            break;
         }
      }
   }

   static char chopt[10] = "";
   Double_t gridl = 0;
   Int_t ndiv, ndivx, ndivy, nx1, nx2, ndivsave;
   Int_t useHparam = 0;
   Double_t umin, umax, uminsave, umaxsave;
   Short_t xAxisPos = Hoption.AxisPos/10;
   Short_t yAxisPos = Hoption.AxisPos - 10*xAxisPos;

   Double_t axmin = gPad->GetUxmin();
   Double_t axmax = gPad->GetUxmax();
   Double_t aymin = gPad->GetUymin();
   Double_t aymax = gPad->GetUymax();
   char *cw = 0;
   TGaxis axis;

   // In case of option 'cont4' or in case of option 'same' over a 'cont4 plot'
   // Hparam must be use for the axis limits.
   if (Hoption.Contour == 14) useHparam = 1;
   if (Hoption.Same) {
      TObject *obj;
      TIter next(gPad->GetListOfPrimitives());
      while ((obj=next())) {
         if (strstr(obj->GetDrawOption(),"cont4")) {
            useHparam = 1;
            break;
         }
      }
   }

   // Paint X axis

   //To make X-axis selectable on iOS device.
   if (gPad->PadInSelectionMode())
      gPad->PushSelectableObject(fXaxis);

   //This condition is ALWAYS true, unless it works on iOS (can be false on iOS).
   if (gPad->PadInSelectionMode() || !gPad->PadInHighlightMode() || (gPad->PadInHighlightMode() && gPad->GetSelected() == fXaxis)) {
      ndivx = fXaxis->GetNdivisions();
      if (ndivx > 1000) {
         nx2   = ndivx/100;
         nx1   = TMath::Max(1, ndivx%100);
         ndivx = 100*nx2 + Int_t(Float_t(nx1)*gPad->GetAbsWNDC());
      }
      axis.SetTextAngle(0);
      axis.ImportAxisAttributes(fXaxis);

      chopt[0] = 0;
      // coverity [Calling risky function]
      strlcat(chopt, "SDH",10);
      // coverity [Calling risky function]
      if (ndivx < 0) strlcat(chopt, "N",10);
      if (gPad->GetGridx()) {
         gridl = (aymax-aymin)/(gPad->GetY2() - gPad->GetY1());
         // coverity [Calling risky function]
         strlcat(chopt, "W",10);
      }

      // Define X-Axis limits
      if (Hoption.Logx) {
         // coverity [Calling risky function]
         strlcat(chopt, "G",10);
         ndiv = TMath::Abs(ndivx);
         if (useHparam) {
            umin = TMath::Power(10,Hparam.xmin);
            umax = TMath::Power(10,Hparam.xmax);
         } else {
            umin = TMath::Power(10,axmin);
            umax = TMath::Power(10,axmax);
         }
      } else {
         ndiv = TMath::Abs(ndivx);
         if (useHparam) {
            umin = Hparam.xmin;
            umax = Hparam.xmax;
         } else {
            umin = axmin;
            umax = axmax;
         }
      }

      // Display axis as time
      if (fXaxis->GetTimeDisplay()) {
         // coverity [Calling risky function]
         strlcat(chopt,"t",10);
         if (strlen(fXaxis->GetTimeFormatOnly()) == 0) {
            axis.SetTimeFormat(fXaxis->ChooseTimeFormat(Hparam.xmax-Hparam.xmin));
         }
      }

      // The main X axis can be on the bottom or on the top of the pad
      Double_t xAxisYPos1, xAxisYPos2;
      if (xAxisPos == 1) {
         // Main X axis top
         xAxisYPos1 = aymax;
         xAxisYPos2 = aymin;
      } else {
         // Main X axis bottom
         xAxisYPos1 = aymin;
         xAxisYPos2 = aymax;
      }

      // Paint the main X axis (always)
      uminsave = umin;
      umaxsave = umax;
      ndivsave = ndiv;
      axis.SetOption(chopt);
      if (xAxisPos) {
         // coverity [Calling risky function]
         strlcat(chopt, "-",10);
         gridl = -gridl;
      }
      if (Hoption.Same && Hoption.Axis) { // Axis repainted (TPad::RedrawAxis)
         axis.SetLabelSize(0.);
         axis.SetTitle("");
      }
      axis.PaintAxis(axmin, xAxisYPos1,
                     axmax, xAxisYPos1,
                     umin, umax,  ndiv, chopt, gridl, drawGridOnly);

      // Paint additional X axis (if needed)
      // On iOS, this additional X axis is neither pickable, nor highlighted.
      // Additional checks PadInSelectionMode etc. does not effect non-iOS platform.
      if (gPad->GetTickx() && !gPad->PadInSelectionMode() && !gPad->PadInHighlightMode()) {
         if (xAxisPos) {
            cw=strstr(chopt,"-");
            *cw='z';
         } else {
            // coverity [Calling risky function]
            strlcat(chopt, "-",10);
         }
         // coverity [Calling risky function]
         if (gPad->GetTickx() < 2) strlcat(chopt, "U",10);
         if ((cw=strstr(chopt,"W"))) *cw='z';
         axis.SetTitle("");
         axis.PaintAxis(axmin, xAxisYPos2,
                        axmax, xAxisYPos2,
                        uminsave, umaxsave,  ndivsave, chopt, gridl, drawGridOnly);
      }
   }//End of "if pad in selection mode etc".

   // Paint Y axis
   //On iOS, Y axis must pushed into the stack of selectable objects.
   if (gPad->PadInSelectionMode())
      gPad->PushSelectableObject(fYaxis);

   //This conditions is ALWAYS true on a platform, different from iOS (on iOS can be true, can be false).
   if (gPad->PadInSelectionMode() || !gPad->PadInHighlightMode() || (gPad->PadInHighlightMode() && gPad->GetSelected() == fYaxis)) {
      ndivy = fYaxis->GetNdivisions();
      axis.ImportAxisAttributes(fYaxis);

      chopt[0] = 0;
      // coverity [Calling risky function]
      strlcat(chopt, "SDH",10);
      // coverity [Calling risky function]
      if (ndivy < 0) strlcat(chopt, "N",10);
      if (gPad->GetGridy()) {
         gridl = (axmax-axmin)/(gPad->GetX2() - gPad->GetX1());
         // coverity [Calling risky function]
         strlcat(chopt, "W",10);
      }

      // Define Y-Axis limits
      if (Hoption.Logy) {
         // coverity [Calling risky function]
         strlcat(chopt, "G",10);
         ndiv = TMath::Abs(ndivy);
         if (useHparam) {
            umin = TMath::Power(10,Hparam.ymin);
            umax = TMath::Power(10,Hparam.ymax);
         } else {
            umin = TMath::Power(10,aymin);
            umax = TMath::Power(10,aymax);
         }
      } else {
         ndiv = TMath::Abs(ndivy);
         if (useHparam) {
            umin = Hparam.ymin;
            umax = Hparam.ymax;
         } else {
            umin = aymin;
            umax = aymax;
         }
      }

      // Display axis as time
      if (fYaxis->GetTimeDisplay()) {
         // coverity [Calling risky function]
         strlcat(chopt,"t",10);
         if (strlen(fYaxis->GetTimeFormatOnly()) == 0) {
            axis.SetTimeFormat(fYaxis->ChooseTimeFormat(Hparam.ymax-Hparam.ymin));
         }
      }

      // The main Y axis can be on the left or on the right of the pad
      Double_t yAxisXPos1, yAxisXPos2;
      if (yAxisPos == 1) {
         // Main Y axis left
         yAxisXPos1 = axmax;
         yAxisXPos2 = axmin;
      } else {
         // Main Y axis right
         yAxisXPos1 = axmin;
         yAxisXPos2 = axmax;
      }

      // Paint the main Y axis (always)
      uminsave = umin;
      umaxsave = umax;
      ndivsave = ndiv;
      axis.SetOption(chopt);
      if (yAxisPos) {
         // coverity [Calling risky function]
         strlcat(chopt, "+L",10);
         gridl = -gridl;
      }
      if (Hoption.Same && Hoption.Axis) { // Axis repainted (TPad::RedrawAxis)
         axis.SetLabelSize(0.);
         axis.SetTitle("");
      }
      axis.PaintAxis(yAxisXPos1, aymin,
                     yAxisXPos1, aymax,
                     umin, umax,  ndiv, chopt, gridl, drawGridOnly);

      // Paint the additional Y axis (if needed)
      // Additional checks for pad mode are required on iOS: this "second" axis is
      // neither pickable, nor highlihted. Additional checks have no effect on non-iOS platform.
      if (gPad->GetTicky() && !gPad->PadInSelectionMode() && !gPad->PadInHighlightMode()) {
         if (gPad->GetTicky() < 2) {
            // coverity [Calling risky function]
            strlcat(chopt, "U",10);
            axis.SetTickSize(-fYaxis->GetTickLength());
         } else {
            // coverity [Calling risky function]
            strlcat(chopt, "+L",10);
         }
         if ((cw=strstr(chopt,"W"))) *cw='z';
         axis.SetTitle("");
         axis.PaintAxis(yAxisXPos2, aymin,
                        yAxisXPos2, aymax,
                        uminsave, umaxsave,  ndivsave, chopt, gridl, drawGridOnly);
      }
   }//End of "if pad is in selection mode etc."

   // Reset the axis if they have been inverted in case of option HBAR
   if (xaxis) {
      fXaxis = xaxis;
      fYaxis = yaxis;
   }
}


//______________________________________________________________________________
void THistPainter::PaintBar(Option_t *)
{
   /* Begin_html
   <a href="#HP10">Draw a bar-chart in a normal pad.</a>
   End_html */

   Int_t bar = Hoption.Bar - 10;
   Double_t xmin,xmax,ymin,ymax,umin,umax,w,y;
   Double_t offset = fH->GetBarOffset();
   Double_t width  = fH->GetBarWidth();
   TBox box;
   Int_t hcolor = fH->GetFillColor();
   if (hcolor == gPad->GetFrameFillColor()) ++hcolor;
   Int_t hstyle = fH->GetFillStyle();
   box.SetFillColor(hcolor);
   box.SetFillStyle(hstyle);
   for (Int_t bin=fXaxis->GetFirst();bin<=fXaxis->GetLast();bin++) {
      y    = fH->GetBinContent(bin);
      xmin = gPad->XtoPad(fXaxis->GetBinLowEdge(bin));
      xmax = gPad->XtoPad(fXaxis->GetBinUpEdge(bin));
      ymin = gPad->GetUymin();
      ymax = gPad->YtoPad(y);
      if (ymax < gPad->GetUymin()) continue;
      if (ymax > gPad->GetUymax()) ymax = gPad->GetUymax();
      if (ymin < gPad->GetUymin()) ymin = gPad->GetUymin();
      if (gStyle->GetHistMinimumZero() && ymin < 0)
         ymin=TMath::Min(0.,gPad->GetUymax());
      w    = (xmax-xmin)*width;
      xmin += offset*(xmax-xmin);
      xmax = xmin + w;
      if (bar < 1) {
         box.PaintBox(xmin,ymin,xmax,ymax);
      } else {
         umin = xmin + bar*(xmax-xmin)/10.;
         umax = xmax - bar*(xmax-xmin)/10.;
         //box.SetFillColor(hcolor+150); //bright
         box.SetFillColor(TColor::GetColorBright(hcolor)); //bright
         box.PaintBox(xmin,ymin,umin,ymax);
         box.SetFillColor(hcolor);
         box.PaintBox(umin,ymin,umax,ymax);
         box.SetFillColor(TColor::GetColorDark(hcolor)); //dark
         box.PaintBox(umax,ymin,xmax,ymax);
      }
   }
}


//______________________________________________________________________________
void THistPainter::PaintBarH(Option_t *)
{
   /* Begin_html
   <a href="#HP10">Draw a bar char in a rotated pad (X vertical, Y horizontal).</a>
   End_html */

   gPad->SetVertical(kFALSE);

   PaintInitH();

   TAxis *xaxis = fXaxis;
   TAxis *yaxis = fYaxis;
   if (!strcmp(xaxis->GetName(),"xaxis")) {
      fXaxis = yaxis;
      fYaxis = xaxis;
   }

   PaintFrame();

   Int_t bar = Hoption.Bar - 20;
   Double_t xmin,xmax,ymin,ymax,umin,umax,w;
   Double_t offset = fH->GetBarOffset();
   Double_t width  = fH->GetBarWidth();
   TBox box;
   Int_t hcolor = fH->GetFillColor();
   if (hcolor == gPad->GetFrameFillColor()) ++hcolor;
   Int_t hstyle = fH->GetFillStyle();
   box.SetFillColor(hcolor);
   box.SetFillStyle(hstyle);
   for (Int_t bin=fYaxis->GetFirst();bin<=fYaxis->GetLast();bin++) {
      ymin = gPad->YtoPad(fYaxis->GetBinLowEdge(bin));
      ymax = gPad->YtoPad(fYaxis->GetBinUpEdge(bin));
      xmin = gPad->GetUxmin();
      xmax = gPad->XtoPad(fH->GetBinContent(bin));
      if (xmax < gPad->GetUxmin()) continue;
      if (xmax > gPad->GetUxmax()) xmax = gPad->GetUxmax();
      if (xmin < gPad->GetUxmin()) xmin = gPad->GetUxmin();
      if (gStyle->GetHistMinimumZero() && xmin < 0)
         xmin=TMath::Min(0.,gPad->GetUxmax());
      w    = (ymax-ymin)*width;
      ymin += offset*(ymax-ymin);
      ymax = ymin + w;
      if (bar < 1) {
         box.PaintBox(xmin,ymin,xmax,ymax);
      } else {
         umin = ymin + bar*(ymax-ymin)/10.;
         umax = ymax - bar*(ymax-ymin)/10.;
         box.SetFillColor(TColor::GetColorDark(hcolor)); //dark
         box.PaintBox(xmin,ymin,xmax,umin);
         box.SetFillColor(hcolor);
         box.PaintBox(xmin,umin,xmax,umax);
         box.SetFillColor(TColor::GetColorBright(hcolor)); //bright
         box.PaintBox(xmin,umax,xmax,ymax);
      }
   }

   PaintTitle();
   //    Draw box with histogram statistics and/or fit parameters
   if (Hoption.Same != 1 && !fH->TestBit(TH1::kNoStats)) {  // bit set via TH1::SetStats
      TIter next(fFunctions);
      TObject *obj = 0;
      while ((obj = next())) {
         if (obj->InheritsFrom(TF1::Class())) break;
         obj = 0;
      }
      PaintStat(gStyle->GetOptStat(),(TF1*)obj);
   }

   PaintAxis(kFALSE);
   fXaxis = xaxis;
   fYaxis = yaxis;
}


//______________________________________________________________________________
void THistPainter::PaintBoxes(Option_t *)
{
   /* Begin_html
   <a href="#HP13">Control function to draw a 2D histogram as a box plot.</a>
   End_html */

   Style_t fillsav   = fH->GetFillStyle();
   Style_t colsav    = fH->GetFillColor();
   if (fH->GetFillColor() == 0)  fH->SetFillStyle(0);
   if (Hoption.Box == 11) fH->SetFillStyle(1001);
   fH->TAttLine::Modify();
   fH->TAttFill::Modify();

   Double_t z, xk,xstep, yk, ystep, xcent, ycent, xlow, xup, ylow, yup;
   Double_t ux1 = gPad->PixeltoX(1);
   Double_t ux0 = gPad->PixeltoX(0);
   Double_t uy1 = gPad->PixeltoY(1);
   Double_t uy0 = gPad->PixeltoY(0);
   Double_t dxmin = 0.51*(gPad->PadtoX(ux1)-gPad->PadtoX(ux0));
   Double_t dymin = 0.51*(gPad->PadtoY(uy0)-gPad->PadtoY(uy1));

   Double_t zmin = fH->GetMinimum();
   Double_t zmax = TMath::Max(TMath::Abs(fH->GetMaximum()),
                              TMath::Abs(fH->GetMinimum()));

   // In case of option SAME, zmin and zmax values are taken from the
   // first plotted 2D histogram.
   if (Hoption.Same) {
      TH2 *h2;
      TIter next(gPad->GetListOfPrimitives());
      while ((h2 = (TH2 *)next())) {
         if (!h2->InheritsFrom(TH2::Class())) continue;
         zmin = h2->GetMinimum();
         zmax = TMath::Max(TMath::Abs(h2->GetMaximum()),
                           TMath::Abs(h2->GetMinimum()));
         if (Hoption.Logz) {
            zmax = TMath::Log10(zmax);
            if (zmin <= 0) {
               zmin = TMath::Log10(zmax*0.001);
            } else {
               zmin = TMath::Log10(zmin);
            }
         }
         break;
      }
   }

   if (Hoption.Logz) {
      if (zmin > 0) {
         zmin = TMath::Log10(zmin*0.1);
         zmax = TMath::Log10(zmax);
      } else {
         return;
      }
   }

   Double_t zratio, dz = zmax - zmin;
   Bool_t kZNeg        = kFALSE;

   // Define the dark and light colors the "button style" boxes.
   Color_t color = fH->GetFillColor();
   Color_t light=0, dark=0;
   if (Hoption.Box == 11) {
      light = TColor::GetColorBright(color);
      dark  = TColor::GetColorDark(color);
   }

   // Loop over all the bins and draw the boxes
   for (Int_t j=Hparam.yfirst; j<=Hparam.ylast;j++) {
      yk    = fYaxis->GetBinLowEdge(j);
      ystep = fYaxis->GetBinWidth(j);
      ycent = 0.5*ystep;
      for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
         Int_t bin  = j*(fXaxis->GetNbins()+2) + i;
         xk    = fXaxis->GetBinLowEdge(i);
         xstep = fXaxis->GetBinWidth(i);
         if (!IsInside(xk+0.5*xstep,yk+0.5*ystep)) continue;
         xcent = 0.5*xstep;
         z     = Hparam.factor*fH->GetBinContent(bin);
         kZNeg = kFALSE;

         if (z <  zmin) continue; // Can be the case with
         if (z >  zmax) z = zmax; // option Same

         if (z < 0) {
            if (Hoption.Logz) continue;
            z = -z;
            kZNeg = kTRUE;
         }
         if (Hoption.Logz) {
            if (z != 0) z = TMath::Log10(z);
            else        z = zmin;
         }

         if (dz == 0) continue;
         zratio = TMath::Sqrt((z-zmin)/dz);
         if (zratio == 0) continue;

         xup  = xcent*zratio + xk + xcent;
         xlow = 2*(xk + xcent) - xup;
         if (xup-xlow < dxmin) xup = xlow+dxmin;
         if (Hoption.Logx) {
            if (xup > 0)  xup  = TMath::Log10(xup);
            else continue;
            if (xlow > 0) xlow = TMath::Log10(xlow);
            else continue;
         }

         yup  = ycent*zratio + yk + ycent;
         ylow = 2*(yk + ycent) - yup;
         if (yup-ylow < dymin) yup = ylow+dymin;
         if (Hoption.Logy) {
            if (yup > 0)  yup  = TMath::Log10(yup);
            else continue;
            if (ylow > 0) ylow = TMath::Log10(ylow);
            else continue;
         }

         xlow = TMath::Max(xlow, gPad->GetUxmin());
         ylow = TMath::Max(ylow, gPad->GetUymin());
         xup  = TMath::Min(xup , gPad->GetUxmax());
         yup  = TMath::Min(yup , gPad->GetUymax());

         if (xlow >= xup) continue;
         if (ylow >= yup) continue;

         if (Hoption.Box == 1) {
            fH->SetFillColor(color);
            fH->TAttFill::Modify();
            gPad->PaintBox(xlow, ylow, xup, yup);
            if (kZNeg) {
               gPad->PaintLine(xlow, ylow, xup, yup);
               gPad->PaintLine(xlow, yup, xup, ylow);
            }
         } else if (Hoption.Box == 11) {
            // Draw the center of the box
            fH->SetFillColor(color);
            fH->TAttFill::Modify();
            gPad->PaintBox(xlow, ylow, xup, yup);

            // Draw top&left part of the box
            Double_t x[7], y[7];
            Double_t bwidth = 0.1;
            x[0] = xlow;                     y[0] = ylow;
            x[1] = xlow + bwidth*(xup-xlow); y[1] = ylow + bwidth*(yup-ylow);
            x[2] = x[1];                     y[2] = yup - bwidth*(yup-ylow);
            x[3] = xup - bwidth*(xup-xlow);  y[3] = y[2];
            x[4] = xup;                      y[4] = yup;
            x[5] = xlow;                     y[5] = yup;
            x[6] = xlow;                     y[6] = ylow;
            if (kZNeg) fH->SetFillColor(dark);
            else       fH->SetFillColor(light);
            fH->TAttFill::Modify();
            gPad->PaintFillArea(7, x, y);

            // Draw bottom&right part of the box
            x[0] = xlow;                     y[0] = ylow;
            x[1] = xlow + bwidth*(xup-xlow); y[1] = ylow + bwidth*(yup-ylow);
            x[2] = xup - bwidth*(xup-xlow);  y[2] = y[1];
            x[3] = x[2];                     y[3] = yup - bwidth*(yup-ylow);
            x[4] = xup;                      y[4] = yup;
            x[5] = xup;                      y[5] = ylow;
            x[6] = xlow;                     y[6] = ylow;
            if (kZNeg) fH->SetFillColor(light);
            else       fH->SetFillColor(dark);
            fH->TAttFill::Modify();
            gPad->PaintFillArea(7, x, y);
         }
      }
   }

   if (Hoption.Zscale) PaintPalette();
   fH->SetFillStyle(fillsav);
   fH->SetFillColor(colsav);
   fH->TAttFill::Modify();
}


//______________________________________________________________________________
void THistPainter::PaintCandlePlot(Option_t *)
{
   /* Begin_html
   <a href="#HP14">Control function to draw a 2D histogram as a candle (box) plot.</a>
   End_html */

   Double_t x,y,w;
   Double_t m1 = 0.055, m2 = 0.25;
   Double_t xpm[1], ypm[1];

   TH1D *hp;
   TH2D *h2 = (TH2D*)fH;

   Double_t *quantiles = new Double_t[5];
   quantiles[0]=0.; quantiles[1]=0.; quantiles[2] = 0.; quantiles[3] = 0.; quantiles[4] = 0.;
   Double_t *prob = new Double_t[5];
   prob[0]=1E-15; prob[1]=0.25; prob[2]=0.5; prob[3]=0.75; prob[4]=1-1E-15;

   Style_t fillsav   = h2->GetFillStyle();
   Style_t colsav    = h2->GetFillColor();
   Style_t linesav   = h2->GetLineStyle();
   Style_t widthsav  = h2->GetLineWidth();
   Style_t pmssav    = h2->GetMarkerStyle();

   if (h2->GetFillColor() == 0)  h2->SetFillStyle(0);

   h2->SetMarkerStyle(24);
   h2->TAttLine::Modify();
   h2->TAttFill::Modify();
   h2->TAttMarker::Modify();

   // Candle plot along X
   if (Hoption.Candle == 1) {
      for (Int_t i=Hparam.xfirst; i<=Hparam.xlast; i++) {
         x = fXaxis->GetBinLowEdge(i);
         w = fXaxis->GetBinWidth(i);
         hp = h2->ProjectionY("_px", i, i);
         if (hp->GetEntries() !=0) {
            hp->GetQuantiles(5, quantiles, prob);
            ypm[0] = hp->GetMean();

            h2->SetLineStyle(1);
            h2->TAttLine::Modify();
            gPad->PaintBox(x+m1*w,  quantiles[1], x+(1-m1)*w, quantiles[3]);
            gPad->PaintLine(x+m2*w, quantiles[0], x+(1-m2)*w, quantiles[0]);
            gPad->PaintLine(x+m2*w, quantiles[4], x+(1-m2)*w, quantiles[4]);
            h2->SetLineWidth(3*widthsav);
            h2->TAttLine::Modify();
            gPad->PaintLine(x+m1*w, quantiles[2], x+(1-m1)*w, quantiles[2]);
            h2->SetLineWidth(widthsav);
            h2->TAttLine::Modify();

            h2->SetLineStyle(2);
            h2->TAttLine::Modify();
            gPad->PaintLine(x+w/2., quantiles[3], x+w/2., quantiles[4]);
            gPad->PaintLine(x+w/2., quantiles[0], x+w/2., quantiles[1]);

            xpm[0] = x+w/2;
            gPad->PaintPolyMarker(1,xpm,ypm);
         }
      }
   // Candle plot along Y
   } else {
      for (Int_t i=Hparam.yfirst; i<=Hparam.ylast; i++) {
         y = fYaxis->GetBinLowEdge(i);
         w = fYaxis->GetBinWidth(i);
         hp = h2->ProjectionX("_py", i, i);
         if (hp->GetEntries() !=0) {
            hp->GetQuantiles(5, quantiles, prob);
            xpm[0] = hp->GetMean();

            h2->SetLineStyle(1);
            h2->TAttLine::Modify();
            gPad->PaintBox(quantiles[1],  y+m1*w, quantiles[3], y+(1-m1)*w);
            gPad->PaintLine(quantiles[0], y+m2*w, quantiles[0], y+(1-m2)*w);
            gPad->PaintLine(quantiles[4], y+m2*w, quantiles[4], y+(1-m2)*w);
            h2->SetLineWidth(3*widthsav);
            h2->TAttLine::Modify();
            gPad->PaintLine(quantiles[2], y+m1*w, quantiles[2], y+(1-m1)*w);
            h2->SetLineWidth(widthsav);
            h2->TAttLine::Modify();

            h2->SetLineStyle(2);
            h2->TAttLine::Modify();
            gPad->PaintLine(quantiles[3], y+w/2., quantiles[4], y+w/2.);
            gPad->PaintLine(quantiles[0], y+w/2., quantiles[1], y+w/2.);

            ypm[0] = y+w/2;
            gPad->PaintPolyMarker(1,xpm,ypm);
         }
      }
   }

   h2->SetFillStyle(fillsav);
   h2->SetFillColor(colsav);
   h2->SetLineStyle(linesav);
   h2->SetMarkerStyle(pmssav);
   h2->SetLineWidth(widthsav);
   h2->TAttFill::Modify();
   h2->TAttLine::Modify();
   h2->TAttMarker::Modify();

   delete [] prob;
   delete [] quantiles;
}


//______________________________________________________________________________
void THistPainter::PaintColorLevels(Option_t *)
{
   /* Begin_html
   <a href="#HP14">Control function to draw a 2D histogram as a color plot.</a>
   End_html */

   Double_t z, zc, xk, xstep, yk, ystep, xlow, xup, ylow, yup;

   Double_t zmin = fH->GetMinimum();
   Double_t zmax = fH->GetMaximum();

   Double_t dz = zmax - zmin;
   if (dz <= 0) { // Histogram filled with a constant value
      zmax += 0.1*TMath::Abs(zmax);
      zmin -= 0.1*TMath::Abs(zmin);
      dz = zmax - zmin;
   }

   if (Hoption.Logz) {
      if (zmin > 0) {
         zmin = TMath::Log10(zmin);
         zmax = TMath::Log10(zmax);
         dz = zmax - zmin;
      } else {
         return;
      }
   }

   Style_t fillsav   = fH->GetFillStyle();
   Style_t colsav    = fH->GetFillColor();
   fH->SetFillStyle(1001);
   fH->TAttFill::Modify();

   // Initialize the levels on the Z axis
   Int_t ncolors  = gStyle->GetNumberOfColors();
   Int_t ndiv   = fH->GetContour();
   if (ndiv == 0 ) {
      ndiv = gStyle->GetNumberContours();
      fH->SetContour(ndiv);
   }
   Int_t ndivz  = TMath::Abs(ndiv);
   if (fH->TestBit(TH1::kUserContour) == 0) fH->SetContour(ndiv);
   Double_t scale = ndivz/dz;

   Int_t color;
   TProfile2D* prof2d = dynamic_cast<TProfile2D*>(fH);
   for (Int_t j=Hparam.yfirst; j<=Hparam.ylast;j++) {
      yk    = fYaxis->GetBinLowEdge(j);
      ystep = fYaxis->GetBinWidth(j);
      for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
         Int_t bin  = j*(fXaxis->GetNbins()+2) + i;
         xk    = fXaxis->GetBinLowEdge(i);
         xstep = fXaxis->GetBinWidth(i);
         if (Hoption.System == kPOLAR && xk<0) xk= 2*TMath::Pi()+xk;
         if (!IsInside(xk+0.5*xstep,yk+0.5*ystep)) continue;
         z     = fH->GetBinContent(bin);
         // if fH is a profile histogram do not draw empty bins
         if (prof2d) {
            const Double_t binEntries = prof2d->GetBinEntries(bin);
            if (binEntries == 0)
               continue;
         } else {
            // don't draw the empty bins for non-profile histograms
            // with positive content
            if (z == 0 && (zmin >= 0 || Hoption.Logz)) continue;
         }

         if (Hoption.Logz) {
            if (z > 0) z = TMath::Log10(z);
            else       z = zmin;
         }
         if (z < zmin) continue;
         xup  = xk + xstep;
         xlow = xk;
         if (Hoption.Logx) {
            if (xup > 0)  xup  = TMath::Log10(xup);
            else continue;
            if (xlow > 0) xlow = TMath::Log10(xlow);
            else continue;
         }
         yup  = yk + ystep;
         ylow = yk;
         if (Hoption.System != kPOLAR) {
            if (Hoption.Logy) {
               if (yup > 0)  yup  = TMath::Log10(yup);
               else continue;
               if (ylow > 0) ylow = TMath::Log10(ylow);
               else continue;
            }
            if (xup  < gPad->GetUxmin()) continue;
            if (yup  < gPad->GetUymin()) continue;
            if (xlow > gPad->GetUxmax()) continue;
            if (ylow > gPad->GetUymax()) continue;
            if (xlow < gPad->GetUxmin()) xlow = gPad->GetUxmin();
            if (ylow < gPad->GetUymin()) ylow = gPad->GetUymin();
            if (xup  > gPad->GetUxmax()) xup  = gPad->GetUxmax();
            if (yup  > gPad->GetUymax()) yup  = gPad->GetUymax();
         }

         if (fH->TestBit(TH1::kUserContour)) {
            zc = fH->GetContourLevelPad(0);
            if (z < zc) continue;
            color = -1;
            for (Int_t k=0; k<ndiv; k++) {
               zc = fH->GetContourLevelPad(k);
               if (z < zc) {
                  continue;
               } else {
                  color++;
               }
            }
         } else {
            color = Int_t(0.01+(z-zmin)*scale);
         }

         Int_t theColor = Int_t((color+0.99)*Float_t(ncolors)/Float_t(ndivz));
         if (theColor > ncolors-1) theColor = ncolors-1;
         fH->SetFillColor(gStyle->GetColorPalette(theColor));
         fH->TAttFill::Modify();
         if (Hoption.System != kPOLAR) {
            gPad->PaintBox(xlow, ylow, xup, yup);
         } else  {
            TCrown crown(0,0,ylow,yup,xlow*TMath::RadToDeg(),xup*TMath::RadToDeg());
            crown.SetFillColor(gStyle->GetColorPalette(theColor));
            crown.Paint();
         }
      }
   }

   if (Hoption.Zscale) PaintPalette();

   fH->SetFillStyle(fillsav);
   fH->SetFillColor(colsav);
   fH->TAttFill::Modify();

}


//______________________________________________________________________________
void THistPainter::PaintContour(Option_t *option)
{
   /* Begin_html
   <a href="#HP16">Control function to draw a 2D histogram as a contour plot.</a>
   End_html */

   Int_t i, j, count, ncontour, icol, n, lj, m, ix, jx, ljfill;
   Int_t itars, mode, ir[4];
   Double_t xsave, ysave, thesave,phisave,x[4], y[4], zc[4];

   if (Hoption.Contour == 14) {
      Hoption.Surf = 12;
      Hoption.Axis = 1;
      thesave = gPad->GetTheta();
      phisave = gPad->GetPhi();
      gPad->SetPhi(0.);
      gPad->SetTheta(90.);
      PaintSurface(option);
      gPad->SetPhi(phisave);
      gPad->SetTheta(thesave);
      TView *view = gPad->GetView();
      if (view) view->SetBit(kCannotRotate); //tested in ExecuteEvent
      PaintAxis();
      return;
   }

   if (Hoption.Same) {
      // If the contour is painted on a 3d plot, the contour lines are
      // paint in 3d too.
      TObject *obj;
      TIter next(gPad->GetListOfPrimitives());
      while ((obj=next())) {
         if (strstr(obj->GetDrawOption(),"surf") ||
             strstr(obj->GetDrawOption(),"lego") ||
             strstr(obj->GetDrawOption(),"tri")) {
               Hoption.Surf = 16;
               PaintSurface(option);
               return;
         }
      }
   }

   if (Hoption.Contour == 15) {
      TGraphDelaunay *dt;
      TList *hl = fH->GetListOfFunctions();
      dt = (TGraphDelaunay*)hl->FindObject("TGraphDelaunay");
      if (!dt) return;
      if (!fGraph2DPainter) fGraph2DPainter = new TGraph2DPainter(dt);
      fGraph2DPainter->Paint(option);
      return;
   }

   gPad->SetBit(TGraph::kClipFrame);

   Double_t *levels  = new Double_t[2*kMAXCONTOUR];
   Double_t *xarr    = new Double_t[2*kMAXCONTOUR];
   Double_t *yarr    = new Double_t[2*kMAXCONTOUR];
   Int_t  *itarr     = new Int_t[2*kMAXCONTOUR];

   Int_t npmax = 0;
   for (i=0;i<2*kMAXCONTOUR;i++) itarr[i] = 0;

   ncontour = fH->GetContour();
   if (ncontour == 0) {
      ncontour = gStyle->GetNumberContours();
      fH->SetContour(ncontour);
   }
   if (ncontour > kMAXCONTOUR) {
      Warning("PaintContour", "maximum number of contours is %d, asked for %d",
              kMAXCONTOUR, ncontour);
      ncontour = kMAXCONTOUR-1;
   }
   if (fH->TestBit(TH1::kUserContour) == 0) fH->SetContour(ncontour);

   for (i=0;i<ncontour;i++) levels[i] = fH->GetContourLevelPad(i);
   //for (i=0;i<ncontour;i++)
   //   levels[i] = Hparam.zmin+(Hparam.zmax-Hparam.zmin)/ncontour*i;
   Int_t linesav   = fH->GetLineStyle();
   Int_t colorsav  = fH->GetLineColor();
   Int_t fillsav  = fH->GetFillColor();
   if (Hoption.Contour == 13) {
      fH->TAttLine::Modify();
   }

   TPolyLine **polys = 0;
   TPolyLine *poly=0;
   TObjArray *contours = 0;
   TList *list = 0;
   TGraph *graph = 0;
   Int_t *np = 0;
   if (Hoption.Contour == 1) {
      np = new Int_t[ncontour];
      for (i=0;i<ncontour;i++) np[i] = 0;
      polys = new TPolyLine*[ncontour];
      for (i=0;i<ncontour;i++) {
         polys[i] = new TPolyLine(100);
      }
      if (Hoption.List == 1) {
         contours = (TObjArray*)gROOT->GetListOfSpecials()->FindObject("contours");
         if (contours) {
            gROOT->GetListOfSpecials()->Remove(contours);
            count = contours->GetSize();
            for (i=0;i<count;i++) {
               list = (TList*)contours->At(i);
               if (list) list->Delete();
            }
         }
         contours = new TObjArray(ncontour);
         contours->SetName("contours");
         gROOT->GetListOfSpecials()->Add(contours);
         for (i=0;i<ncontour;i++) {
            list = new TList();
            contours->Add(list);
         }
      }
   }
   Int_t theColor;
   Int_t ncolors = gStyle->GetNumberOfColors();
   Int_t ndivz   = TMath::Abs(ncontour);

   Int_t k,ipoly;
   for (j=Hparam.yfirst; j<Hparam.ylast; j++) {
      y[0] = fYaxis->GetBinCenter(j);
      y[1] = y[0];
      y[2] = fYaxis->GetBinCenter(j+1);
      y[3] = y[2];
      for (i=Hparam.xfirst; i<Hparam.xlast; i++) {
         zc[0] = fH->GetBinContent(i,   j);
         zc[1] = fH->GetBinContent(i+1, j);
         zc[2] = fH->GetBinContent(i+1, j+1);
         zc[3] = fH->GetBinContent(i,   j+1);
         if (!IsInside(fXaxis->GetBinCenter(i),fYaxis->GetBinCenter(j))) continue;
         if (Hoption.Logz) {
            if (zc[0] > 0)   zc[0] = TMath::Log10(zc[0]);
            else             zc[0] = Hparam.zmin;
            if (zc[1] > 0)   zc[1] = TMath::Log10(zc[1]);
            else             zc[1] = Hparam.zmin;
            if (zc[2] > 0)   zc[2] = TMath::Log10(zc[2]);
            else             zc[2] = Hparam.zmin;
            if (zc[3] > 0)   zc[3] = TMath::Log10(zc[3]);
            else             zc[3] = Hparam.zmin;
         }
         for (k=0;k<4;k++) {
            ir[k] = TMath::BinarySearch(ncontour,levels,zc[k]);
         }
         if (ir[0] != ir[1] || ir[1] != ir[2] || ir[2] != ir[3] || ir[3] != ir[0]) {
            x[0] = fXaxis->GetBinCenter(i);
            x[3] = x[0];
            x[1] = fXaxis->GetBinCenter(i+1);
            x[2] = x[1];
            if (zc[0] <= zc[1]) n = 0; else n = 1;
            if (zc[2] <= zc[3]) m = 2; else m = 3;
            if (zc[n] > zc[m]) n = m;
            n++;
            lj=1;
            for (ix=1;ix<=4;ix++) {
               m = n%4 + 1;
               ljfill = PaintContourLine(zc[n-1],ir[n-1],x[n-1],y[n-1],zc[m-1],
                     ir[m-1],x[m-1],y[m-1],&xarr[lj-1],&yarr[lj-1],&itarr[lj-1], levels);
               lj += 2*ljfill;
               n = m;
            }

            if (zc[0] <= zc[1]) n = 0; else n = 1;
            if (zc[2] <= zc[3]) m = 2; else m = 3;
            if (zc[n] > zc[m]) n = m;
            n++;
            lj=2;
            for (ix=1;ix<=4;ix++) {
               if (n == 1) m = 4;
               else        m = n-1;
               ljfill = PaintContourLine(zc[n-1],ir[n-1],x[n-1],y[n-1],zc[m-1],
                     ir[m-1],x[m-1],y[m-1],&xarr[lj-1],&yarr[lj-1],&itarr[lj-1], levels);
               lj += 2*ljfill;
               n = m;
            }

   //     Re-order endpoints

            count = 0;
            for (ix=1; ix<=lj-5; ix +=2) {
               //count = 0;
               while (itarr[ix-1] != itarr[ix]) {
                  xsave = xarr[ix];
                  ysave = yarr[ix];
                  itars = itarr[ix];
                  for (jx=ix; jx<=lj-5; jx +=2) {
                     xarr[jx]  = xarr[jx+2];
                     yarr[jx]  = yarr[jx+2];
                     itarr[jx] = itarr[jx+2];
                  }
                  xarr[lj-3]  = xsave;
                  yarr[lj-3]  = ysave;
                  itarr[lj-3] = itars;
                  if (count > 100) break;
                  count++;
               }
            }

            if (count > 100) continue;
            for (ix=1; ix<=lj-2; ix +=2) {
               theColor = Int_t((itarr[ix-1]+0.99)*Float_t(ncolors)/Float_t(ndivz));
               icol = gStyle->GetColorPalette(theColor);
               if (Hoption.Contour == 11) {
                  fH->SetLineColor(icol);
               }
               if (Hoption.Contour == 12) {
                  mode = icol%5;
                  if (mode == 0) mode = 5;
                  fH->SetLineStyle(mode);
               }
               if (Hoption.Contour != 1) {
                  fH->TAttLine::Modify();
                  gPad->PaintPolyLine(2,&xarr[ix-1],&yarr[ix-1]);
                  continue;
               }

               ipoly = itarr[ix-1];
               if (ipoly >=0 && ipoly <ncontour) {
                  poly = polys[ipoly];
                  poly->SetPoint(np[ipoly]  ,xarr[ix-1],yarr[ix-1]);
                  poly->SetPoint(np[ipoly]+1,xarr[ix],  yarr[ix]);
                  np[ipoly] += 2;
                  if (npmax < np[ipoly]) npmax = np[ipoly];
               }
            }
         } // end of if (ir[0]
      } //end of for (i
   } //end of for (j

   Double_t xmin,ymin;
   Double_t *xp, *yp;
   Int_t nadd,iminus,iplus;
   Double_t *xx, *yy;
   Int_t istart;
   Int_t first = ncontour;
   Int_t *polysort = 0;
   Int_t contListNb;
   if (Hoption.Contour != 1) goto theEND;

   //The 2 points line generated above are now sorted/merged to generate
   //a list of consecutive points.
   // If the option "List" has been specified, the list of points is saved
   // in the form of TGraph objects in the ROOT list of special objects.
   xmin = gPad->GetUxmin();
   ymin = gPad->GetUymin();
   xp = new Double_t[2*npmax];
   yp = new Double_t[2*npmax];
   polysort = new Int_t[ncontour];
   //find first positive contour
   for (ipoly=0;ipoly<ncontour;ipoly++) {
      if (levels[ipoly] >= 0) {first = ipoly; break;}
   }
   //store negative contours from 0 to minimum, then all positive contours
   k = 0;
   for (ipoly=first-1;ipoly>=0;ipoly--) {polysort[k] = ipoly; k++;}
   for (ipoly=first;ipoly<ncontour;ipoly++) {polysort[k] = ipoly; k++;}
   // we can now draw sorted contours
   contListNb = 0;
   fH->SetFillStyle(1001);
   for (k=0;k<ncontour;k++) {
      ipoly = polysort[k];
      if (np[ipoly] == 0) continue;
      if (Hoption.List) list = (TList*)contours->At(contListNb);
      contListNb++;
      poly = polys[ipoly];
      xx = poly->GetX();
      yy = poly->GetY();
      istart = 0;
      while (1) {
         iminus = npmax;
         iplus  = iminus+1;
         xp[iminus]= xx[istart];   yp[iminus] = yy[istart];
         xp[iplus] = xx[istart+1]; yp[iplus]  = yy[istart+1];
         xx[istart]   = xmin; yy[istart]   = ymin;
         xx[istart+1] = xmin; yy[istart+1] = ymin;
         while (1) {
            nadd = 0;
            for (i=2;i<np[ipoly];i+=2) {
               if (xx[i] == xp[iplus] && yy[i] == yp[iplus]) {
                  iplus++;
                  xp[iplus] = xx[i+1]; yp[iplus]  = yy[i+1];
                  xx[i]   = xmin; yy[i]   = ymin;
                  xx[i+1] = xmin; yy[i+1] = ymin;
                  nadd++;
               }
               if (xx[i+1] == xp[iminus] && yy[i+1] == yp[iminus]) {
                  iminus--;
                  xp[iminus] = xx[i];   yp[iminus]  = yy[i];
                  xx[i]   = xmin; yy[i]   = ymin;
                  xx[i+1] = xmin; yy[i+1] = ymin;
                  nadd++;
               }
            }
            if (nadd == 0) break;
         }
         theColor = Int_t((ipoly+0.99)*Float_t(ncolors)/Float_t(ndivz));
         icol = gStyle->GetColorPalette(theColor);
         if (ndivz > 1) fH->SetFillColor(icol);
         fH->TAttFill::Modify();
         gPad->PaintFillArea(iplus-iminus+1,&xp[iminus],&yp[iminus]);
         if (Hoption.List) {
            graph = new TGraph(iplus-iminus+1,&xp[iminus],&yp[iminus]);
            graph->SetFillColor(icol);
            graph->SetLineWidth(fH->GetLineWidth());
            list->Add(graph);
         }
         //check if more points are left
         istart = 0;
         for (i=2;i<np[ipoly];i+=2) {
            if (xx[i] != xmin && yy[i] != ymin) {
               istart = i;
               break;
            }
         }
         if (istart == 0) break;
      }
   }

   for (i=0;i<ncontour;i++) delete polys[i];
   delete [] polys;
   delete [] xp;
   delete [] yp;
   delete [] polysort;

theEND:
   gPad->ResetBit(TGraph::kClipFrame);
   if (Hoption.Zscale) PaintPalette();
   fH->SetLineStyle(linesav);
   fH->SetLineColor(colorsav);
   fH->SetFillColor(fillsav);
   if (np) delete [] np;
   delete [] xarr;
   delete [] yarr;
   delete [] itarr;
   delete [] levels;
}


//______________________________________________________________________________
Int_t THistPainter::PaintContourLine(Double_t elev1, Int_t icont1, Double_t x1, Double_t y1,
                            Double_t elev2, Int_t icont2, Double_t x2, Double_t y2,
                            Double_t *xarr, Double_t *yarr, Int_t *itarr, Double_t *levels)
{
   /* Begin_html
   Fill the matrix XARR YARR for Contour Plot.
   End_html */

   Bool_t vert;
   Double_t tlen, tdif, elev, diff, pdif, xlen;
   Int_t n, i, icount;

   if (x1 == x2) {
      vert = kTRUE;
      tlen = y2 - y1;
   } else {
      vert = kFALSE;
      tlen = x2 - x1;
   }

   n = icont1 +1;
   tdif = elev2 - elev1;
   i = 0;
   icount = 0;
   while (n <= icont2 && i <= kMAXCONTOUR/2 -3) {
      //elev = fH->GetContourLevel(n);
      elev = levels[n];
      diff = elev - elev1;
      pdif = diff/tdif;
      xlen = tlen*pdif;
      if (vert) {
         if (Hoption.Logx)
            xarr[i] = TMath::Log10(x1);
         else
            xarr[i] = x1;
         if (Hoption.Logy)
            yarr[i] = TMath::Log10(y1 + xlen);
         else
            yarr[i] = y1 + xlen;
      } else {
         if (Hoption.Logx)
            xarr[i] = TMath::Log10(x1 + xlen);
         else
            xarr[i] = x1 + xlen;
         if (Hoption.Logy)
            yarr[i] = TMath::Log10(y1);
         else
            yarr[i] = y1;
      }
      itarr[i] = n;
      icount++;
      i +=2;
      n++;
   }
   return icount;
}


//______________________________________________________________________________
void THistPainter::PaintErrors(Option_t *)
{
   /* Begin_html
   <a href="#HP09">Draw 1D histograms error bars.</a>
   End_html */

   // On iOS, we do not highlight histogram, if it's not picked at the moment
   // (but part of histogram (axis or pavestat) was picked, that's why this code
   // is called at all. This conditional statement never executes on non-iOS platform.
   if (gPad->PadInHighlightMode() && gPad->GetSelected() != fH) return;

   const Int_t kBASEMARKER=8;
   Double_t xp, yp, ex1, ex2, ey1, ey2;
   Double_t delta;
   Double_t s2x, s2y, bxsize, bysize, symbolsize, xerror, sbase;
   Double_t xi1, xi2, xi3, xi4, yi1, yi2, yi3, yi4;
   Double_t xmin, xmax, ymin, ymax;
   Double_t logxmin = 0;
   Double_t logymin = 0;
   Int_t i, k, npoints, first, last, fixbin;
   Int_t if1 = 0;
   Int_t if2 = 0;
   Int_t drawmarker, errormarker;
   Int_t option0, option1, option2, option3, option4, optionE, optionEX0, optionI0;

   Double_t *xline = 0;
   Double_t *yline = 0;
   option0 = option1 = option2 = option3 = option4 = optionE = optionEX0 = optionI0 = 0;
   if (Int_t(Hoption.Error/10) == 2) {optionEX0 = 1; Hoption.Error -= 10;}
   if (Hoption.Error == 31) {optionEX0 = 1; Hoption.Error = 1;}
   if (Hoption.Error == 10) option0 = 1;
   if (Hoption.Error == 11) option1 = 1;
   if (Hoption.Error == 12) option2 = 1;
   if (Hoption.Error == 13) option3 = 1;
   if (Hoption.Error == 14) {option4 = 1; option3 = 1;}
   if (Hoption.Error == 15) {optionI0 = 1; option3 = 1;}
   if (Hoption.Error == 16) {optionI0 = 1; option4 = 1; option3 = 1;}
   if (option2+option3 == 0) optionE = 1;
   if (Hoption.Error == 0) optionE = 0;
   if (fXaxis->GetXbins()->fN) fixbin = 0;
   else                        fixbin = 1;

   errormarker = fH->GetMarkerStyle();
   if (optionEX0) {
      xerror = 0;
   } else {
      xerror = gStyle->GetErrorX();
   }
   symbolsize  = fH->GetMarkerSize();
   if (errormarker == 1) symbolsize = 0.01;
   sbase       = symbolsize*kBASEMARKER;
   // set the graphics attributes

   fH->TAttLine::Modify();
   fH->TAttFill::Modify();
   fH->TAttMarker::Modify();

   // set the first and last bin

   Double_t factor = Hparam.factor;
   first      = Hparam.xfirst;
   last       = Hparam.xlast;
   npoints    = last - first  +1;
   xmin       = gPad->GetUxmin();
   xmax       = gPad->GetUxmax();
   ymin       = gPad->GetUymin();
   ymax       = gPad->GetUymax();


   if (option3) {
      xline = new Double_t[2*npoints];
      yline = new Double_t[2*npoints];
      if (!xline || !yline) {
         Error("PaintErrors", "too many points, out of memory");
         return;
      }
      if1 = 1;
      if2 = 2*npoints;
   }

   //  compute the offset of the error bars due to the symbol size
   s2x    = gPad->PixeltoX(Int_t(0.5*sbase)) - gPad->PixeltoX(0);
   s2y    =-gPad->PixeltoY(Int_t(0.5*sbase)) + gPad->PixeltoY(0);

   // compute size of the lines at the end of the error bars
   Int_t dxend = Int_t(gStyle->GetEndErrorSize());
   bxsize    = gPad->PixeltoX(dxend) - gPad->PixeltoX(0);
   bysize    =-gPad->PixeltoY(dxend) + gPad->PixeltoY(0);


   if (fixbin) {
      if (Hoption.Logx) xp = TMath::Power(10,Hparam.xmin) + 0.5*Hparam.xbinsize;
      else              xp = Hparam.xmin + 0.5*Hparam.xbinsize;
   }
   else {
      delta = fH->GetBinWidth(first);
      xp    = fH->GetBinLowEdge(first) + 0.5*delta;
   }

   // if errormarker = 0 or symbolsize = 0. no symbol is drawn
   if (Hoption.Logx) logxmin = TMath::Power(10,Hparam.xmin);
   if (Hoption.Logy) logymin = TMath::Power(10,Hparam.ymin);

   //    ---------------------- Loop over the points---------------------
   for (k=first; k<=last; k++) {

      //          get the data
      //     xp      = X position of the current point
      //     yp      = Y position of the current point
      //     ex1   = Low X error
      //     ex2   = Up X error
      //     ey1   = Low Y error
      //     ey2   = Up Y error
      //     (xi,yi) = Error bars coordinates

      if (Hoption.Logx) {
         if (xp <= 0) goto L30;
         if (xp < logxmin) goto L30;
         if (xp > TMath::Power(10,xmax)) break;
      } else {
         if (xp < xmin) goto L30;
         if (xp > xmax) break;
      }
      yp = factor*fH->GetBinContent(k);
      if (optionI0 && yp==0) goto L30;
      if (fixbin) {
         ex1 = xerror*Hparam.xbinsize;
      } else {
         delta = fH->GetBinWidth(k);
         ex1 = xerror*delta;
      }
      if (fH->GetBinErrorOption() == TH1::kNormal) {
         ey1 = factor*fH->GetBinError(k);
         ey2 = ey1;
      }
      else {
         ey1 = factor*fH->GetBinErrorLow(k);
         ey2 = factor*fH->GetBinErrorUp(k);
      }
      ex2 = ex1;

      xi4 = xp;
      xi3 = xp;
      xi2 = xp + ex2;
      xi1 = xp - ex1;

      yi1 = yp;
      yi2 = yp;
      yi3 = yp - ey1;
      yi4 = yp + ey2;

      //          take the LOG if necessary
      if (Hoption.Logx) {
         xi1 = TMath::Log10(TMath::Max(xi1,logxmin));
         xi2 = TMath::Log10(TMath::Max(xi2,logxmin));
         xi3 = TMath::Log10(TMath::Max(xi3,logxmin));
         xi4 = TMath::Log10(TMath::Max(xi4,logxmin));
      }
      if (Hoption.Logy) {
         yi1 = TMath::Log10(TMath::Max(yi1,logymin));
         yi2 = TMath::Log10(TMath::Max(yi2,logymin));
         yi3 = TMath::Log10(TMath::Max(yi3,logymin));
         yi4 = TMath::Log10(TMath::Max(yi4,logymin));
      }

      // test if error bars are not outside the limits
      //  otherwise they are truncated

      xi1 = TMath::Max(xi1,xmin);
      xi2 = TMath::Min(xi2,xmax);
      yi3 = TMath::Max(yi3,ymin);
      yi4 = TMath::Min(yi4,ymax);

      //  test if the marker is on the frame limits. If "Yes", the
      //  marker will not be drawn and the error bars will be readjusted.

      drawmarker = kTRUE;
      if (!option0 && !option3) {
         if (Hoption.Logy && yp < logymin) goto L30;
         if (yi1 < ymin || yi1 > ymax) goto L30;
         if (Hoption.Error != 0 && yp == 0 && ey1 <= 0) drawmarker = kFALSE;
      }
      if (!symbolsize || !errormarker) drawmarker = kFALSE;

      //  draw the error rectangles
      if (option2) gPad->PaintBox(xi1,yi3,xi2,yi4);

      //  keep points for fill area drawing
      if (option3) {
         xline[if1-1] = xi3;
         xline[if2-1] = xi3;
         yline[if1-1] = yi4;
         yline[if2-1] = yi3;
         if1++;
         if2--;
      }

      //          draw the error bars
      if (optionE && drawmarker) {
         if ((yi3 < yi1 - s2y) && (yi3 < ymax)) gPad->PaintLine(xi3,yi3,xi4,TMath::Min(yi1 - s2y,ymax));
         if ((yi1 + s2y < yi4) && (yi4 > ymin)) gPad->PaintLine(xi3,TMath::Max(yi1 + s2y, ymin),xi4,yi4);
         // don't duplicate the horizontal line
         if (Hoption.Hist != 2) {
            if (yi1<ymax && yi1>ymin) {
              if (xi1 < xi3 - s2x) gPad->PaintLine(xi1,yi1,xi3 - s2x,yi2);
              if (xi3 + s2x < xi2) gPad->PaintLine(xi3 + s2x,yi1,xi2,yi2);
            }
         }
      }
      if (optionE && !drawmarker && ey1 != 0) {
         if ((yi3 < yi1) && (yi3 < ymax)) gPad->PaintLine(xi3,yi3,xi4,TMath::Min(yi1,ymax));
         if ((yi1 < yi4) && (yi4 > ymin)) gPad->PaintLine(xi3,TMath::Max(yi1,ymin),xi4,yi4);
         // don't duplicate the horizontal line
         if (Hoption.Hist != 2) {
            if (yi1<ymax && yi1>ymin) {
               if (xi1 < xi3) gPad->PaintLine(xi1,yi1,xi3,yi2);
               if (xi3 < xi2) gPad->PaintLine(xi3,yi1,xi2,yi2);
            }
         }
      }

      //          draw line at the end of the error bars

      if (option1 && drawmarker) {
         if (yi3 < yi1-s2y) gPad->PaintLine(xi3 - bxsize,yi3,xi3 + bxsize,yi3);
         if (yi4 > yi1+s2y) gPad->PaintLine(xi3 - bxsize,yi4,xi3 + bxsize,yi4);
         if (xi1 < xi3-s2x) gPad->PaintLine(xi1,yi1 - bysize,xi1,yi1 + bysize);
         if (xi2 > xi3+s2x) gPad->PaintLine(xi2,yi1 - bysize,xi2,yi1 + bysize);
      }

      //          draw the marker

      if (drawmarker) gPad->PaintPolyMarker(1, &xi3, &yi1);

L30:
      if (fixbin) xp += Hparam.xbinsize;
      else {
         if (k < last) {
            delta = fH->GetBinWidth(k+1);
            xp    = fH->GetBinLowEdge(k+1) + 0.5*delta;
         }
      }
   }  //end of for loop

   //          draw the filled area

   if (option3) {
      TGraph graph;
      graph.SetLineStyle(fH->GetLineStyle());
      graph.SetLineColor(fH->GetLineColor());
      graph.SetLineWidth(fH->GetLineWidth());
      graph.SetFillStyle(fH->GetFillStyle());
      graph.SetFillColor(fH->GetFillColor());
      Int_t logx = gPad->GetLogx();
      Int_t logy = gPad->GetLogy();
      gPad->SetLogx(0);
      gPad->SetLogy(0);

      // In some cases the number of points in the fill area is smaller than
      // 2*npoints. In such cases the array xline and yline must be arranged
      // before being plotted. The next loop does that.
      if (if2 > npoints) {
         for (i=1; i<if1; i++) {
            xline[if1-2+i] = xline[if2-1+i];
            yline[if1-2+i] = yline[if2-1+i];
         }
         npoints = if1-1;
      }
      if (option4) graph.PaintGraph(2*npoints,xline,yline,"FC");
      else         graph.PaintGraph(2*npoints,xline,yline,"F");
      gPad->SetLogx(logx);
      gPad->SetLogy(logy);
      delete [] xline;
      delete [] yline;
   }
}


//______________________________________________________________________________
void THistPainter::Paint2DErrors(Option_t *)
{
   /* Begin_html
   Draw 2D histograms errors.
   End_html */

   fH->TAttMarker::Modify();
   fH->TAttLine::Modify();

   // Define the 3D view
   fXbuf[0] = Hparam.xmin;
   fYbuf[0] = Hparam.xmax;
   fXbuf[1] = Hparam.ymin;
   fYbuf[1] = Hparam.ymax;
   fXbuf[2] = Hparam.zmin;
   fYbuf[2] = Hparam.zmax;
   fLego = new TPainter3dAlgorithms(fXbuf, fYbuf);
   TView *view = gPad->GetView();
   if (!view) {
      Error("Paint2DErrors", "no TView in current pad");
      return;
   }
   Double_t thedeg =  90 - gPad->GetTheta();
   Double_t phideg = -90 - gPad->GetPhi();
   Double_t psideg = view->GetPsi();
   Int_t irep;
   view->SetView(phideg, thedeg, psideg, irep);

   // Set color/style for back box
   fLego->SetFillStyle(gPad->GetFrameFillStyle());
   fLego->SetFillColor(gPad->GetFrameFillColor());
   fLego->TAttFill::Modify();
   Int_t backcolor = gPad->GetFrameFillColor();
   if (Hoption.System != kCARTESIAN) backcolor = 0;
   view->PadRange(backcolor);
   fLego->SetFillStyle(fH->GetFillStyle());
   fLego->SetFillColor(fH->GetFillColor());
   fLego->TAttFill::Modify();

   // Paint the Back Box if needed
   if (Hoption.BackBox && !Hoption.Same && !Hoption.Lego && !Hoption.Surf) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
      fLego->BackBox(90);
   }

   // Paint the Errors
   Double_t x, ex, x1, x2;
   Double_t y, ey, y1, y2;
   Double_t z, ez1, ez2, z1, z2;
   Double_t temp1[3],temp2[3];
   Double_t xyerror;
   if (Hoption.Error == 110) {
      xyerror = 0;
   } else {
      xyerror = gStyle->GetErrorX();
   }

   Double_t xk, xstep, yk, ystep;
   for (Int_t j=Hparam.yfirst; j<=Hparam.ylast;j++) {
      y  = fYaxis->GetBinCenter(j);
      ey = fYaxis->GetBinWidth(j)*xyerror;
      y1 = y-ey;
      y2 = y+ey;
      if (Hoption.Logy) {
         if (y > 0)  y = TMath::Log10(y);
         else        continue;
         if (y1 > 0) y1 = TMath::Log10(y1);
         else        y1 = Hparam.ymin;
         if (y2 > 0) y2 = TMath::Log10(y2);
         else        y2 = Hparam.ymin;
      }
      yk    = fYaxis->GetBinLowEdge(j);
      ystep = fYaxis->GetBinWidth(j);
      for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
         xk    = fXaxis->GetBinLowEdge(i);
         xstep = fXaxis->GetBinWidth(i);
         if (!IsInside(xk+0.5*xstep,yk+0.5*ystep)) continue;
         Int_t bin = fH->GetBin(i,j);
         x  = fXaxis->GetBinCenter(i);
         ex = fXaxis->GetBinWidth(i)*xyerror;
         x1 = x-ex;
         x2 = x+ex;
         if (Hoption.Logx) {
            if (x > 0)  x = TMath::Log10(x);
            else        continue;
            if (x1 > 0) x1 = TMath::Log10(x1);
            else        x1 = Hparam.xmin;
            if (x2 > 0) x2 = TMath::Log10(x2);
            else        x2 = Hparam.xmin;
         }
         z  = fH->GetBinContent(bin);
         if (fH->GetBinErrorOption() == TH1::kNormal) {
            ez1 = fH->GetBinError(bin);
            ez2 = ez1;
         }
         else {
            ez1 = fH->GetBinErrorLow(bin);
            ez2 = fH->GetBinErrorUp(bin);
         }
         z1 = z - ez1;
         z2 = z + ez2;
         if (Hoption.Logz) {
            if (z > 0)   z = TMath::Log10(z);
            else         z = Hparam.zmin;
            if (z1 > 0) z1 = TMath::Log10(z1);
            else        z1 = Hparam.zmin;
            if (z2 > 0) z2 = TMath::Log10(z2);
            else        z2 = Hparam.zmin;

         }
         if (z <= Hparam.zmin) continue;
         if (z >  Hparam.zmax) z = Hparam.zmax;

         temp1[0] = x1;
         temp1[1] = y;
         temp1[2] = z;
         temp2[0] = x2;
         temp2[1] = y;
         temp2[2] = z;
         gPad->PaintLine3D(temp1, temp2);
         temp1[0] = x;
         temp1[1] = y1;
         temp1[2] = z;
         temp2[0] = x;
         temp2[1] = y2;
         temp2[2] = z;
         gPad->PaintLine3D(temp1, temp2);
         temp1[0] = x;
         temp1[1] = y;
         temp1[2] = z1;
         temp2[0] = x;
         temp2[1] = y;
         temp2[2] = z2;
         gPad->PaintLine3D(temp1, temp2);
         temp1[0] = x;
         temp1[1] = y;
         temp1[2] = z;
         view->WCtoNDC(temp1, &temp2[0]);
         gPad->PaintPolyMarker(1, &temp2[0], &temp2[1]);
      }
   }

   // Paint the Front Box if needed
   if (Hoption.FrontBox) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove2);
      fLego->FrontBox(90);
   }

   // Paint the Axis if needed
   if (!Hoption.Axis && !Hoption.Same && !Hoption.Lego && !Hoption.Surf) {
      TGaxis *axis = new TGaxis();
      PaintLegoAxis(axis, 90);
      delete axis;
   }

   delete fLego; fLego = 0;
}


//______________________________________________________________________________
void THistPainter::PaintFrame()
{
   /* Begin_html
   Calculate range and clear pad (canvas).
   End_html */

   if (Hoption.Same) return;

   RecalculateRange();

   if (Hoption.Lego || Hoption.Surf || Hoption.Tri ||
       Hoption.Contour == 14 || Hoption.Error >= 100) {
      TObject *frame = gPad->FindObject("TFrame");
      if (frame) gPad->GetListOfPrimitives()->Remove(frame);
      return;
   }

   //The next statement is always executed on non-iOS platform,
   //on iOS depends on pad mode.
   if (!gPad->PadInSelectionMode() && !gPad->PadInHighlightMode())
      gPad->PaintPadFrame(Hparam.xmin,Hparam.ymin,Hparam.xmax,Hparam.ymax);
}


//______________________________________________________________________________
void THistPainter::PaintFunction(Option_t *)
{
   /* Begin_html
   <a href="#HP28">Paint functions associated to an histogram.</a>
   End_html */

   TObjOptLink *lnk = (TObjOptLink*)fFunctions->FirstLink();
   TObject *obj;

   while (lnk) {
      obj = lnk->GetObject();
      TVirtualPad *padsave = gPad;
      if (obj->InheritsFrom(TF2::Class())) {
         if (obj->TestBit(TF2::kNotDraw) == 0) {
            if (Hoption.Lego || Hoption.Surf) {
               TF2 *f2 = (TF2*)obj;
               f2->SetMinimum(fH->GetMinimum());
               f2->SetMaximum(fH->GetMaximum());
               f2->SetRange(fH->GetXaxis()->GetXmin(), fH->GetYaxis()->GetXmin(), fH->GetXaxis()->GetXmax(), fH->GetYaxis()->GetXmax() );
               f2->Paint("surf same");
            } else {
               obj->Paint("cont3 same");
            }
         }
      } else if (obj->InheritsFrom(TF1::Class())) {
         if (obj->TestBit(TF1::kNotDraw) == 0) obj->Paint("lsame");
      } else  {
         //Let's make this 'function' selectable on iOS device (for example, it can be TPaveStat).
         gPad->PushSelectableObject(obj);

         //The next statement is ALWAYS executed on non-iOS platform, on iOS it depends on pad's mode
         //and picked object.
         if (!gPad->PadInHighlightMode() || (gPad->PadInHighlightMode() && obj == gPad->GetSelected()))
            obj->Paint(lnk->GetOption());
      }
      lnk = (TObjOptLink*)lnk->Next();
      padsave->cd();
   }
}


//______________________________________________________________________________
void THistPainter::PaintHist(Option_t *)
{
   /* Begin_html
   <a href="#HP01b">Control routine to draw 1D histograms.</a>
   End_html */

   //On iOS: do not highlight hist, if part of it was selected.
   //Never executes on non-iOS platform.
   if (gPad->PadInHighlightMode() && gPad->GetSelected() != fH)
      return;

   static char chopth[17];

   Int_t htype, oldhtype;
   Int_t i, j, first, last, nbins, fixbin;
   Double_t c1, yb;
   yb = 0;

   strlcpy(chopth, "                ",17);

   Double_t ymin = Hparam.ymin;
   Double_t ymax = Hparam.ymax;
   Double_t baroffset = fH->GetBarOffset();
   Double_t barwidth  = fH->GetBarWidth();
   Double_t baroffsetsave = gStyle->GetBarOffset();
   Double_t barwidthsave  = gStyle->GetBarWidth();
   gStyle->SetBarOffset(baroffset);
   gStyle->SetBarWidth(barwidth);

   //       Create "LIFE" structure to keep current histogram status

   first = Hparam.xfirst;
   last  = Hparam.xlast;
   nbins = last - first + 1;

   Double_t *keepx = 0;
   Double_t *keepy = 0;
   if (fXaxis->GetXbins()->fN) fixbin = 0;
   else                        fixbin = 1;
   if (fixbin) keepx = new Double_t[2];
   else        keepx = new Double_t[nbins+1];
   keepy = new Double_t[nbins];
   Double_t logymin = 0;
   if (Hoption.Logy) logymin = TMath::Power(10,ymin);

   //      Loop on histogram bins

   for (j=first; j<=last;j++) {
      c1 = Hparam.factor*fH->GetBinContent(j);
      if (TMath::Abs(ymax-ymin) > 0) {
         if (Hoption.Logy) yb = TMath::Log10(TMath::Max(c1,.1*logymin));
         else              yb = c1;
      }
      if (!Hoption.Line) {
         yb = TMath::Max(yb, ymin);
         yb = TMath::Min(yb, ymax);
      }
      keepy[j-first] = yb;
   }

   //              Draw histogram according to value of FillStyle and FillColor

   if (fixbin) { keepx[0] = Hparam.xmin; keepx[1] = Hparam.xmax; }
   else {
      for (i=0; i<nbins; i++) keepx[i] = fXaxis->GetBinLowEdge(i+first);
      keepx[nbins] = fXaxis->GetBinUpEdge(nbins-1+first);
   }

   //         Prepare Fill area (systematic with option "Bar").

   oldhtype = fH->GetFillStyle();
   htype    = oldhtype;
   if (Hoption.Bar) {
      if (htype == 0 || htype == 1000) htype = 1001;
   }

   Width_t lw = (Width_t)fH->GetLineWidth();

   //         Code option for GrapHist

   if (Hoption.Line) chopth[0] = 'L';
   if (Hoption.Star) chopth[1] = '*';
   if (Hoption.Mark) chopth[2] = 'P';
   if (Hoption.Mark == 10) chopth[3] = '0';
   if (Hoption.Line || Hoption.Curve || Hoption.Hist || Hoption.Bar) {
      if (Hoption.Curve)    chopth[3] = 'C';
      if (Hoption.Hist > 0) chopth[4] = 'H';
      else if (Hoption.Bar) chopth[5] = 'B';
      if (fH->GetFillColor() && htype) {
         if (Hoption.Logy) {
            chopth[6] = '1';
         }
         if (Hoption.Hist > 0 || Hoption.Curve || Hoption.Line) {
            chopth[7] = 'F';
         }
      }
   }
   if (!fixbin && strlen(chopth)) {
      chopth[8] = 'N';
   }

   if (Hoption.Fill == 2)    chopth[13] = '2';

   //         Option LOGX

   if (Hoption.Logx) {
      chopth[9]  = 'G';
      chopth[10] = 'X';
      if (fixbin) {
         keepx[0] = TMath::Power(10,keepx[0]);
         keepx[1] = TMath::Power(10,keepx[1]);
      }
   }

   if (Hoption.Off) {
      chopth[11] = ']';
      chopth[12] = '[';
   }

   //         Draw the histogram

   TGraph graph;
   graph.SetLineWidth(lw);
   graph.SetLineStyle(fH->GetLineStyle());
   graph.SetLineColor(fH->GetLineColor());
   graph.SetFillStyle(htype);
   graph.SetFillColor(fH->GetFillColor());
   graph.SetMarkerStyle(fH->GetMarkerStyle());
   graph.SetMarkerSize(fH->GetMarkerSize());
   graph.SetMarkerColor(fH->GetMarkerColor());
   if (!Hoption.Same) graph.ResetBit(TGraph::kClipFrame);

   graph.PaintGrapHist(nbins, keepx, keepy ,chopth);

   delete [] keepx;
   delete [] keepy;
   gStyle->SetBarOffset(baroffsetsave);
   gStyle->SetBarWidth(barwidthsave);

   htype=oldhtype;
}


//______________________________________________________________________________
void THistPainter::PaintH3(Option_t *option)
{
   /* Begin_html
   <a href="#HP01d">Control function to draw a 3D histograms.</a>
   End_html */

   char *cmd;
   TString opt = fH->GetDrawOption();
   opt.ToLower();
   Int_t irep;

   if (fH->GetDrawOption() && (strstr(opt,"box") ||  strstr(opt,"lego"))) {
      cmd = Form("TMarker3DBox::PaintH3((TH1 *)0x%lx,\"%s\");",(Long_t)fH,option);
   } else if (fH->GetDrawOption() && strstr(opt,"iso")) {
      PaintH3Iso();
      return;
   } else if (strstr(option,"tf3")) {
      PaintTF3();
      return;
   } else {
      cmd = Form("TPolyMarker3D::PaintH3((TH1 *)0x%lx,\"%s\");",(Long_t)fH,option);
   }

   if (strstr(opt,"fb")) Hoption.FrontBox = 0;
   if (strstr(opt,"bb")) Hoption.BackBox = 0;

   TView *view = gPad->GetView();
   if (!view) return;
   Double_t thedeg =  90 - gPad->GetTheta();
   Double_t phideg = -90 - gPad->GetPhi();
   Double_t psideg = view->GetPsi();
   view->SetView(phideg, thedeg, psideg, irep);

   // Paint the data
   gROOT->ProcessLine(cmd);

   if (Hoption.Same) return;

   // Draw axis
   view->SetOutlineToCube();
   TSeqCollection *ol = view->GetOutline();
   if (ol && Hoption.BackBox && Hoption.FrontBox) ol->Paint(option);
   Hoption.System = kCARTESIAN;
   TGaxis *axis = new TGaxis();
   if (!Hoption.Axis && !Hoption.Same) PaintLegoAxis(axis, 90);
   delete axis;

   // Draw palette. In case of 4D plot with TTree::Draw() the palette should
   // be painted with the option colz.
   if (fH->GetDrawOption() && strstr(opt,"colz")) {
      Int_t ndiv   = fH->GetContour();
      if (ndiv == 0 ) {
         ndiv = gStyle->GetNumberContours();
         fH->SetContour(ndiv);
      }
      PaintPalette();
   }

   // Draw title
   PaintTitle();

   //Draw stats and fit results
   TF1 *fit  = 0;
   TIter next(fFunctions);
   TObject *obj;
   while ((obj = next())) {
      if (obj->InheritsFrom(TF1::Class())) {
         fit = (TF1*)obj;
         break;
      }
   }
   if (Hoption.Same != 1) {
      if (!fH->TestBit(TH1::kNoStats)) {  // bit set via TH1::SetStats
         PaintStat3(gStyle->GetOptStat(),fit);
      }
   }

}


//______________________________________________________________________________
Int_t THistPainter::PaintInit()
{
   /* Begin_html
   Compute histogram parameters used by the drawing routines.
   End_html */

   if (fH->GetDimension() > 1 || Hoption.Lego || Hoption.Surf) return 1;

   Int_t i;
   static const char *where = "PaintInit";
   Double_t yMARGIN = gStyle->GetHistTopMargin();
   Int_t maximum = 0;
   Int_t minimum = 0;
   if (fH->GetMaximumStored() != -1111) maximum = 1;
   if (fH->GetMinimumStored() != -1111) minimum = 1;

   //     Compute X axis parameters

   Int_t last      = fXaxis->GetLast();
   Int_t first     = fXaxis->GetFirst();
   Hparam.xlowedge = fXaxis->GetBinLowEdge(first);
   Hparam.xbinsize = fXaxis->GetBinWidth(first);
   Hparam.xlast    = last;
   Hparam.xfirst   = first;
   Hparam.xmin     = Hparam.xlowedge;
   Hparam.xmax     = fXaxis->GetBinLowEdge(last)+fXaxis->GetBinWidth(last);

   //       if log scale in X, replace xmin,max by the log
   if (Hoption.Logx) {
      if (Hparam.xmax<=0) {
         Error(where, "cannot set X axis to log scale");
         return 0;
      }
      if (Hparam.xlowedge <=0 ) {
         if (Hoption.Same) {
            Hparam.xlowedge = TMath::Power(10, gPad->GetUxmin());
         } else {
            for (i=first; i<=last; i++) {
               Double_t binLow = fXaxis->GetBinLowEdge(i);
               if (binLow>0) {
                  Hparam.xlowedge = binLow;
                  break;
               }
            }
            if (Hparam.xlowedge<=0) {
               Error(where, "cannot set X axis to log scale");
               return 0;
            }
         }
         Hparam.xmin  = Hparam.xlowedge;
      }
      Hparam.xfirst= fXaxis->FindFixBin(Hparam.xmin);
      Hparam.xlast = fXaxis->FindFixBin(Hparam.xmax);
      Hparam.xmin  = TMath::Log10(Hparam.xmin);
      Hparam.xmax  = TMath::Log10(Hparam.xmax);
      if (Hparam.xlast  > last)  Hparam.xlast  = last;
      if (Hparam.xfirst < first) Hparam.xfirst = first;
   }

   //     Compute Y axis parameters
   Double_t bigp = TMath::Power(10,32);
   Double_t ymax = -bigp;
   Double_t ymin = bigp;
   Double_t c1, e1;
   Double_t xv[1];
   Double_t fval;
   TObject *f;
   TF1 *f1;
   Double_t allchan = 0;
   Int_t nonNullErrors = 0;
   TIter   next(fFunctions);
   for (i=first; i<=last;i++) {
      c1 = fH->GetBinContent(i);
      ymax = TMath::Max(ymax,c1);
      if (Hoption.Logy) {
         if (c1 > 0) ymin = TMath::Min(ymin,c1);
      } else {
         ymin = TMath::Min(ymin,c1);
      }
      if (Hoption.Error) {
         if (fH->GetBinErrorOption() == TH1::kNormal)
            e1 = fH->GetBinError(i);
         else
            e1 = fH->GetBinErrorUp(i);
         if (e1 > 0) nonNullErrors++;
         ymax = TMath::Max(ymax,c1+e1);
         if (fH->GetBinErrorOption() != TH1::kNormal)
            e1 = fH->GetBinErrorLow(i);

         if (Hoption.Logy) {
            if (c1-e1>0.01*TMath::Abs(c1)) ymin = TMath::Min(ymin,c1-e1);
         } else {
            ymin = TMath::Min(ymin,c1-e1);
         }
      }
      if (Hoption.Func) {
         xv[0] = fXaxis->GetBinCenter(i);
         while ((f = (TObject*) next())) {
            if (f->IsA() == TF1::Class()) {
               f1 = (TF1*)f;
               if (xv[0] < f1->GetXmin() || xv[0] > f1->GetXmax()) continue;
               fval = f1->Eval(xv[0],0,0);
               ymax = TMath::Max(ymax,fval);
               if (Hoption.Logy) {
                  if (c1 > 0 && fval > 0.3*c1) ymin = TMath::Min(ymin,fval);
               }
            }
         }
         next.Reset();
      }
      allchan += c1;
   }
   if (!nonNullErrors) {
      if (Hoption.Error) {
         if (!Hoption.Mark && !Hoption.Line && !Hoption.Star && !Hoption.Curve) Hoption.Hist = 2;
         Hoption.Error=0;
      }
   }


   //     Take into account maximum , minimum

   if (Hoption.Logy && ymin <= 0) {
      if (ymax >= 1) ymin = TMath::Max(.005,ymax*1e-10);
      else           ymin = 0.001*ymax;
   }

   Double_t xm = ymin;
   if (maximum) ymax = fH->GetMaximumStored();
   if (minimum) xm   = fH->GetMinimumStored();
   if (Hoption.Logy && xm < 0) {
      Error(where, "log scale requested with a negative argument (%f)", xm);
      return 0;
   } else if (Hoption.Logy && xm>=0 && ymax==0) { // empty histogram in log scale
      ymin = 0.01;
      ymax = 10.;
   } else {
      ymin = xm;
   }

   if (ymin >= ymax) {
      if (Hoption.Logy) {
         if (ymax > 0) ymin = 0.001*ymax;
         else {
            if (!Hoption.Same) Error(where, "log scale is requested but maximum is less or equal 0 (%f)", ymax);
            return 0;
         }
      }
      else {
         if (ymin > 0) {
            ymin = 0;
            ymax *= 2;
         } else if (ymin < 0) {
            ymax = 0;
            ymin *= 2;
         } else {
            ymin = 0;
            ymax = 1;
         }
      }
   }

   // In some cases, mainly because of precision issues, ymin and ymax could almost equal.
   if (TMath::AreEqualRel(ymin,ymax,1E-15)) {
      ymin = ymin*(1-1E-14);
      ymax = ymax*(1+1E-14);
   }

   //     take into account normalization factor
   Hparam.allchan = allchan;
   Double_t factor = allchan;
   if (fH->GetNormFactor() > 0) factor = fH->GetNormFactor();
   if (allchan) factor /= allchan;
   if (factor == 0) factor = 1;
   Hparam.factor = factor;
   ymax = factor*ymax;
   ymin = factor*ymin;
   //just in case the norm factor is negative
   // this may happen with a positive norm factor and a negative integral !
   if (ymax < ymin) {
      Double_t temp = ymax;
      ymax = ymin;
      ymin = temp;
   }

   //         For log scales, histogram coordinates are LOG10(ymin) and
   //         LOG10(ymax). Final adjustment (if not option "Same"
   //         or "+" for ymax) of ymax and ymin for logarithmic scale, if
   //         Maximum and Minimum are not defined.
   if (Hoption.Logy) {
      if (ymin <=0 || ymax <=0) {
         Error(where, "Cannot set Y axis to log scale");
         return 0;
      }
      ymin = TMath::Log10(ymin);
      if (!minimum) ymin += TMath::Log10(0.5);
      ymax = TMath::Log10(ymax);
      if (!maximum) ymax += TMath::Log10(2*(0.9/0.95));
      if (!Hoption.Same) {
         Hparam.ymin = ymin;
         Hparam.ymax = ymax;
      }
      return 1;
   }

   //         final adjustment of ymin for linear scale.
   //         if minimum is not set , then ymin is set to zero if >0
   //         or to ymin - margin if <0.
   if (!minimum) {
      if (gStyle->GetHistMinimumZero()) {
         if (ymin >= 0) ymin = 0;
         else           ymin -= yMARGIN*(ymax-ymin);
      } else {
         Double_t dymin = yMARGIN*(ymax-ymin);
         if (ymin >= 0 && (ymin-dymin <= 0)) ymin  = 0;
         else                                ymin -= dymin;
      }
   }

   //         final adjustment of YMAXI for linear scale (if not option "Same"):
   //         decrease histogram height to MAX% of allowed height if HMAXIM
   //         has not been called.
   if (!maximum) {
      ymax += yMARGIN*(ymax-ymin);
   }

   Hparam.ymin = ymin;
   Hparam.ymax = ymax;
   return 1;
}


//______________________________________________________________________________
Int_t THistPainter::PaintInitH()
{
   /* Begin_html
   Compute histogram parameters used by the drawing routines for a rotated pad.
   End_html */

   static const char *where = "PaintInitH";
   Double_t yMARGIN = gStyle->GetHistTopMargin();
   Int_t maximum = 0;
   Int_t minimum = 0;
   if (fH->GetMaximumStored() != -1111) maximum = 1;
   if (fH->GetMinimumStored() != -1111) minimum = 1;

   //     Compute X axis parameters

   Int_t last      = fXaxis->GetLast();
   Int_t first     = fXaxis->GetFirst();
   Hparam.xlowedge = fXaxis->GetBinLowEdge(first);
   Hparam.xbinsize = fXaxis->GetBinWidth(first);
   Hparam.xlast    = last;
   Hparam.xfirst   = first;
   Hparam.ymin     = Hparam.xlowedge;
   Hparam.ymax     = fXaxis->GetBinLowEdge(last)+fXaxis->GetBinWidth(last);

   //       if log scale in Y, replace ymin,max by the log
   if (Hoption.Logy) {
      if (Hparam.xlowedge <=0 ) {
         Hparam.xlowedge = 0.1*Hparam.xbinsize;
         Hparam.ymin  = Hparam.xlowedge;
      }
      if (Hparam.ymin <=0 || Hparam.ymax <=0) {
         Error(where, "cannot set Y axis to log scale");
         return 0;
      }
      Hparam.xfirst= fXaxis->FindFixBin(Hparam.ymin);
      Hparam.xlast = fXaxis->FindFixBin(Hparam.ymax);
      Hparam.ymin  = TMath::Log10(Hparam.ymin);
      Hparam.ymax  = TMath::Log10(Hparam.ymax);
      if (Hparam.xlast > last) Hparam.xlast = last;
   }

   //     Compute Y axis parameters
   Double_t bigp = TMath::Power(10,32);
   Double_t xmax = -bigp;
   Double_t xmin = bigp;
   Double_t c1, e1;
   Double_t xv[1];
   Double_t fval;
   Int_t i;
   TObject *f;
   TF1 *f1;
   Double_t allchan = 0;
   TIter   next(fFunctions);
   for (i=first; i<=last;i++) {
      c1 = fH->GetBinContent(i);
      xmax = TMath::Max(xmax,c1);
      xmin = TMath::Min(xmin,c1);
      if (Hoption.Error) {
         e1 = fH->GetBinError(i);
         xmax = TMath::Max(xmax,c1+e1);
         xmin = TMath::Min(xmin,c1-e1);
      }
      if (Hoption.Func) {
         xv[0] = fXaxis->GetBinCenter(i);
         while ((f = (TObject*) next())) {
            if (f->IsA() == TF1::Class()) {
               f1 = (TF1*)f;
               if (xv[0] < f1->GetXmin() || xv[0] > f1->GetXmax()) continue;
               fval = f1->Eval(xv[0],0,0);
               xmax = TMath::Max(xmax,fval);
               if (Hoption.Logy) {
                  if (fval > 0.3*c1) xmin = TMath::Min(xmin,fval);
               }
            }
         }
         next.Reset();
      }
      allchan += c1;
   }

   //     Take into account maximum , minimum

   if (Hoption.Logx && xmin <= 0) {
      if (xmax >= 1) xmin = TMath::Max(.5,xmax*1e-10);
      else           xmin = 0.001*xmax;
   }
   Double_t xm = xmin;
   if (maximum) xmax = fH->GetMaximumStored();
   if (minimum) xm   = fH->GetMinimumStored();
   if (Hoption.Logx && xm <= 0) {
      Error(where, "log scale requested with zero or negative argument (%f)", xm);
      return 0;
   }
   else xmin = xm;
   if (xmin >= xmax) {
      if (Hoption.Logx) {
         if (xmax > 0) xmin = 0.001*xmax;
         else {
            if (!Hoption.Same) Error(where, "log scale is requested but maximum is less or equal 0 (%f)", xmax);
            return 0;
         }
      }
      else {
         if (xmin > 0) {
            xmin = 0;
            xmax *= 2;
         } else if (xmin < 0) {
            xmax = 0;
            xmin *= 2;
         } else {
            xmin = -1;
            xmax = 1;
         }
      }
   }

   //     take into account normalization factor
   Hparam.allchan = allchan;
   Double_t factor = allchan;
   if (fH->GetNormFactor() > 0) factor = fH->GetNormFactor();
   if (allchan) factor /= allchan;
   if (factor == 0) factor = 1;
   Hparam.factor = factor;
   xmax = factor*xmax;
   xmin = factor*xmin;

   //         For log scales, histogram coordinates are LOG10(ymin) and
   //         LOG10(ymax). Final adjustment (if not option "Same"
   //         or "+" for ymax) of ymax and ymin for logarithmic scale, if
   //         Maximum and Minimum are not defined.
   if (Hoption.Logx) {
      if (xmin <=0 || xmax <=0) {
         Error(where, "Cannot set Y axis to log scale");
         return 0;
      }
      xmin = TMath::Log10(xmin);
      if (!minimum) xmin += TMath::Log10(0.5);
      xmax = TMath::Log10(xmax);
      if (!maximum) xmax += TMath::Log10(2*(0.9/0.95));
      if (!Hoption.Same) {
         Hparam.xmin = xmin;
         Hparam.xmax = xmax;
      }
      return 1;
   }

   //         final adjustment of ymin for linear scale.
   //         if minimum is not set , then ymin is set to zero if >0
   //         or to ymin - margin if <0.
   if (!minimum) {
      if (xmin >= 0) xmin = 0;
      else           xmin -= yMARGIN*(xmax-xmin);
   }

   //         final adjustment of YMAXI for linear scale (if not option "Same"):
   //         decrease histogram height to MAX% of allowed height if HMAXIM
   //         has not been called.
   if (!maximum) {
      xmax += yMARGIN*(xmax-xmin);
   }
   Hparam.xmin = xmin;
   Hparam.xmax = xmax;
   return 1;
}


//______________________________________________________________________________
void THistPainter::PaintH3Iso()
{
   /* Begin_html
   <a href="#HP25">Control function to draw a 3D histogram with Iso Surfaces.</a>
   End_html */

   const Double_t ydiff = 1;
   const Double_t yligh1 = 10;
   const Double_t qa = 0.15;
   const Double_t qd = 0.15;
   const Double_t qs = 0.8;
   Double_t fmin, fmax;
   Int_t i, irep;
   Int_t nbcol = 28;
   Int_t icol1 = 201;
   Int_t ic1 = icol1;
   Int_t ic2 = ic1+nbcol;
   Int_t ic3 = ic2+nbcol;

   TGaxis *axis = new TGaxis();
   TAxis *xaxis = fH->GetXaxis();
   TAxis *yaxis = fH->GetYaxis();
   TAxis *zaxis = fH->GetZaxis();

   Int_t nx = fH->GetNbinsX();
   Int_t ny = fH->GetNbinsY();
   Int_t nz = fH->GetNbinsZ();

   Double_t *x = new Double_t[nx];
   Double_t *y = new Double_t[ny];
   Double_t *z = new Double_t[nz];

   for (i=0; i<nx; i++) x[i] = xaxis->GetBinCenter(i+1);
   for (i=0; i<ny; i++) y[i] = yaxis->GetBinCenter(i+1);
   for (i=0; i<nz; i++) z[i] = zaxis->GetBinCenter(i+1);

   fXbuf[0] = xaxis->GetBinLowEdge(xaxis->GetFirst());
   fYbuf[0] = xaxis->GetBinUpEdge(xaxis->GetLast());
   fXbuf[1] = yaxis->GetBinLowEdge(yaxis->GetFirst());
   fYbuf[1] = yaxis->GetBinUpEdge(yaxis->GetLast());
   fXbuf[2] = zaxis->GetBinLowEdge(zaxis->GetFirst());
   fYbuf[2] = zaxis->GetBinUpEdge(zaxis->GetLast());

   Double_t s[3];
   s[0] = fH->GetSumOfWeights()/(fH->GetNbinsX()*fH->GetNbinsY()*fH->GetNbinsZ());
   s[1] = 0.5*s[0];
   s[2] = 1.5*s[0];

   fLego = new TPainter3dAlgorithms(fXbuf, fYbuf);

   TView *view = gPad->GetView();
   if (!view) {
      Error("PaintH3Iso", "no TView in current pad");
      delete [] x;
      delete [] y;
      delete [] z;
      return;
   }
   Double_t thedeg =  90 - gPad->GetTheta();
   Double_t phideg = -90 - gPad->GetPhi();
   Double_t psideg = view->GetPsi();
   view->SetView(phideg, thedeg, psideg, irep);

   Int_t backcolor = gPad->GetFrameFillColor();
   if (Hoption.System != kCARTESIAN) backcolor = 0;
   view->PadRange(backcolor);

   Double_t dcol = 0.5/Double_t(nbcol);
   TColor *colref = gROOT->GetColor(fH->GetFillColor());
   if (!colref) {
      delete [] x;
      delete [] y;
      delete [] z;
      return;
   }
   Float_t r, g, b, hue, light, satur;
   colref->GetRGB(r,g,b);
   TColor::RGBtoHLS(r,g,b,hue,light,satur);
   TColor *acol;
   for (Int_t col=0;col<nbcol;col++) {
      acol = gROOT->GetColor(col+icol1);
      TColor::HLStoRGB(hue, .4+col*dcol, satur, r, g, b);
      if (acol) acol->SetRGB(r, g, b);
   }

   fLego->InitMoveScreen(-1.1,1.1);

   if (Hoption.BackBox) {
      fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
      fLego->BackBox(90);
   }

   fLego->LightSource(0, ydiff, 0, 0, 0, irep);
   fLego->LightSource(1, yligh1, 1, 1, 1, irep);
   fLego->SurfaceProperty(qa, qd, qs, 1, irep);
   fmin = ydiff*qa;
   fmax = ydiff*qa + (yligh1+0.1)*(qd+qs);
   fLego->SetIsoSurfaceParameters(fmin, fmax, nbcol, ic1, ic2, ic3);

   fLego->IsoSurface(1, s, nx, ny, nz, x, y, z, "BF");

   if (Hoption.FrontBox) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove2);
      fLego->FrontBox(90);
   }
   if (!Hoption.Axis && !Hoption.Same) PaintLegoAxis(axis, 90);

   PaintTitle();

   delete axis;
   delete fLego; fLego = 0;
   delete [] x;
   delete [] y;
   delete [] z;
}


//______________________________________________________________________________
void THistPainter::PaintLego(Option_t *)
{
   /* Begin_html
   <a href="#HP17">Control function to draw a 2D histogram as a lego plot.</a>
   End_html */

   Int_t raster = 1;
   if (Hparam.zmin == 0 && Hparam.zmax == 0) {Hparam.zmin = -1; Hparam.zmax = 1;}
   Int_t   nx      = Hparam.xlast - Hparam.xfirst + 1;
   Int_t   ny      = Hparam.ylast - Hparam.yfirst + 1;
   Double_t zmin   = Hparam.zmin;
   Double_t zmax   = Hparam.zmax;
   Double_t xlab1  = Hparam.xmin;
   Double_t xlab2  = Hparam.xmax;
   Double_t ylab1  = Hparam.ymin;
   Double_t ylab2  = Hparam.ymax;
   Double_t dangle = 10*3.141592/180; //Delta angle for Rapidity option
   Double_t deltaz = TMath::Abs(zmin);
   if (deltaz == 0) deltaz = 1;
   if (zmin >= zmax) {
      zmin -= 0.5*deltaz;
      zmax += 0.5*deltaz;
   }
   Double_t z1c = zmin;
   Double_t z2c = zmin + (zmax-zmin)*(1+gStyle->GetHistTopMargin());

   //     Compute the lego limits and instantiate a lego object
   fXbuf[0] = -1;
   fYbuf[0] =  1;
   fXbuf[1] = -1;
   fYbuf[1] =  1;
   if (Hoption.System == kPOLAR) {
      fXbuf[2] = z1c;
      fYbuf[2] = z2c;
   } else if (Hoption.System == kCYLINDRICAL) {
      if (Hoption.Logy) {
         if (ylab1 > 0) fXbuf[2] = TMath::Log10(ylab1);
         else           fXbuf[2] = 0;
         if (ylab2 > 0) fYbuf[2] = TMath::Log10(ylab2);
         else           fYbuf[2] = 0;
      } else {
         fXbuf[2] = ylab1;
         fYbuf[2] = ylab2;
      }
      z1c = 0; z2c = 1;
   } else if (Hoption.System == kSPHERICAL) {
      fXbuf[2] = -1;
      fYbuf[2] =  1;
      z1c = 0; z2c = 1;
   } else if (Hoption.System == kRAPIDITY) {
      fXbuf[2] = -1/TMath::Tan(dangle);
      fYbuf[2] =  1/TMath::Tan(dangle);
   } else {
      fXbuf[0] = xlab1;
      fYbuf[0] = xlab2;
      fXbuf[1] = ylab1;
      fYbuf[1] = ylab2;
      fXbuf[2] = z1c;
      fYbuf[2] = z2c;
      raster  = 0;
   }

   fLego = new TPainter3dAlgorithms(fXbuf, fYbuf, Hoption.System);

   Int_t nids = -1;
   TH1 * hid = NULL;
   Color_t colormain = -1, colordark = -1;
   Bool_t drawShadowsInLego1 = kTRUE;

   // LEGO3 is like LEGO1 except that the black lines around each lego are not drawn.
   if (Hoption.Lego == 13) {
      Hoption.Lego = 11;
      fLego->SetMesh(0);
   }
   // LEGO4 is like LEGO1 except no shadows are drawn.
   if (Hoption.Lego == 14) {
      Hoption.Lego = 11;
      drawShadowsInLego1 = kFALSE;
   }

   //          Create axis object

   TGaxis *axis = new TGaxis();

   //                  Initialize the levels on the Z axis
   Int_t ndiv   = fH->GetContour();
   if (ndiv == 0 ) {
      ndiv = gStyle->GetNumberContours();
      fH->SetContour(ndiv);
   }
   Int_t ndivz  = TMath::Abs(ndiv);
   if (fH->TestBit(TH1::kUserContour) == 0) fH->SetContour(ndiv);

   //     Initialize colors
   if (!fStack) {
      fLego->SetEdgeAtt(fH->GetLineColor(),fH->GetLineStyle(),fH->GetLineWidth(),0);
   } else {
      for (Int_t id=0;id<=fStack->GetSize();id++) {
         hid = (TH1*)fStack->At((id==0)?id:id-1);
         fLego->SetEdgeAtt(hid->GetLineColor(),hid->GetLineStyle(),hid->GetLineWidth(),id);
      }
   }

   if (Hoption.Lego == 11) {
      nids = 1;
      if (fStack) nids = fStack->GetSize();
      hid = fH;
      for (Int_t id=0;id<=nids;id++) {
         if (id > 0 && fStack) hid = (TH1*)fStack->At(id-1);
         colormain = hid->GetFillColor();
         if (colormain == 1) colormain = 17; //avoid drawing with black
         if (drawShadowsInLego1) colordark = TColor::GetColorDark(colormain);
         else                    colordark = colormain;
         fLego->SetColorMain(colormain,id);
         fLego->SetColorDark(colordark,id);
         if (id <= 1)    fLego->SetColorMain(colormain,-1);  // Set Bottom color
         if (id == nids) fLego->SetColorMain(colormain,99);  // Set Top color
      }
   }

   //     Now ready to draw the lego plot
   Int_t irep = 0;

   TView *view = gPad->GetView();
   if (!view) {
      Error("PaintLego", "no TView in current pad");
      return;
   }

   Double_t thedeg =  90 - gPad->GetTheta();
   Double_t phideg = -90 - gPad->GetPhi();
   Double_t psideg = view->GetPsi();
   view->SetView(phideg, thedeg, psideg, irep);

   fLego->SetLineColor(kBlack);  /// zgrid color for lego1 & lego2
   fLego->SetFillStyle(fH->GetFillStyle());

   //     Set color/style for back box
   fLego->SetFillStyle(gPad->GetFrameFillStyle());
   fLego->SetFillColor(gPad->GetFrameFillColor());
   fLego->TAttFill::Modify();

   Int_t backcolor = gPad->GetFrameFillColor();
   if (Hoption.System != kCARTESIAN) backcolor = 0;
   view->PadRange(backcolor);

   fLego->SetFillStyle(fH->GetFillStyle());
   fLego->SetFillColor(fH->GetFillColor());
   fLego->TAttFill::Modify();

   fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);

   if (raster) fLego->InitRaster(-1.1,-1.1,1.1,1.1,1000,800);
   else        fLego->InitMoveScreen(-1.1,1.1);

   if (Hoption.Lego == 11 || Hoption.Lego == 12) {
      if (Hoption.System == kCARTESIAN && Hoption.BackBox) {
         fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
         fLego->BackBox(90);
      }
   }

   if (Hoption.Lego == 12) DefineColorLevels(ndivz);

   fLego->SetLegoFunction(&TPainter3dAlgorithms::LegoFunction);
   if (Hoption.Lego ==  1) fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceRaster2);
   if (Hoption.Lego == 11) fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMode3);
   if (Hoption.Lego == 12) fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMode2);
   if (Hoption.System == kPOLAR) {
      if (Hoption.Lego ==  1) fLego->LegoPolar(1,nx,ny,"FB");
      if (Hoption.Lego == 11) fLego->LegoPolar(1,nx,ny,"BF");
      if (Hoption.Lego == 12) fLego->LegoPolar(1,nx,ny,"BF");
   } else if (Hoption.System == kCYLINDRICAL) {
      if (Hoption.Lego ==  1) fLego->LegoCylindrical(1,nx,ny,"FB");
      if (Hoption.Lego == 11) fLego->LegoCylindrical(1,nx,ny,"BF");
      if (Hoption.Lego == 12) fLego->LegoCylindrical(1,nx,ny,"BF");
   } else if (Hoption.System == kSPHERICAL) {
      if (Hoption.Lego ==  1) fLego->LegoSpherical(0,1,nx,ny,"FB");
      if (Hoption.Lego == 11) fLego->LegoSpherical(0,1,nx,ny,"BF");
      if (Hoption.Lego == 12) fLego->LegoSpherical(0,1,nx,ny,"BF");
   } else if (Hoption.System == kRAPIDITY) {
      if (Hoption.Lego ==  1) fLego->LegoSpherical(1,1,nx,ny,"FB");
      if (Hoption.Lego == 11) fLego->LegoSpherical(1,1,nx,ny,"BF");
      if (Hoption.Lego == 12) fLego->LegoSpherical(1,1,nx,ny,"BF");
   } else {
      if (Hoption.Lego ==  1) {
                              fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove2);
                              fLego->LegoCartesian(90,nx,ny,"FB");}
      if (Hoption.Lego == 11) fLego->LegoCartesian(90,nx,ny,"BF");
      if (Hoption.Lego == 12) fLego->LegoCartesian(90,nx,ny,"BF");
   }

   if (Hoption.Lego == 1 || Hoption.Lego == 11) {
      if (Hoption.System == kCARTESIAN && Hoption.BackBox) {
         fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
         fLego->BackBox(90);
      }
   }
   if (Hoption.System == kCARTESIAN) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove2);
      if (Hoption.FrontBox) fLego->FrontBox(90);
   }
   if (!Hoption.Axis && !Hoption.Same) PaintLegoAxis(axis, 90);
   if (Hoption.Zscale) PaintPalette();
   delete axis;
   delete fLego; fLego = 0;
}


//______________________________________________________________________________
void THistPainter::PaintLegoAxis(TGaxis *axis, Double_t ang)
{
   /* Begin_html
   Draw the axis for legos and surface plots.
   End_html */

   static Double_t epsil = 0.001;

   Double_t cosa, sina;
   Double_t bmin, bmax;
   Double_t r[24]        /* was [3][8] */;
   Int_t ndivx, ndivy, ndivz, i;
   Double_t x1[3], x2[3], y1[3], y2[3], z1[3], z2[3], av[24]  /*  was [3][8] */;
   static char chopax[8], chopay[8], chopaz[8];
   Int_t ix1, ix2, iy1, iy2, iz1, iz2;
   Double_t rad;

   TView *view = gPad->GetView();
   if (!view) {
      Error("PaintLegoAxis", "no TView in current pad");
      return;
   }

   // In polar coordinates, draw a short line going from the external circle
   // corresponding to r = 1 up to r = 1.1
   if (Hoption.System == kPOLAR) {
      r[0] = 1;
      r[1] = 0;
      r[2] = 0;
      view->WCtoNDC(r, x1);
      r[0] = 1.1;
      r[1] = 0;
      r[2] = 0;
      view->WCtoNDC(r, x2);
      gPad->PaintLine(x1[0],x1[1],x2[0],x2[1]);
      return;
   }

   if (Hoption.System != kCARTESIAN) return;

   rad = TMath::ATan(1.) * 4. /180.;
   cosa = TMath::Cos(ang*rad);
   sina = TMath::Sin(ang*rad);

   view->AxisVertex(ang, av, ix1, ix2, iy1, iy2, iz1, iz2);
   for (i = 1; i <= 8; ++i) {
      r[i*3 - 3] = av[i*3 - 3] + av[i*3 - 2]*cosa;
      r[i*3 - 2] = av[i*3 - 2]*sina;
      r[i*3 - 1] = av[i*3 - 1];
   }

   view->WCtoNDC(&r[ix1*3 - 3], x1);
   view->WCtoNDC(&r[ix2*3 - 3], x2);
   view->WCtoNDC(&r[iy1*3 - 3], y1);
   view->WCtoNDC(&r[iy2*3 - 3], y2);
   view->WCtoNDC(&r[iz1*3 - 3], z1);
   view->WCtoNDC(&r[iz2*3 - 3], z2);

   view->SetAxisNDC(x1, x2, y1, y2, z1, z2);

   Double_t *rmin = view->GetRmin();
   Double_t *rmax = view->GetRmax();
   if (!rmin || !rmax) return;

   // Initialize the axis options
   if (x1[0] > x2[0]) strlcpy(chopax, "SDH=+",8);
   else               strlcpy(chopax, "SDH=-",8);
   if (y1[0] > y2[0]) strlcpy(chopay, "SDH=+",8);
   else               strlcpy(chopay, "SDH=-",8);
   strlcpy(chopaz, "SDH+=",8);

   // Option LOG is required ?
   // coverity [Calling risky function]
   if (Hoption.Logx) strlcat(chopax,"G",8);
   // coverity [Calling risky function]
   if (Hoption.Logy) strlcat(chopay,"G",8);
   // coverity [Calling risky function]
   if (Hoption.Logz) strlcat(chopaz,"G",8);

   // Initialize the number of divisions. If the
   // number of divisions is negative, option 'N' is required.
   ndivx = fXaxis->GetNdivisions();
   ndivy = fYaxis->GetNdivisions();
   ndivz = fZaxis->GetNdivisions();
   if (ndivx < 0) {
      ndivx = TMath::Abs(ndivx);
      // coverity [Calling risky function]
      strlcat(chopax, "N",8);
   }
   if (ndivy < 0) {
      ndivy = TMath::Abs(ndivy);
      // coverity [Calling risky function]
      strlcat(chopay, "N",8);
   }
   if (ndivz < 0) {
      ndivz = TMath::Abs(ndivz);
      // coverity [Calling risky function]
      strlcat(chopaz, "N",8);
   }

   // Set Axis attributes.
   // The variable SCALE  rescales the VSIZ
   // in order to have the same label size for all angles.

   axis->SetLineWidth(1);

   // X axis drawing
   if (TMath::Abs(x1[0] - x2[0]) >= epsil || TMath::Abs(x1[1] - x2[1]) > epsil) {
      axis->ImportAxisAttributes(fXaxis);
      axis->SetLabelOffset(fXaxis->GetLabelOffset()+fXaxis->GetTickLength());
      if (Hoption.Logx && !fH->InheritsFrom(TH3::Class())) {
         bmin = TMath::Power(10, rmin[0]);
         bmax = TMath::Power(10, rmax[0]);
      } else {
         bmin = rmin[0];
         bmax = rmax[0];
      }
      // Option time display is required ?
      if (fXaxis->GetTimeDisplay()) {
         // coverity [Calling risky function]
         strlcat(chopax,"t",8);
         if (strlen(fXaxis->GetTimeFormatOnly()) == 0) {
            axis->SetTimeFormat(fXaxis->ChooseTimeFormat(bmax-bmin));
         } else {
            axis->SetTimeFormat(fXaxis->GetTimeFormat());
         }
      }
      axis->SetOption(chopax);
      axis->PaintAxis(x1[0], x1[1], x2[0], x2[1], bmin, bmax, ndivx, chopax);
   }

   // Y axis drawing
   if (TMath::Abs(y1[0] - y2[0]) >= epsil || TMath::Abs(y1[1] - y2[1]) > epsil) {
      axis->ImportAxisAttributes(fYaxis);
      axis->SetLabelOffset(fYaxis->GetLabelOffset()+fYaxis->GetTickLength());

      if (fH->GetDimension() < 2) {
         strlcpy(chopay, "V=+UN",8);
         ndivy = 0;
      }
      if (TMath::Abs(y1[0] - y2[0]) < epsil) {
         y2[0] = y1[0];
      }
      if (Hoption.Logy && !fH->InheritsFrom(TH3::Class())) {
         bmin = TMath::Power(10, rmin[1]);
         bmax = TMath::Power(10, rmax[1]);
      } else {
         bmin = rmin[1];
         bmax = rmax[1];
      }
      // Option time display is required ?
      if (fYaxis->GetTimeDisplay()) {
         // coverity [Calling risky function]
         strlcat(chopay,"t",8);
         if (strlen(fYaxis->GetTimeFormatOnly()) == 0) {
            axis->SetTimeFormat(fYaxis->ChooseTimeFormat(bmax-bmin));
         } else {
            axis->SetTimeFormat(fYaxis->GetTimeFormat());
         }
      }
      axis->SetOption(chopay);
      axis->PaintAxis(y1[0], y1[1], y2[0], y2[1], bmin, bmax, ndivy, chopay);
   }

   // Z axis drawing
   if (TMath::Abs(z1[0] - z2[0]) >= 100*epsil || TMath::Abs(z1[1] - z2[1]) > 100*epsil) {
      axis->ImportAxisAttributes(fZaxis);
      if (Hoption.Logz && !fH->InheritsFrom(TH3::Class())) {
         bmin = TMath::Power(10, rmin[2]);
         bmax = TMath::Power(10, rmax[2]);
      } else {
         bmin = rmin[2];
         bmax = rmax[2];
      }
      // Option time display is required ?
      if (fZaxis->GetTimeDisplay()) {
         // coverity [Calling risky function]
         strlcat(chopaz,"t",8);
         if (strlen(fZaxis->GetTimeFormatOnly()) == 0) {
            axis->SetTimeFormat(fZaxis->ChooseTimeFormat(bmax-bmin));
         } else {
            axis->SetTimeFormat(fZaxis->GetTimeFormat());
         }
      }
      axis->SetOption(chopaz);
      axis->PaintAxis(z1[0], z1[1], z2[0], z2[1], bmin, bmax, ndivz, chopaz);
   }

   //fH->SetLineStyle(1);  /// otherwise fEdgeStyle[i] gets overwritten!
}


//______________________________________________________________________________
void THistPainter::PaintPalette()
{
   /* Begin_html
   <a href="#HP22">Paint the color palette on the right side of the pad.</a>
   End_html */

   TPaletteAxis *palette = (TPaletteAxis*)fFunctions->FindObject("palette");
   TView *view = gPad->GetView();
   if (palette) {
      if (view) {
         if (!palette->TestBit(TPaletteAxis::kHasView)) {
            fFunctions->Remove(palette);
            delete palette; palette = 0;
         }
      } else {
         if (palette->TestBit(TPaletteAxis::kHasView)) {
            fFunctions->Remove(palette);
            delete palette; palette = 0;
         }
      }
   }

   if (!palette) {
      Double_t xup  = gPad->GetUxmax();
      Double_t x2   = gPad->PadtoX(gPad->GetX2());
      Double_t ymin = gPad->PadtoY(gPad->GetUymin());
      Double_t ymax = gPad->PadtoY(gPad->GetUymax());
      Double_t xr   = 0.05*(gPad->GetX2() - gPad->GetX1());
      Double_t xmin = gPad->PadtoX(xup +0.1*xr);
      Double_t xmax = gPad->PadtoX(xup + xr);
      if (xmax > x2) xmax = gPad->PadtoX(gPad->GetX2()-0.01*xr);
      palette = new TPaletteAxis(xmin,ymin,xmax,ymax,fH);
      fFunctions->AddFirst(palette);
      palette->Paint();
   }
}


//______________________________________________________________________________
void THistPainter::PaintScatterPlot(Option_t *option)
{
   /* Begin_html
   <a href="#HP11">Control function to draw a 2D histogram as a scatter plot.</a>
   End_html */

   fH->TAttMarker::Modify();

   Int_t k, marker;
   Double_t dz, z, xk,xstep, yk, ystep;
   Double_t scale = 1;
   Bool_t ltest  = kFALSE;
   Double_t zmax  = fH->GetMaximum();
   Double_t zmin  = fH->GetMinimum();
   if (zmin == 0 && zmax == 0) return;
   if (zmin == zmax) {
      zmax += 0.1*TMath::Abs(zmax);
      zmin -= 0.1*TMath::Abs(zmin);
   }
   Int_t ncells = (Hparam.ylast-Hparam.yfirst)*(Hparam.xlast-Hparam.xfirst);
   if (Hoption.Logz) {
      if (zmin > 0) zmin = TMath::Log10(zmin);
      else          zmin = 0;
      if (zmax > 0) zmax = TMath::Log10(zmax);
      else          zmax = 0;
      if (zmin == 0 && zmax == 0) return;
      dz = zmax - zmin;
      scale = 100/dz;
      if (ncells > 10000) scale /= 5;
      ltest = kTRUE;
   } else {
      dz = zmax - zmin;
      if (dz >= kNMAX || zmax < 1) {
         scale = (kNMAX-1)/dz;
         if (ncells > 10000) scale /= 5;
         ltest = kTRUE;
      }
   }
   if (fH->GetMinimumStored() == -1111) {
      Double_t yMARGIN = gStyle->GetHistTopMargin();
      if (gStyle->GetHistMinimumZero()) {
         if (zmin >= 0) zmin = 0;
         else           zmin -= yMARGIN*(zmax-zmin);
      } else {
         Double_t dzmin = yMARGIN*(zmax-zmin);
         if (zmin >= 0 && (zmin-dzmin <= 0)) zmin  = 0;
         else                                zmin -= dzmin;
      }
   }

   TString opt = option;
   opt.ToLower();
   if (opt.Contains("scat=")) {
      char optscat[100];
      strlcpy(optscat,opt.Data(),100);
      char *oscat = strstr(optscat,"scat=");
      char *blank = strstr(oscat," "); if (blank) *blank = 0;
      sscanf(oscat+5,"%lg",&scale);
   }
   // use an independent instance of a random generator
   // instead of gRandom to avoid conflicts and
   // to get same random numbers when drawing the same histogram
   TRandom2 random;
   marker=0;
   for (Int_t j=Hparam.yfirst; j<=Hparam.ylast;j++) {
      yk    = fYaxis->GetBinLowEdge(j);
      ystep = fYaxis->GetBinWidth(j);
      for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
         Int_t bin  = j*(fXaxis->GetNbins()+2) + i;
         xk    = fXaxis->GetBinLowEdge(i);
         xstep = fXaxis->GetBinWidth(i);
         if (!IsInside(xk+0.5*xstep,yk+0.5*ystep)) continue;
         z     = fH->GetBinContent(bin);
         if (z < zmin) z = zmin;
         if (z > zmax) z = zmax;
         if (Hoption.Logz) {
            if (z > 0) z = TMath::Log10(z) - zmin;
         } else {
            z    -=  zmin;
         }
         if (z <= 0) continue;
         k = Int_t(z*scale);
         if (ltest) k++;
         if (k > 0) {
            for (Int_t loop=0; loop<k; loop++) {
               if (k+marker >= kNMAX) {
                  gPad->PaintPolyMarker(marker, fXbuf, fYbuf);
                  marker=0;
               }
               fXbuf[marker] = (random.Rndm(loop)*xstep) + xk;
               fYbuf[marker] = (random.Rndm(loop)*ystep) + yk;
               if (Hoption.Logx) {
                  if (fXbuf[marker] > 0) fXbuf[marker] = TMath::Log10(fXbuf[marker]);
                  else                   break;
               }
               if (Hoption.Logy) {
                  if (fYbuf[marker] > 0) fYbuf[marker] = TMath::Log10(fYbuf[marker]);
                  else                  break;
               }
               if (fXbuf[marker] < gPad->GetUxmin()) break;
               if (fYbuf[marker] < gPad->GetUymin()) break;
               if (fXbuf[marker] > gPad->GetUxmax()) break;
               if (fYbuf[marker] > gPad->GetUymax()) break;
               marker++;
            }
         }
      }
   }
   if (marker > 0) gPad->PaintPolyMarker(marker, fXbuf, fYbuf);

   if (Hoption.Zscale) PaintPalette();
}


//______________________________________________________________________________
void THistPainter::PaintSpecialObjects(const TObject *obj, Option_t *option)
{
   /* Begin_html
   Static function to paint special objects like vectors and matrices.
   This function is called via gROOT->ProcessLine to paint these objects
   without having a direct dependency of the graphics or histogramming
   system.
   End_html */

   if (!obj) return;
   Bool_t status = TH1::AddDirectoryStatus();
   TH1::AddDirectory(kFALSE);

   if (obj->InheritsFrom(TMatrixFBase::Class())) {
      // case TMatrixF
      TH2F *R__TMatrixFBase = new TH2F((TMatrixFBase &)*obj);
      R__TMatrixFBase->SetBit(kCanDelete);
      R__TMatrixFBase->Draw(option);

   } else if (obj->InheritsFrom(TMatrixDBase::Class())) {
      // case TMatrixD
      TH2D *R__TMatrixDBase = new TH2D((TMatrixDBase &)*obj);
      R__TMatrixDBase->SetBit(kCanDelete);
      R__TMatrixDBase->Draw(option);

   } else if (obj->InheritsFrom(TVectorF::Class())) {
      //case TVectorF
      TH1F *R__TVectorF = new TH1F((TVectorF &)*obj);
      R__TVectorF->SetBit(kCanDelete);
      R__TVectorF->Draw(option);

   } else if (obj->InheritsFrom(TVectorD::Class())) {
      //case TVectorD
      TH1D *R__TVectorD = new TH1D((TVectorD &)*obj);
      R__TVectorD->SetBit(kCanDelete);
      R__TVectorD->Draw(option);
   }

   TH1::AddDirectory(status);
}


//______________________________________________________________________________
void THistPainter::PaintStat(Int_t dostat, TF1 *fit)
{
   /* Begin_html
   <a href="#HP07">Draw the statistics box for 1D and profile histograms.</a>
   End_html */

   static char t[100];
   Int_t dofit;
   TPaveStats *stats  = 0;
   TIter next(fFunctions);
   TObject *obj;
   while ((obj = next())) {
      if (obj->InheritsFrom(TPaveStats::Class())) {
         stats = (TPaveStats*)obj;
         break;
      }
   }

   if (stats && dostat) {
      dofit  = stats->GetOptFit();
      dostat = stats->GetOptStat();
   } else {
      dofit  = gStyle->GetOptFit();
   }
   if (!dofit) fit = 0;
   if (dofit  == 1) dofit  =  111;
   if (dostat == 1) dostat = 1111;
   Int_t print_name    = dostat%10;
   Int_t print_entries = (dostat/10)%10;
   Int_t print_mean    = (dostat/100)%10;
   Int_t print_rms     = (dostat/1000)%10;
   Int_t print_under   = (dostat/10000)%10;
   Int_t print_over    = (dostat/100000)%10;
   Int_t print_integral= (dostat/1000000)%10;
   Int_t print_skew    = (dostat/10000000)%10;
   Int_t print_kurt    = (dostat/100000000)%10;
   Int_t nlines = print_name + print_entries + print_mean + print_rms +
                  print_under + print_over + print_integral +
                  print_skew + print_kurt;
   Int_t print_fval    = dofit%10;
   Int_t print_ferrors = (dofit/10)%10;
   Int_t print_fchi2   = (dofit/100)%10;
   Int_t print_fprob   = (dofit/1000)%10;
   Int_t nlinesf = print_fval + print_fchi2 + print_fprob;
   if (fit) {
      if (print_fval < 2) nlinesf += fit->GetNumberFreeParameters();
      else                nlinesf += fit->GetNpar();
   }
   if (fH->InheritsFrom(TProfile::Class())) nlinesf += print_mean + print_rms;

   // Pavetext with statistics
   Bool_t done = kFALSE;
   if (!dostat && !fit) {
      if (stats) { fFunctions->Remove(stats); delete stats;}
      return;
   }
   Double_t  statw  = gStyle->GetStatW();
   if (fit) statw   = 1.8*gStyle->GetStatW();
   Double_t  stath  = (nlines+nlinesf)*gStyle->GetStatFontSize();
   if (stath <= 0 || 3 == (gStyle->GetStatFont()%10)) {
      stath = 0.25*(nlines+nlinesf)*gStyle->GetStatH();
   }
   if (stats) {
      stats->Clear();
      done = kTRUE;
   } else {
      stats  = new TPaveStats(
               gStyle->GetStatX()-statw,
               gStyle->GetStatY()-stath,
               gStyle->GetStatX(),
               gStyle->GetStatY(),"brNDC");

      stats->SetParent(fH);
      stats->SetOptFit(dofit);
      stats->SetOptStat(dostat);
      stats->SetFillColor(gStyle->GetStatColor());
      stats->SetFillStyle(gStyle->GetStatStyle());
      stats->SetBorderSize(gStyle->GetStatBorderSize());
      stats->SetTextFont(gStyle->GetStatFont());
      if (gStyle->GetStatFont()%10 > 2)
         stats->SetTextSize(gStyle->GetStatFontSize());
      stats->SetFitFormat(gStyle->GetFitFormat());
      stats->SetStatFormat(gStyle->GetStatFormat());
      stats->SetName("stats");

      stats->SetTextColor(gStyle->GetStatTextColor());
      stats->SetTextAlign(12);
      stats->SetBit(kCanDelete);
      stats->SetBit(kMustCleanup);
   }
   if (print_name)  stats->AddText(fH->GetName());
   if (print_entries) {
      if (fH->GetEntries() < 1e7) snprintf(t,100,"%s = %-7d",gStringEntries.Data(),Int_t(fH->GetEntries()+0.5));
      else                        snprintf(t,100,"%s = %14.7g",gStringEntries.Data(),Float_t(fH->GetEntries()));
      stats->AddText(t);
   }
   char textstats[50];
   if (print_mean) {
      if (print_mean == 1) {
         snprintf(textstats,50,"%s  = %s%s",gStringMean.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetMean(1));
      } else {
         snprintf(textstats,50,"%s  = %s%s #pm %s%s",gStringMean.Data(),"%",stats->GetStatFormat()
                                                  ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetMean(1),fH->GetMeanError(1));
      }
      stats->AddText(t);
      if (fH->InheritsFrom(TProfile::Class())) {
         if (print_mean == 1) {
            snprintf(textstats,50,"%s = %s%s",gStringMeanY.Data(),"%",stats->GetStatFormat());
            snprintf(t,100,textstats,fH->GetMean(2));
         } else {
            snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringMeanY.Data(),"%",stats->GetStatFormat()
                                                      ,"%",stats->GetStatFormat());
            snprintf(t,100,textstats,fH->GetMean(2),fH->GetMeanError(2));
         }
         stats->AddText(t);
      }
   }
   if (print_rms) {
      if (print_rms == 1) {
         snprintf(textstats,50,"%s   = %s%s",gStringRMS.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetRMS(1));
      } else {
         snprintf(textstats,50,"%s   = %s%s #pm %s%s",gStringRMS.Data(),"%",stats->GetStatFormat()
                                                  ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetRMS(1),fH->GetRMSError(1));
      }
      stats->AddText(t);
      if (fH->InheritsFrom(TProfile::Class())) {
         if (print_rms == 1) {
            snprintf(textstats,50,"%s = %s%s",gStringRMSY.Data(),"%",stats->GetStatFormat());
            snprintf(t,100,textstats,fH->GetRMS(2));
         } else {
            snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringRMSY.Data(),"%",stats->GetStatFormat()
                                                     ,"%",stats->GetStatFormat());
            snprintf(t,100,textstats,fH->GetRMS(2),fH->GetRMSError(2));
         }
         stats->AddText(t);
      }
   }
   if (print_under) {
      snprintf(textstats,50,"%s = %s%s",gStringUnderflow.Data(),"%",stats->GetStatFormat());
      snprintf(t,100,textstats,fH->GetBinContent(0));
      stats->AddText(t);
   }
   if (print_over) {
      snprintf(textstats,50,"%s  = %s%s",gStringOverflow.Data(),"%",stats->GetStatFormat());
      snprintf(t,100,textstats,fH->GetBinContent(fXaxis->GetNbins()+1));
      stats->AddText(t);
   }
   if (print_integral) {
      if (print_integral == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringIntegral.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->Integral());
      } else {
         snprintf(textstats,50,"%s = %s%s",gStringIntegralBinWidth.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->Integral("width"));
      }
      stats->AddText(t);
   }
   if (print_skew) {
      if (print_skew == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringSkewness.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetSkewness(1));
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringSkewness.Data(),"%",stats->GetStatFormat()
                                                     ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetSkewness(1),fH->GetSkewness(11));
      }
      stats->AddText(t);
   }
   if (print_kurt) {
      if (print_kurt == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringKurtosis.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetKurtosis(1));
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringKurtosis.Data(),"%",stats->GetStatFormat()
                                                     ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,fH->GetKurtosis(1),fH->GetKurtosis(11));
      }
      stats->AddText(t);
   }

   // Draw Fit parameters
   if (fit) {
      Int_t ndf = fit->GetNDF();
      snprintf(textstats,50,"#chi^{2} / ndf = %s%s / %d","%",stats->GetFitFormat(),ndf);
      snprintf(t,100,textstats,(Float_t)fit->GetChisquare());
      if (print_fchi2) stats->AddText(t);
      if (print_fprob) {
         snprintf(textstats,50,"Prob  = %s%s","%",stats->GetFitFormat());
         snprintf(t,100,textstats,(Float_t)TMath::Prob(fit->GetChisquare(),ndf));
         stats->AddText(t);
      }
      if (print_fval || print_ferrors) {
         Double_t parmin,parmax;
         Int_t a;
         for (Int_t ipar=0;ipar<fit->GetNpar();ipar++) {
            fit->GetParLimits(ipar,parmin,parmax);
            if (print_fval < 2 && parmin*parmax != 0 && parmin >= parmax) continue;
            snprintf(t,100,"%-8s ",fit->GetParName(ipar));
            a = strlen(t);
            if (a>50) a = 50;
            if (print_ferrors) {
               snprintf(textstats,50,"= %s%s #pm %s ", "%",stats->GetFitFormat(),
                       GetBestFormat(fit->GetParameter(ipar), fit->GetParError(ipar), stats->GetFitFormat()));
               snprintf(&t[a],100,textstats,(Float_t)fit->GetParameter(ipar)
                               ,(Float_t)fit->GetParError(ipar));
            } else {
               snprintf(textstats,50,"= %s%s ","%",stats->GetFitFormat());
               snprintf(&t[a],100,textstats,(Float_t)fit->GetParameter(ipar));
            }
            t[63] = 0;
            stats->AddText(t);
         }
      }
   }

   if (!done) fFunctions->Add(stats);
   stats->Paint();
}


//______________________________________________________________________________
void THistPainter::PaintStat2(Int_t dostat, TF1 *fit)
{
   /* Begin_html
   <a href="#HP07">Draw the statistics box for 2D histograms.</a>
   End_html */

   if (fH->GetDimension() != 2) return;
   TH2 *h2 = (TH2*)fH;

   static char t[100];
   Int_t dofit;
   TPaveStats *stats  = 0;
   TIter next(fFunctions);
   TObject *obj;
   while ((obj = next())) {
      if (obj->InheritsFrom(TPaveStats::Class())) {
         stats = (TPaveStats*)obj;
         break;
      }
   }
   if (stats && dostat) {
      dofit  = stats->GetOptFit();
      dostat = stats->GetOptStat();
   } else {
      dofit  = gStyle->GetOptFit();
   }
   if (dostat == 1) dostat = 1111;
   Int_t print_name    = dostat%10;
   Int_t print_entries = (dostat/10)%10;
   Int_t print_mean    = (dostat/100)%10;
   Int_t print_rms     = (dostat/1000)%10;
   Int_t print_under   = (dostat/10000)%10;
   Int_t print_over    = (dostat/100000)%10;
   Int_t print_integral= (dostat/1000000)%10;
   Int_t print_skew    = (dostat/10000000)%10;
   Int_t print_kurt    = (dostat/100000000)%10;
   Int_t nlines = print_name + print_entries + 2*print_mean + 2*print_rms + print_integral;
   if (print_under || print_over) nlines += 3;

   // Pavetext with statistics
   if (!gStyle->GetOptFit()) fit = 0;
   Bool_t done = kFALSE;
   if (!dostat && !fit) {
      if (stats) { fFunctions->Remove(stats); delete stats;}
      return;
   }
   Double_t  statw  = gStyle->GetStatW();
   if (fit) statw   = 1.8*gStyle->GetStatW();
   Double_t  stath  = nlines*gStyle->GetStatFontSize();
   if (stath <= 0 || 3 == (gStyle->GetStatFont()%10)) {
      stath = 0.25*nlines*gStyle->GetStatH();
   }
   if (fit) stath += gStyle->GetStatH();
   if (stats) {
      stats->Clear();
      done = kTRUE;
   } else {
      stats  = new TPaveStats(
               gStyle->GetStatX()-statw,
               gStyle->GetStatY()-stath,
               gStyle->GetStatX(),
               gStyle->GetStatY(),"brNDC");

      stats->SetParent(fH);
      stats->SetOptFit(dofit);
      stats->SetOptStat(dostat);
      stats->SetFillColor(gStyle->GetStatColor());
      stats->SetFillStyle(gStyle->GetStatStyle());
      stats->SetBorderSize(gStyle->GetStatBorderSize());
      stats->SetName("stats");

      stats->SetTextColor(gStyle->GetStatTextColor());
      stats->SetTextAlign(12);
      stats->SetTextFont(gStyle->GetStatFont());
      if (gStyle->GetStatFont()%10 > 2)
         stats->SetTextSize(gStyle->GetStatFontSize());
      stats->SetFitFormat(gStyle->GetFitFormat());
      stats->SetStatFormat(gStyle->GetStatFormat());
      stats->SetBit(kCanDelete);
      stats->SetBit(kMustCleanup);
   }
   if (print_name)  stats->AddText(h2->GetName());
   if (print_entries) {
      if (h2->GetEntries() < 1e7) snprintf(t,100,"%s = %-7d",gStringEntries.Data(),Int_t(h2->GetEntries()+0.5));
      else                        snprintf(t,100,"%s = %14.7g",gStringEntries.Data(),Float_t(h2->GetEntries()));
      stats->AddText(t);
   }
   char textstats[50];
   if (print_mean) {
      if (print_mean == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringMeanX.Data(),"%",stats->GetStatFormat());
         snprintf(t,50,textstats,h2->GetMean(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringMeanY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetMean(2));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringMeanX.Data(),"%",stats->GetStatFormat()
                                                   ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetMean(1),h2->GetMeanError(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringMeanY.Data(),"%",stats->GetStatFormat()
                                                   ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetMean(2),h2->GetMeanError(2));
         stats->AddText(t);
      }
   }
   if (print_rms) {
      if (print_rms == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringRMSX.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetRMS(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringRMSY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetRMS(2));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringRMSX.Data(),"%",stats->GetStatFormat()
                                                  ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetRMS(1),h2->GetRMSError(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringRMSY.Data(),"%",stats->GetStatFormat()
                                                  ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetRMS(2),h2->GetRMSError(2));
         stats->AddText(t);
      }
   }
   if (print_integral) {
      snprintf(t,100,"%s  = %6.4g",gStringIntegral.Data(),h2->Integral());
      stats->AddText(t);
   }
   if (print_skew) {
      if (print_skew == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringSkewnessX.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetSkewness(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringSkewnessY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetSkewness(2));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringSkewnessX.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetSkewness(1),h2->GetSkewness(11));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringSkewnessY.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetSkewness(2),h2->GetSkewness(12));
         stats->AddText(t);
      }
   }
   if (print_kurt) {
      if (print_kurt == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringKurtosisX.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetKurtosis(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringKurtosisY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetKurtosis(2));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringKurtosisX.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetKurtosis(1),h2->GetKurtosis(11));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringKurtosisY.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h2->GetKurtosis(2),h2->GetKurtosis(12));
         stats->AddText(t);
      }
   }
   if (print_under || print_over) {
      //get 3*3 under/overflows for 2d hist
      Double_t unov[9];

      Int_t cellsX = h2->GetXaxis()->GetNbins() + 1;
      Int_t cellsY = h2->GetYaxis()->GetNbins() + 1;
      Int_t firstX = std::max(1, h2->GetXaxis()->GetFirst());
      Int_t firstY = std::max(1, h2->GetYaxis()->GetFirst());
      Int_t lastX  = std::min(h2->GetXaxis()->GetLast(), h2->GetXaxis()->GetNbins());
      Int_t lastY  = std::min(h2->GetYaxis()->GetLast(), h2->GetYaxis()->GetNbins());

      unov[0] = h2->Integral(      0, firstX-1, lastY+1, cellsY  );
      unov[1] = h2->Integral(firstX , lastX   , lastY+1, cellsY  );
      unov[2] = h2->Integral(lastX+1, cellsX  , lastY+1, cellsY  );
      unov[3] = h2->Integral(      0, firstX-1, firstY , lastY   );
      unov[4] = h2->Integral(firstX , lastX   , firstY , lastY   );
      unov[5] = h2->Integral(lastX+1, cellsX  , firstY , lastY   );
      unov[6] = h2->Integral(      0, firstX-1,       0, firstY-1);
      unov[7] = h2->Integral(firstX, lastX,           0, firstY-1);
      unov[8] = h2->Integral(lastX+1, cellsX  ,       0, firstY-1);

      snprintf(t, 100," %7d|%7d|%7d\n", (Int_t)unov[0], (Int_t)unov[1], (Int_t)unov[2]);
      stats->AddText(t);
      if (h2->GetEntries() < 1e7)
         snprintf(t, 100," %7d|%7d|%7d\n", (Int_t)unov[3], (Int_t)unov[4], (Int_t)unov[5]);
      else
         snprintf(t, 100," %7d|%14.7g|%7d\n", (Int_t)unov[3], (Float_t)unov[4], (Int_t)unov[5]);
      stats->AddText(t);
      snprintf(t, 100," %7d|%7d|%7d\n", (Int_t)unov[6], (Int_t)unov[7], (Int_t)unov[8]);
      stats->AddText(t);
   }

   // Draw Fit parameters
   if (fit) {
      Int_t ndf = fit->GetNDF();
      snprintf(t,100,"#chi^{2} / ndf = %6.4g / %d",(Float_t)fit->GetChisquare(),ndf);
      stats->AddText(t);
      for (Int_t ipar=0;ipar<fit->GetNpar();ipar++) {
         snprintf(t,100,"%-8s = %5.4g #pm %5.4g ",fit->GetParName(ipar)
                                   ,(Float_t)fit->GetParameter(ipar)
                                   ,(Float_t)fit->GetParError(ipar));
         t[63] = 0;
         stats->AddText(t);
      }
   }

   if (!done) fFunctions->Add(stats);
   stats->Paint();
}


//______________________________________________________________________________
void THistPainter::PaintStat3(Int_t dostat, TF1 *fit)
{
   /* Begin_html
   <a href="#HP07">Draw the statistics box for 3D histograms.</a>
   End_html */

   if (fH->GetDimension() != 3) return;
   TH3 *h3 = (TH3*)fH;

   static char t[100];
   Int_t dofit;
   TPaveStats *stats  = 0;
   TIter next(fFunctions);
   TObject *obj;
   while ((obj = next())) {
      if (obj->InheritsFrom(TPaveStats::Class())) {
         stats = (TPaveStats*)obj;
         break;
      }
   }
   if (stats && dostat) {
      dofit  = stats->GetOptFit();
      dostat = stats->GetOptStat();
   } else {
      dofit  = gStyle->GetOptFit();
   }
   if (dostat == 1) dostat = 1111;
   Int_t print_name    = dostat%10;
   Int_t print_entries = (dostat/10)%10;
   Int_t print_mean    = (dostat/100)%10;
   Int_t print_rms     = (dostat/1000)%10;
   Int_t print_under   = (dostat/10000)%10;
   Int_t print_over    = (dostat/100000)%10;
   Int_t print_integral= (dostat/1000000)%10;
   Int_t print_skew    = (dostat/10000000)%10;
   Int_t print_kurt    = (dostat/100000000)%10;
   Int_t nlines = print_name + print_entries + 3*print_mean + 3*print_rms + print_integral;
   if (print_under || print_over) nlines += 3;

   // Pavetext with statistics
   if (!gStyle->GetOptFit()) fit = 0;
   Bool_t done = kFALSE;
   if (!dostat && !fit) {
      if (stats) { fFunctions->Remove(stats); delete stats;}
      return;
   }
   Double_t  statw  = gStyle->GetStatW();
   if (fit) statw   = 1.8*gStyle->GetStatW();
   Double_t  stath  = nlines*gStyle->GetStatFontSize();
   if (stath <= 0 || 3 == (gStyle->GetStatFont()%10)) {
      stath = 0.25*nlines*gStyle->GetStatH();
   }
   if (fit) stath += gStyle->GetStatH();
   if (stats) {
      stats->Clear();
      done = kTRUE;
   } else {
      stats  = new TPaveStats(
               gStyle->GetStatX()-statw,
               gStyle->GetStatY()-stath,
               gStyle->GetStatX(),
               gStyle->GetStatY(),"brNDC");

      stats->SetParent(fH);
      stats->SetOptFit(dofit);
      stats->SetOptStat(dostat);
      stats->SetFillColor(gStyle->GetStatColor());
      stats->SetFillStyle(gStyle->GetStatStyle());
      stats->SetBorderSize(gStyle->GetStatBorderSize());
      stats->SetName("stats");

      stats->SetTextColor(gStyle->GetStatTextColor());
      stats->SetTextAlign(12);
      stats->SetTextFont(gStyle->GetStatFont());
      stats->SetFitFormat(gStyle->GetFitFormat());
      stats->SetStatFormat(gStyle->GetStatFormat());
      stats->SetBit(kCanDelete);
      stats->SetBit(kMustCleanup);
   }
   if (print_name)  stats->AddText(h3->GetName());
   if (print_entries) {
      if (h3->GetEntries() < 1e7) snprintf(t,100,"%s = %-7d",gStringEntries.Data(),Int_t(h3->GetEntries()+0.5));
      else                        snprintf(t,100,"%s = %14.7g",gStringEntries.Data(),Float_t(h3->GetEntries()+0.5));
      stats->AddText(t);
   }
   char textstats[50];
   if (print_mean) {
      if (print_mean == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringMeanX.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetMean(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringMeanY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetMean(2));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringMeanZ.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetMean(3));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringMeanX.Data(),"%",stats->GetStatFormat()
                                                   ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetMean(1),h3->GetMeanError(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringMeanY.Data(),"%",stats->GetStatFormat()
                                                   ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetMean(2),h3->GetMeanError(2));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringMeanZ.Data(),"%",stats->GetStatFormat()
                                                   ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetMean(3),h3->GetMeanError(3));
         stats->AddText(t);
      }
   }
   if (print_rms) {
      if (print_rms == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringRMSX.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetRMS(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringRMSY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetRMS(2));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringRMSZ.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetRMS(3));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringRMSX.Data(),"%",stats->GetStatFormat()
                                                  ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetRMS(1),h3->GetRMSError(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringRMSY.Data(),"%",stats->GetStatFormat()
                                                  ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetRMS(2),h3->GetRMSError(2));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringRMSZ.Data(),"%",stats->GetStatFormat()
                                                  ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetRMS(3),h3->GetRMSError(3));
         stats->AddText(t);
      }
   }
   if (print_integral) {
      snprintf(t,100,"%s  = %6.4g",gStringIntegral.Data(),h3->Integral());
      stats->AddText(t);
   }
   if (print_skew) {
      if (print_skew == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringSkewnessX.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetSkewness(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringSkewnessY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetSkewness(2));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringSkewnessZ.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetSkewness(3));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringSkewnessX.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetSkewness(1),h3->GetSkewness(11));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringSkewnessY.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetSkewness(2),h3->GetSkewness(12));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringSkewnessZ.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetSkewness(3),h3->GetSkewness(13));
         stats->AddText(t);
      }
   }
   if (print_kurt) {
      if (print_kurt == 1) {
         snprintf(textstats,50,"%s = %s%s",gStringKurtosisX.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetKurtosis(1));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringKurtosisY.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetKurtosis(2));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s",gStringKurtosisZ.Data(),"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetKurtosis(3));
         stats->AddText(t);
      } else {
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringKurtosisX.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetKurtosis(1),h3->GetKurtosis(11));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringKurtosisY.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetKurtosis(2),h3->GetKurtosis(12));
         stats->AddText(t);
         snprintf(textstats,50,"%s = %s%s #pm %s%s",gStringKurtosisZ.Data(),"%",stats->GetStatFormat()
                                                       ,"%",stats->GetStatFormat());
         snprintf(t,100,textstats,h3->GetKurtosis(3),h3->GetKurtosis(13));
         stats->AddText(t);
      }
   }
   if (print_under || print_over) {
      // no underflow - overflow printing for a 3D histogram
      // one would need a 3D table
//       //get 3*3 under/overflows for 2d hist
//       Double_t unov[9];

//       unov[0] = h3->Integral(0,h3->GetXaxis()->GetFirst()-1,h3->GetYaxis()->GetLast()+1,h3->GetYaxis()->GetNbins()+1);
//       unov[1] = h3->Integral(h3->GetXaxis()->GetFirst(),h3->GetXaxis()->GetLast(),h3->GetYaxis()->GetLast()+1,h3->GetYaxis()->GetNbins()+1);
//       unov[2] = h3->Integral(h3->GetXaxis()->GetLast()+1,h3->GetXaxis()->GetNbins()+1,h3->GetYaxis()->GetLast()+1,h3->GetYaxis()->GetNbins()+1);
//       unov[3] = h3->Integral(0,h3->GetXaxis()->GetFirst()-1,h3->GetYaxis()->GetFirst(),h3->GetYaxis()->GetLast());
//       unov[4] = h3->Integral(h3->GetXaxis()->GetFirst(),h3->GetXaxis()->GetLast(),h3->GetYaxis()->GetFirst(),h3->GetYaxis()->GetLast());
//       unov[5] = h3->Integral(h3->GetXaxis()->GetLast()+1,h3->GetXaxis()->GetNbins()+1,h3->GetYaxis()->GetFirst(),h3->GetYaxis()->GetLast());
//       unov[6] = h3->Integral(0,h3->GetXaxis()->GetFirst()-1,0,h3->GetYaxis()->GetFirst()-1);
//       unov[7] = h3->Integral(h3->GetXaxis()->GetFirst(),h3->GetXaxis()->GetLast(),0,h3->GetYaxis()->GetFirst()-1);
//       unov[8] = h3->Integral(h3->GetXaxis()->GetLast()+1,h3->GetXaxis()->GetNbins()+1,0,h3->GetYaxis()->GetFirst()-1);

//       sprintf(t, " %7d|%7d|%7d\n", (Int_t)unov[0], (Int_t)unov[1], (Int_t)unov[2]);
//       stats->AddText(t);
//       if (h3->GetEntries() < 1e7)
//          sprintf(t, " %7d|%7d|%7d\n", (Int_t)unov[3], (Int_t)unov[4], (Int_t)unov[5]);
//       else
//          sprintf(t, " %7d|%14.7g|%7d\n", (Int_t)unov[3], (Float_t)unov[4], (Int_t)unov[5]);
//       stats->AddText(t);
//       sprintf(t, " %7d|%7d|%7d\n", (Int_t)unov[6], (Int_t)unov[7], (Int_t)unov[8]);
//       stats->AddText(t);
   }

   // Draw Fit parameters
   if (fit) {
      Int_t ndf = fit->GetNDF();
      snprintf(t,100,"#chi^{2} / ndf = %6.4g / %d",(Float_t)fit->GetChisquare(),ndf);
      stats->AddText(t);
      for (Int_t ipar=0;ipar<fit->GetNpar();ipar++) {
         snprintf(t,100,"%-8s = %5.4g #pm %5.4g ",fit->GetParName(ipar)
                                   ,(Float_t)fit->GetParameter(ipar)
                                   ,(Float_t)fit->GetParError(ipar));
         t[32] = 0;
         stats->AddText(t);
      }
   }

   if (!done) fFunctions->Add(stats);
   stats->Paint();
}


//______________________________________________________________________________
void THistPainter::PaintSurface(Option_t *)
{
   /* Begin_html
   <a href="#HP18">Control function to draw a 2D histogram as a surface plot.</a>
   End_html */

   const Double_t ydiff = 1;
   const Double_t yligh1 = 10;
   const Double_t qa = 0.15;
   const Double_t qd = 0.15;
   const Double_t qs = 0.8;
   Double_t fmin, fmax;
   Int_t raster = 0;
   Int_t irep   = 0;

   if (Hparam.zmin == 0 && Hparam.zmax == 0) {Hparam.zmin = -1; Hparam.zmax = 1;}
   Int_t   nx      = Hparam.xlast - Hparam.xfirst;
   Int_t   ny      = Hparam.ylast - Hparam.yfirst;
   Double_t zmin   = Hparam.zmin;
   Double_t zmax   = Hparam.zmax;
   Double_t xlab1  = Hparam.xmin;
   Double_t xlab2  = Hparam.xmax;
   Double_t ylab1  = Hparam.ymin;
   Double_t ylab2  = Hparam.ymax;
   Double_t dangle = 10*3.141592/180; //Delta angle for Rapidity option
   Double_t deltaz = TMath::Abs(zmin);
   if (deltaz == 0) deltaz = 1;
   if (zmin >= zmax) {
      zmin -= 0.5*deltaz;
      zmax += 0.5*deltaz;
   }
   Double_t z1c = zmin;
   Double_t z2c = zmin + (zmax-zmin)*(1+gStyle->GetHistTopMargin());
   //     Compute the lego limits and instantiate a lego object
   fXbuf[0] = -1;
   fYbuf[0] =  1;
   fXbuf[1] = -1;
   fYbuf[1] =  1;
   if (Hoption.System >= kPOLAR && (Hoption.Surf == 1 || Hoption.Surf == 13)) raster = 1;
   if (Hoption.System == kPOLAR) {
      fXbuf[2] = z1c;
      fYbuf[2] = z2c;
   } else if (Hoption.System == kCYLINDRICAL) {
      if (Hoption.Logy) {
         if (ylab1 > 0) fXbuf[2] = TMath::Log10(ylab1);
         else           fXbuf[2] = 0;
         if (ylab2 > 0) fYbuf[2] = TMath::Log10(ylab2);
         else           fYbuf[2] = 0;
      } else {
         fXbuf[2] = ylab1;
         fYbuf[2] = ylab2;
      }
      z1c = 0; z2c = 1;
   } else if (Hoption.System == kSPHERICAL) {
      fXbuf[2] = -1;
      fYbuf[2] =  1;
      z1c = 0; z2c = 1;
   } else if (Hoption.System == kRAPIDITY) {
      fXbuf[2] = -1/TMath::Tan(dangle);
      fYbuf[2] =  1/TMath::Tan(dangle);
   } else {
      fXbuf[0] = xlab1;
      fYbuf[0] = xlab2;
      fXbuf[1] = ylab1;
      fYbuf[1] = ylab2;
      fXbuf[2] = z1c;
      fYbuf[2] = z2c;
   }

   fLego = new TPainter3dAlgorithms(fXbuf, fYbuf, Hoption.System);
   fLego->SetEdgeAtt(fH->GetLineColor(),fH->GetLineStyle(),fH->GetLineWidth(),0);
   fLego->SetFillColor(fH->GetFillColor());

   //          Create axis object

   TGaxis *axis = new TGaxis();

   //                  Initialize the levels on the Z axis
   Int_t ndiv   = fH->GetContour();
   if (ndiv == 0 ) {
      ndiv = gStyle->GetNumberContours();
      fH->SetContour(ndiv);
   }
   Int_t ndivz  = TMath::Abs(ndiv);
   if (fH->TestBit(TH1::kUserContour) == 0) fH->SetContour(ndiv);

   if (Hoption.Surf == 13 || Hoption.Surf == 15) fLego->SetMesh(3);
   if (Hoption.Surf == 12 || Hoption.Surf == 14 || Hoption.Surf == 17) fLego->SetMesh(0);

   //     Close the surface in case of non cartesian coordinates.

   if (Hoption.System != kCARTESIAN) {nx++; ny++;}

   //     Now ready to draw the surface plot

   TView *view = gPad->GetView();
   if (!view) {
      Error("PaintSurface", "no TView in current pad");
      return;
   }

   Double_t thedeg =  90 - gPad->GetTheta();
   Double_t phideg = -90 - gPad->GetPhi();
   Double_t psideg = view->GetPsi();
   view->SetView(phideg, thedeg, psideg, irep);

   //     Set color/style for back box
   if (Hoption.Same) {
      fLego->SetFillStyle(0);
      fLego->SetFillColor(1);
   } else {
      fLego->SetFillStyle(gPad->GetFrameFillStyle());
      fLego->SetFillColor(gPad->GetFrameFillColor());
   }
   fLego->TAttFill::Modify();

   Int_t backcolor = gPad->GetFrameFillColor();
   if (Hoption.System != kCARTESIAN) backcolor = 0;
   view->PadRange(backcolor);

   fLego->SetFillStyle(fH->GetFillStyle());
   fLego->SetFillColor(fH->GetFillColor());
   fLego->TAttFill::Modify();

   //     Draw the filled contour on top
   Int_t icol1 = fH->GetFillColor();

   Int_t hoption35 = Hoption.Surf;
   if (Hoption.Surf == 13 || Hoption.Surf == 15) {
      DefineColorLevels(ndivz);
      Hoption.Surf = 23;
      fLego->SetSurfaceFunction(&TPainter3dAlgorithms::SurfaceFunction);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMode2);
      if (Hoption.System == kPOLAR)       fLego->SurfacePolar(1,nx,ny,"BF");
      if (Hoption.System == kCYLINDRICAL) fLego->SurfaceCylindrical(1,nx,ny,"BF");
      if (Hoption.System == kSPHERICAL)   fLego->SurfaceSpherical(0,1,nx,ny,"BF");
      if (Hoption.System == kRAPIDITY )   fLego->SurfaceSpherical(1,1,nx,ny,"BF");
      if (Hoption.System == kCARTESIAN)   fLego->SurfaceCartesian(90,nx,ny,"BF");
      Hoption.Surf = hoption35;
      fLego->SetMesh(1);
   }

   if (raster) fLego->InitRaster(-1.1,-1.1,1.1,1.1,1000,800);
   else        fLego->InitMoveScreen(-1.1,1.1);

   if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 14 || Hoption.Surf == 17) {
      fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);
      if (Hoption.System == kCARTESIAN && Hoption.BackBox) {
         fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
         fLego->BackBox(90);
      }
   }

   //     Gouraud Shading surface
   if (Hoption.Surf == 14) {
   //    Set light sources
      fLego->LightSource(0, ydiff, 0,0,0,irep);
      fLego->LightSource(1, yligh1 ,1,1,1,irep);
      fLego->SurfaceProperty(qa, qd, qs, 1, irep);
      fmin = ydiff*qa;
      fmax = fmin + (yligh1+0.1)*(qd+qs);
      Int_t nbcol = 28;
      icol1 = 201;
      Double_t dcol = 0.5/Double_t(nbcol);
      TColor *colref = gROOT->GetColor(fH->GetFillColor());
      if (!colref) return;
      Float_t r,g,b,hue,light,satur;
      colref->GetRGB(r,g,b);
      TColor::RGBtoHLS(r,g,b,hue,light,satur);
      TColor *acol;
      for (Int_t col=0;col<nbcol;col++) {
         acol = gROOT->GetColor(col+icol1);
         TColor::HLStoRGB(hue,.4+col*dcol,satur,r,g,b);
         acol->SetRGB(r,g,b);
      }
      fLego->Spectrum(nbcol, fmin, fmax, icol1, 1, irep);
      fLego->SetSurfaceFunction(&TPainter3dAlgorithms::GouraudFunction);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMode2);
      if (Hoption.System == kPOLAR)       fLego->SurfacePolar(1,nx,ny,"BF");
      if (Hoption.System == kCYLINDRICAL) fLego->SurfaceCylindrical(1,nx,ny,"BF");
      if (Hoption.System == kSPHERICAL)   fLego->SurfaceSpherical(0,1,nx,ny,"BF");
      if (Hoption.System == kRAPIDITY )   fLego->SurfaceSpherical(1,1,nx,ny,"BF");
      if (Hoption.System == kCARTESIAN)   fLego->SurfaceCartesian(90,nx,ny,"BF");
   } else if (Hoption.Surf == 15) {
   // The surface is not drawn in this case.
   } else {
   //     Draw the surface
      if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 16 || Hoption.Surf == 17) {
         DefineColorLevels(ndivz);
      } else {
         fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);
      }
      fLego->SetSurfaceFunction(&TPainter3dAlgorithms::SurfaceFunction);
      if (Hoption.Surf ==  1 || Hoption.Surf == 13) fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceRaster1);
      if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 17) fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMode2);
      if (Hoption.System == kPOLAR) {
         if (Hoption.Surf ==  1 || Hoption.Surf == 13) fLego->SurfacePolar(1,nx,ny,"FB");
         if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 17) fLego->SurfacePolar(1,nx,ny,"BF");
      } else if (Hoption.System == kCYLINDRICAL) {
         if (Hoption.Surf ==  1 || Hoption.Surf == 13) fLego->SurfaceCylindrical(1,nx,ny,"FB");
         if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 17) fLego->SurfaceCylindrical(1,nx,ny,"BF");
      } else if (Hoption.System == kSPHERICAL) {
         if (Hoption.Surf ==  1 || Hoption.Surf == 13) fLego->SurfaceSpherical(0,1,nx,ny,"FB");
         if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 17) fLego->SurfaceSpherical(0,1,nx,ny,"BF");
      } else if (Hoption.System == kRAPIDITY) {
         if (Hoption.Surf ==  1 || Hoption.Surf == 13) fLego->SurfaceSpherical(1,1,nx,ny,"FB");
         if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 17) fLego->SurfaceSpherical(1,1,nx,ny,"BF");
      } else {
         if (Hoption.Surf ==  1 || Hoption.Surf == 13) fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
         if (Hoption.Surf == 16) fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove3);
         if (Hoption.Surf ==  1 || Hoption.Surf == 13 || Hoption.Surf == 16) fLego->SurfaceCartesian(90,nx,ny,"FB");
         if (Hoption.Surf == 11 || Hoption.Surf == 12 || Hoption.Surf == 17) fLego->SurfaceCartesian(90,nx,ny,"BF");
      }
   }

   // Paint the line contour on top for option SURF7
   if (Hoption.Surf == 17) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);
      Hoption.Surf = 23;
      fLego->SetSurfaceFunction(&TPainter3dAlgorithms::SurfaceFunction);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove3);
      if (Hoption.System == kPOLAR)       fLego->SurfacePolar(1,nx,ny,"FB");
      if (Hoption.System == kCYLINDRICAL) fLego->SurfaceCylindrical(1,nx,ny,"FB");
      if (Hoption.System == kSPHERICAL)   fLego->SurfaceSpherical(0,1,nx,ny,"FB");
      if (Hoption.System == kRAPIDITY )   fLego->SurfaceSpherical(1,1,nx,ny,"FB");
      if (Hoption.System == kCARTESIAN)   fLego->SurfaceCartesian(90,nx,ny,"FB");
   }

   if ((!Hoption.Same) &&
       (Hoption.Surf == 1 || Hoption.Surf == 13 || Hoption.Surf == 16)) {
      if (Hoption.System == kCARTESIAN && Hoption.BackBox) {
         fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
         fLego->BackBox(90);
      }
   }
   if (Hoption.System == kCARTESIAN) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove2);
      if (Hoption.FrontBox) fLego->FrontBox(90);
   }
   if (!Hoption.Axis && !Hoption.Same) PaintLegoAxis(axis, 90);

   if (Hoption.Zscale) PaintPalette();

   delete axis;
   delete fLego; fLego = 0;
}


//______________________________________________________________________________
void THistPainter::PaintTriangles(Option_t *option)
{
   /* Begin_html
   Control function to draw a table using Delaunay triangles.
   End_html */

   TGraphDelaunay *dt;

   // Check if fH contains a TGraphDelaunay
   TList *hl = fH->GetListOfFunctions();
   dt = (TGraphDelaunay*)hl->FindObject("TGraphDelaunay");
   if (!dt) return;

   // If needed, create a TGraph2DPainter
   if (!fGraph2DPainter) fGraph2DPainter = new TGraph2DPainter(dt);

   // Define the 3D view
   if (Hoption.Same) {
      TView *viewsame = gPad->GetView();
      if (!viewsame) {
         Error("PaintTriangles", "no TView in current pad, do not use option SAME");
         return;
      }
      Double_t *rmin = viewsame->GetRmin();
      Double_t *rmax = viewsame->GetRmax();
      if (!rmin || !rmax) return;
      fXbuf[0] = rmin[0];
      fYbuf[0] = rmax[0];
      fXbuf[1] = rmin[1];
      fYbuf[1] = rmax[1];
      fXbuf[2] = rmin[2];
      fYbuf[2] = rmax[2];
   } else {
      fXbuf[0] = Hparam.xmin;
      fYbuf[0] = Hparam.xmax;
      fXbuf[1] = Hparam.ymin;
      fYbuf[1] = Hparam.ymax;
      fXbuf[2] = Hparam.zmin;
      fYbuf[2] = Hparam.zmax;
   }

   fLego = new TPainter3dAlgorithms(fXbuf, fYbuf);
   TView *view = gPad->GetView();
   if (!view) {
      Error("PaintTriangles", "no TView in current pad");
      return;
   }
   Double_t thedeg =  90 - gPad->GetTheta();
   Double_t phideg = -90 - gPad->GetPhi();
   Double_t psideg = view->GetPsi();
   Int_t irep;
   view->SetView(phideg, thedeg, psideg, irep);

   // Set color/style for back box
   fLego->SetFillStyle(gPad->GetFrameFillStyle());
   fLego->SetFillColor(gPad->GetFrameFillColor());
   fLego->TAttFill::Modify();
   Int_t backcolor = gPad->GetFrameFillColor();
   if (Hoption.System != kCARTESIAN) backcolor = 0;
   view->PadRange(backcolor);
   fLego->SetFillStyle(fH->GetFillStyle());
   fLego->SetFillColor(fH->GetFillColor());
   fLego->TAttFill::Modify();

   // Paint the Back Box if needed
   if (Hoption.BackBox && !Hoption.Same) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
      fLego->BackBox(90);
   }

   // Paint the triangles
   fGraph2DPainter->Paint(option);

   // Paint the Front Box if needed
   if (Hoption.FrontBox) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove2);
      fLego->FrontBox(90);
   }

   // Paint the Axis if needed
   if (!Hoption.Axis && !Hoption.Same) {
      TGaxis *axis = new TGaxis();
      PaintLegoAxis(axis, 90);
      delete axis;
   }

   if (Hoption.Zscale) PaintPalette();

   delete fLego; fLego = 0;
}


//______________________________________________________________________________
void THistPainter::DefineColorLevels(Int_t ndivz)
{
   /* Begin_html
   Define the color levels used to paint legos, surfaces etc..
   End_html */

   Int_t i, irep;

   // Initialize the color levels
   if (ndivz >= 100) {
      Warning("PaintSurface", "too many color levels, %d, reset to 8", ndivz);
      ndivz = 8;
   }
   Double_t *funlevel = new Double_t[ndivz+1];
   Int_t *colorlevel = new Int_t[ndivz+1];
   Int_t theColor;
   Int_t ncolors = gStyle->GetNumberOfColors();
   for (i = 0; i < ndivz; ++i) {
      funlevel[i] = fH->GetContourLevelPad(i);
      theColor = Int_t((i+0.99)*Float_t(ncolors)/Float_t(ndivz));
      colorlevel[i] = gStyle->GetColorPalette(theColor);
   }
   colorlevel[ndivz] = gStyle->GetColorPalette(ncolors-1);
   fLego->ColorFunction(ndivz, funlevel, colorlevel, irep);
   delete [] colorlevel;
   delete [] funlevel;
}


//______________________________________________________________________________
void THistPainter::PaintTable(Option_t *option)
{
   /* Begin_html
   <a href="#HP01c">Control function to draw 2D/3D histograms (tables).</a>
   End_html */

   if (!TableInit()) return;  //fill Hparam structure with histo parameters

   PaintFrame();

   //if palette option not specified, delete a possible existing palette
   if (!Hoption.Zscale) {
      TObject *palette = fFunctions->FindObject("palette");
      if (palette) { fFunctions->Remove(palette); delete palette;}
   }

   if (fH->InheritsFrom(TH2Poly::Class())) {
      if (Hoption.Fill)    PaintTH2PolyBins("f");
      if (Hoption.Color)   PaintTH2PolyColorLevels(option);
      if (Hoption.Scat)    PaintTH2PolyScatterPlot(option);
      if (Hoption.Text)    PaintTH2PolyText(option);
      if (Hoption.Line)    PaintTH2PolyBins("l");
      if (Hoption.Mark)    PaintTH2PolyBins("P");
   } else if (fH->GetEntries() != 0 && Hoption.Axis<=0) {
      if (Hoption.Scat)    PaintScatterPlot(option);
      if (Hoption.Arrow)   PaintArrows(option);
      if (Hoption.Box)     PaintBoxes(option);
      if (Hoption.Color)   PaintColorLevels(option);
      if (Hoption.Contour) PaintContour(option);
      if (Hoption.Text)    PaintText(option);
      if (Hoption.Error >= 100)   Paint2DErrors(option);
      if (Hoption.Candle)  PaintCandlePlot(option);
   }

   if (Hoption.Lego) PaintLego(option);
   if (Hoption.Surf && !Hoption.Contour) PaintSurface(option);
   if (Hoption.Tri) PaintTriangles(option);

   if (!Hoption.Lego && !Hoption.Surf &&
       !Hoption.Tri  && !(Hoption.Error >= 100)) PaintAxis(kFALSE); // Draw the axes

   PaintTitle();    //    Draw histogram title

   TF1 *fit  = 0;
   TIter next(fFunctions);
   TObject *obj;
   while ((obj = next())) {
      if (obj->InheritsFrom(TF1::Class())) {
         fit = (TF1*)obj;
         break;
      }
   }
   if (Hoption.Same != 1) {
      if (!fH->TestBit(TH1::kNoStats)) {  // bit set via TH1::SetStats
         if (!gPad->PadInSelectionMode() && !gPad->PadInHighlightMode()) {
            //ALWAYS executed on non-iOS platform.
            //On iOS, depends on mode.
            PaintStat2(gStyle->GetOptStat(),fit);
         }
      }
   }
}


//______________________________________________________________________________
void THistPainter::PaintTH2PolyBins(Option_t *option)
{
   /* Begin_html
    Control function to draw a TH2Poly bins' contours.
    option = "F" draw the bins as filled areas.
    option = "L" draw the bins as line.
    option = "P" draw the bins as markers.
    End_html */

   //Do not highlight the histogram, if its part was picked.
   if (gPad->PadInHighlightMode() && gPad->GetSelected() != fH) return;

   TString opt = option;
   opt.ToLower();
   Bool_t line = kFALSE;
   Bool_t fill = kFALSE;
   Bool_t mark = kFALSE;
   if (opt.Contains("l")) line = kTRUE;
   if (opt.Contains("f")) fill = kTRUE;
   if (opt.Contains("p")) mark = kTRUE;

   TH2PolyBin  *b;

   TIter next(((TH2Poly*)fH)->GetBins());
   TObject *obj, *poly;

   while ((obj=next())) {
      b     = (TH2PolyBin*)obj;
      poly  = b->GetPolygon();

      // Paint the TGraph bins.
      if (poly->IsA() == TGraph::Class()) {
         TGraph *g  = (TGraph*)poly;
         g->TAttLine::Modify();
         g->TAttMarker::Modify();
         g->TAttFill::Modify();
         if (line) g->Paint("L");
         if (fill) g->Paint("F");
         if (mark) g->Paint("P");
      }

      // Paint the TMultiGraph bins.
      if (poly->IsA() == TMultiGraph::Class()) {
         TMultiGraph *mg = (TMultiGraph*)poly;
         TList *gl = mg->GetListOfGraphs();
         if (!gl) return;
         TGraph *g;
         TIter nextg(gl);
         while ((g = (TGraph*) nextg())) {
            g->TAttLine::Modify();
            g->TAttMarker::Modify();
            g->TAttFill::Modify();
            if (line) g->Paint("L");
            if (fill) g->Paint("F");
            if (mark) g->Paint("P");
         }
      }
   }
}


//______________________________________________________________________________
void THistPainter::PaintTH2PolyColorLevels(Option_t *)
{
   /* Begin_html
    <a href="#HP20a">Control function to draw a TH2Poly as a color plot.</a>
    End_html */

   //Do not highlight the histogram, if its part was picked.
   if (gPad->PadInHighlightMode() && gPad->GetSelected() != fH)
      return;

   Int_t ncolors, color, theColor;
   Double_t z, zc;
   Double_t zmin = fH->GetMinimum();
   Double_t zmax = fH->GetMaximum();
   if (Hoption.Logz) {
      if (zmax > 0) {
         if (zmin <= 0) zmin = TMath::Min((Double_t)1, (Double_t)0.001*zmax);
         zmin = TMath::Log10(zmin);
         zmax = TMath::Log10(zmax);
      } else {
         return;
      }
   }
   Double_t dz = zmax - zmin;

   // Initialize the levels on the Z axis
   ncolors     = gStyle->GetNumberOfColors();
   Int_t ndiv  = fH->GetContour();
   if (ndiv == 0 ) {
      ndiv = gStyle->GetNumberContours();
      fH->SetContour(ndiv);
   }
   Int_t ndivz  = TMath::Abs(ndiv);
   if (fH->TestBit(TH1::kUserContour) == 0) fH->SetContour(ndiv);
   Double_t scale = ndivz/dz;

   TH2PolyBin  *b;

   TIter next(((TH2Poly*)fH)->GetBins());
   TObject *obj, *poly;

   while ((obj=next())) {
      b     = (TH2PolyBin*)obj;
      poly  = b->GetPolygon();

      z = b->GetContent();
      if (Hoption.Logz) {
         if (z > 0) z = TMath::Log10(z);
         else       z = zmin;
      }
      if (z < zmin) continue;

      // Define the bin color.
      if (fH->TestBit(TH1::kUserContour)) {
         zc = fH->GetContourLevelPad(0);
         if (z < zc) continue;
         color = -1;
         for (Int_t k=0; k<ndiv; k++) {
            zc = fH->GetContourLevelPad(k);
            if (z < zc) {
               continue;
            } else {
               color++;
            }
         }
      } else {
         color = Int_t(0.01+(z-zmin)*scale);
      }
      theColor = Int_t((color+0.99)*Float_t(ncolors)/Float_t(ndivz));
      if (theColor > ncolors-1) theColor = ncolors-1;

      // Paint the TGraph bins.
      if (poly->IsA() == TGraph::Class()) {
         TGraph *g  = (TGraph*)poly;
         g->SetFillColor(gStyle->GetColorPalette(theColor));
         g->TAttFill::Modify();
         g->Paint("F");
      }

      // Paint the TMultiGraph bins.
      if (poly->IsA() == TMultiGraph::Class()) {
         TMultiGraph *mg = (TMultiGraph*)poly;
         TList *gl = mg->GetListOfGraphs();
         if (!gl) return;
         TGraph *g;
         TIter nextg(gl);
         while ((g = (TGraph*) nextg())) {
            g->SetFillColor(gStyle->GetColorPalette(theColor));
            g->TAttFill::Modify();
            g->Paint("F");
         }
      }
   }
   if (Hoption.Zscale) PaintPalette();
}


//______________________________________________________________________________
void THistPainter::PaintTH2PolyScatterPlot(Option_t *)
{
   /* Begin_html
    <a href="#HP20a">Control function to draw a TH2Poly as a scatter plot.</a>
    End_html */

   //Do not highlight the histogram, if its part was selected.
   if (gPad->PadInHighlightMode() && gPad->GetSelected() != fH)
      return;

   Int_t k, loop, marker=0;
   Double_t z, xk,xstep, yk, ystep, xp, yp;
   Double_t scale = 1;
   Double_t zmin = fH->GetMinimum();
   Double_t zmax = fH->GetMaximum();
   if (Hoption.Logz) {
      if (zmax > 0) {
         if (zmin <= 0) zmin = TMath::Min((Double_t)1, (Double_t)0.001*zmax);
         zmin = TMath::Log10(zmin);
         zmax = TMath::Log10(zmax);
      } else {
         return;
      }
   }
   Double_t dz = zmax - zmin;
   scale = (kNMAX-1)/dz;


   // use an independent instance of a random generator
   // instead of gRandom to avoid conflicts and
   // to get same random numbers when drawing the same histogram
   TRandom2 random;

   TH2PolyBin  *b;

   TIter next(((TH2Poly*)fH)->GetBins());
   TObject *obj, *poly;

   Double_t maxarea = 0, a;
   while ((obj=next())) {
      b     = (TH2PolyBin*)obj;
      a     = b->GetArea();
      if (a>maxarea) maxarea = a;
   }

   next.Reset();

   while ((obj=next())) {
      b     = (TH2PolyBin*)obj;
      poly  = b->GetPolygon();
      z     = b->GetContent();
      if (z < zmin) z = zmin;
      if (z > zmax) z = zmax;
      if (Hoption.Logz) {
         if (z > 0) z = TMath::Log10(z) - zmin;
      } else {
         z    -=  zmin;
      }
      k     = Int_t((z*scale)*(b->GetArea()/maxarea));
      xk    = b->GetXMin();
      yk    = b->GetYMin();
      xstep = b->GetXMax()-xk;
      ystep = b->GetYMax()-yk;

      // Paint the TGraph bins.
      if (poly->IsA() == TGraph::Class()) {
         TGraph *g  = (TGraph*)poly;
         if (k <= 0 || z <= 0) continue;
         loop = 0;
         while (loop<k) {
            if (k+marker >= kNMAX) {
               gPad->PaintPolyMarker(marker, fXbuf, fYbuf);
               marker=0;
            }
            xp = (random.Rndm(loop)*xstep) + xk;
            yp = (random.Rndm(loop)*ystep) + yk;
            if (g->IsInside(xp,yp)) {
               fXbuf[marker] = xp;
               fYbuf[marker] = yp;
               marker++;
               loop++;
            }
         }
         if (marker > 0) gPad->PaintPolyMarker(marker, fXbuf, fYbuf);
      }

      // Paint the TMultiGraph bins.
      if (poly->IsA() == TMultiGraph::Class()) {
         TMultiGraph *mg = (TMultiGraph*)poly;
         TList *gl = mg->GetListOfGraphs();
         if (!gl) return;
         if (k <= 0 || z <= 0) continue;
         loop = 0;
         while (loop<k) {
            if (k+marker >= kNMAX) {
               gPad->PaintPolyMarker(marker, fXbuf, fYbuf);
               marker=0;
            }
            xp = (random.Rndm(loop)*xstep) + xk;
            yp = (random.Rndm(loop)*ystep) + yk;
            if (mg->IsInside(xp,yp)) {
               fXbuf[marker] = xp;
               fYbuf[marker] = yp;
               marker++;
               loop++;
            }
         }
         if (marker > 0) gPad->PaintPolyMarker(marker, fXbuf, fYbuf);
      }
   }
   PaintTH2PolyBins("l");
}


//______________________________________________________________________________
void THistPainter::PaintTH2PolyText(Option_t *)
{
   /* Begin_html
    <a href="#HP20a">Control function to draw a TH2Poly as a text plot.</a>
    End_html */

   TLatex text;
   text.SetTextFont(gStyle->GetTextFont());
   text.SetTextColor(fH->GetMarkerColor());
   text.SetTextSize(0.02*fH->GetMarkerSize());

   Double_t x, y, z, e, angle = 0;
   char value[50];
   char format[32];
   snprintf(format,32,"%s%s","%",gStyle->GetPaintTextFormat());
   if (Hoption.Text >= 1000) angle = Hoption.Text%1000;
   Int_t opt = (Int_t)Hoption.Text/1000;

   text.SetTextAlign(22);
   if (Hoption.Text ==  1) angle = 0;
   text.SetTextAngle(angle);
   text.TAttText::Modify();

   TH2PolyBin *b;

   TIter next(((TH2Poly*)fH)->GetBins());
   TObject *obj, *p;

   while ((obj=next())) {
      b = (TH2PolyBin*)obj;
      p = b->GetPolygon();
      x = (b->GetXMin()+b->GetXMax())/2;
      if (Hoption.Logx) {
         if (x > 0)  x  = TMath::Log10(x);
         else continue;
      }
      y = (b->GetYMin()+b->GetYMax())/2;
      if (Hoption.Logy) {
         if (y > 0)  y  = TMath::Log10(y);
         else continue;
      }
      z = b->GetContent();
      if (z < Hparam.zmin || (z == 0 && !gStyle->GetHistMinimumZero()) ) continue;
      if (opt==2) {
         e = fH->GetBinError(b->GetBinNumber());
         snprintf(format,32,"#splitline{%s%s}{#pm %s%s}",
                                    "%",gStyle->GetPaintTextFormat(),
                                    "%",gStyle->GetPaintTextFormat());
         snprintf(value,50,format,z,e);
      } else {
         snprintf(value,50,format,z);
      }
      if (opt==3) text.PaintLatex(x,y,angle,0.02*fH->GetMarkerSize(),p->GetName());
      else        text.PaintLatex(x,y,angle,0.02*fH->GetMarkerSize(),value);
   }

   PaintTH2PolyBins("l");
}


//______________________________________________________________________________
void THistPainter::PaintText(Option_t *)
{
   /* Begin_html
   <a href="#HP15">Control function to draw a 1D/2D histograms with the bin values.</a>
   End_html */

   TLatex text;
   text.SetTextFont(gStyle->GetTextFont());
   text.SetTextColor(fH->GetMarkerColor());
   text.SetTextSize(0.02*fH->GetMarkerSize());

   Double_t x, y, z, e, angle = 0;
   char value[50];
   char format[32];
   snprintf(format,32,"%s%s","%",gStyle->GetPaintTextFormat());
   if (Hoption.Text >= 1000) angle = Hoption.Text%1000;

   // 1D histograms
   if (fH->GetDimension() == 1) {
      Bool_t getentries = kFALSE;
      Double_t yt;
      TProfile *hp = (TProfile*)fH;
      if (Hoption.Text>2000 && fH->InheritsFrom(TProfile::Class())) {
         Hoption.Text = Hoption.Text-2000;
         getentries = kTRUE;
      }
      if (Hoption.Text ==  1) angle = 90;
      text.SetTextAlign(11);
      if (angle == 90) text.SetTextAlign(12);
      if (angle ==  0) text.SetTextAlign(21);
      text.TAttText::Modify();
      Double_t dt = 0.02*(gPad->GetY2()-gPad->GetY1());
      for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
         if (Hoption.Bar) {
            x  = fH->GetXaxis()->GetBinLowEdge(i)+
                 fH->GetXaxis()->GetBinWidth(i)*
                 (fH->GetBarOffset()+0.5*fH->GetBarWidth());
         } else {
            x  = fH->GetXaxis()->GetBinCenter(i);
         }
         y  = fH->GetBinContent(i);
         yt = y;
         if (gStyle->GetHistMinimumZero() && y<0) y = 0;
         if (getentries) yt = hp->GetBinEntries(i);
         if (yt == 0.) continue;
         snprintf(value,50,format,yt);
         if (Hoption.Logx) {
            if (x > 0)  x  = TMath::Log10(x);
            else continue;
         }
         if (Hoption.Logy) {
            if (y > 0)  y  = TMath::Log10(y);
            else continue;
         }
         if (y >= gPad->GetY2()) continue;
         if (y <= gPad->GetY1()) continue;
         text.PaintLatex(x,y+0.2*dt,angle,0.02*fH->GetMarkerSize(),value);
      }

   // 2D histograms
   } else {
      text.SetTextAlign(22);
      if (Hoption.Text ==  1) angle = 0;
      text.SetTextAngle(angle);
      text.TAttText::Modify();
      for (Int_t j=Hparam.yfirst; j<=Hparam.ylast;j++) {
         y    = fYaxis->GetBinCenter(j);
         if (Hoption.Logy) {
            if (y > 0)  y  = TMath::Log10(y);
            else continue;
         }
         for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
            Int_t bin  = j*(fXaxis->GetNbins()+2) + i;
            x    = fXaxis->GetBinCenter(i);
            if (Hoption.Logx) {
               if (x > 0)  x  = TMath::Log10(x);
               else continue;
            }
            if (!IsInside(x,y)) continue;
            z = fH->GetBinContent(bin);
            if (z < Hparam.zmin || (z == 0 && !gStyle->GetHistMinimumZero()) ) continue;
            if (Hoption.Text>2000) {
               e = fH->GetBinError(bin);
               snprintf(format,32,"#splitline{%s%s}{#pm %s%s}",
                                          "%",gStyle->GetPaintTextFormat(),
                                          "%",gStyle->GetPaintTextFormat());
               snprintf(value,50,format,z,e);
            } else {
               snprintf(value,50,format,z);
            }
            text.PaintLatex(x,y,angle,0.02*fH->GetMarkerSize(),value);
         }
      }
   }
}


//______________________________________________________________________________
void THistPainter::PaintTF3()
{
   /* Begin_html
   <a href="#HP27">Control function to draw a 3D implicit functions.</a>
   End_html */

   Int_t irep;

   TGaxis *axis = new TGaxis();
   TAxis *xaxis = fH->GetXaxis();
   TAxis *yaxis = fH->GetYaxis();
   TAxis *zaxis = fH->GetZaxis();

   fXbuf[0] = xaxis->GetBinLowEdge(xaxis->GetFirst());
   fYbuf[0] = xaxis->GetBinUpEdge(xaxis->GetLast());
   fXbuf[1] = yaxis->GetBinLowEdge(yaxis->GetFirst());
   fYbuf[1] = yaxis->GetBinUpEdge(yaxis->GetLast());
   fXbuf[2] = zaxis->GetBinLowEdge(zaxis->GetFirst());
   fYbuf[2] = zaxis->GetBinUpEdge(zaxis->GetLast());

   fLego = new TPainter3dAlgorithms(fXbuf, fYbuf);

   TView *view = gPad->GetView();
   if (!view) {
      Error("PaintTF3", "no TView in current pad");
      return;
   }
   Double_t thedeg =  90 - gPad->GetTheta();
   Double_t phideg = -90 - gPad->GetPhi();
   Double_t psideg = view->GetPsi();
   view->SetView(phideg, thedeg, psideg, irep);

   fLego->InitMoveScreen(-1.1,1.1);

   if (Hoption.BackBox) {
      fLego->DefineGridLevels(fZaxis->GetNdivisions()%100);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove1);
      fLego->BackBox(90);
   }

   fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMode1);

   fLego->ImplicitFunction(fXbuf, fYbuf, fH->GetNbinsX(),
                                         fH->GetNbinsY(),
                                         fH->GetNbinsZ(), "BF");

   if (Hoption.FrontBox) {
      fLego->InitMoveScreen(-1.1,1.1);
      fLego->SetDrawFace(&TPainter3dAlgorithms::DrawFaceMove2);
      fLego->FrontBox(90);
   }
   if (!Hoption.Axis && !Hoption.Same) PaintLegoAxis(axis, 90);

   PaintTitle();

   delete axis;
   delete fLego; fLego = 0;
}


//______________________________________________________________________________
void THistPainter::PaintTitle()
{
   /* Begin_html
   Draw the histogram title
   <p>
   The title is drawn according to the title alignment returned by
   <tt>GetTitleAlign()</tt>. It is a 2 digits integer): hv
   <p>
   where <tt>"h"</tt> is the horizontal alignment and <tt>"v"</tt> is the
   vertical alignment.
   <ul>
   <li> <tt>"h"</tt> can get the values 1 2 3 for left, center, and right
   <li> <tt>"v"</tt> can get the values 1 2 3 for bottom, middle and top
   </ul>
   for instance the default alignment is: 13 (left top)
   End_html */

   if (Hoption.Same) return;
   if (fH->TestBit(TH1::kNoTitle)) return;
   Int_t nt = strlen(fH->GetTitle());
   TPaveText *title = 0;
   TObject *obj;
   TIter next(gPad->GetListOfPrimitives());
   while ((obj = next())) {
      if (!obj->InheritsFrom(TPaveText::Class())) continue;
      title = (TPaveText*)obj;
      if (strcmp(title->GetName(),"title")) {title = 0; continue;}
      break;
   }
   if (nt == 0 || gStyle->GetOptTitle() <= 0) {
      if (title) delete title;
      return;
   }
   Double_t ht = gStyle->GetTitleH();
   Double_t wt = gStyle->GetTitleW();
   if (ht <= 0) ht = 1.1*gStyle->GetTitleFontSize();
   if (ht <= 0) ht = 0.05;
   if (wt <= 0) {
      TLatex l;
      l.SetTextSize(ht);
      l.SetTitle(fH->GetTitle());
      // adjustment in case the title has several lines (#splitline)
      ht = TMath::Max(ht, 1.2*l.GetYsize()/(gPad->GetY2() - gPad->GetY1()));
      Double_t wndc = l.GetXsize()/(gPad->GetX2() - gPad->GetX1());
      wt = TMath::Min(0.7, 0.02+wndc);
   }
   if (title) {
      TText *t0 = (TText*)title->GetLine(0);
      if (t0) {
         if (!strcmp(t0->GetTitle(),fH->GetTitle())) return;
         t0->SetTitle(fH->GetTitle());
         if (wt > 0) title->SetX2NDC(title->GetX1NDC()+wt);
      }
      return;
   }

   Int_t talh = gStyle->GetTitleAlign()/10;
   if (talh < 1) talh = 1; if (talh > 3) talh = 3;
   Int_t talv = gStyle->GetTitleAlign()%10;
   if (talv < 1) talv = 1; if (talv > 3) talv = 3;
   Double_t xpos, ypos;
   xpos = gStyle->GetTitleX();
   ypos = gStyle->GetTitleY();
   if (talh == 2) xpos = xpos-wt/2.;
   if (talh == 3) xpos = xpos-wt;
   if (talv == 2) ypos = ypos+ht/2.;
   if (talv == 1) ypos = ypos+ht;

   TPaveText *ptitle = new TPaveText(xpos, ypos-ht, xpos+wt, ypos,"blNDC");

   //     box with the histogram title
   ptitle->SetFillColor(gStyle->GetTitleFillColor());
   ptitle->SetFillStyle(gStyle->GetTitleStyle());
   ptitle->SetName("title");
   ptitle->SetBorderSize(gStyle->GetTitleBorderSize());
   ptitle->SetTextColor(gStyle->GetTitleTextColor());
   ptitle->SetTextFont(gStyle->GetTitleFont(""));
   if (gStyle->GetTitleFont("")%10 > 2)
      ptitle->SetTextSize(gStyle->GetTitleFontSize());
   ptitle->AddText(fH->GetTitle());
   ptitle->SetBit(kCanDelete);
   ptitle->Draw();
   ptitle->Paint();

}


//______________________________________________________________________________
void THistPainter::ProcessMessage(const char *mess, const TObject *obj)
{
   /* Begin_html
    Process message "mess".
   End_html */

   if (!strcmp(mess,"SetF3")) {
      TPainter3dAlgorithms::SetF3((TF3*)obj);
   } else if (!strcmp(mess,"SetF3ClippingBoxOff")) {
      TPainter3dAlgorithms::SetF3ClippingBoxOff();
   } else if (!strcmp(mess,"SetF3ClippingBoxOn")) {
      TVectorD &v =  (TVectorD&)(*obj);
      Double_t xclip = v(0);
      Double_t yclip = v(1);
      Double_t zclip = v(2);
      TPainter3dAlgorithms::SetF3ClippingBoxOn(xclip,yclip,zclip);
   }
}


//______________________________________________________________________________
Int_t THistPainter::ProjectAitoff2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab)
{
   /* Begin_html
   Static function.<br>
   Convert Right Ascension, Declination to X,Y using an AITOFF projection.
   This procedure can be used to create an all-sky map in Galactic
   coordinates with an equal-area Aitoff projection.  Output map
   coordinates are zero longitude centered.
   Also called Hammer-Aitoff projection (first presented by Ernst von Hammer in 1892)
   <p>
   source: GMT<br>
   code from  Ernst-Jan Buis
   End_html */

   Double_t x, y;

   Double_t alpha2 = (l/2)*TMath::DegToRad();
   Double_t delta  = b*TMath::DegToRad();
   Double_t r2     = TMath::Sqrt(2.);
   Double_t f      = 2*r2/TMath::Pi();
   Double_t cdec   = TMath::Cos(delta);
   Double_t denom  = TMath::Sqrt(1. + cdec*TMath::Cos(alpha2));
   x      = cdec*TMath::Sin(alpha2)*2.*r2/denom;
   y      = TMath::Sin(delta)*r2/denom;
   x     *= TMath::RadToDeg()/f;
   y     *= TMath::RadToDeg()/f;
   //  x *= -1.; // for a skymap swap left<->right
   Al = x;
   Ab = y;

   return 0;
}


//______________________________________________________________________________
Int_t THistPainter::ProjectMercator2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab)
{
   /* Begin_html
   Static function <br>
   Probably the most famous of the various map projections, the Mercator projection
   takes its name from Mercator who presented it in 1569. It is a cylindrical, conformal projection
   with no distortion along the equator.
   The Mercator projection has been used extensively for world maps in which the distortion towards
   the polar regions grows rather large, thus incorrectly giving the impression that, for example,
   Greenland is larger than South America. In reality, the latter is about eight times the size of
   Greenland. Also, the Former Soviet Union looks much bigger than Africa or South America. One may wonder
   whether this illusion has had any influence on U.S. foreign policy.' (Source: GMT)
   code from  Ernst-Jan Buis
   End_html */

   Al = l;
   Double_t aid = TMath::Tan((TMath::PiOver2() + b*TMath::DegToRad())/2);
   Ab = TMath::Log(aid);
   return 0;
}


//______________________________________________________________________________
Int_t THistPainter::ProjectSinusoidal2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab)
{
   /* Begin_html
   Static function code from  Ernst-Jan Buis
   End_html */

   Al = l*cos(b*TMath::DegToRad());
   Ab = b;
   return 0;
}


//______________________________________________________________________________
Int_t THistPainter::ProjectParabolic2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab)
{
   /* Begin_html
   Static function code from  Ernst-Jan Buis
   End_html */

   Al = l*(2.*TMath::Cos(2*b*TMath::DegToRad()/3) - 1);
   Ab = 180*TMath::Sin(b*TMath::DegToRad()/3);
   return 0;
}


//______________________________________________________________________________
void THistPainter::RecalculateRange()
{
   /* Begin_html
   Recompute the histogram range following graphics operations.
   End_html */

   if (Hoption.Same) return;

   //     Compute x,y range
   Double_t xmin = Hparam.xmin;
   Double_t xmax = Hparam.xmax;
   Double_t ymin = Hparam.ymin;
   Double_t ymax = Hparam.ymax;

   Double_t xmin_aid, ymin_aid, xmax_aid, ymax_aid;
   if (Hoption.Proj ==1) {
      // TODO : check x range not lower than -180 and not higher than 180
      THistPainter::ProjectAitoff2xy(Hparam.xmin, Hparam.ymin, xmin_aid, ymin_aid);
      THistPainter::ProjectAitoff2xy(Hparam.xmin, Hparam.ymax, xmin,     ymax_aid);
      THistPainter::ProjectAitoff2xy(Hparam.xmax, Hparam.ymax, xmax_aid, ymax);
      THistPainter::ProjectAitoff2xy(Hparam.xmax, Hparam.ymin, xmax,     ymin);

      if (xmin > xmin_aid) xmin = xmin_aid;
      if (ymin > ymin_aid) ymin = ymin_aid;
      if (xmax < xmax_aid) xmax = xmax_aid;
      if (ymax < ymax_aid) ymax = ymax_aid;
      if (Hparam.ymin<0 && Hparam.ymax>0) {
         // there is an  'equator', check its range in the plot..
         THistPainter::ProjectAitoff2xy(Hparam.xmin*0.9999, 0, xmin_aid, ymin_aid);
         THistPainter::ProjectAitoff2xy(Hparam.xmax*0.9999, 0, xmax_aid, ymin_aid);
         if (xmin >xmin_aid) xmin = xmin_aid;
         if (xmax <xmax_aid) xmax = xmax_aid;
      }
      if (Hparam.xmin<0 && Hparam.xmax>0) {
         THistPainter::ProjectAitoff2xy(0, Hparam.ymin, xmin_aid, ymin_aid);
         THistPainter::ProjectAitoff2xy(0, Hparam.ymax, xmax_aid, ymax_aid);
         if (ymin >ymin_aid) ymin = ymin_aid;
         if (ymax <ymax_aid) ymax = ymax_aid;
      }
   } else if ( Hoption.Proj ==2) {
      if (Hparam.ymin <= -90 || Hparam.ymax >=90) {
         Warning("Mercator Projection", "Latitude out of range %f or %f", Hparam.ymin, Hparam.ymax);
         Hoption.Proj = 0;
      } else {
         THistPainter::ProjectMercator2xy(Hparam.xmin, Hparam.ymin, xmin, ymin);
         THistPainter::ProjectMercator2xy(Hparam.xmax, Hparam.ymax, xmax, ymax);
      }
   } else if (Hoption.Proj == 3) {
      THistPainter::ProjectSinusoidal2xy(Hparam.xmin, Hparam.ymin, xmin_aid, ymin_aid);
      THistPainter::ProjectSinusoidal2xy(Hparam.xmin, Hparam.ymax, xmin,     ymax_aid);
      THistPainter::ProjectSinusoidal2xy(Hparam.xmax, Hparam.ymax, xmax_aid, ymax);
      THistPainter::ProjectSinusoidal2xy(Hparam.xmax, Hparam.ymin, xmax,     ymin);

      if (xmin > xmin_aid) xmin = xmin_aid;
      if (ymin > ymin_aid) ymin = ymin_aid;
      if (xmax < xmax_aid) xmax = xmax_aid;
      if (ymax < ymax_aid) ymax = ymax_aid;
      if (Hparam.ymin<0 && Hparam.ymax>0) {
         THistPainter::ProjectSinusoidal2xy(Hparam.xmin, 0, xmin_aid, ymin_aid);
         THistPainter::ProjectSinusoidal2xy(Hparam.xmax, 0, xmax_aid, ymin_aid);
         if (xmin >xmin_aid) xmin = xmin_aid;
         if (xmax <xmax_aid) xmax = xmax_aid;
      }
      if (Hparam.xmin<0 && Hparam.xmax>0) {
         THistPainter::ProjectSinusoidal2xy(0,Hparam.ymin, xmin_aid, ymin_aid);
         THistPainter::ProjectSinusoidal2xy(0, Hparam.ymax, xmax_aid, ymin_aid);
         if (ymin >ymin_aid) ymin = ymin_aid;
         if (ymax <ymax_aid) ymax = ymax_aid;
      }
   } else if (Hoption.Proj == 4) {
      THistPainter::ProjectParabolic2xy(Hparam.xmin, Hparam.ymin, xmin_aid, ymin_aid);
      THistPainter::ProjectParabolic2xy(Hparam.xmin, Hparam.ymax, xmin,     ymax_aid);
      THistPainter::ProjectParabolic2xy(Hparam.xmax, Hparam.ymax, xmax_aid, ymax);
      THistPainter::ProjectParabolic2xy(Hparam.xmax, Hparam.ymin, xmax,     ymin);

      if (xmin > xmin_aid) xmin = xmin_aid;
      if (ymin > ymin_aid) ymin = ymin_aid;
      if (xmax < xmax_aid) xmax = xmax_aid;
      if (ymax < ymax_aid) ymax = ymax_aid;
      if (Hparam.ymin<0 && Hparam.ymax>0) {
         THistPainter::ProjectParabolic2xy(Hparam.xmin, 0, xmin_aid, ymin_aid);
         THistPainter::ProjectParabolic2xy(Hparam.xmax, 0, xmax_aid, ymin_aid);
         if (xmin >xmin_aid) xmin = xmin_aid;
         if (xmax <xmax_aid) xmax = xmax_aid;
      }
      if (Hparam.xmin<0 && Hparam.xmax>0) {
         THistPainter::ProjectParabolic2xy(0, Hparam.ymin, xmin_aid, ymin_aid);
         THistPainter::ProjectParabolic2xy(0, Hparam.ymax, xmax_aid, ymin_aid);
         if (ymin >ymin_aid) ymin = ymin_aid;
         if (ymax <ymax_aid) ymax = ymax_aid;
      }
   }
   Hparam.xmin= xmin;
   Hparam.xmax= xmax;
   Hparam.ymin= ymin;
   Hparam.ymax= ymax;

   Double_t dx   = xmax-xmin;
   Double_t dy   = ymax-ymin;
   Double_t dxr  = dx/(1 - gPad->GetLeftMargin()   - gPad->GetRightMargin());
   Double_t dyr  = dy/(1 - gPad->GetBottomMargin() - gPad->GetTopMargin());

   // Range() could change the size of the pad pixmap and therefore should
   // be called before the other paint routines
   gPad->Range(xmin - dxr*gPad->GetLeftMargin(),
                      ymin - dyr*gPad->GetBottomMargin(),
                      xmax + dxr*gPad->GetRightMargin(),
                      ymax + dyr*gPad->GetTopMargin());
   gPad->RangeAxis(xmin, ymin, xmax, ymax);
}


//______________________________________________________________________________
void THistPainter::SetHistogram(TH1 *h)
{
   /* Begin_html
   Set current histogram to "h".
   End_html */

   if (h == 0)  return;
   fH = h;
   fXaxis = h->GetXaxis();
   fYaxis = h->GetYaxis();
   fZaxis = h->GetZaxis();
   fFunctions = fH->GetListOfFunctions();
}


//______________________________________________________________________________
Int_t THistPainter::TableInit()
{
   /* Begin_html
   Initialize various options to draw 2D histograms.
   End_html */

   static const char *where = "TableInit";

   Int_t first, last;
   Double_t yMARGIN= gStyle->GetHistTopMargin();
   Double_t zmin, zmax;
   Int_t maximum = 0;
   Int_t minimum = 0;
   if (fH->GetMaximumStored() != -1111) maximum = 1;
   if (fH->GetMinimumStored() != -1111) minimum = 1;

   //    -----------------  Compute X axis parameters
   first           = fXaxis->GetFirst();
   last            = fXaxis->GetLast();
   Hparam.xlast    = last;
   Hparam.xfirst   = first;
   Hparam.xlowedge = fXaxis->GetBinLowEdge(first);
   Hparam.xbinsize = fXaxis->GetBinWidth(first);
   Hparam.xmin     = Hparam.xlowedge;
   Hparam.xmax     = fXaxis->GetBinLowEdge(last)+fXaxis->GetBinWidth(last);

   //       if log scale in X, replace xmin,max by the log
   if (Hoption.Logx) {
   //   find the first edge of a bin that is > 0
      if (Hparam.xlowedge <=0 ) {
         Hparam.xlowedge = fXaxis->GetBinUpEdge(fXaxis->FindFixBin(0.01*Hparam.xbinsize));
         Hparam.xmin  = Hparam.xlowedge;
      }
      if (Hparam.xmin <=0 || Hparam.xmax <=0) {
         Error(where, "cannot set X axis to log scale");
         return 0;
      }
      Hparam.xfirst= fXaxis->FindFixBin(Hparam.xmin);
      if (Hparam.xfirst < first) Hparam.xfirst = first;
      Hparam.xlast = fXaxis->FindFixBin(Hparam.xmax);
      if (Hparam.xlast > last) Hparam.xlast = last;
      Hparam.xmin  = TMath::Log10(Hparam.xmin);
      Hparam.xmax  = TMath::Log10(Hparam.xmax);
   }

   //    -----------------  Compute Y axis parameters
   first           = fYaxis->GetFirst();
   last            = fYaxis->GetLast();
   Hparam.ylast    = last;
   Hparam.yfirst   = first;
   Hparam.ylowedge = fYaxis->GetBinLowEdge(first);
   Hparam.ybinsize = fYaxis->GetBinWidth(first);
   if (!Hparam.ybinsize) Hparam.ybinsize = 1;
   Hparam.ymin     = Hparam.ylowedge;
   Hparam.ymax     = fYaxis->GetBinLowEdge(last)+fYaxis->GetBinWidth(last);

   //       if log scale in Y, replace ymin,max by the log
   if (Hoption.Logy) {
      if (Hparam.ylowedge <=0 ) {
         Hparam.ylowedge = fYaxis->GetBinUpEdge(fYaxis->FindFixBin(0.01*Hparam.ybinsize));
         Hparam.ymin  = Hparam.ylowedge;
      }
      if (Hparam.ymin <=0 || Hparam.ymax <=0) {
         Error(where, "cannot set Y axis to log scale");
         return 0;
      }
      Hparam.yfirst= fYaxis->FindFixBin(Hparam.ymin);
      if (Hparam.yfirst < first) Hparam.yfirst = first;
      Hparam.ylast = fYaxis->FindFixBin(Hparam.ymax);
      if (Hparam.ylast > last) Hparam.ylast = last;
      Hparam.ymin  = TMath::Log10(Hparam.ymin);
      Hparam.ymax  = TMath::Log10(Hparam.ymax);
   }


   //    -----------------  Compute Z axis parameters
   Double_t bigp = TMath::Power(10,32);
   zmax = -bigp;
   zmin = bigp;
   Double_t c1, e1;
   Double_t allchan = 0;
   for (Int_t j=Hparam.yfirst; j<=Hparam.ylast;j++) {
      for (Int_t i=Hparam.xfirst; i<=Hparam.xlast;i++) {
         c1 = fH->GetBinContent(i,j);
         zmax = TMath::Max(zmax,c1);
         if (Hoption.Error) {
            e1 = fH->GetBinError(i,j);
            zmax = TMath::Max(zmax,c1+e1);
         }
         zmin = TMath::Min(zmin,c1);
         allchan += c1;
      }
   }

   //     Take into account maximum , minimum

   if (maximum) zmax = fH->GetMaximumStored();
   if (minimum) zmin = fH->GetMinimumStored();
   if (Hoption.Logz && zmax < 0) {
      if (!Hoption.Same) Error(where, "log scale is requested but maximum is less or equal 0 (%f)", zmax);
      return 0;
   } else if (Hoption.Logz && zmin>=0 && zmax==0) { // empty histogram in log scale
      zmin = 0.01;
      zmax = 10.;
   }
   if (zmin >= zmax) {
      if (Hoption.Logz) {
         if (zmax > 0) zmin = 0.001*zmax;
         else {
            if (!Hoption.Same) Error(where, "log scale is requested but maximum is less or equal 0 (%f)", zmax);
            return 0;
         }
      }
   }

   //     take into account normalization factor
   Hparam.allchan = allchan;
   Double_t factor = allchan;
   if (fH->GetNormFactor() > 0) factor = fH->GetNormFactor();
   if (allchan) factor /= allchan;
   if (factor == 0) factor = 1;
   Hparam.factor = factor;
   zmax = factor*zmax;
   zmin = factor*zmin;
   c1 = zmax;
   if (TMath::Abs(zmin) > TMath::Abs(c1)) c1 = zmin;

   //         For log scales, histogram coordinates are log10(ymin) and
   //         log10(ymax). Final adjustment (if not option "Same")
   //         or "+" for ymax) of ymax and ymin for logarithmic scale, if
   //         Maximum and Minimum are not defined.
   if (Hoption.Logz) {
      if (zmin <= 0) {
         zmin = TMath::Min((Double_t)1, (Double_t)0.001*zmax);
         fH->SetMinimum(zmin);
      }
      zmin = TMath::Log10(zmin);
      if (!minimum) zmin += TMath::Log10(0.5);
      zmax = TMath::Log10(zmax);
      if (!maximum) zmax += TMath::Log10(2*(0.9/0.95));
      goto LZMIN;
   }

   //         final adjustment of YMAXI for linear scale (if not option "Same"):
   //         decrease histogram height to MAX% of allowed height if HMAXIM
   //         has not been called.
   //         MAX% is the value in percent which has been set in HPLSET
   //         (default is 90%).
   if (!maximum) {
      zmax += yMARGIN*(zmax-zmin);
   }

   //         final adjustment of ymin for linear scale.
   //         if minimum is not set , then ymin is set to zero if >0
   //         or to ymin - yMARGIN if <0.
   if (!minimum) {
      if (gStyle->GetHistMinimumZero()) {
         if (zmin >= 0) zmin = 0;
         else           zmin -= yMARGIN*(zmax-zmin);
      } else {
         Double_t dzmin = yMARGIN*(zmax-zmin);
         if (zmin >= 0 && (zmin-dzmin <= 0)) zmin  = 0;
         else                                zmin -= dzmin;
      }
   }

LZMIN:
   Hparam.zmin = zmin;
   Hparam.zmax = zmax;

   //     Set bar offset and width
   Hparam.baroffset = fH->GetBarOffset();
   Hparam.barwidth  = fH->GetBarWidth();

   return 1;
}


//______________________________________________________________________________
const char * THistPainter::GetBestFormat(Double_t v, Double_t e, const char *f)
{
   /* Begin_html
   This function returns the best format to print the error value (e)
   knowing the parameter value (v) and the format (f) used to print it.
   End_html */

   static char ef[20];
   char tf[20], tv[64];

   // print v with the format f in tv.
   snprintf(tf,20,"%s%s","%",f);
   snprintf(tv,64,tf,v);

   // Analyse tv.
   TString sv = tv;
   int ie = sv.Index("e");
   int iE = sv.Index("E");
   int id = sv.Index(".");

   // v has been printed with the exponent notation.
   // There is 2 cases, the exponent is positive or negative
   if (ie >= 0 || iE >= 0) {
      if (sv.Index("+") >= 0) {
         if (e < 1) {
            snprintf(ef,20,"%s.1f","%");
         } else {
            if (ie >= 0) {
               snprintf(ef,20,"%s.%de","%",ie-id-1);
            } else {
               snprintf(ef,20,"%s.%dE","%",iE-id-1);
            }
         }
      } else {
         if (ie >= 0) {
            snprintf(ef,20,"%s.%de","%",ie-id-1);
         } else {
            snprintf(ef,20,"%s.%dE","%",iE-id-1);
         }
      }

   // There is not '.' in tv. e will be printed with one decimal digit.
   } else if (id < 0) {
      snprintf(ef,20,"%s.1f","%");

   // There is a '.' in tv and no exponent notation. e's decimal part will
   // have the same number of digits as v's one.
   } else {
      snprintf(ef,20,"%s.%df","%",sv.Length()-id-1);
   }

   return ef;
}


//______________________________________________________________________________
void THistPainter::SetShowProjection(const char *option,Int_t nbins)
{
   /* Begin_html
   Set projection.
   End_html */

   if (fShowProjection) return;
   TString opt = option;
   opt.ToLower();
   Int_t projection = 0;
   if (opt.Contains("x"))  projection = 1;
   if (opt.Contains("y"))  projection = 2;
   if (opt.Contains("z"))  projection = 3;
   if (opt.Contains("xy")) projection = 4;
   if (opt.Contains("yx")) projection = 5;
   if (opt.Contains("xz")) projection = 6;
   if (opt.Contains("zx")) projection = 7;
   if (opt.Contains("yz")) projection = 8;
   if (opt.Contains("zy")) projection = 9;
   if (projection < 4) fShowOption = option+1;
   else                fShowOption = option+2;
   fShowProjection = projection+100*nbins;
   gROOT->MakeDefCanvas();
   gPad->SetName(Form("c_%lx_projection_%d", (ULong_t)fH, fShowProjection));
   gPad->SetGrid();
}


//______________________________________________________________________________
void THistPainter::ShowProjectionX(Int_t /*px*/, Int_t py)
{
   /* Begin_html
   Show projection onto X.
   End_html */

   Int_t nbins = (Int_t)fShowProjection/100;
   gPad->SetDoubleBuffer(0); // turn off double buffer mode
   gVirtualX->SetDrawMode(TVirtualX::kInvert); // set the drawing mode to XOR mode

   // Erase old position and draw a line at current position
   static int pyold1 = 0;
   static int pyold2 = 0;
   float uxmin = gPad->GetUxmin();
   float uxmax = gPad->GetUxmax();
   int pxmin   = gPad->XtoAbsPixel(uxmin);
   int pxmax   = gPad->XtoAbsPixel(uxmax);
   Float_t upy = gPad->AbsPixeltoY(py);
   Float_t y   = gPad->PadtoY(upy);
   Int_t biny1 = fH->GetYaxis()->FindBin(y);
   Int_t biny2 = TMath::Min(biny1+nbins-1, fH->GetYaxis()->GetNbins());
   Int_t py1   = gPad->YtoAbsPixel(fH->GetYaxis()->GetBinLowEdge(biny1));
   Int_t py2   = gPad->YtoAbsPixel(fH->GetYaxis()->GetBinUpEdge(biny2));

   if (pyold1 || pyold2) gVirtualX->DrawBox(pxmin,pyold1,pxmax,pyold2,TVirtualX::kFilled);
   gVirtualX->DrawBox(pxmin,py1,pxmax,py2,TVirtualX::kFilled);
   pyold1 = py1;
   pyold2 = py2;

   // Create or set the new canvas proj x
   TVirtualPad *padsav = gPad;
   TVirtualPad *c = (TVirtualPad*)gROOT->GetListOfCanvases()->FindObject(Form("c_%lx_projection_%d",
                                                                              (ULong_t)fH, fShowProjection));
   if (c) {
      c->Clear();
   } else {
      fShowProjection = 0;
      pyold1 = 0;
      pyold2 = 0;
      return;
   }
   c->cd();
   c->SetLogy(padsav->GetLogz());
   c->SetLogx(padsav->GetLogx());

   // Draw slice corresponding to mouse position
   TString prjName = TString::Format("slice_px_of_%s",fH->GetName());
   TH1D *hp = ((TH2*)fH)->ProjectionX(prjName, biny1, biny2);
   if (hp) {
      hp->SetFillColor(38);
      // apply a patch from Oliver Freyermuth to set the title in the projection using the range of the projected Y values 
      if (biny1 == biny2) {
         Double_t valueFrom   = fH->GetYaxis()->GetBinLowEdge(biny1);
         Double_t valueTo     = fH->GetYaxis()->GetBinUpEdge(biny1);
         // Limit precision to 1 digit more than the difference between upper and lower bound (to also catch 121.5-120.5).
         Int_t valuePrecision = -TMath::Nint(TMath::Log10(valueTo-valueFrom))+1;
         if (fH->GetYaxis()->GetLabels() != NULL) {
            hp->SetTitle(TString::Format("ProjectionX of biny=%d [y=%.*lf..%.*lf] %s", biny1, valuePrecision, valueFrom, valuePrecision, valueTo, fH->GetYaxis()->GetBinLabel(biny1)));
         } else {
            hp->SetTitle(TString::Format("ProjectionX of biny=%d [y=%.*lf..%.*lf]", biny1, valuePrecision, valueFrom, valuePrecision, valueTo));
         }
      } else {
         Double_t valueFrom   = fH->GetYaxis()->GetBinLowEdge(biny1);
         Double_t valueTo     = fH->GetYaxis()->GetBinUpEdge(biny2);
         // Limit precision to 1 digit more than the difference between upper and lower bound (to also catch 121.5-120.5).
         // biny1 is used here to get equal precision no matter how large the binrange is,
         // otherwise precision may change when moving the mouse to the histogram boundaries (limiting effective binrange).
         Int_t valuePrecision = -TMath::Nint(TMath::Log10(fH->GetYaxis()->GetBinUpEdge(biny1)-valueFrom))+1;
         if (fH->GetYaxis()->GetLabels() != NULL) {
            hp->SetTitle(TString::Format("ProjectionX of biny=[%d,%d] [y=%.*lf..%.*lf] [%s..%s]", biny1, biny2, valuePrecision, valueFrom, valuePrecision, valueTo, fH->GetYaxis()->GetBinLabel(biny1), fH->GetYaxis()->GetBinLabel(biny2)));
         } else {
            hp->SetTitle(TString::Format("ProjectionX of biny=[%d,%d] [y=%.*lf..%.*lf]", biny1, biny2, valuePrecision, valueFrom, valuePrecision, valueTo));
         }
      }
      hp->SetXTitle(fH->GetXaxis()->GetTitle());
      hp->SetYTitle("Number of Entries");
      hp->Draw();
      c->Update();
      padsav->cd();
   }
}


//______________________________________________________________________________
void THistPainter::ShowProjectionY(Int_t px, Int_t /*py*/)
{
   /* Begin_html
   Show projection onto Y.
   End_html */

   Int_t nbins = (Int_t)fShowProjection/100;
   gPad->SetDoubleBuffer(0);             // turn off double buffer mode
   gVirtualX->SetDrawMode(TVirtualX::kInvert);  // set the drawing mode to XOR mode

   // Erase old position and draw a line at current position
   static int pxold1 = 0;
   static int pxold2 = 0;
   float uymin = gPad->GetUymin();
   float uymax = gPad->GetUymax();
   int pymin   = gPad->YtoAbsPixel(uymin);
   int pymax   = gPad->YtoAbsPixel(uymax);
   Float_t upx = gPad->AbsPixeltoX(px);
   Float_t x   = gPad->PadtoX(upx);
   Int_t binx1 = fH->GetXaxis()->FindBin(x);
   Int_t binx2 = TMath::Min(binx1+nbins-1, fH->GetXaxis()->GetNbins());
   Int_t px1   = gPad->XtoAbsPixel(fH->GetXaxis()->GetBinLowEdge(binx1));
   Int_t px2   = gPad->XtoAbsPixel(fH->GetXaxis()->GetBinUpEdge(binx2));

   if (pxold1 || pxold2) gVirtualX->DrawBox(pxold1,pymin,pxold2,pymax,TVirtualX::kFilled);
   gVirtualX->DrawBox(px1,pymin,px2,pymax,TVirtualX::kFilled);
   pxold1 = px1;
   pxold2 = px2;

   // Create or set the new canvas proj y
   TVirtualPad *padsav = gPad;
   TVirtualPad *c = (TVirtualPad*)gROOT->GetListOfCanvases()->FindObject(Form("c_%lx_projection_%d",
                                                                              (ULong_t)fH, fShowProjection));
   if (c) {
      c->Clear();
   } else {
      fShowProjection = 0;
      pxold1 = 0;
      pxold2 = 0;
      return;
   }
   c->cd();
   c->SetLogy(padsav->GetLogz());
   c->SetLogx(padsav->GetLogy());

   // Draw slice corresponding to mouse position
   TString prjName = TString::Format("slice_py_of_%s",fH->GetName());
   TH1D *hp = ((TH2*)fH)->ProjectionY(prjName, binx1, binx2);
   if (hp) {
      hp->SetFillColor(38);
      // apply a patch from Oliver Freyermuth to set the title in the projection using the range of the projected X values 
      if (binx1 == binx2) {
         Double_t valueFrom   = fH->GetXaxis()->GetBinLowEdge(binx1);
         Double_t valueTo     = fH->GetXaxis()->GetBinUpEdge(binx1);
         // Limit precision to 1 digit more than the difference between upper and lower bound (to also catch 121.5-120.5). 
         Int_t valuePrecision = -TMath::Nint(TMath::Log10(valueTo-valueFrom))+1;
         if (fH->GetXaxis()->GetLabels() != NULL) {
            hp->SetTitle(TString::Format("ProjectionY of binx=%d [x=%.*lf..%.*lf] [%s]", binx1, valuePrecision, valueFrom, valuePrecision, valueTo, fH->GetXaxis()->GetBinLabel(binx1)));
         } else {
            hp->SetTitle(TString::Format("ProjectionY of binx=%d [x=%.*lf..%.*lf]", binx1, valuePrecision, valueFrom, valuePrecision, valueTo));
         }
      } else {
         Double_t valueFrom   = fH->GetXaxis()->GetBinLowEdge(binx1);
         Double_t valueTo     = fH->GetXaxis()->GetBinUpEdge(binx2);
         // Limit precision to 1 digit more than the difference between upper and lower bound (to also catch 121.5-120.5).
         // binx1 is used here to get equal precision no matter how large the binrange is,
         // otherwise precision may change when moving the mouse to the histogram boundaries (limiting effective binrange).
         Int_t valuePrecision = -TMath::Nint(TMath::Log10(fH->GetXaxis()->GetBinUpEdge(binx1)-valueFrom))+1;
         if (fH->GetXaxis()->GetLabels() != NULL) {
            hp->SetTitle(TString::Format("ProjectionY of binx=[%d,%d] [x=%.*lf..%.*lf] [%s..%s]", binx1, binx2, valuePrecision, valueFrom, valuePrecision, valueTo, fH->GetXaxis()->GetBinLabel(binx1), fH->GetXaxis()->GetBinLabel(binx2)));
         } else {
            hp->SetTitle(TString::Format("ProjectionY of binx=[%d,%d] [x=%.*lf..%.*lf]", binx1, binx2, valuePrecision, valueFrom, valuePrecision, valueTo));
         }
      }
      hp->SetXTitle(fH->GetYaxis()->GetTitle());
      hp->SetYTitle("Number of Entries");
      hp->Draw();
      c->Update();
      padsav->cd();
   }
}


//______________________________________________________________________________
void THistPainter::ShowProjection3(Int_t px, Int_t py)
{
   /* Begin_html
   Show projection (specified by <tt>fShowProjection</tt>) of a <tt>TH3</tt>.
   The drawing option for the projection is in <tt>fShowOption</tt>.
   <p>
   First implementation; R.Brun <br>
   Full implementation: Tim Tran (timtran@jlab.org)  April 2006
   End_html */

   Int_t nbins=(Int_t)fShowProjection/100; //decode nbins
   if (fH->GetDimension() < 3) {
      if (fShowProjection%100 == 1) {ShowProjectionX(px,py); return;}
      if (fShowProjection%100 == 2) {ShowProjectionY(px,py); return;}
   }

   gPad->SetDoubleBuffer(0);             // turn off double buffer mode
   gVirtualX->SetDrawMode(TVirtualX::kInvert);  // set the drawing mode to XOR mode

   // Erase old position and draw a line at current position
   TView *view = gPad->GetView();
   if (!view) return;
   TH3 *h3 = (TH3*)fH;
   TAxis *xaxis = h3->GetXaxis();
   TAxis *yaxis = h3->GetYaxis();
   TAxis *zaxis = h3->GetZaxis();
   Double_t u[3],xx[3];

   static TPoint line1[2];//store end points of a line, initialised 0 by default
   static TPoint line2[2];// second line when slice thickness > 1 bin thickness
   static TPoint line3[2];
   static TPoint line4[2];
   static TPoint endface1[5];
   static TPoint endface2[5];
   static TPoint rect1[5];//store vertices of the polyline (rectangle), initialsed 0 by default
   static TPoint rect2[5];// second rectangle when slice thickness > 1 bin thickness

   Double_t uxmin = gPad->GetUxmin();
   Double_t uxmax = gPad->GetUxmax();
   Double_t uymin = gPad->GetUymin();
   Double_t uymax = gPad->GetUymax();

   int pxmin = gPad->XtoAbsPixel(uxmin);
   int pxmax = gPad->XtoAbsPixel(uxmax);
   if (pxmin==pxmax) return;
   int pymin = gPad->YtoAbsPixel(uymin);
   int pymax = gPad->YtoAbsPixel(uymax);
   if (pymin==pymax) return;
   Double_t cx    = (pxmax-pxmin)/(uxmax-uxmin);
   Double_t cy    = (pymax-pymin)/(uymax-uymin);
   TVirtualPad *padsav = gPad;
   TVirtualPad *c = (TVirtualPad*)gROOT->GetListOfCanvases()->FindObject(Form("c_%lx_projection_%d",
                                                                              (ULong_t)fH, fShowProjection));
   if (!c) {
      fShowProjection = 0;
      return;
   }

   switch ((Int_t)fShowProjection%100) {
      case 1:
         // "x"
         {
            Int_t firstY = yaxis->GetFirst();
            Int_t lastY  = yaxis->GetLast();
            Int_t biny = firstY + Int_t((lastY-firstY)*(px-pxmin)/(pxmax-pxmin));
            Int_t biny2 = TMath::Min(biny+nbins-1,yaxis->GetNbins() );
            yaxis->SetRange(biny,biny2);
            Int_t firstZ = zaxis->GetFirst();
            Int_t lastZ  = zaxis->GetLast();
            Int_t binz = firstZ + Int_t((lastZ-firstZ)*(py-pymin)/(pymax-pymin));
            Int_t binz2 = TMath::Min(binz+nbins-1,zaxis->GetNbins() );
            zaxis->SetRange(binz,binz2);
            if (line1[0].GetX()) gVirtualX->DrawPolyLine(2,line1);
            if (nbins>1 && line1[0].GetX()) {
               gVirtualX->DrawPolyLine(2,line2);
               gVirtualX->DrawPolyLine(2,line3);
               gVirtualX->DrawPolyLine(2,line4);
               gVirtualX->DrawPolyLine(5,endface1);
               gVirtualX->DrawPolyLine(5,endface2);
            }
            xx[0] = xaxis->GetXmin();
            xx[2] = zaxis->GetBinCenter(binz);
            xx[1] = yaxis->GetBinCenter(biny);
            view->WCtoNDC(xx,u);
            line1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            line1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[0] = xaxis->GetXmax();
            view->WCtoNDC(xx,u);
            line1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            line1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(2,line1);
            if (nbins>1) {
               xx[0] = xaxis->GetXmin();
               xx[2] = zaxis->GetBinCenter(binz+nbins-1);
               xx[1] = yaxis->GetBinCenter(biny);
               view->WCtoNDC(xx,u);
               line2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[0] = xaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               xx[0] = xaxis->GetXmin();
               xx[2] = zaxis->GetBinCenter(binz+nbins-1);
               xx[1] = yaxis->GetBinCenter(biny+nbins-1);
               view->WCtoNDC(xx,u);
               line3[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line3[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[0] = xaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line3[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line3[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               xx[0] = xaxis->GetXmin();
               xx[2] = zaxis->GetBinCenter(binz);
               xx[1] = yaxis->GetBinCenter(biny+nbins-1);
               view->WCtoNDC(xx,u);
               line4[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line4[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[0] = xaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line4[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line4[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               endface1[0].SetX(line1[0].GetX());
               endface1[0].SetY(line1[0].GetY());
               endface1[1].SetX(line2[0].GetX());
               endface1[1].SetY(line2[0].GetY());
               endface1[2].SetX(line3[0].GetX());
               endface1[2].SetY(line3[0].GetY());
               endface1[3].SetX(line4[0].GetX());
               endface1[3].SetY(line4[0].GetY());
               endface1[4].SetX(line1[0].GetX());
               endface1[4].SetY(line1[0].GetY());

               endface2[0].SetX(line1[1].GetX());
               endface2[0].SetY(line1[1].GetY());
               endface2[1].SetX(line2[1].GetX());
               endface2[1].SetY(line2[1].GetY());
               endface2[2].SetX(line3[1].GetX());
               endface2[2].SetY(line3[1].GetY());
               endface2[3].SetX(line4[1].GetX());
               endface2[3].SetY(line4[1].GetY());
               endface2[4].SetX(line1[1].GetX());
               endface2[4].SetY(line1[1].GetY());

               gVirtualX->DrawPolyLine(2,line2);
               gVirtualX->DrawPolyLine(2,line3);
               gVirtualX->DrawPolyLine(2,line4);
               gVirtualX->DrawPolyLine(5,endface1);
               gVirtualX->DrawPolyLine(5,endface2);
            }
            c->Clear();
            c->cd();
            TH1 *hp = h3->Project3D("x");
            yaxis->SetRange(firstY,lastY);
            zaxis->SetRange(firstZ,lastZ);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins == 1) 
                  hp->SetTitle(TString::Format("ProjectionX of biny=%d [y=%.1f..%.1f] binz=%d [z=%.1f..%.1f]", biny, yaxis->GetBinLowEdge(biny), yaxis->GetBinUpEdge(biny), 
                                               binz, zaxis->GetBinLowEdge(binz), zaxis->GetBinUpEdge(binz)));
               else { 
                  hp->SetTitle(TString::Format("ProjectionX, biny=[%d,%d] [y=%.1f..%.1f], binz=[%d,%d] [z=%.1f..%.1f]", biny, biny2, yaxis->GetBinLowEdge(biny), yaxis->GetBinUpEdge(biny2), 
                                               binz, binz2, zaxis->GetBinLowEdge(binz), zaxis->GetBinUpEdge(binz2) ) );
               }
               hp->SetXTitle(fH->GetXaxis()->GetTitle());
               hp->SetYTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 2:
         // "y"
         {
            Int_t firstX = xaxis->GetFirst();
            Int_t lastX  = xaxis->GetLast();
            Int_t binx = firstX + Int_t((lastX-firstX)*(px-pxmin)/(pxmax-pxmin));
            Int_t binx2 = TMath::Min(binx+nbins-1,xaxis->GetNbins() );                        
            xaxis->SetRange(binx,binx2);
            Int_t firstZ = zaxis->GetFirst();
            Int_t lastZ  = zaxis->GetLast();
            Int_t binz = firstZ + Int_t((lastZ-firstZ)*(py-pymin)/(pymax-pymin));
            Int_t binz2 = TMath::Min(binz+nbins-1,zaxis->GetNbins() );
            zaxis->SetRange(binz,binz2);
            if (line1[0].GetX()) gVirtualX->DrawPolyLine(2,line1);
            if (nbins>1 && line1[0].GetX()) {
               gVirtualX->DrawPolyLine(2,line2);
               gVirtualX->DrawPolyLine(2,line3);
               gVirtualX->DrawPolyLine(2,line4);
               gVirtualX->DrawPolyLine(5,endface1);
               gVirtualX->DrawPolyLine(5,endface2);
            }
            xx[0]=xaxis->GetBinCenter(binx);
            xx[2] = zaxis->GetBinCenter(binz);
            xx[1] = yaxis->GetXmin();
            view->WCtoNDC(xx,u);
            line1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            line1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[1] = yaxis->GetXmax();
            view->WCtoNDC(xx,u);
            line1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            line1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(2,line1);
            if (nbins>1) {
               xx[1] = yaxis->GetXmin();
               xx[2] = zaxis->GetBinCenter(binz+nbins-1);
               xx[0] = xaxis->GetBinCenter(binx);
               view->WCtoNDC(xx,u);
               line2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[1] = yaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               xx[1] = yaxis->GetXmin();
               xx[2] = zaxis->GetBinCenter(binz+nbins-1);
               xx[0] = xaxis->GetBinCenter(binx+nbins-1);
               view->WCtoNDC(xx,u);
               line3[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line3[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[1] = yaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line3[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line3[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               xx[1] = yaxis->GetXmin();
               xx[2] = zaxis->GetBinCenter(binz);
               xx[0] = xaxis->GetBinCenter(binx+nbins-1);
               view->WCtoNDC(xx,u);
               line4[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line4[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[1] = yaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line4[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line4[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               endface1[0].SetX(line1[0].GetX());
               endface1[0].SetY(line1[0].GetY());
               endface1[1].SetX(line2[0].GetX());
               endface1[1].SetY(line2[0].GetY());
               endface1[2].SetX(line3[0].GetX());
               endface1[2].SetY(line3[0].GetY());
               endface1[3].SetX(line4[0].GetX());
               endface1[3].SetY(line4[0].GetY());
               endface1[4].SetX(line1[0].GetX());
               endface1[4].SetY(line1[0].GetY());

               endface2[0].SetX(line1[1].GetX());
               endface2[0].SetY(line1[1].GetY());
               endface2[1].SetX(line2[1].GetX());
               endface2[1].SetY(line2[1].GetY());
               endface2[2].SetX(line3[1].GetX());
               endface2[2].SetY(line3[1].GetY());
               endface2[3].SetX(line4[1].GetX());
               endface2[3].SetY(line4[1].GetY());
               endface2[4].SetX(line1[1].GetX());
               endface2[4].SetY(line1[1].GetY());

               gVirtualX->DrawPolyLine(2,line2);
               gVirtualX->DrawPolyLine(2,line3);
               gVirtualX->DrawPolyLine(2,line4);
               gVirtualX->DrawPolyLine(5,endface1);
               gVirtualX->DrawPolyLine(5,endface2);
            }
            c->Clear();
            c->cd();
            TH1 *hp = h3->Project3D("y");
            xaxis->SetRange(firstX,lastX);
            zaxis->SetRange(firstZ,lastZ);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins == 1) 
                  hp->SetTitle(TString::Format("ProjectionY of binx=%d [x=%.1f..%.1f] binz=%d [z=%.1f..%.1f]", binx, xaxis->GetBinLowEdge(binx), xaxis->GetBinUpEdge(binx), 
                                               binz, zaxis->GetBinLowEdge(binz), zaxis->GetBinUpEdge(binz)));
               else 
                  hp->SetTitle(TString::Format("ProjectionY, binx=[%d,%d] [x=%.1f..%.1f], binz=[%d,%d] [z=%.1f..%.1f]", binx, binx2, xaxis->GetBinLowEdge(binx), xaxis->GetBinUpEdge(binx2), 
                                               binz, binz2, zaxis->GetBinLowEdge(binz), zaxis->GetBinUpEdge(binz2) ) );
               hp->SetXTitle(fH->GetYaxis()->GetTitle());
               hp->SetYTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 3:
         // "z"
         {
            Int_t firstX = xaxis->GetFirst();
            Int_t lastX  = xaxis->GetLast();
            Int_t binx = firstX + Int_t((lastX-firstX)*(px-pxmin)/(pxmax-pxmin));
            Int_t binx2 = TMath::Min(binx+nbins-1,xaxis->GetNbins() );                        
            xaxis->SetRange(binx,binx2);
            Int_t firstY = yaxis->GetFirst();
            Int_t lastY  = yaxis->GetLast();
            Int_t biny = firstY + Int_t((lastY-firstY)*(py-pymin)/(pymax-pymin));
            Int_t biny2 = TMath::Min(biny+nbins-1,yaxis->GetNbins() );
            yaxis->SetRange(biny,biny2);
            if (line1[0].GetX()) gVirtualX->DrawPolyLine(2,line1);
            if (nbins>1 && line1[0].GetX()) {
               gVirtualX->DrawPolyLine(2,line2);
               gVirtualX->DrawPolyLine(2,line3);
               gVirtualX->DrawPolyLine(2,line4);
               gVirtualX->DrawPolyLine(5,endface1);
               gVirtualX->DrawPolyLine(5,endface2);
            }
            xx[0] = xaxis->GetBinCenter(binx);
            xx[1] = yaxis->GetBinCenter(biny);
            xx[2] = zaxis->GetXmin();
            view->WCtoNDC(xx,u);
            line1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            line1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[2] = zaxis->GetXmax();
            view->WCtoNDC(xx,u);
            line1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            line1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(2,line1);
            if (nbins>1) {
               xx[2] = zaxis->GetXmin();
               xx[1] = yaxis->GetBinCenter(biny+nbins-1);
               xx[0] = xaxis->GetBinCenter(binx);
               view->WCtoNDC(xx,u);
               line2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[2] = zaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               xx[2] = zaxis->GetXmin();
               xx[1] = yaxis->GetBinCenter(biny+nbins-1);
               xx[0] = xaxis->GetBinCenter(binx+nbins-1);
               view->WCtoNDC(xx,u);
               line3[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line3[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[2] = zaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line3[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line3[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               xx[2] = zaxis->GetXmin();
               xx[1] = yaxis->GetBinCenter(biny);
               xx[0] = xaxis->GetBinCenter(binx+nbins-1);
               view->WCtoNDC(xx,u);
               line4[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line4[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[2] = zaxis->GetXmax();
               view->WCtoNDC(xx,u);
               line4[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               line4[1].SetY(pymin + Int_t((u[1]-uymin)*cy));

               endface1[0].SetX(line1[0].GetX());
               endface1[0].SetY(line1[0].GetY());
               endface1[1].SetX(line2[0].GetX());
               endface1[1].SetY(line2[0].GetY());
               endface1[2].SetX(line3[0].GetX());
               endface1[2].SetY(line3[0].GetY());
               endface1[3].SetX(line4[0].GetX());
               endface1[3].SetY(line4[0].GetY());
               endface1[4].SetX(line1[0].GetX());
               endface1[4].SetY(line1[0].GetY());

               endface2[0].SetX(line1[1].GetX());
               endface2[0].SetY(line1[1].GetY());
               endface2[1].SetX(line2[1].GetX());
               endface2[1].SetY(line2[1].GetY());
               endface2[2].SetX(line3[1].GetX());
               endface2[2].SetY(line3[1].GetY());
               endface2[3].SetX(line4[1].GetX());
               endface2[3].SetY(line4[1].GetY());
               endface2[4].SetX(line1[1].GetX());
               endface2[4].SetY(line1[1].GetY());

               gVirtualX->DrawPolyLine(2,line2);
               gVirtualX->DrawPolyLine(2,line3);
               gVirtualX->DrawPolyLine(2,line4);
               gVirtualX->DrawPolyLine(5,endface1);
               gVirtualX->DrawPolyLine(5,endface2);
            }
            c->Clear();
            c->cd();
            TH1 *hp = h3->Project3D("z");
            xaxis->SetRange(firstX,lastX);
            yaxis->SetRange(firstY,lastY);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins == 1) 
                  hp->SetTitle(TString::Format("ProjectionZ of binx=%d [x=%.1f..%.1f] biny=%d [y=%.1f..%.1f]", binx, xaxis->GetBinLowEdge(binx), xaxis->GetBinUpEdge(binx), 
                                               biny, yaxis->GetBinLowEdge(biny), yaxis->GetBinUpEdge(biny)));
               else 
                  hp->SetTitle(TString::Format("ProjectionZ, binx=[%d,%d] [x=%.1f..%.1f], biny=[%d,%d] [y=%.1f..%.1f]", binx, binx2, xaxis->GetBinLowEdge(binx), xaxis->GetBinUpEdge(binx2), 
                                               biny, biny2, yaxis->GetBinLowEdge(biny), yaxis->GetBinUpEdge(biny2) ) );
               hp->SetXTitle(fH->GetZaxis()->GetTitle());
               hp->SetYTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 4:
         // "xy"
         {
            Int_t first = zaxis->GetFirst();
            Int_t last  = zaxis->GetLast();
            Int_t binz  = first + Int_t((last-first)*(py-pymin)/(pymax-pymin));
            Int_t binz2 = TMath::Min(binz+nbins-1,zaxis->GetNbins() );
            zaxis->SetRange(binz,binz2);
            if (rect1[0].GetX())            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1 && rect2[0].GetX()) gVirtualX->DrawPolyLine(5,rect2);
            xx[0] = xaxis->GetXmin();
            xx[1] = yaxis->GetXmax();
            xx[2] = zaxis->GetBinCenter(binz);
            view->WCtoNDC(xx,u);
            rect1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            rect1[4].SetX(rect1[0].GetX());
            rect1[4].SetY(rect1[0].GetY());
            xx[0] = xaxis->GetXmax();
            view->WCtoNDC(xx,u);
            rect1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[1] = yaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[0] = xaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1) {
               xx[0] = xaxis->GetXmin();
               xx[1] = yaxis->GetXmax();
               xx[2] = zaxis->GetBinCenter(binz+nbins-1);
               view->WCtoNDC(xx,u);
               rect2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               rect2[4].SetX(rect2[0].GetX());
               rect2[4].SetY(rect2[0].GetY());
               xx[0] = xaxis->GetXmax();
               view->WCtoNDC(xx,u);
               rect2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[1] = yaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[0] = xaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
               gVirtualX->DrawPolyLine(5,rect2);
            }

            c->Clear();
            c->cd();
            TH2 *hp = (TH2*)h3->Project3D("xy");
            zaxis->SetRange(first,last);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins==1)hp->SetTitle(TString::Format("ProjectionXY of binz=%d [z=%.1f..%.f]", binz,zaxis->GetBinLowEdge(binz),zaxis->GetBinUpEdge(binz)));
               else        hp->SetTitle(TString::Format("ProjectionXY, binz=[%d,%d] [z=%.1f..%.1f]", binz,binz2,zaxis->GetBinLowEdge(binz),zaxis->GetBinUpEdge(binz2)));
               hp->SetXTitle(fH->GetYaxis()->GetTitle());
               hp->SetYTitle(fH->GetXaxis()->GetTitle());
               hp->SetZTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 5:
         // "yx"
         {
            Int_t first = zaxis->GetFirst();
            Int_t last  = zaxis->GetLast();
            Int_t binz = first + Int_t((last-first)*(py-pymin)/(pymax-pymin));
            Int_t binz2 = TMath::Min(binz+nbins-1,zaxis->GetNbins() );
            zaxis->SetRange(binz,binz2);
            if (rect1[0].GetX())            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1 && rect2[0].GetX()) gVirtualX->DrawPolyLine(5,rect2);
            xx[0] = xaxis->GetXmin();
            xx[1] = yaxis->GetXmax();
            xx[2] = zaxis->GetBinCenter(binz);
            view->WCtoNDC(xx,u);
            rect1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            rect1[4].SetX(rect1[0].GetX());
            rect1[4].SetY(rect1[0].GetY());
            xx[0] = xaxis->GetXmax();
            view->WCtoNDC(xx,u);
            rect1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[1] = yaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[0] = xaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1) {
               xx[0] = xaxis->GetXmin();
               xx[1] = yaxis->GetXmax();
               xx[2] = zaxis->GetBinCenter(binz+nbins-1);
               view->WCtoNDC(xx,u);
               rect2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               rect2[4].SetX(rect2[0].GetX());
               rect2[4].SetY(rect2[0].GetY());
               xx[0] = xaxis->GetXmax();
               view->WCtoNDC(xx,u);
               rect2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[1] = yaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[0] = xaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
               gVirtualX->DrawPolyLine(5,rect2);
            }
            c->Clear();
            c->cd();
            TH2 *hp = (TH2*)h3->Project3D("yx");
            zaxis->SetRange(first,last);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins==1)hp->SetTitle(TString::Format("ProjectionYX of binz=%d [z=%.1f..%.f]", binz,zaxis->GetBinLowEdge(binz),zaxis->GetBinUpEdge(binz)));
               else        hp->SetTitle(TString::Format("ProjectionYX, binz=[%d,%d] [z=%.1f..%.1f]", binz,binz2,zaxis->GetBinLowEdge(binz),zaxis->GetBinUpEdge(binz2)));
               hp->SetXTitle(fH->GetXaxis()->GetTitle());
               hp->SetYTitle(fH->GetYaxis()->GetTitle());
               hp->SetZTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 6:
         // "xz"
         {
            Int_t first = yaxis->GetFirst();
            Int_t last  = yaxis->GetLast();
            Int_t biny = first + Int_t((last-first)*(py-pymin)/(pymax-pymin));
            Int_t biny2 = TMath::Min(biny+nbins-1,yaxis->GetNbins() );
            yaxis->SetRange(biny,biny2);
            if (rect1[0].GetX())            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1 && rect1[0].GetX()) gVirtualX->DrawPolyLine(5,rect2);
            xx[0] = xaxis->GetXmin();
            xx[2] = zaxis->GetXmax();
            xx[1] = yaxis->GetBinCenter(biny);
            view->WCtoNDC(xx,u);
            rect1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            rect1[4].SetX(rect1[0].GetX());
            rect1[4].SetY(rect1[0].GetY());
            xx[0] = xaxis->GetXmax();
            view->WCtoNDC(xx,u);
            rect1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[2] = zaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[0] = xaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1) {
               xx[0] = xaxis->GetXmin();
               xx[2] = zaxis->GetXmax();
               xx[1] = yaxis->GetBinCenter(biny+nbins-1);
               view->WCtoNDC(xx,u);
               rect2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               rect2[4].SetX(rect2[0].GetX());
               rect2[4].SetY(rect2[0].GetY());
               xx[0] = xaxis->GetXmax();
               view->WCtoNDC(xx,u);
               rect2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[2] = zaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[0] = xaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
               gVirtualX->DrawPolyLine(5,rect2);
            }
            c->Clear();
            c->cd();
            TH2 *hp = (TH2*)h3->Project3D("xz");
            yaxis->SetRange(first,last);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins==1)hp->SetTitle(TString::Format("ProjectionXZ of biny=%d [y=%.1f..%.f]", biny,yaxis->GetBinLowEdge(biny),yaxis->GetBinUpEdge(biny)));
               else        hp->SetTitle(TString::Format("ProjectionXZ, biny=[%d,%d] [y=%.1f..%.1f]", biny,biny2,yaxis->GetBinLowEdge(biny),yaxis->GetBinUpEdge(biny2)));
               hp->SetXTitle(fH->GetZaxis()->GetTitle());
               hp->SetYTitle(fH->GetXaxis()->GetTitle());
               hp->SetZTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 7:
         // "zx"
         {
            Int_t first = yaxis->GetFirst();
            Int_t last  = yaxis->GetLast();
            Int_t biny = first + Int_t((last-first)*(py-pymin)/(pymax-pymin));
            Int_t biny2 = TMath::Min(biny+nbins-1,yaxis->GetNbins() );
            yaxis->SetRange(biny,biny2);
            if (rect1[0].GetX())            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1 && rect1[0].GetX()) gVirtualX->DrawPolyLine(5,rect2);
            xx[0] = xaxis->GetXmin();
            xx[2] = zaxis->GetXmax();
            xx[1] = yaxis->GetBinCenter(biny);
            view->WCtoNDC(xx,u);
            rect1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            rect1[4].SetX(rect1[0].GetX());
            rect1[4].SetY(rect1[0].GetY());
            xx[0] = xaxis->GetXmax();
            view->WCtoNDC(xx,u);
            rect1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[2] = zaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[0] = xaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1) {
               xx[0] = xaxis->GetXmin();
               xx[2] = zaxis->GetXmax();
               xx[1] = yaxis->GetBinCenter(biny+nbins-1);
               view->WCtoNDC(xx,u);
               rect2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               rect2[4].SetX(rect2[0].GetX());
               rect2[4].SetY(rect2[0].GetY());
               xx[0] = xaxis->GetXmax();
               view->WCtoNDC(xx,u);
               rect2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[2] = zaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[0] = xaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
               gVirtualX->DrawPolyLine(5,rect2);
            }
            c->Clear();
            c->cd();
            TH2 *hp = (TH2*)h3->Project3D("zx");
            yaxis->SetRange(first,last);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins==1)hp->SetTitle(TString::Format("ProjectionZX of biny=%d [y=%.1f..%.f]", biny,yaxis->GetBinLowEdge(biny),yaxis->GetBinUpEdge(biny)));
               else        hp->SetTitle(TString::Format("ProjectionZX, biny=[%d,%d] [y=%.1f..%.1f]", biny,biny2,yaxis->GetBinLowEdge(biny),yaxis->GetBinUpEdge(biny2)));
               hp->SetXTitle(fH->GetXaxis()->GetTitle());
               hp->SetYTitle(fH->GetZaxis()->GetTitle());
               hp->SetZTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 8:
         // "yz"
         {
            Int_t first = xaxis->GetFirst();
            Int_t last  = xaxis->GetLast();
            Int_t binx = first + Int_t((last-first)*(px-pxmin)/(pxmax-pxmin));
            Int_t binx2 = TMath::Min(binx+nbins-1,xaxis->GetNbins() );                        
            xaxis->SetRange(binx,binx2);
            if (rect1[0].GetX()) gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1 && rect1[0].GetX()) gVirtualX->DrawPolyLine(5,rect2);
            xx[2] = zaxis->GetXmin();
            xx[1] = yaxis->GetXmax();
            xx[0] = xaxis->GetBinCenter(binx);
            view->WCtoNDC(xx,u);
            rect1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            rect1[4].SetX(rect1[0].GetX());
            rect1[4].SetY(rect1[0].GetY());
            xx[2] = zaxis->GetXmax();
            view->WCtoNDC(xx,u);
            rect1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[1] = yaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[2] = zaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1) {
               xx[2] = zaxis->GetXmin();
               xx[1] = yaxis->GetXmax();
               xx[0] = xaxis->GetBinCenter(binx+nbins-1);
               view->WCtoNDC(xx,u);
               rect2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               rect2[4].SetX(rect2[0].GetX());
               rect2[4].SetY(rect2[0].GetY());
               xx[2] = zaxis->GetXmax();
               view->WCtoNDC(xx,u);
               rect2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[1] = yaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[2] = zaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
               gVirtualX->DrawPolyLine(5,rect2);
            }
            c->Clear();
            c->cd();
            TH2 *hp = (TH2*)h3->Project3D("yz");
            xaxis->SetRange(first,last);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins==1)hp->SetTitle(TString::Format("ProjectionYZ of binx=%d [x=%.1f..%.f]", binx,xaxis->GetBinLowEdge(binx),xaxis->GetBinUpEdge(binx)));
               else         hp->SetTitle(TString::Format("ProjectionYZ, binx=[%d,%d] [x=%.1f..%.1f]", binx,binx2,xaxis->GetBinLowEdge(binx),xaxis->GetBinUpEdge(binx2)));
               hp->SetXTitle(fH->GetZaxis()->GetTitle());
               hp->SetYTitle(fH->GetYaxis()->GetTitle());
               hp->SetZTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

      case 9:
         // "zy"
         {
            Int_t first = xaxis->GetFirst();
            Int_t last  = xaxis->GetLast();
            Int_t binx = first + Int_t((last-first)*(px-pxmin)/(pxmax-pxmin));
            Int_t binx2 = TMath::Min(binx+nbins-1,xaxis->GetNbins() );                        
            xaxis->SetRange(binx,binx2);
            if (rect1[0].GetX()) gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1 && rect1[0].GetX()) gVirtualX->DrawPolyLine(5,rect2);
            xx[2] = zaxis->GetXmin();
            xx[1] = yaxis->GetXmax();
            xx[0] = xaxis->GetBinCenter(binx);
            view->WCtoNDC(xx,u);
            rect1[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
            rect1[4].SetX(rect1[0].GetX());
            rect1[4].SetY(rect1[0].GetY());
            xx[2] = zaxis->GetXmax();
            view->WCtoNDC(xx,u);
            rect1[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[1] = yaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
            xx[2] = zaxis->GetXmin();
            view->WCtoNDC(xx,u);
            rect1[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
            rect1[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
            gVirtualX->DrawPolyLine(5,rect1);
            if (nbins>1) {
               xx[2] = zaxis->GetXmin();
               xx[1] = yaxis->GetXmax();
               xx[0] = xaxis->GetBinCenter(binx+nbins-1);
               view->WCtoNDC(xx,u);
               rect2[0].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[0].SetY(pymin + Int_t((u[1]-uymin)*cy));
               rect2[4].SetX(rect2[0].GetX());
               rect2[4].SetY(rect2[0].GetY());
               xx[2] = zaxis->GetXmax();
               view->WCtoNDC(xx,u);
               rect2[1].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[1].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[1] = yaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[2].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[2].SetY(pymin + Int_t((u[1]-uymin)*cy));
               xx[2] = zaxis->GetXmin();
               view->WCtoNDC(xx,u);
               rect2[3].SetX(pxmin + Int_t((u[0]-uxmin)*cx));
               rect2[3].SetY(pymin + Int_t((u[1]-uymin)*cy));
               gVirtualX->DrawPolyLine(5,rect2);
            }
            c->Clear();
            c->cd();
            TH2 *hp = (TH2*)h3->Project3D("zy");
            xaxis->SetRange(first,last);
            if (hp) {
               hp->SetFillColor(38);
               if (nbins==1)hp->SetTitle(TString::Format("ProjectionZY of binx=%d [x=%.1f..%.f]", binx,xaxis->GetBinLowEdge(binx),xaxis->GetBinUpEdge(binx)));
               else         hp->SetTitle(TString::Format("ProjectionZY, binx=[%d,%d] [x=%.1f..%.1f]", binx,binx2,xaxis->GetBinLowEdge(binx),xaxis->GetBinUpEdge(binx2)));
               hp->SetXTitle(fH->GetYaxis()->GetTitle());
               hp->SetYTitle(fH->GetZaxis()->GetTitle());
               hp->SetZTitle("Number of Entries");
               hp->Draw(fShowOption.Data());
            }
         }
         break;

   }
   c->Update();
   padsav->cd();
}
 THistPainter.cxx:1
 THistPainter.cxx:2
 THistPainter.cxx:3
 THistPainter.cxx:4
 THistPainter.cxx:5
 THistPainter.cxx:6
 THistPainter.cxx:7
 THistPainter.cxx:8
 THistPainter.cxx:9
 THistPainter.cxx:10
 THistPainter.cxx:11
 THistPainter.cxx:12
 THistPainter.cxx:13
 THistPainter.cxx:14
 THistPainter.cxx:15
 THistPainter.cxx:16
 THistPainter.cxx:17
 THistPainter.cxx:18
 THistPainter.cxx:19
 THistPainter.cxx:20
 THistPainter.cxx:21
 THistPainter.cxx:22
 THistPainter.cxx:23
 THistPainter.cxx:24
 THistPainter.cxx:25
 THistPainter.cxx:26
 THistPainter.cxx:27
 THistPainter.cxx:28
 THistPainter.cxx:29
 THistPainter.cxx:30
 THistPainter.cxx:31
 THistPainter.cxx:32
 THistPainter.cxx:33
 THistPainter.cxx:34
 THistPainter.cxx:35
 THistPainter.cxx:36
 THistPainter.cxx:37
 THistPainter.cxx:38
 THistPainter.cxx:39
 THistPainter.cxx:40
 THistPainter.cxx:41
 THistPainter.cxx:42
 THistPainter.cxx:43
 THistPainter.cxx:44
 THistPainter.cxx:45
 THistPainter.cxx:46
 THistPainter.cxx:47
 THistPainter.cxx:48
 THistPainter.cxx:49
 THistPainter.cxx:50
 THistPainter.cxx:51
 THistPainter.cxx:52
 THistPainter.cxx:53
 THistPainter.cxx:54
 THistPainter.cxx:55
 THistPainter.cxx:56
 THistPainter.cxx:57
 THistPainter.cxx:58
 THistPainter.cxx:59
 THistPainter.cxx:60
 THistPainter.cxx:61
 THistPainter.cxx:62
 THistPainter.cxx:63
 THistPainter.cxx:64
 THistPainter.cxx:65
 THistPainter.cxx:66
 THistPainter.cxx:67
 THistPainter.cxx:68
 THistPainter.cxx:69
 THistPainter.cxx:70
 THistPainter.cxx:71
 THistPainter.cxx:72
 THistPainter.cxx:73
 THistPainter.cxx:74
 THistPainter.cxx:75
 THistPainter.cxx:76
 THistPainter.cxx:77
 THistPainter.cxx:78
 THistPainter.cxx:79
 THistPainter.cxx:80
 THistPainter.cxx:81
 THistPainter.cxx:82
 THistPainter.cxx:83
 THistPainter.cxx:84
 THistPainter.cxx:85
 THistPainter.cxx:86
 THistPainter.cxx:87
 THistPainter.cxx:88
 THistPainter.cxx:89
 THistPainter.cxx:90
 THistPainter.cxx:91
 THistPainter.cxx:92
 THistPainter.cxx:93
 THistPainter.cxx:94
 THistPainter.cxx:95
 THistPainter.cxx:96
 THistPainter.cxx:97
 THistPainter.cxx:98
 THistPainter.cxx:99
 THistPainter.cxx:100
 THistPainter.cxx:101
 THistPainter.cxx:102
 THistPainter.cxx:103
 THistPainter.cxx:104
 THistPainter.cxx:105
 THistPainter.cxx:106
 THistPainter.cxx:107
 THistPainter.cxx:108
 THistPainter.cxx:109
 THistPainter.cxx:110
 THistPainter.cxx:111
 THistPainter.cxx:112
 THistPainter.cxx:113
 THistPainter.cxx:114
 THistPainter.cxx:115
 THistPainter.cxx:116
 THistPainter.cxx:117
 THistPainter.cxx:118
 THistPainter.cxx:119
 THistPainter.cxx:120
 THistPainter.cxx:121
 THistPainter.cxx:122
 THistPainter.cxx:123
 THistPainter.cxx:124
 THistPainter.cxx:125
 THistPainter.cxx:126
 THistPainter.cxx:127
 THistPainter.cxx:128
 THistPainter.cxx:129
 THistPainter.cxx:130
 THistPainter.cxx:131
 THistPainter.cxx:132
 THistPainter.cxx:133
 THistPainter.cxx:134
 THistPainter.cxx:135
 THistPainter.cxx:136
 THistPainter.cxx:137
 THistPainter.cxx:138
 THistPainter.cxx:139
 THistPainter.cxx:140
 THistPainter.cxx:141
 THistPainter.cxx:142
 THistPainter.cxx:143
 THistPainter.cxx:144
 THistPainter.cxx:145
 THistPainter.cxx:146
 THistPainter.cxx:147
 THistPainter.cxx:148
 THistPainter.cxx:149
 THistPainter.cxx:150
 THistPainter.cxx:151
 THistPainter.cxx:152
 THistPainter.cxx:153
 THistPainter.cxx:154
 THistPainter.cxx:155
 THistPainter.cxx:156
 THistPainter.cxx:157
 THistPainter.cxx:158
 THistPainter.cxx:159
 THistPainter.cxx:160
 THistPainter.cxx:161
 THistPainter.cxx:162
 THistPainter.cxx:163
 THistPainter.cxx:164
 THistPainter.cxx:165
 THistPainter.cxx:166
 THistPainter.cxx:167
 THistPainter.cxx:168
 THistPainter.cxx:169
 THistPainter.cxx:170
 THistPainter.cxx:171
 THistPainter.cxx:172
 THistPainter.cxx:173
 THistPainter.cxx:174
 THistPainter.cxx:175
 THistPainter.cxx:176
 THistPainter.cxx:177
 THistPainter.cxx:178
 THistPainter.cxx:179
 THistPainter.cxx:180
 THistPainter.cxx:181
 THistPainter.cxx:182
 THistPainter.cxx:183
 THistPainter.cxx:184
 THistPainter.cxx:185
 THistPainter.cxx:186
 THistPainter.cxx:187
 THistPainter.cxx:188
 THistPainter.cxx:189
 THistPainter.cxx:190
 THistPainter.cxx:191
 THistPainter.cxx:192
 THistPainter.cxx:193
 THistPainter.cxx:194
 THistPainter.cxx:195
 THistPainter.cxx:196
 THistPainter.cxx:197
 THistPainter.cxx:198
 THistPainter.cxx:199
 THistPainter.cxx:200
 THistPainter.cxx:201
 THistPainter.cxx:202
 THistPainter.cxx:203
 THistPainter.cxx:204
 THistPainter.cxx:205
 THistPainter.cxx:206
 THistPainter.cxx:207
 THistPainter.cxx:208
 THistPainter.cxx:209
 THistPainter.cxx:210
 THistPainter.cxx:211
 THistPainter.cxx:212
 THistPainter.cxx:213
 THistPainter.cxx:214
 THistPainter.cxx:215
 THistPainter.cxx:216
 THistPainter.cxx:217
 THistPainter.cxx:218
 THistPainter.cxx:219
 THistPainter.cxx:220
 THistPainter.cxx:221
 THistPainter.cxx:222
 THistPainter.cxx:223
 THistPainter.cxx:224
 THistPainter.cxx:225
 THistPainter.cxx:226
 THistPainter.cxx:227
 THistPainter.cxx:228
 THistPainter.cxx:229
 THistPainter.cxx:230
 THistPainter.cxx:231
 THistPainter.cxx:232
 THistPainter.cxx:233
 THistPainter.cxx:234
 THistPainter.cxx:235
 THistPainter.cxx:236
 THistPainter.cxx:237
 THistPainter.cxx:238
 THistPainter.cxx:239
 THistPainter.cxx:240
 THistPainter.cxx:241
 THistPainter.cxx:242
 THistPainter.cxx:243
 THistPainter.cxx:244
 THistPainter.cxx:245
 THistPainter.cxx:246
 THistPainter.cxx:247
 THistPainter.cxx:248
 THistPainter.cxx:249
 THistPainter.cxx:250
 THistPainter.cxx:251
 THistPainter.cxx:252
 THistPainter.cxx:253
 THistPainter.cxx:254
 THistPainter.cxx:255
 THistPainter.cxx:256
 THistPainter.cxx:257
 THistPainter.cxx:258
 THistPainter.cxx:259
 THistPainter.cxx:260
 THistPainter.cxx:261
 THistPainter.cxx:262
 THistPainter.cxx:263
 THistPainter.cxx:264
 THistPainter.cxx:265
 THistPainter.cxx:266
 THistPainter.cxx:267
 THistPainter.cxx:268
 THistPainter.cxx:269
 THistPainter.cxx:270
 THistPainter.cxx:271
 THistPainter.cxx:272
 THistPainter.cxx:273
 THistPainter.cxx:274
 THistPainter.cxx:275
 THistPainter.cxx:276
 THistPainter.cxx:277
 THistPainter.cxx:278
 THistPainter.cxx:279
 THistPainter.cxx:280
 THistPainter.cxx:281
 THistPainter.cxx:282
 THistPainter.cxx:283
 THistPainter.cxx:284
 THistPainter.cxx:285
 THistPainter.cxx:286
 THistPainter.cxx:287
 THistPainter.cxx:288
 THistPainter.cxx:289
 THistPainter.cxx:290
 THistPainter.cxx:291
 THistPainter.cxx:292
 THistPainter.cxx:293
 THistPainter.cxx:294
 THistPainter.cxx:295
 THistPainter.cxx:296
 THistPainter.cxx:297
 THistPainter.cxx:298
 THistPainter.cxx:299
 THistPainter.cxx:300
 THistPainter.cxx:301
 THistPainter.cxx:302
 THistPainter.cxx:303
 THistPainter.cxx:304
 THistPainter.cxx:305
 THistPainter.cxx:306
 THistPainter.cxx:307
 THistPainter.cxx:308
 THistPainter.cxx:309
 THistPainter.cxx:310
 THistPainter.cxx:311
 THistPainter.cxx:312
 THistPainter.cxx:313
 THistPainter.cxx:314
 THistPainter.cxx:315
 THistPainter.cxx:316
 THistPainter.cxx:317
 THistPainter.cxx:318
 THistPainter.cxx:319
 THistPainter.cxx:320
 THistPainter.cxx:321
 THistPainter.cxx:322
 THistPainter.cxx:323
 THistPainter.cxx:324
 THistPainter.cxx:325
 THistPainter.cxx:326
 THistPainter.cxx:327
 THistPainter.cxx:328
 THistPainter.cxx:329
 THistPainter.cxx:330
 THistPainter.cxx:331
 THistPainter.cxx:332
 THistPainter.cxx:333
 THistPainter.cxx:334
 THistPainter.cxx:335
 THistPainter.cxx:336
 THistPainter.cxx:337
 THistPainter.cxx:338
 THistPainter.cxx:339
 THistPainter.cxx:340
 THistPainter.cxx:341
 THistPainter.cxx:342
 THistPainter.cxx:343
 THistPainter.cxx:344
 THistPainter.cxx:345
 THistPainter.cxx:346
 THistPainter.cxx:347
 THistPainter.cxx:348
 THistPainter.cxx:349
 THistPainter.cxx:350
 THistPainter.cxx:351
 THistPainter.cxx:352
 THistPainter.cxx:353
 THistPainter.cxx:354
 THistPainter.cxx:355
 THistPainter.cxx:356
 THistPainter.cxx:357
 THistPainter.cxx:358
 THistPainter.cxx:359
 THistPainter.cxx:360
 THistPainter.cxx:361
 THistPainter.cxx:362
 THistPainter.cxx:363
 THistPainter.cxx:364
 THistPainter.cxx:365
 THistPainter.cxx:366
 THistPainter.cxx:367
 THistPainter.cxx:368
 THistPainter.cxx:369
 THistPainter.cxx:370
 THistPainter.cxx:371
 THistPainter.cxx:372
 THistPainter.cxx:373
 THistPainter.cxx:374
 THistPainter.cxx:375
 THistPainter.cxx:376
 THistPainter.cxx:377
 THistPainter.cxx:378
 THistPainter.cxx:379
 THistPainter.cxx:380
 THistPainter.cxx:381
 THistPainter.cxx:382
 THistPainter.cxx:383
 THistPainter.cxx:384
 THistPainter.cxx:385
 THistPainter.cxx:386
 THistPainter.cxx:387
 THistPainter.cxx:388
 THistPainter.cxx:389
 THistPainter.cxx:390
 THistPainter.cxx:391
 THistPainter.cxx:392
 THistPainter.cxx:393
 THistPainter.cxx:394
 THistPainter.cxx:395
 THistPainter.cxx:396
 THistPainter.cxx:397
 THistPainter.cxx:398
 THistPainter.cxx:399
 THistPainter.cxx:400
 THistPainter.cxx:401
 THistPainter.cxx:402
 THistPainter.cxx:403
 THistPainter.cxx:404
 THistPainter.cxx:405
 THistPainter.cxx:406
 THistPainter.cxx:407
 THistPainter.cxx:408
 THistPainter.cxx:409
 THistPainter.cxx:410
 THistPainter.cxx:411
 THistPainter.cxx:412
 THistPainter.cxx:413
 THistPainter.cxx:414
 THistPainter.cxx:415
 THistPainter.cxx:416
 THistPainter.cxx:417
 THistPainter.cxx:418
 THistPainter.cxx:419
 THistPainter.cxx:420
 THistPainter.cxx:421
 THistPainter.cxx:422
 THistPainter.cxx:423
 THistPainter.cxx:424
 THistPainter.cxx:425
 THistPainter.cxx:426
 THistPainter.cxx:427
 THistPainter.cxx:428
 THistPainter.cxx:429
 THistPainter.cxx:430
 THistPainter.cxx:431
 THistPainter.cxx:432
 THistPainter.cxx:433
 THistPainter.cxx:434
 THistPainter.cxx:435
 THistPainter.cxx:436
 THistPainter.cxx:437
 THistPainter.cxx:438
 THistPainter.cxx:439
 THistPainter.cxx:440
 THistPainter.cxx:441
 THistPainter.cxx:442
 THistPainter.cxx:443
 THistPainter.cxx:444
 THistPainter.cxx:445
 THistPainter.cxx:446
 THistPainter.cxx:447
 THistPainter.cxx:448
 THistPainter.cxx:449
 THistPainter.cxx:450
 THistPainter.cxx:451
 THistPainter.cxx:452
 THistPainter.cxx:453
 THistPainter.cxx:454
 THistPainter.cxx:455
 THistPainter.cxx:456
 THistPainter.cxx:457
 THistPainter.cxx:458
 THistPainter.cxx:459
 THistPainter.cxx:460
 THistPainter.cxx:461
 THistPainter.cxx:462
 THistPainter.cxx:463
 THistPainter.cxx:464
 THistPainter.cxx:465
 THistPainter.cxx:466
 THistPainter.cxx:467
 THistPainter.cxx:468
 THistPainter.cxx:469
 THistPainter.cxx:470
 THistPainter.cxx:471
 THistPainter.cxx:472
 THistPainter.cxx:473
 THistPainter.cxx:474
 THistPainter.cxx:475
 THistPainter.cxx:476
 THistPainter.cxx:477
 THistPainter.cxx:478
 THistPainter.cxx:479
 THistPainter.cxx:480
 THistPainter.cxx:481
 THistPainter.cxx:482
 THistPainter.cxx:483
 THistPainter.cxx:484
 THistPainter.cxx:485
 THistPainter.cxx:486
 THistPainter.cxx:487
 THistPainter.cxx:488
 THistPainter.cxx:489
 THistPainter.cxx:490
 THistPainter.cxx:491
 THistPainter.cxx:492
 THistPainter.cxx:493
 THistPainter.cxx:494
 THistPainter.cxx:495
 THistPainter.cxx:496
 THistPainter.cxx:497
 THistPainter.cxx:498
 THistPainter.cxx:499
 THistPainter.cxx:500
 THistPainter.cxx:501
 THistPainter.cxx:502
 THistPainter.cxx:503
 THistPainter.cxx:504
 THistPainter.cxx:505
 THistPainter.cxx:506
 THistPainter.cxx:507
 THistPainter.cxx:508
 THistPainter.cxx:509
 THistPainter.cxx:510
 THistPainter.cxx:511
 THistPainter.cxx:512
 THistPainter.cxx:513
 THistPainter.cxx:514
 THistPainter.cxx:515
 THistPainter.cxx:516
 THistPainter.cxx:517
 THistPainter.cxx:518
 THistPainter.cxx:519
 THistPainter.cxx:520
 THistPainter.cxx:521
 THistPainter.cxx:522
 THistPainter.cxx:523
 THistPainter.cxx:524
 THistPainter.cxx:525
 THistPainter.cxx:526
 THistPainter.cxx:527
 THistPainter.cxx:528
 THistPainter.cxx:529
 THistPainter.cxx:530
 THistPainter.cxx:531
 THistPainter.cxx:532
 THistPainter.cxx:533
 THistPainter.cxx:534
 THistPainter.cxx:535
 THistPainter.cxx:536
 THistPainter.cxx:537
 THistPainter.cxx:538
 THistPainter.cxx:539
 THistPainter.cxx:540
 THistPainter.cxx:541
 THistPainter.cxx:542
 THistPainter.cxx:543
 THistPainter.cxx:544
 THistPainter.cxx:545
 THistPainter.cxx:546
 THistPainter.cxx:547
 THistPainter.cxx:548
 THistPainter.cxx:549
 THistPainter.cxx:550
 THistPainter.cxx:551
 THistPainter.cxx:552
 THistPainter.cxx:553
 THistPainter.cxx:554
 THistPainter.cxx:555
 THistPainter.cxx:556
 THistPainter.cxx:557
 THistPainter.cxx:558
 THistPainter.cxx:559
 THistPainter.cxx:560
 THistPainter.cxx:561
 THistPainter.cxx:562
 THistPainter.cxx:563
 THistPainter.cxx:564
 THistPainter.cxx:565
 THistPainter.cxx:566
 THistPainter.cxx:567
 THistPainter.cxx:568
 THistPainter.cxx:569
 THistPainter.cxx:570
 THistPainter.cxx:571
 THistPainter.cxx:572
 THistPainter.cxx:573
 THistPainter.cxx:574
 THistPainter.cxx:575
 THistPainter.cxx:576
 THistPainter.cxx:577
 THistPainter.cxx:578
 THistPainter.cxx:579
 THistPainter.cxx:580
 THistPainter.cxx:581
 THistPainter.cxx:582
 THistPainter.cxx:583
 THistPainter.cxx:584
 THistPainter.cxx:585
 THistPainter.cxx:586
 THistPainter.cxx:587
 THistPainter.cxx:588
 THistPainter.cxx:589
 THistPainter.cxx:590
 THistPainter.cxx:591
 THistPainter.cxx:592
 THistPainter.cxx:593
 THistPainter.cxx:594
 THistPainter.cxx:595
 THistPainter.cxx:596
 THistPainter.cxx:597
 THistPainter.cxx:598
 THistPainter.cxx:599
 THistPainter.cxx:600
 THistPainter.cxx:601
 THistPainter.cxx:602
 THistPainter.cxx:603
 THistPainter.cxx:604
 THistPainter.cxx:605
 THistPainter.cxx:606
 THistPainter.cxx:607
 THistPainter.cxx:608
 THistPainter.cxx:609
 THistPainter.cxx:610
 THistPainter.cxx:611
 THistPainter.cxx:612
 THistPainter.cxx:613
 THistPainter.cxx:614
 THistPainter.cxx:615
 THistPainter.cxx:616
 THistPainter.cxx:617
 THistPainter.cxx:618
 THistPainter.cxx:619
 THistPainter.cxx:620
 THistPainter.cxx:621
 THistPainter.cxx:622
 THistPainter.cxx:623
 THistPainter.cxx:624
 THistPainter.cxx:625
 THistPainter.cxx:626
 THistPainter.cxx:627
 THistPainter.cxx:628
 THistPainter.cxx:629
 THistPainter.cxx:630
 THistPainter.cxx:631
 THistPainter.cxx:632
 THistPainter.cxx:633
 THistPainter.cxx:634
 THistPainter.cxx:635
 THistPainter.cxx:636
 THistPainter.cxx:637
 THistPainter.cxx:638
 THistPainter.cxx:639
 THistPainter.cxx:640
 THistPainter.cxx:641
 THistPainter.cxx:642
 THistPainter.cxx:643
 THistPainter.cxx:644
 THistPainter.cxx:645
 THistPainter.cxx:646
 THistPainter.cxx:647
 THistPainter.cxx:648
 THistPainter.cxx:649
 THistPainter.cxx:650
 THistPainter.cxx:651
 THistPainter.cxx:652
 THistPainter.cxx:653
 THistPainter.cxx:654
 THistPainter.cxx:655
 THistPainter.cxx:656
 THistPainter.cxx:657
 THistPainter.cxx:658
 THistPainter.cxx:659
 THistPainter.cxx:660
 THistPainter.cxx:661
 THistPainter.cxx:662
 THistPainter.cxx:663
 THistPainter.cxx:664
 THistPainter.cxx:665
 THistPainter.cxx:666
 THistPainter.cxx:667
 THistPainter.cxx:668
 THistPainter.cxx:669
 THistPainter.cxx:670
 THistPainter.cxx:671
 THistPainter.cxx:672
 THistPainter.cxx:673
 THistPainter.cxx:674
 THistPainter.cxx:675
 THistPainter.cxx:676
 THistPainter.cxx:677
 THistPainter.cxx:678
 THistPainter.cxx:679
 THistPainter.cxx:680
 THistPainter.cxx:681
 THistPainter.cxx:682
 THistPainter.cxx:683
 THistPainter.cxx:684
 THistPainter.cxx:685
 THistPainter.cxx:686
 THistPainter.cxx:687
 THistPainter.cxx:688
 THistPainter.cxx:689
 THistPainter.cxx:690
 THistPainter.cxx:691
 THistPainter.cxx:692
 THistPainter.cxx:693
 THistPainter.cxx:694
 THistPainter.cxx:695
 THistPainter.cxx:696
 THistPainter.cxx:697
 THistPainter.cxx:698
 THistPainter.cxx:699
 THistPainter.cxx:700
 THistPainter.cxx:701
 THistPainter.cxx:702
 THistPainter.cxx:703
 THistPainter.cxx:704
 THistPainter.cxx:705
 THistPainter.cxx:706
 THistPainter.cxx:707
 THistPainter.cxx:708
 THistPainter.cxx:709
 THistPainter.cxx:710
 THistPainter.cxx:711
 THistPainter.cxx:712
 THistPainter.cxx:713
 THistPainter.cxx:714
 THistPainter.cxx:715
 THistPainter.cxx:716
 THistPainter.cxx:717
 THistPainter.cxx:718
 THistPainter.cxx:719
 THistPainter.cxx:720
 THistPainter.cxx:721
 THistPainter.cxx:722
 THistPainter.cxx:723
 THistPainter.cxx:724
 THistPainter.cxx:725
 THistPainter.cxx:726
 THistPainter.cxx:727
 THistPainter.cxx:728
 THistPainter.cxx:729
 THistPainter.cxx:730
 THistPainter.cxx:731
 THistPainter.cxx:732
 THistPainter.cxx:733
 THistPainter.cxx:734
 THistPainter.cxx:735
 THistPainter.cxx:736
 THistPainter.cxx:737
 THistPainter.cxx:738
 THistPainter.cxx:739
 THistPainter.cxx:740
 THistPainter.cxx:741
 THistPainter.cxx:742
 THistPainter.cxx:743
 THistPainter.cxx:744
 THistPainter.cxx:745
 THistPainter.cxx:746
 THistPainter.cxx:747
 THistPainter.cxx:748
 THistPainter.cxx:749
 THistPainter.cxx:750
 THistPainter.cxx:751
 THistPainter.cxx:752
 THistPainter.cxx:753
 THistPainter.cxx:754
 THistPainter.cxx:755
 THistPainter.cxx:756
 THistPainter.cxx:757
 THistPainter.cxx:758
 THistPainter.cxx:759
 THistPainter.cxx:760
 THistPainter.cxx:761
 THistPainter.cxx:762
 THistPainter.cxx:763
 THistPainter.cxx:764
 THistPainter.cxx:765
 THistPainter.cxx:766
 THistPainter.cxx:767
 THistPainter.cxx:768
 THistPainter.cxx:769
 THistPainter.cxx:770
 THistPainter.cxx:771
 THistPainter.cxx:772
 THistPainter.cxx:773
 THistPainter.cxx:774
 THistPainter.cxx:775
 THistPainter.cxx:776
 THistPainter.cxx:777
 THistPainter.cxx:778
 THistPainter.cxx:779
 THistPainter.cxx:780
 THistPainter.cxx:781
 THistPainter.cxx:782
 THistPainter.cxx:783
 THistPainter.cxx:784
 THistPainter.cxx:785
 THistPainter.cxx:786
 THistPainter.cxx:787
 THistPainter.cxx:788
 THistPainter.cxx:789
 THistPainter.cxx:790
 THistPainter.cxx:791
 THistPainter.cxx:792
 THistPainter.cxx:793
 THistPainter.cxx:794
 THistPainter.cxx:795
 THistPainter.cxx:796
 THistPainter.cxx:797
 THistPainter.cxx:798
 THistPainter.cxx:799
 THistPainter.cxx:800
 THistPainter.cxx:801
 THistPainter.cxx:802
 THistPainter.cxx:803
 THistPainter.cxx:804
 THistPainter.cxx:805
 THistPainter.cxx:806
 THistPainter.cxx:807
 THistPainter.cxx:808
 THistPainter.cxx:809
 THistPainter.cxx:810
 THistPainter.cxx:811
 THistPainter.cxx:812
 THistPainter.cxx:813
 THistPainter.cxx:814
 THistPainter.cxx:815
 THistPainter.cxx:816
 THistPainter.cxx:817
 THistPainter.cxx:818
 THistPainter.cxx:819
 THistPainter.cxx:820
 THistPainter.cxx:821
 THistPainter.cxx:822
 THistPainter.cxx:823
 THistPainter.cxx:824
 THistPainter.cxx:825
 THistPainter.cxx:826
 THistPainter.cxx:827
 THistPainter.cxx:828
 THistPainter.cxx:829
 THistPainter.cxx:830
 THistPainter.cxx:831
 THistPainter.cxx:832
 THistPainter.cxx:833
 THistPainter.cxx:834
 THistPainter.cxx:835
 THistPainter.cxx:836
 THistPainter.cxx:837
 THistPainter.cxx:838
 THistPainter.cxx:839
 THistPainter.cxx:840
 THistPainter.cxx:841
 THistPainter.cxx:842
 THistPainter.cxx:843
 THistPainter.cxx:844
 THistPainter.cxx:845
 THistPainter.cxx:846
 THistPainter.cxx:847
 THistPainter.cxx:848
 THistPainter.cxx:849
 THistPainter.cxx:850
 THistPainter.cxx:851
 THistPainter.cxx:852
 THistPainter.cxx:853
 THistPainter.cxx:854
 THistPainter.cxx:855
 THistPainter.cxx:856
 THistPainter.cxx:857
 THistPainter.cxx:858
 THistPainter.cxx:859
 THistPainter.cxx:860
 THistPainter.cxx:861
 THistPainter.cxx:862
 THistPainter.cxx:863
 THistPainter.cxx:864
 THistPainter.cxx:865
 THistPainter.cxx:866
 THistPainter.cxx:867
 THistPainter.cxx:868
 THistPainter.cxx:869
 THistPainter.cxx:870
 THistPainter.cxx:871
 THistPainter.cxx:872
 THistPainter.cxx:873
 THistPainter.cxx:874
 THistPainter.cxx:875
 THistPainter.cxx:876
 THistPainter.cxx:877
 THistPainter.cxx:878
 THistPainter.cxx:879
 THistPainter.cxx:880
 THistPainter.cxx:881
 THistPainter.cxx:882
 THistPainter.cxx:883
 THistPainter.cxx:884
 THistPainter.cxx:885
 THistPainter.cxx:886
 THistPainter.cxx:887
 THistPainter.cxx:888
 THistPainter.cxx:889
 THistPainter.cxx:890
 THistPainter.cxx:891
 THistPainter.cxx:892
 THistPainter.cxx:893
 THistPainter.cxx:894
 THistPainter.cxx:895
 THistPainter.cxx:896
 THistPainter.cxx:897
 THistPainter.cxx:898
 THistPainter.cxx:899
 THistPainter.cxx:900
 THistPainter.cxx:901
 THistPainter.cxx:902
 THistPainter.cxx:903
 THistPainter.cxx:904
 THistPainter.cxx:905
 THistPainter.cxx:906
 THistPainter.cxx:907
 THistPainter.cxx:908
 THistPainter.cxx:909
 THistPainter.cxx:910
 THistPainter.cxx:911
 THistPainter.cxx:912
 THistPainter.cxx:913
 THistPainter.cxx:914
 THistPainter.cxx:915
 THistPainter.cxx:916
 THistPainter.cxx:917
 THistPainter.cxx:918
 THistPainter.cxx:919
 THistPainter.cxx:920
 THistPainter.cxx:921
 THistPainter.cxx:922
 THistPainter.cxx:923
 THistPainter.cxx:924
 THistPainter.cxx:925
 THistPainter.cxx:926
 THistPainter.cxx:927
 THistPainter.cxx:928
 THistPainter.cxx:929
 THistPainter.cxx:930
 THistPainter.cxx:931
 THistPainter.cxx:932
 THistPainter.cxx:933
 THistPainter.cxx:934
 THistPainter.cxx:935
 THistPainter.cxx:936
 THistPainter.cxx:937
 THistPainter.cxx:938
 THistPainter.cxx:939
 THistPainter.cxx:940
 THistPainter.cxx:941
 THistPainter.cxx:942
 THistPainter.cxx:943
 THistPainter.cxx:944
 THistPainter.cxx:945
 THistPainter.cxx:946
 THistPainter.cxx:947
 THistPainter.cxx:948
 THistPainter.cxx:949
 THistPainter.cxx:950
 THistPainter.cxx:951
 THistPainter.cxx:952
 THistPainter.cxx:953
 THistPainter.cxx:954
 THistPainter.cxx:955
 THistPainter.cxx:956
 THistPainter.cxx:957
 THistPainter.cxx:958
 THistPainter.cxx:959
 THistPainter.cxx:960
 THistPainter.cxx:961
 THistPainter.cxx:962
 THistPainter.cxx:963
 THistPainter.cxx:964
 THistPainter.cxx:965
 THistPainter.cxx:966
 THistPainter.cxx:967
 THistPainter.cxx:968
 THistPainter.cxx:969
 THistPainter.cxx:970
 THistPainter.cxx:971
 THistPainter.cxx:972
 THistPainter.cxx:973
 THistPainter.cxx:974
 THistPainter.cxx:975
 THistPainter.cxx:976
 THistPainter.cxx:977
 THistPainter.cxx:978
 THistPainter.cxx:979
 THistPainter.cxx:980
 THistPainter.cxx:981
 THistPainter.cxx:982
 THistPainter.cxx:983
 THistPainter.cxx:984
 THistPainter.cxx:985
 THistPainter.cxx:986
 THistPainter.cxx:987
 THistPainter.cxx:988
 THistPainter.cxx:989
 THistPainter.cxx:990
 THistPainter.cxx:991
 THistPainter.cxx:992
 THistPainter.cxx:993
 THistPainter.cxx:994
 THistPainter.cxx:995
 THistPainter.cxx:996
 THistPainter.cxx:997
 THistPainter.cxx:998
 THistPainter.cxx:999
 THistPainter.cxx:1000
 THistPainter.cxx:1001
 THistPainter.cxx:1002
 THistPainter.cxx:1003
 THistPainter.cxx:1004
 THistPainter.cxx:1005
 THistPainter.cxx:1006
 THistPainter.cxx:1007
 THistPainter.cxx:1008
 THistPainter.cxx:1009
 THistPainter.cxx:1010
 THistPainter.cxx:1011
 THistPainter.cxx:1012
 THistPainter.cxx:1013
 THistPainter.cxx:1014
 THistPainter.cxx:1015
 THistPainter.cxx:1016
 THistPainter.cxx:1017
 THistPainter.cxx:1018
 THistPainter.cxx:1019
 THistPainter.cxx:1020
 THistPainter.cxx:1021
 THistPainter.cxx:1022
 THistPainter.cxx:1023
 THistPainter.cxx:1024
 THistPainter.cxx:1025
 THistPainter.cxx:1026
 THistPainter.cxx:1027
 THistPainter.cxx:1028
 THistPainter.cxx:1029
 THistPainter.cxx:1030
 THistPainter.cxx:1031
 THistPainter.cxx:1032
 THistPainter.cxx:1033
 THistPainter.cxx:1034
 THistPainter.cxx:1035
 THistPainter.cxx:1036
 THistPainter.cxx:1037
 THistPainter.cxx:1038
 THistPainter.cxx:1039
 THistPainter.cxx:1040
 THistPainter.cxx:1041
 THistPainter.cxx:1042
 THistPainter.cxx:1043
 THistPainter.cxx:1044
 THistPainter.cxx:1045
 THistPainter.cxx:1046
 THistPainter.cxx:1047
 THistPainter.cxx:1048
 THistPainter.cxx:1049
 THistPainter.cxx:1050
 THistPainter.cxx:1051
 THistPainter.cxx:1052
 THistPainter.cxx:1053
 THistPainter.cxx:1054
 THistPainter.cxx:1055
 THistPainter.cxx:1056
 THistPainter.cxx:1057
 THistPainter.cxx:1058
 THistPainter.cxx:1059
 THistPainter.cxx:1060
 THistPainter.cxx:1061
 THistPainter.cxx:1062
 THistPainter.cxx:1063
 THistPainter.cxx:1064
 THistPainter.cxx:1065
 THistPainter.cxx:1066
 THistPainter.cxx:1067
 THistPainter.cxx:1068
 THistPainter.cxx:1069
 THistPainter.cxx:1070
 THistPainter.cxx:1071
 THistPainter.cxx:1072
 THistPainter.cxx:1073
 THistPainter.cxx:1074
 THistPainter.cxx:1075
 THistPainter.cxx:1076
 THistPainter.cxx:1077
 THistPainter.cxx:1078
 THistPainter.cxx:1079
 THistPainter.cxx:1080
 THistPainter.cxx:1081
 THistPainter.cxx:1082
 THistPainter.cxx:1083
 THistPainter.cxx:1084
 THistPainter.cxx:1085
 THistPainter.cxx:1086
 THistPainter.cxx:1087
 THistPainter.cxx:1088
 THistPainter.cxx:1089
 THistPainter.cxx:1090
 THistPainter.cxx:1091
 THistPainter.cxx:1092
 THistPainter.cxx:1093
 THistPainter.cxx:1094
 THistPainter.cxx:1095
 THistPainter.cxx:1096
 THistPainter.cxx:1097
 THistPainter.cxx:1098
 THistPainter.cxx:1099
 THistPainter.cxx:1100
 THistPainter.cxx:1101
 THistPainter.cxx:1102
 THistPainter.cxx:1103
 THistPainter.cxx:1104
 THistPainter.cxx:1105
 THistPainter.cxx:1106
 THistPainter.cxx:1107
 THistPainter.cxx:1108
 THistPainter.cxx:1109
 THistPainter.cxx:1110
 THistPainter.cxx:1111
 THistPainter.cxx:1112
 THistPainter.cxx:1113
 THistPainter.cxx:1114
 THistPainter.cxx:1115
 THistPainter.cxx:1116
 THistPainter.cxx:1117
 THistPainter.cxx:1118
 THistPainter.cxx:1119
 THistPainter.cxx:1120
 THistPainter.cxx:1121
 THistPainter.cxx:1122
 THistPainter.cxx:1123
 THistPainter.cxx:1124
 THistPainter.cxx:1125
 THistPainter.cxx:1126
 THistPainter.cxx:1127
 THistPainter.cxx:1128
 THistPainter.cxx:1129
 THistPainter.cxx:1130
 THistPainter.cxx:1131
 THistPainter.cxx:1132
 THistPainter.cxx:1133
 THistPainter.cxx:1134
 THistPainter.cxx:1135
 THistPainter.cxx:1136
 THistPainter.cxx:1137
 THistPainter.cxx:1138
 THistPainter.cxx:1139
 THistPainter.cxx:1140
 THistPainter.cxx:1141
 THistPainter.cxx:1142
 THistPainter.cxx:1143
 THistPainter.cxx:1144
 THistPainter.cxx:1145
 THistPainter.cxx:1146
 THistPainter.cxx:1147
 THistPainter.cxx:1148
 THistPainter.cxx:1149
 THistPainter.cxx:1150
 THistPainter.cxx:1151
 THistPainter.cxx:1152
 THistPainter.cxx:1153
 THistPainter.cxx:1154
 THistPainter.cxx:1155
 THistPainter.cxx:1156
 THistPainter.cxx:1157
 THistPainter.cxx:1158
 THistPainter.cxx:1159
 THistPainter.cxx:1160
 THistPainter.cxx:1161
 THistPainter.cxx:1162
 THistPainter.cxx:1163
 THistPainter.cxx:1164
 THistPainter.cxx:1165
 THistPainter.cxx:1166
 THistPainter.cxx:1167
 THistPainter.cxx:1168
 THistPainter.cxx:1169
 THistPainter.cxx:1170
 THistPainter.cxx:1171
 THistPainter.cxx:1172
 THistPainter.cxx:1173
 THistPainter.cxx:1174
 THistPainter.cxx:1175
 THistPainter.cxx:1176
 THistPainter.cxx:1177
 THistPainter.cxx:1178
 THistPainter.cxx:1179
 THistPainter.cxx:1180
 THistPainter.cxx:1181
 THistPainter.cxx:1182
 THistPainter.cxx:1183
 THistPainter.cxx:1184
 THistPainter.cxx:1185
 THistPainter.cxx:1186
 THistPainter.cxx:1187
 THistPainter.cxx:1188
 THistPainter.cxx:1189
 THistPainter.cxx:1190
 THistPainter.cxx:1191
 THistPainter.cxx:1192
 THistPainter.cxx:1193
 THistPainter.cxx:1194
 THistPainter.cxx:1195
 THistPainter.cxx:1196
 THistPainter.cxx:1197
 THistPainter.cxx:1198
 THistPainter.cxx:1199
 THistPainter.cxx:1200
 THistPainter.cxx:1201
 THistPainter.cxx:1202
 THistPainter.cxx:1203
 THistPainter.cxx:1204
 THistPainter.cxx:1205
 THistPainter.cxx:1206
 THistPainter.cxx:1207
 THistPainter.cxx:1208
 THistPainter.cxx:1209
 THistPainter.cxx:1210
 THistPainter.cxx:1211
 THistPainter.cxx:1212
 THistPainter.cxx:1213
 THistPainter.cxx:1214
 THistPainter.cxx:1215
 THistPainter.cxx:1216
 THistPainter.cxx:1217
 THistPainter.cxx:1218
 THistPainter.cxx:1219
 THistPainter.cxx:1220
 THistPainter.cxx:1221
 THistPainter.cxx:1222
 THistPainter.cxx:1223
 THistPainter.cxx:1224
 THistPainter.cxx:1225
 THistPainter.cxx:1226
 THistPainter.cxx:1227
 THistPainter.cxx:1228
 THistPainter.cxx:1229
 THistPainter.cxx:1230
 THistPainter.cxx:1231
 THistPainter.cxx:1232
 THistPainter.cxx:1233
 THistPainter.cxx:1234
 THistPainter.cxx:1235
 THistPainter.cxx:1236
 THistPainter.cxx:1237
 THistPainter.cxx:1238
 THistPainter.cxx:1239
 THistPainter.cxx:1240
 THistPainter.cxx:1241
 THistPainter.cxx:1242
 THistPainter.cxx:1243
 THistPainter.cxx:1244
 THistPainter.cxx:1245
 THistPainter.cxx:1246
 THistPainter.cxx:1247
 THistPainter.cxx:1248
 THistPainter.cxx:1249
 THistPainter.cxx:1250
 THistPainter.cxx:1251
 THistPainter.cxx:1252
 THistPainter.cxx:1253
 THistPainter.cxx:1254
 THistPainter.cxx:1255
 THistPainter.cxx:1256
 THistPainter.cxx:1257
 THistPainter.cxx:1258
 THistPainter.cxx:1259
 THistPainter.cxx:1260
 THistPainter.cxx:1261
 THistPainter.cxx:1262
 THistPainter.cxx:1263
 THistPainter.cxx:1264
 THistPainter.cxx:1265
 THistPainter.cxx:1266
 THistPainter.cxx:1267
 THistPainter.cxx:1268
 THistPainter.cxx:1269
 THistPainter.cxx:1270
 THistPainter.cxx:1271
 THistPainter.cxx:1272
 THistPainter.cxx:1273
 THistPainter.cxx:1274
 THistPainter.cxx:1275
 THistPainter.cxx:1276
 THistPainter.cxx:1277
 THistPainter.cxx:1278
 THistPainter.cxx:1279
 THistPainter.cxx:1280
 THistPainter.cxx:1281
 THistPainter.cxx:1282
 THistPainter.cxx:1283
 THistPainter.cxx:1284
 THistPainter.cxx:1285
 THistPainter.cxx:1286
 THistPainter.cxx:1287
 THistPainter.cxx:1288
 THistPainter.cxx:1289
 THistPainter.cxx:1290
 THistPainter.cxx:1291
 THistPainter.cxx:1292
 THistPainter.cxx:1293
 THistPainter.cxx:1294
 THistPainter.cxx:1295
 THistPainter.cxx:1296
 THistPainter.cxx:1297
 THistPainter.cxx:1298
 THistPainter.cxx:1299
 THistPainter.cxx:1300
 THistPainter.cxx:1301
 THistPainter.cxx:1302
 THistPainter.cxx:1303
 THistPainter.cxx:1304
 THistPainter.cxx:1305
 THistPainter.cxx:1306
 THistPainter.cxx:1307
 THistPainter.cxx:1308
 THistPainter.cxx:1309
 THistPainter.cxx:1310
 THistPainter.cxx:1311
 THistPainter.cxx:1312
 THistPainter.cxx:1313
 THistPainter.cxx:1314
 THistPainter.cxx:1315
 THistPainter.cxx:1316
 THistPainter.cxx:1317
 THistPainter.cxx:1318
 THistPainter.cxx:1319
 THistPainter.cxx:1320
 THistPainter.cxx:1321
 THistPainter.cxx:1322
 THistPainter.cxx:1323
 THistPainter.cxx:1324
 THistPainter.cxx:1325
 THistPainter.cxx:1326
 THistPainter.cxx:1327
 THistPainter.cxx:1328
 THistPainter.cxx:1329
 THistPainter.cxx:1330
 THistPainter.cxx:1331
 THistPainter.cxx:1332
 THistPainter.cxx:1333
 THistPainter.cxx:1334
 THistPainter.cxx:1335
 THistPainter.cxx:1336
 THistPainter.cxx:1337
 THistPainter.cxx:1338
 THistPainter.cxx:1339
 THistPainter.cxx:1340
 THistPainter.cxx:1341
 THistPainter.cxx:1342
 THistPainter.cxx:1343
 THistPainter.cxx:1344
 THistPainter.cxx:1345
 THistPainter.cxx:1346
 THistPainter.cxx:1347
 THistPainter.cxx:1348
 THistPainter.cxx:1349
 THistPainter.cxx:1350
 THistPainter.cxx:1351
 THistPainter.cxx:1352
 THistPainter.cxx:1353
 THistPainter.cxx:1354
 THistPainter.cxx:1355
 THistPainter.cxx:1356
 THistPainter.cxx:1357
 THistPainter.cxx:1358
 THistPainter.cxx:1359
 THistPainter.cxx:1360
 THistPainter.cxx:1361
 THistPainter.cxx:1362
 THistPainter.cxx:1363
 THistPainter.cxx:1364
 THistPainter.cxx:1365
 THistPainter.cxx:1366
 THistPainter.cxx:1367
 THistPainter.cxx:1368
 THistPainter.cxx:1369
 THistPainter.cxx:1370
 THistPainter.cxx:1371
 THistPainter.cxx:1372
 THistPainter.cxx:1373
 THistPainter.cxx:1374
 THistPainter.cxx:1375
 THistPainter.cxx:1376
 THistPainter.cxx:1377
 THistPainter.cxx:1378
 THistPainter.cxx:1379
 THistPainter.cxx:1380
 THistPainter.cxx:1381
 THistPainter.cxx:1382
 THistPainter.cxx:1383
 THistPainter.cxx:1384
 THistPainter.cxx:1385
 THistPainter.cxx:1386
 THistPainter.cxx:1387
 THistPainter.cxx:1388
 THistPainter.cxx:1389
 THistPainter.cxx:1390
 THistPainter.cxx:1391
 THistPainter.cxx:1392
 THistPainter.cxx:1393
 THistPainter.cxx:1394
 THistPainter.cxx:1395
 THistPainter.cxx:1396
 THistPainter.cxx:1397
 THistPainter.cxx:1398
 THistPainter.cxx:1399
 THistPainter.cxx:1400
 THistPainter.cxx:1401
 THistPainter.cxx:1402
 THistPainter.cxx:1403
 THistPainter.cxx:1404
 THistPainter.cxx:1405
 THistPainter.cxx:1406
 THistPainter.cxx:1407
 THistPainter.cxx:1408
 THistPainter.cxx:1409
 THistPainter.cxx:1410
 THistPainter.cxx:1411
 THistPainter.cxx:1412
 THistPainter.cxx:1413
 THistPainter.cxx:1414
 THistPainter.cxx:1415
 THistPainter.cxx:1416
 THistPainter.cxx:1417
 THistPainter.cxx:1418
 THistPainter.cxx:1419
 THistPainter.cxx:1420
 THistPainter.cxx:1421
 THistPainter.cxx:1422
 THistPainter.cxx:1423
 THistPainter.cxx:1424
 THistPainter.cxx:1425
 THistPainter.cxx:1426
 THistPainter.cxx:1427
 THistPainter.cxx:1428
 THistPainter.cxx:1429
 THistPainter.cxx:1430
 THistPainter.cxx:1431
 THistPainter.cxx:1432
 THistPainter.cxx:1433
 THistPainter.cxx:1434
 THistPainter.cxx:1435
 THistPainter.cxx:1436
 THistPainter.cxx:1437
 THistPainter.cxx:1438
 THistPainter.cxx:1439
 THistPainter.cxx:1440
 THistPainter.cxx:1441
 THistPainter.cxx:1442
 THistPainter.cxx:1443
 THistPainter.cxx:1444
 THistPainter.cxx:1445
 THistPainter.cxx:1446
 THistPainter.cxx:1447
 THistPainter.cxx:1448
 THistPainter.cxx:1449
 THistPainter.cxx:1450
 THistPainter.cxx:1451
 THistPainter.cxx:1452
 THistPainter.cxx:1453
 THistPainter.cxx:1454
 THistPainter.cxx:1455
 THistPainter.cxx:1456
 THistPainter.cxx:1457
 THistPainter.cxx:1458
 THistPainter.cxx:1459
 THistPainter.cxx:1460
 THistPainter.cxx:1461
 THistPainter.cxx:1462
 THistPainter.cxx:1463
 THistPainter.cxx:1464
 THistPainter.cxx:1465
 THistPainter.cxx:1466
 THistPainter.cxx:1467
 THistPainter.cxx:1468
 THistPainter.cxx:1469
 THistPainter.cxx:1470
 THistPainter.cxx:1471
 THistPainter.cxx:1472
 THistPainter.cxx:1473
 THistPainter.cxx:1474
 THistPainter.cxx:1475
 THistPainter.cxx:1476
 THistPainter.cxx:1477
 THistPainter.cxx:1478
 THistPainter.cxx:1479
 THistPainter.cxx:1480
 THistPainter.cxx:1481
 THistPainter.cxx:1482
 THistPainter.cxx:1483
 THistPainter.cxx:1484
 THistPainter.cxx:1485
 THistPainter.cxx:1486
 THistPainter.cxx:1487
 THistPainter.cxx:1488
 THistPainter.cxx:1489
 THistPainter.cxx:1490
 THistPainter.cxx:1491
 THistPainter.cxx:1492
 THistPainter.cxx:1493
 THistPainter.cxx:1494
 THistPainter.cxx:1495
 THistPainter.cxx:1496
 THistPainter.cxx:1497
 THistPainter.cxx:1498
 THistPainter.cxx:1499
 THistPainter.cxx:1500
 THistPainter.cxx:1501
 THistPainter.cxx:1502
 THistPainter.cxx:1503
 THistPainter.cxx:1504
 THistPainter.cxx:1505
 THistPainter.cxx:1506
 THistPainter.cxx:1507
 THistPainter.cxx:1508
 THistPainter.cxx:1509
 THistPainter.cxx:1510
 THistPainter.cxx:1511
 THistPainter.cxx:1512
 THistPainter.cxx:1513
 THistPainter.cxx:1514
 THistPainter.cxx:1515
 THistPainter.cxx:1516
 THistPainter.cxx:1517
 THistPainter.cxx:1518
 THistPainter.cxx:1519
 THistPainter.cxx:1520
 THistPainter.cxx:1521
 THistPainter.cxx:1522
 THistPainter.cxx:1523
 THistPainter.cxx:1524
 THistPainter.cxx:1525
 THistPainter.cxx:1526
 THistPainter.cxx:1527
 THistPainter.cxx:1528
 THistPainter.cxx:1529
 THistPainter.cxx:1530
 THistPainter.cxx:1531
 THistPainter.cxx:1532
 THistPainter.cxx:1533
 THistPainter.cxx:1534
 THistPainter.cxx:1535
 THistPainter.cxx:1536
 THistPainter.cxx:1537
 THistPainter.cxx:1538
 THistPainter.cxx:1539
 THistPainter.cxx:1540
 THistPainter.cxx:1541
 THistPainter.cxx:1542
 THistPainter.cxx:1543
 THistPainter.cxx:1544
 THistPainter.cxx:1545
 THistPainter.cxx:1546
 THistPainter.cxx:1547
 THistPainter.cxx:1548
 THistPainter.cxx:1549
 THistPainter.cxx:1550
 THistPainter.cxx:1551
 THistPainter.cxx:1552
 THistPainter.cxx:1553
 THistPainter.cxx:1554
 THistPainter.cxx:1555
 THistPainter.cxx:1556
 THistPainter.cxx:1557
 THistPainter.cxx:1558
 THistPainter.cxx:1559
 THistPainter.cxx:1560
 THistPainter.cxx:1561
 THistPainter.cxx:1562
 THistPainter.cxx:1563
 THistPainter.cxx:1564
 THistPainter.cxx:1565
 THistPainter.cxx:1566
 THistPainter.cxx:1567
 THistPainter.cxx:1568
 THistPainter.cxx:1569
 THistPainter.cxx:1570
 THistPainter.cxx:1571
 THistPainter.cxx:1572
 THistPainter.cxx:1573
 THistPainter.cxx:1574
 THistPainter.cxx:1575
 THistPainter.cxx:1576
 THistPainter.cxx:1577
 THistPainter.cxx:1578
 THistPainter.cxx:1579
 THistPainter.cxx:1580
 THistPainter.cxx:1581
 THistPainter.cxx:1582
 THistPainter.cxx:1583
 THistPainter.cxx:1584
 THistPainter.cxx:1585
 THistPainter.cxx:1586
 THistPainter.cxx:1587
 THistPainter.cxx:1588
 THistPainter.cxx:1589
 THistPainter.cxx:1590
 THistPainter.cxx:1591
 THistPainter.cxx:1592
 THistPainter.cxx:1593
 THistPainter.cxx:1594
 THistPainter.cxx:1595
 THistPainter.cxx:1596
 THistPainter.cxx:1597
 THistPainter.cxx:1598
 THistPainter.cxx:1599
 THistPainter.cxx:1600
 THistPainter.cxx:1601
 THistPainter.cxx:1602
 THistPainter.cxx:1603
 THistPainter.cxx:1604
 THistPainter.cxx:1605
 THistPainter.cxx:1606
 THistPainter.cxx:1607
 THistPainter.cxx:1608
 THistPainter.cxx:1609
 THistPainter.cxx:1610
 THistPainter.cxx:1611
 THistPainter.cxx:1612
 THistPainter.cxx:1613
 THistPainter.cxx:1614
 THistPainter.cxx:1615
 THistPainter.cxx:1616
 THistPainter.cxx:1617
 THistPainter.cxx:1618
 THistPainter.cxx:1619
 THistPainter.cxx:1620
 THistPainter.cxx:1621
 THistPainter.cxx:1622
 THistPainter.cxx:1623
 THistPainter.cxx:1624
 THistPainter.cxx:1625
 THistPainter.cxx:1626
 THistPainter.cxx:1627
 THistPainter.cxx:1628
 THistPainter.cxx:1629
 THistPainter.cxx:1630
 THistPainter.cxx:1631
 THistPainter.cxx:1632
 THistPainter.cxx:1633
 THistPainter.cxx:1634
 THistPainter.cxx:1635
 THistPainter.cxx:1636
 THistPainter.cxx:1637
 THistPainter.cxx:1638
 THistPainter.cxx:1639
 THistPainter.cxx:1640
 THistPainter.cxx:1641
 THistPainter.cxx:1642
 THistPainter.cxx:1643
 THistPainter.cxx:1644
 THistPainter.cxx:1645
 THistPainter.cxx:1646
 THistPainter.cxx:1647
 THistPainter.cxx:1648
 THistPainter.cxx:1649
 THistPainter.cxx:1650
 THistPainter.cxx:1651
 THistPainter.cxx:1652
 THistPainter.cxx:1653
 THistPainter.cxx:1654
 THistPainter.cxx:1655
 THistPainter.cxx:1656
 THistPainter.cxx:1657
 THistPainter.cxx:1658
 THistPainter.cxx:1659
 THistPainter.cxx:1660
 THistPainter.cxx:1661
 THistPainter.cxx:1662
 THistPainter.cxx:1663
 THistPainter.cxx:1664
 THistPainter.cxx:1665
 THistPainter.cxx:1666
 THistPainter.cxx:1667
 THistPainter.cxx:1668
 THistPainter.cxx:1669
 THistPainter.cxx:1670
 THistPainter.cxx:1671
 THistPainter.cxx:1672
 THistPainter.cxx:1673
 THistPainter.cxx:1674
 THistPainter.cxx:1675
 THistPainter.cxx:1676
 THistPainter.cxx:1677
 THistPainter.cxx:1678
 THistPainter.cxx:1679
 THistPainter.cxx:1680
 THistPainter.cxx:1681
 THistPainter.cxx:1682
 THistPainter.cxx:1683
 THistPainter.cxx:1684
 THistPainter.cxx:1685
 THistPainter.cxx:1686
 THistPainter.cxx:1687
 THistPainter.cxx:1688
 THistPainter.cxx:1689
 THistPainter.cxx:1690
 THistPainter.cxx:1691
 THistPainter.cxx:1692
 THistPainter.cxx:1693
 THistPainter.cxx:1694
 THistPainter.cxx:1695
 THistPainter.cxx:1696
 THistPainter.cxx:1697
 THistPainter.cxx:1698
 THistPainter.cxx:1699
 THistPainter.cxx:1700
 THistPainter.cxx:1701
 THistPainter.cxx:1702
 THistPainter.cxx:1703
 THistPainter.cxx:1704
 THistPainter.cxx:1705
 THistPainter.cxx:1706
 THistPainter.cxx:1707
 THistPainter.cxx:1708
 THistPainter.cxx:1709
 THistPainter.cxx:1710
 THistPainter.cxx:1711
 THistPainter.cxx:1712
 THistPainter.cxx:1713
 THistPainter.cxx:1714
 THistPainter.cxx:1715
 THistPainter.cxx:1716
 THistPainter.cxx:1717
 THistPainter.cxx:1718
 THistPainter.cxx:1719
 THistPainter.cxx:1720
 THistPainter.cxx:1721
 THistPainter.cxx:1722
 THistPainter.cxx:1723
 THistPainter.cxx:1724
 THistPainter.cxx:1725
 THistPainter.cxx:1726
 THistPainter.cxx:1727
 THistPainter.cxx:1728
 THistPainter.cxx:1729
 THistPainter.cxx:1730
 THistPainter.cxx:1731
 THistPainter.cxx:1732
 THistPainter.cxx:1733
 THistPainter.cxx:1734
 THistPainter.cxx:1735
 THistPainter.cxx:1736
 THistPainter.cxx:1737
 THistPainter.cxx:1738
 THistPainter.cxx:1739
 THistPainter.cxx:1740
 THistPainter.cxx:1741
 THistPainter.cxx:1742
 THistPainter.cxx:1743
 THistPainter.cxx:1744
 THistPainter.cxx:1745
 THistPainter.cxx:1746
 THistPainter.cxx:1747
 THistPainter.cxx:1748
 THistPainter.cxx:1749
 THistPainter.cxx:1750
 THistPainter.cxx:1751
 THistPainter.cxx:1752
 THistPainter.cxx:1753
 THistPainter.cxx:1754
 THistPainter.cxx:1755
 THistPainter.cxx:1756
 THistPainter.cxx:1757
 THistPainter.cxx:1758
 THistPainter.cxx:1759
 THistPainter.cxx:1760
 THistPainter.cxx:1761
 THistPainter.cxx:1762
 THistPainter.cxx:1763
 THistPainter.cxx:1764
 THistPainter.cxx:1765
 THistPainter.cxx:1766
 THistPainter.cxx:1767
 THistPainter.cxx:1768
 THistPainter.cxx:1769
 THistPainter.cxx:1770
 THistPainter.cxx:1771
 THistPainter.cxx:1772
 THistPainter.cxx:1773
 THistPainter.cxx:1774
 THistPainter.cxx:1775
 THistPainter.cxx:1776
 THistPainter.cxx:1777
 THistPainter.cxx:1778
 THistPainter.cxx:1779
 THistPainter.cxx:1780
 THistPainter.cxx:1781
 THistPainter.cxx:1782
 THistPainter.cxx:1783
 THistPainter.cxx:1784
 THistPainter.cxx:1785
 THistPainter.cxx:1786
 THistPainter.cxx:1787
 THistPainter.cxx:1788
 THistPainter.cxx:1789
 THistPainter.cxx:1790
 THistPainter.cxx:1791
 THistPainter.cxx:1792
 THistPainter.cxx:1793
 THistPainter.cxx:1794
 THistPainter.cxx:1795
 THistPainter.cxx:1796
 THistPainter.cxx:1797
 THistPainter.cxx:1798
 THistPainter.cxx:1799
 THistPainter.cxx:1800
 THistPainter.cxx:1801
 THistPainter.cxx:1802
 THistPainter.cxx:1803
 THistPainter.cxx:1804
 THistPainter.cxx:1805
 THistPainter.cxx:1806
 THistPainter.cxx:1807
 THistPainter.cxx:1808
 THistPainter.cxx:1809
 THistPainter.cxx:1810
 THistPainter.cxx:1811
 THistPainter.cxx:1812
 THistPainter.cxx:1813
 THistPainter.cxx:1814
 THistPainter.cxx:1815
 THistPainter.cxx:1816
 THistPainter.cxx:1817
 THistPainter.cxx:1818
 THistPainter.cxx:1819
 THistPainter.cxx:1820
 THistPainter.cxx:1821
 THistPainter.cxx:1822
 THistPainter.cxx:1823
 THistPainter.cxx:1824
 THistPainter.cxx:1825
 THistPainter.cxx:1826
 THistPainter.cxx:1827
 THistPainter.cxx:1828
 THistPainter.cxx:1829
 THistPainter.cxx:1830
 THistPainter.cxx:1831
 THistPainter.cxx:1832
 THistPainter.cxx:1833
 THistPainter.cxx:1834
 THistPainter.cxx:1835
 THistPainter.cxx:1836
 THistPainter.cxx:1837
 THistPainter.cxx:1838
 THistPainter.cxx:1839
 THistPainter.cxx:1840
 THistPainter.cxx:1841
 THistPainter.cxx:1842
 THistPainter.cxx:1843
 THistPainter.cxx:1844
 THistPainter.cxx:1845
 THistPainter.cxx:1846
 THistPainter.cxx:1847
 THistPainter.cxx:1848
 THistPainter.cxx:1849
 THistPainter.cxx:1850
 THistPainter.cxx:1851
 THistPainter.cxx:1852
 THistPainter.cxx:1853
 THistPainter.cxx:1854
 THistPainter.cxx:1855
 THistPainter.cxx:1856
 THistPainter.cxx:1857
 THistPainter.cxx:1858
 THistPainter.cxx:1859
 THistPainter.cxx:1860
 THistPainter.cxx:1861
 THistPainter.cxx:1862
 THistPainter.cxx:1863
 THistPainter.cxx:1864
 THistPainter.cxx:1865
 THistPainter.cxx:1866
 THistPainter.cxx:1867
 THistPainter.cxx:1868
 THistPainter.cxx:1869
 THistPainter.cxx:1870
 THistPainter.cxx:1871
 THistPainter.cxx:1872
 THistPainter.cxx:1873
 THistPainter.cxx:1874
 THistPainter.cxx:1875
 THistPainter.cxx:1876
 THistPainter.cxx:1877
 THistPainter.cxx:1878
 THistPainter.cxx:1879
 THistPainter.cxx:1880
 THistPainter.cxx:1881
 THistPainter.cxx:1882
 THistPainter.cxx:1883
 THistPainter.cxx:1884
 THistPainter.cxx:1885
 THistPainter.cxx:1886
 THistPainter.cxx:1887
 THistPainter.cxx:1888
 THistPainter.cxx:1889
 THistPainter.cxx:1890
 THistPainter.cxx:1891
 THistPainter.cxx:1892
 THistPainter.cxx:1893
 THistPainter.cxx:1894
 THistPainter.cxx:1895
 THistPainter.cxx:1896
 THistPainter.cxx:1897
 THistPainter.cxx:1898
 THistPainter.cxx:1899
 THistPainter.cxx:1900
 THistPainter.cxx:1901
 THistPainter.cxx:1902
 THistPainter.cxx:1903
 THistPainter.cxx:1904
 THistPainter.cxx:1905
 THistPainter.cxx:1906
 THistPainter.cxx:1907
 THistPainter.cxx:1908
 THistPainter.cxx:1909
 THistPainter.cxx:1910
 THistPainter.cxx:1911
 THistPainter.cxx:1912
 THistPainter.cxx:1913
 THistPainter.cxx:1914
 THistPainter.cxx:1915
 THistPainter.cxx:1916
 THistPainter.cxx:1917
 THistPainter.cxx:1918
 THistPainter.cxx:1919
 THistPainter.cxx:1920
 THistPainter.cxx:1921
 THistPainter.cxx:1922
 THistPainter.cxx:1923
 THistPainter.cxx:1924
 THistPainter.cxx:1925
 THistPainter.cxx:1926
 THistPainter.cxx:1927
 THistPainter.cxx:1928
 THistPainter.cxx:1929
 THistPainter.cxx:1930
 THistPainter.cxx:1931
 THistPainter.cxx:1932
 THistPainter.cxx:1933
 THistPainter.cxx:1934
 THistPainter.cxx:1935
 THistPainter.cxx:1936
 THistPainter.cxx:1937
 THistPainter.cxx:1938
 THistPainter.cxx:1939
 THistPainter.cxx:1940
 THistPainter.cxx:1941
 THistPainter.cxx:1942
 THistPainter.cxx:1943
 THistPainter.cxx:1944
 THistPainter.cxx:1945
 THistPainter.cxx:1946
 THistPainter.cxx:1947
 THistPainter.cxx:1948
 THistPainter.cxx:1949
 THistPainter.cxx:1950
 THistPainter.cxx:1951
 THistPainter.cxx:1952
 THistPainter.cxx:1953
 THistPainter.cxx:1954
 THistPainter.cxx:1955
 THistPainter.cxx:1956
 THistPainter.cxx:1957
 THistPainter.cxx:1958
 THistPainter.cxx:1959
 THistPainter.cxx:1960
 THistPainter.cxx:1961
 THistPainter.cxx:1962
 THistPainter.cxx:1963
 THistPainter.cxx:1964
 THistPainter.cxx:1965
 THistPainter.cxx:1966
 THistPainter.cxx:1967
 THistPainter.cxx:1968
 THistPainter.cxx:1969
 THistPainter.cxx:1970
 THistPainter.cxx:1971
 THistPainter.cxx:1972
 THistPainter.cxx:1973
 THistPainter.cxx:1974
 THistPainter.cxx:1975
 THistPainter.cxx:1976
 THistPainter.cxx:1977
 THistPainter.cxx:1978
 THistPainter.cxx:1979
 THistPainter.cxx:1980
 THistPainter.cxx:1981
 THistPainter.cxx:1982
 THistPainter.cxx:1983
 THistPainter.cxx:1984
 THistPainter.cxx:1985
 THistPainter.cxx:1986
 THistPainter.cxx:1987
 THistPainter.cxx:1988
 THistPainter.cxx:1989
 THistPainter.cxx:1990
 THistPainter.cxx:1991
 THistPainter.cxx:1992
 THistPainter.cxx:1993
 THistPainter.cxx:1994
 THistPainter.cxx:1995
 THistPainter.cxx:1996
 THistPainter.cxx:1997
 THistPainter.cxx:1998
 THistPainter.cxx:1999
 THistPainter.cxx:2000
 THistPainter.cxx:2001
 THistPainter.cxx:2002
 THistPainter.cxx:2003
 THistPainter.cxx:2004
 THistPainter.cxx:2005
 THistPainter.cxx:2006
 THistPainter.cxx:2007
 THistPainter.cxx:2008
 THistPainter.cxx:2009
 THistPainter.cxx:2010
 THistPainter.cxx:2011
 THistPainter.cxx:2012
 THistPainter.cxx:2013
 THistPainter.cxx:2014
 THistPainter.cxx:2015
 THistPainter.cxx:2016
 THistPainter.cxx:2017
 THistPainter.cxx:2018
 THistPainter.cxx:2019
 THistPainter.cxx:2020
 THistPainter.cxx:2021
 THistPainter.cxx:2022
 THistPainter.cxx:2023
 THistPainter.cxx:2024
 THistPainter.cxx:2025
 THistPainter.cxx:2026
 THistPainter.cxx:2027
 THistPainter.cxx:2028
 THistPainter.cxx:2029
 THistPainter.cxx:2030
 THistPainter.cxx:2031
 THistPainter.cxx:2032
 THistPainter.cxx:2033
 THistPainter.cxx:2034
 THistPainter.cxx:2035
 THistPainter.cxx:2036
 THistPainter.cxx:2037
 THistPainter.cxx:2038
 THistPainter.cxx:2039
 THistPainter.cxx:2040
 THistPainter.cxx:2041
 THistPainter.cxx:2042
 THistPainter.cxx:2043
 THistPainter.cxx:2044
 THistPainter.cxx:2045
 THistPainter.cxx:2046
 THistPainter.cxx:2047
 THistPainter.cxx:2048
 THistPainter.cxx:2049
 THistPainter.cxx:2050
 THistPainter.cxx:2051
 THistPainter.cxx:2052
 THistPainter.cxx:2053
 THistPainter.cxx:2054
 THistPainter.cxx:2055
 THistPainter.cxx:2056
 THistPainter.cxx:2057
 THistPainter.cxx:2058
 THistPainter.cxx:2059
 THistPainter.cxx:2060
 THistPainter.cxx:2061
 THistPainter.cxx:2062
 THistPainter.cxx:2063
 THistPainter.cxx:2064
 THistPainter.cxx:2065
 THistPainter.cxx:2066
 THistPainter.cxx:2067
 THistPainter.cxx:2068
 THistPainter.cxx:2069
 THistPainter.cxx:2070
 THistPainter.cxx:2071
 THistPainter.cxx:2072
 THistPainter.cxx:2073
 THistPainter.cxx:2074
 THistPainter.cxx:2075
 THistPainter.cxx:2076
 THistPainter.cxx:2077
 THistPainter.cxx:2078
 THistPainter.cxx:2079
 THistPainter.cxx:2080
 THistPainter.cxx:2081
 THistPainter.cxx:2082
 THistPainter.cxx:2083
 THistPainter.cxx:2084
 THistPainter.cxx:2085
 THistPainter.cxx:2086
 THistPainter.cxx:2087
 THistPainter.cxx:2088
 THistPainter.cxx:2089
 THistPainter.cxx:2090
 THistPainter.cxx:2091
 THistPainter.cxx:2092
 THistPainter.cxx:2093
 THistPainter.cxx:2094
 THistPainter.cxx:2095
 THistPainter.cxx:2096
 THistPainter.cxx:2097
 THistPainter.cxx:2098
 THistPainter.cxx:2099
 THistPainter.cxx:2100
 THistPainter.cxx:2101
 THistPainter.cxx:2102
 THistPainter.cxx:2103
 THistPainter.cxx:2104
 THistPainter.cxx:2105
 THistPainter.cxx:2106
 THistPainter.cxx:2107
 THistPainter.cxx:2108
 THistPainter.cxx:2109
 THistPainter.cxx:2110
 THistPainter.cxx:2111
 THistPainter.cxx:2112
 THistPainter.cxx:2113
 THistPainter.cxx:2114
 THistPainter.cxx:2115
 THistPainter.cxx:2116
 THistPainter.cxx:2117
 THistPainter.cxx:2118
 THistPainter.cxx:2119
 THistPainter.cxx:2120
 THistPainter.cxx:2121
 THistPainter.cxx:2122
 THistPainter.cxx:2123
 THistPainter.cxx:2124
 THistPainter.cxx:2125
 THistPainter.cxx:2126
 THistPainter.cxx:2127
 THistPainter.cxx:2128
 THistPainter.cxx:2129
 THistPainter.cxx:2130
 THistPainter.cxx:2131
 THistPainter.cxx:2132
 THistPainter.cxx:2133
 THistPainter.cxx:2134
 THistPainter.cxx:2135
 THistPainter.cxx:2136
 THistPainter.cxx:2137
 THistPainter.cxx:2138
 THistPainter.cxx:2139
 THistPainter.cxx:2140
 THistPainter.cxx:2141
 THistPainter.cxx:2142
 THistPainter.cxx:2143
 THistPainter.cxx:2144
 THistPainter.cxx:2145
 THistPainter.cxx:2146
 THistPainter.cxx:2147
 THistPainter.cxx:2148
 THistPainter.cxx:2149
 THistPainter.cxx:2150
 THistPainter.cxx:2151
 THistPainter.cxx:2152
 THistPainter.cxx:2153
 THistPainter.cxx:2154
 THistPainter.cxx:2155
 THistPainter.cxx:2156
 THistPainter.cxx:2157
 THistPainter.cxx:2158
 THistPainter.cxx:2159
 THistPainter.cxx:2160
 THistPainter.cxx:2161
 THistPainter.cxx:2162
 THistPainter.cxx:2163
 THistPainter.cxx:2164
 THistPainter.cxx:2165
 THistPainter.cxx:2166
 THistPainter.cxx:2167
 THistPainter.cxx:2168
 THistPainter.cxx:2169
 THistPainter.cxx:2170
 THistPainter.cxx:2171
 THistPainter.cxx:2172
 THistPainter.cxx:2173
 THistPainter.cxx:2174
 THistPainter.cxx:2175
 THistPainter.cxx:2176
 THistPainter.cxx:2177
 THistPainter.cxx:2178
 THistPainter.cxx:2179
 THistPainter.cxx:2180
 THistPainter.cxx:2181
 THistPainter.cxx:2182
 THistPainter.cxx:2183
 THistPainter.cxx:2184
 THistPainter.cxx:2185
 THistPainter.cxx:2186
 THistPainter.cxx:2187
 THistPainter.cxx:2188
 THistPainter.cxx:2189
 THistPainter.cxx:2190
 THistPainter.cxx:2191
 THistPainter.cxx:2192
 THistPainter.cxx:2193
 THistPainter.cxx:2194
 THistPainter.cxx:2195
 THistPainter.cxx:2196
 THistPainter.cxx:2197
 THistPainter.cxx:2198
 THistPainter.cxx:2199
 THistPainter.cxx:2200
 THistPainter.cxx:2201
 THistPainter.cxx:2202
 THistPainter.cxx:2203
 THistPainter.cxx:2204
 THistPainter.cxx:2205
 THistPainter.cxx:2206
 THistPainter.cxx:2207
 THistPainter.cxx:2208
 THistPainter.cxx:2209
 THistPainter.cxx:2210
 THistPainter.cxx:2211
 THistPainter.cxx:2212
 THistPainter.cxx:2213
 THistPainter.cxx:2214
 THistPainter.cxx:2215
 THistPainter.cxx:2216
 THistPainter.cxx:2217
 THistPainter.cxx:2218
 THistPainter.cxx:2219
 THistPainter.cxx:2220
 THistPainter.cxx:2221
 THistPainter.cxx:2222
 THistPainter.cxx:2223
 THistPainter.cxx:2224
 THistPainter.cxx:2225
 THistPainter.cxx:2226
 THistPainter.cxx:2227
 THistPainter.cxx:2228
 THistPainter.cxx:2229
 THistPainter.cxx:2230
 THistPainter.cxx:2231
 THistPainter.cxx:2232
 THistPainter.cxx:2233
 THistPainter.cxx:2234
 THistPainter.cxx:2235
 THistPainter.cxx:2236
 THistPainter.cxx:2237
 THistPainter.cxx:2238
 THistPainter.cxx:2239
 THistPainter.cxx:2240
 THistPainter.cxx:2241
 THistPainter.cxx:2242
 THistPainter.cxx:2243
 THistPainter.cxx:2244
 THistPainter.cxx:2245
 THistPainter.cxx:2246
 THistPainter.cxx:2247
 THistPainter.cxx:2248
 THistPainter.cxx:2249
 THistPainter.cxx:2250
 THistPainter.cxx:2251
 THistPainter.cxx:2252
 THistPainter.cxx:2253
 THistPainter.cxx:2254
 THistPainter.cxx:2255
 THistPainter.cxx:2256
 THistPainter.cxx:2257
 THistPainter.cxx:2258
 THistPainter.cxx:2259
 THistPainter.cxx:2260
 THistPainter.cxx:2261
 THistPainter.cxx:2262
 THistPainter.cxx:2263
 THistPainter.cxx:2264
 THistPainter.cxx:2265
 THistPainter.cxx:2266
 THistPainter.cxx:2267
 THistPainter.cxx:2268
 THistPainter.cxx:2269
 THistPainter.cxx:2270
 THistPainter.cxx:2271
 THistPainter.cxx:2272
 THistPainter.cxx:2273
 THistPainter.cxx:2274
 THistPainter.cxx:2275
 THistPainter.cxx:2276
 THistPainter.cxx:2277
 THistPainter.cxx:2278
 THistPainter.cxx:2279
 THistPainter.cxx:2280
 THistPainter.cxx:2281
 THistPainter.cxx:2282
 THistPainter.cxx:2283
 THistPainter.cxx:2284
 THistPainter.cxx:2285
 THistPainter.cxx:2286
 THistPainter.cxx:2287
 THistPainter.cxx:2288
 THistPainter.cxx:2289
 THistPainter.cxx:2290
 THistPainter.cxx:2291
 THistPainter.cxx:2292
 THistPainter.cxx:2293
 THistPainter.cxx:2294
 THistPainter.cxx:2295
 THistPainter.cxx:2296
 THistPainter.cxx:2297
 THistPainter.cxx:2298
 THistPainter.cxx:2299
 THistPainter.cxx:2300
 THistPainter.cxx:2301
 THistPainter.cxx:2302
 THistPainter.cxx:2303
 THistPainter.cxx:2304
 THistPainter.cxx:2305
 THistPainter.cxx:2306
 THistPainter.cxx:2307
 THistPainter.cxx:2308
 THistPainter.cxx:2309
 THistPainter.cxx:2310
 THistPainter.cxx:2311
 THistPainter.cxx:2312
 THistPainter.cxx:2313
 THistPainter.cxx:2314
 THistPainter.cxx:2315
 THistPainter.cxx:2316
 THistPainter.cxx:2317
 THistPainter.cxx:2318
 THistPainter.cxx:2319
 THistPainter.cxx:2320
 THistPainter.cxx:2321
 THistPainter.cxx:2322
 THistPainter.cxx:2323
 THistPainter.cxx:2324
 THistPainter.cxx:2325
 THistPainter.cxx:2326
 THistPainter.cxx:2327
 THistPainter.cxx:2328
 THistPainter.cxx:2329
 THistPainter.cxx:2330
 THistPainter.cxx:2331
 THistPainter.cxx:2332
 THistPainter.cxx:2333
 THistPainter.cxx:2334
 THistPainter.cxx:2335
 THistPainter.cxx:2336
 THistPainter.cxx:2337
 THistPainter.cxx:2338
 THistPainter.cxx:2339
 THistPainter.cxx:2340
 THistPainter.cxx:2341
 THistPainter.cxx:2342
 THistPainter.cxx:2343
 THistPainter.cxx:2344
 THistPainter.cxx:2345
 THistPainter.cxx:2346
 THistPainter.cxx:2347
 THistPainter.cxx:2348
 THistPainter.cxx:2349
 THistPainter.cxx:2350
 THistPainter.cxx:2351
 THistPainter.cxx:2352
 THistPainter.cxx:2353
 THistPainter.cxx:2354
 THistPainter.cxx:2355
 THistPainter.cxx:2356
 THistPainter.cxx:2357
 THistPainter.cxx:2358
 THistPainter.cxx:2359
 THistPainter.cxx:2360
 THistPainter.cxx:2361
 THistPainter.cxx:2362
 THistPainter.cxx:2363
 THistPainter.cxx:2364
 THistPainter.cxx:2365
 THistPainter.cxx:2366
 THistPainter.cxx:2367
 THistPainter.cxx:2368
 THistPainter.cxx:2369
 THistPainter.cxx:2370
 THistPainter.cxx:2371
 THistPainter.cxx:2372
 THistPainter.cxx:2373
 THistPainter.cxx:2374
 THistPainter.cxx:2375
 THistPainter.cxx:2376
 THistPainter.cxx:2377
 THistPainter.cxx:2378
 THistPainter.cxx:2379
 THistPainter.cxx:2380
 THistPainter.cxx:2381
 THistPainter.cxx:2382
 THistPainter.cxx:2383
 THistPainter.cxx:2384
 THistPainter.cxx:2385
 THistPainter.cxx:2386
 THistPainter.cxx:2387
 THistPainter.cxx:2388
 THistPainter.cxx:2389
 THistPainter.cxx:2390
 THistPainter.cxx:2391
 THistPainter.cxx:2392
 THistPainter.cxx:2393
 THistPainter.cxx:2394
 THistPainter.cxx:2395
 THistPainter.cxx:2396
 THistPainter.cxx:2397
 THistPainter.cxx:2398
 THistPainter.cxx:2399
 THistPainter.cxx:2400
 THistPainter.cxx:2401
 THistPainter.cxx:2402
 THistPainter.cxx:2403
 THistPainter.cxx:2404
 THistPainter.cxx:2405
 THistPainter.cxx:2406
 THistPainter.cxx:2407
 THistPainter.cxx:2408
 THistPainter.cxx:2409
 THistPainter.cxx:2410
 THistPainter.cxx:2411
 THistPainter.cxx:2412
 THistPainter.cxx:2413
 THistPainter.cxx:2414
 THistPainter.cxx:2415
 THistPainter.cxx:2416
 THistPainter.cxx:2417
 THistPainter.cxx:2418
 THistPainter.cxx:2419
 THistPainter.cxx:2420
 THistPainter.cxx:2421
 THistPainter.cxx:2422
 THistPainter.cxx:2423
 THistPainter.cxx:2424
 THistPainter.cxx:2425
 THistPainter.cxx:2426
 THistPainter.cxx:2427
 THistPainter.cxx:2428
 THistPainter.cxx:2429
 THistPainter.cxx:2430
 THistPainter.cxx:2431
 THistPainter.cxx:2432
 THistPainter.cxx:2433
 THistPainter.cxx:2434
 THistPainter.cxx:2435
 THistPainter.cxx:2436
 THistPainter.cxx:2437
 THistPainter.cxx:2438
 THistPainter.cxx:2439
 THistPainter.cxx:2440
 THistPainter.cxx:2441
 THistPainter.cxx:2442
 THistPainter.cxx:2443
 THistPainter.cxx:2444
 THistPainter.cxx:2445
 THistPainter.cxx:2446
 THistPainter.cxx:2447
 THistPainter.cxx:2448
 THistPainter.cxx:2449
 THistPainter.cxx:2450
 THistPainter.cxx:2451
 THistPainter.cxx:2452
 THistPainter.cxx:2453
 THistPainter.cxx:2454
 THistPainter.cxx:2455
 THistPainter.cxx:2456
 THistPainter.cxx:2457
 THistPainter.cxx:2458
 THistPainter.cxx:2459
 THistPainter.cxx:2460
 THistPainter.cxx:2461
 THistPainter.cxx:2462
 THistPainter.cxx:2463
 THistPainter.cxx:2464
 THistPainter.cxx:2465
 THistPainter.cxx:2466
 THistPainter.cxx:2467
 THistPainter.cxx:2468
 THistPainter.cxx:2469
 THistPainter.cxx:2470
 THistPainter.cxx:2471
 THistPainter.cxx:2472
 THistPainter.cxx:2473
 THistPainter.cxx:2474
 THistPainter.cxx:2475
 THistPainter.cxx:2476
 THistPainter.cxx:2477
 THistPainter.cxx:2478
 THistPainter.cxx:2479
 THistPainter.cxx:2480
 THistPainter.cxx:2481
 THistPainter.cxx:2482
 THistPainter.cxx:2483
 THistPainter.cxx:2484
 THistPainter.cxx:2485
 THistPainter.cxx:2486
 THistPainter.cxx:2487
 THistPainter.cxx:2488
 THistPainter.cxx:2489
 THistPainter.cxx:2490
 THistPainter.cxx:2491
 THistPainter.cxx:2492
 THistPainter.cxx:2493
 THistPainter.cxx:2494
 THistPainter.cxx:2495
 THistPainter.cxx:2496
 THistPainter.cxx:2497
 THistPainter.cxx:2498
 THistPainter.cxx:2499
 THistPainter.cxx:2500
 THistPainter.cxx:2501
 THistPainter.cxx:2502
 THistPainter.cxx:2503
 THistPainter.cxx:2504
 THistPainter.cxx:2505
 THistPainter.cxx:2506
 THistPainter.cxx:2507
 THistPainter.cxx:2508
 THistPainter.cxx:2509
 THistPainter.cxx:2510
 THistPainter.cxx:2511
 THistPainter.cxx:2512
 THistPainter.cxx:2513
 THistPainter.cxx:2514
 THistPainter.cxx:2515
 THistPainter.cxx:2516
 THistPainter.cxx:2517
 THistPainter.cxx:2518
 THistPainter.cxx:2519
 THistPainter.cxx:2520
 THistPainter.cxx:2521
 THistPainter.cxx:2522
 THistPainter.cxx:2523
 THistPainter.cxx:2524
 THistPainter.cxx:2525
 THistPainter.cxx:2526
 THistPainter.cxx:2527
 THistPainter.cxx:2528
 THistPainter.cxx:2529
 THistPainter.cxx:2530
 THistPainter.cxx:2531
 THistPainter.cxx:2532
 THistPainter.cxx:2533
 THistPainter.cxx:2534
 THistPainter.cxx:2535
 THistPainter.cxx:2536
 THistPainter.cxx:2537
 THistPainter.cxx:2538
 THistPainter.cxx:2539
 THistPainter.cxx:2540
 THistPainter.cxx:2541
 THistPainter.cxx:2542
 THistPainter.cxx:2543
 THistPainter.cxx:2544
 THistPainter.cxx:2545
 THistPainter.cxx:2546
 THistPainter.cxx:2547
 THistPainter.cxx:2548
 THistPainter.cxx:2549
 THistPainter.cxx:2550
 THistPainter.cxx:2551
 THistPainter.cxx:2552
 THistPainter.cxx:2553
 THistPainter.cxx:2554
 THistPainter.cxx:2555
 THistPainter.cxx:2556
 THistPainter.cxx:2557
 THistPainter.cxx:2558
 THistPainter.cxx:2559
 THistPainter.cxx:2560
 THistPainter.cxx:2561
 THistPainter.cxx:2562
 THistPainter.cxx:2563
 THistPainter.cxx:2564
 THistPainter.cxx:2565
 THistPainter.cxx:2566
 THistPainter.cxx:2567
 THistPainter.cxx:2568
 THistPainter.cxx:2569
 THistPainter.cxx:2570
 THistPainter.cxx:2571
 THistPainter.cxx:2572
 THistPainter.cxx:2573
 THistPainter.cxx:2574
 THistPainter.cxx:2575
 THistPainter.cxx:2576
 THistPainter.cxx:2577
 THistPainter.cxx:2578
 THistPainter.cxx:2579
 THistPainter.cxx:2580
 THistPainter.cxx:2581
 THistPainter.cxx:2582
 THistPainter.cxx:2583
 THistPainter.cxx:2584
 THistPainter.cxx:2585
 THistPainter.cxx:2586
 THistPainter.cxx:2587
 THistPainter.cxx:2588
 THistPainter.cxx:2589
 THistPainter.cxx:2590
 THistPainter.cxx:2591
 THistPainter.cxx:2592
 THistPainter.cxx:2593
 THistPainter.cxx:2594
 THistPainter.cxx:2595
 THistPainter.cxx:2596
 THistPainter.cxx:2597
 THistPainter.cxx:2598
 THistPainter.cxx:2599
 THistPainter.cxx:2600
 THistPainter.cxx:2601
 THistPainter.cxx:2602
 THistPainter.cxx:2603
 THistPainter.cxx:2604
 THistPainter.cxx:2605
 THistPainter.cxx:2606
 THistPainter.cxx:2607
 THistPainter.cxx:2608
 THistPainter.cxx:2609
 THistPainter.cxx:2610
 THistPainter.cxx:2611
 THistPainter.cxx:2612
 THistPainter.cxx:2613
 THistPainter.cxx:2614
 THistPainter.cxx:2615
 THistPainter.cxx:2616
 THistPainter.cxx:2617
 THistPainter.cxx:2618
 THistPainter.cxx:2619
 THistPainter.cxx:2620
 THistPainter.cxx:2621
 THistPainter.cxx:2622
 THistPainter.cxx:2623
 THistPainter.cxx:2624
 THistPainter.cxx:2625
 THistPainter.cxx:2626
 THistPainter.cxx:2627
 THistPainter.cxx:2628
 THistPainter.cxx:2629
 THistPainter.cxx:2630
 THistPainter.cxx:2631
 THistPainter.cxx:2632
 THistPainter.cxx:2633
 THistPainter.cxx:2634
 THistPainter.cxx:2635
 THistPainter.cxx:2636
 THistPainter.cxx:2637
 THistPainter.cxx:2638
 THistPainter.cxx:2639
 THistPainter.cxx:2640
 THistPainter.cxx:2641
 THistPainter.cxx:2642
 THistPainter.cxx:2643
 THistPainter.cxx:2644
 THistPainter.cxx:2645
 THistPainter.cxx:2646
 THistPainter.cxx:2647
 THistPainter.cxx:2648
 THistPainter.cxx:2649
 THistPainter.cxx:2650
 THistPainter.cxx:2651
 THistPainter.cxx:2652
 THistPainter.cxx:2653
 THistPainter.cxx:2654
 THistPainter.cxx:2655
 THistPainter.cxx:2656
 THistPainter.cxx:2657
 THistPainter.cxx:2658
 THistPainter.cxx:2659
 THistPainter.cxx:2660
 THistPainter.cxx:2661
 THistPainter.cxx:2662
 THistPainter.cxx:2663
 THistPainter.cxx:2664
 THistPainter.cxx:2665
 THistPainter.cxx:2666
 THistPainter.cxx:2667
 THistPainter.cxx:2668
 THistPainter.cxx:2669
 THistPainter.cxx:2670
 THistPainter.cxx:2671
 THistPainter.cxx:2672
 THistPainter.cxx:2673
 THistPainter.cxx:2674
 THistPainter.cxx:2675
 THistPainter.cxx:2676
 THistPainter.cxx:2677
 THistPainter.cxx:2678
 THistPainter.cxx:2679
 THistPainter.cxx:2680
 THistPainter.cxx:2681
 THistPainter.cxx:2682
 THistPainter.cxx:2683
 THistPainter.cxx:2684
 THistPainter.cxx:2685
 THistPainter.cxx:2686
 THistPainter.cxx:2687
 THistPainter.cxx:2688
 THistPainter.cxx:2689
 THistPainter.cxx:2690
 THistPainter.cxx:2691
 THistPainter.cxx:2692
 THistPainter.cxx:2693
 THistPainter.cxx:2694
 THistPainter.cxx:2695
 THistPainter.cxx:2696
 THistPainter.cxx:2697
 THistPainter.cxx:2698
 THistPainter.cxx:2699
 THistPainter.cxx:2700
 THistPainter.cxx:2701
 THistPainter.cxx:2702
 THistPainter.cxx:2703
 THistPainter.cxx:2704
 THistPainter.cxx:2705
 THistPainter.cxx:2706
 THistPainter.cxx:2707
 THistPainter.cxx:2708
 THistPainter.cxx:2709
 THistPainter.cxx:2710
 THistPainter.cxx:2711
 THistPainter.cxx:2712
 THistPainter.cxx:2713
 THistPainter.cxx:2714
 THistPainter.cxx:2715
 THistPainter.cxx:2716
 THistPainter.cxx:2717
 THistPainter.cxx:2718
 THistPainter.cxx:2719
 THistPainter.cxx:2720
 THistPainter.cxx:2721
 THistPainter.cxx:2722
 THistPainter.cxx:2723
 THistPainter.cxx:2724
 THistPainter.cxx:2725
 THistPainter.cxx:2726
 THistPainter.cxx:2727
 THistPainter.cxx:2728
 THistPainter.cxx:2729
 THistPainter.cxx:2730
 THistPainter.cxx:2731
 THistPainter.cxx:2732
 THistPainter.cxx:2733
 THistPainter.cxx:2734
 THistPainter.cxx:2735
 THistPainter.cxx:2736
 THistPainter.cxx:2737
 THistPainter.cxx:2738
 THistPainter.cxx:2739
 THistPainter.cxx:2740
 THistPainter.cxx:2741
 THistPainter.cxx:2742
 THistPainter.cxx:2743
 THistPainter.cxx:2744
 THistPainter.cxx:2745
 THistPainter.cxx:2746
 THistPainter.cxx:2747
 THistPainter.cxx:2748
 THistPainter.cxx:2749
 THistPainter.cxx:2750
 THistPainter.cxx:2751
 THistPainter.cxx:2752
 THistPainter.cxx:2753
 THistPainter.cxx:2754
 THistPainter.cxx:2755
 THistPainter.cxx:2756
 THistPainter.cxx:2757
 THistPainter.cxx:2758
 THistPainter.cxx:2759
 THistPainter.cxx:2760
 THistPainter.cxx:2761
 THistPainter.cxx:2762
 THistPainter.cxx:2763
 THistPainter.cxx:2764
 THistPainter.cxx:2765
 THistPainter.cxx:2766
 THistPainter.cxx:2767
 THistPainter.cxx:2768
 THistPainter.cxx:2769
 THistPainter.cxx:2770
 THistPainter.cxx:2771
 THistPainter.cxx:2772
 THistPainter.cxx:2773
 THistPainter.cxx:2774
 THistPainter.cxx:2775
 THistPainter.cxx:2776
 THistPainter.cxx:2777
 THistPainter.cxx:2778
 THistPainter.cxx:2779
 THistPainter.cxx:2780
 THistPainter.cxx:2781
 THistPainter.cxx:2782
 THistPainter.cxx:2783
 THistPainter.cxx:2784
 THistPainter.cxx:2785
 THistPainter.cxx:2786
 THistPainter.cxx:2787
 THistPainter.cxx:2788
 THistPainter.cxx:2789
 THistPainter.cxx:2790
 THistPainter.cxx:2791
 THistPainter.cxx:2792
 THistPainter.cxx:2793
 THistPainter.cxx:2794
 THistPainter.cxx:2795
 THistPainter.cxx:2796
 THistPainter.cxx:2797
 THistPainter.cxx:2798
 THistPainter.cxx:2799
 THistPainter.cxx:2800
 THistPainter.cxx:2801
 THistPainter.cxx:2802
 THistPainter.cxx:2803
 THistPainter.cxx:2804
 THistPainter.cxx:2805
 THistPainter.cxx:2806
 THistPainter.cxx:2807
 THistPainter.cxx:2808
 THistPainter.cxx:2809
 THistPainter.cxx:2810
 THistPainter.cxx:2811
 THistPainter.cxx:2812
 THistPainter.cxx:2813
 THistPainter.cxx:2814
 THistPainter.cxx:2815
 THistPainter.cxx:2816
 THistPainter.cxx:2817
 THistPainter.cxx:2818
 THistPainter.cxx:2819
 THistPainter.cxx:2820
 THistPainter.cxx:2821
 THistPainter.cxx:2822
 THistPainter.cxx:2823
 THistPainter.cxx:2824
 THistPainter.cxx:2825
 THistPainter.cxx:2826
 THistPainter.cxx:2827
 THistPainter.cxx:2828
 THistPainter.cxx:2829
 THistPainter.cxx:2830
 THistPainter.cxx:2831
 THistPainter.cxx:2832
 THistPainter.cxx:2833
 THistPainter.cxx:2834
 THistPainter.cxx:2835
 THistPainter.cxx:2836
 THistPainter.cxx:2837
 THistPainter.cxx:2838
 THistPainter.cxx:2839
 THistPainter.cxx:2840
 THistPainter.cxx:2841
 THistPainter.cxx:2842
 THistPainter.cxx:2843
 THistPainter.cxx:2844
 THistPainter.cxx:2845
 THistPainter.cxx:2846
 THistPainter.cxx:2847
 THistPainter.cxx:2848
 THistPainter.cxx:2849
 THistPainter.cxx:2850
 THistPainter.cxx:2851
 THistPainter.cxx:2852
 THistPainter.cxx:2853
 THistPainter.cxx:2854
 THistPainter.cxx:2855
 THistPainter.cxx:2856
 THistPainter.cxx:2857
 THistPainter.cxx:2858
 THistPainter.cxx:2859
 THistPainter.cxx:2860
 THistPainter.cxx:2861
 THistPainter.cxx:2862
 THistPainter.cxx:2863
 THistPainter.cxx:2864
 THistPainter.cxx:2865
 THistPainter.cxx:2866
 THistPainter.cxx:2867
 THistPainter.cxx:2868
 THistPainter.cxx:2869
 THistPainter.cxx:2870
 THistPainter.cxx:2871
 THistPainter.cxx:2872
 THistPainter.cxx:2873
 THistPainter.cxx:2874
 THistPainter.cxx:2875
 THistPainter.cxx:2876
 THistPainter.cxx:2877
 THistPainter.cxx:2878
 THistPainter.cxx:2879
 THistPainter.cxx:2880
 THistPainter.cxx:2881
 THistPainter.cxx:2882
 THistPainter.cxx:2883
 THistPainter.cxx:2884
 THistPainter.cxx:2885
 THistPainter.cxx:2886
 THistPainter.cxx:2887
 THistPainter.cxx:2888
 THistPainter.cxx:2889
 THistPainter.cxx:2890
 THistPainter.cxx:2891
 THistPainter.cxx:2892
 THistPainter.cxx:2893
 THistPainter.cxx:2894
 THistPainter.cxx:2895
 THistPainter.cxx:2896
 THistPainter.cxx:2897
 THistPainter.cxx:2898
 THistPainter.cxx:2899
 THistPainter.cxx:2900
 THistPainter.cxx:2901
 THistPainter.cxx:2902
 THistPainter.cxx:2903
 THistPainter.cxx:2904
 THistPainter.cxx:2905
 THistPainter.cxx:2906
 THistPainter.cxx:2907
 THistPainter.cxx:2908
 THistPainter.cxx:2909
 THistPainter.cxx:2910
 THistPainter.cxx:2911
 THistPainter.cxx:2912
 THistPainter.cxx:2913
 THistPainter.cxx:2914
 THistPainter.cxx:2915
 THistPainter.cxx:2916
 THistPainter.cxx:2917
 THistPainter.cxx:2918
 THistPainter.cxx:2919
 THistPainter.cxx:2920
 THistPainter.cxx:2921
 THistPainter.cxx:2922
 THistPainter.cxx:2923
 THistPainter.cxx:2924
 THistPainter.cxx:2925
 THistPainter.cxx:2926
 THistPainter.cxx:2927
 THistPainter.cxx:2928
 THistPainter.cxx:2929
 THistPainter.cxx:2930
 THistPainter.cxx:2931
 THistPainter.cxx:2932
 THistPainter.cxx:2933
 THistPainter.cxx:2934
 THistPainter.cxx:2935
 THistPainter.cxx:2936
 THistPainter.cxx:2937
 THistPainter.cxx:2938
 THistPainter.cxx:2939
 THistPainter.cxx:2940
 THistPainter.cxx:2941
 THistPainter.cxx:2942
 THistPainter.cxx:2943
 THistPainter.cxx:2944
 THistPainter.cxx:2945
 THistPainter.cxx:2946
 THistPainter.cxx:2947
 THistPainter.cxx:2948
 THistPainter.cxx:2949
 THistPainter.cxx:2950
 THistPainter.cxx:2951
 THistPainter.cxx:2952
 THistPainter.cxx:2953
 THistPainter.cxx:2954
 THistPainter.cxx:2955
 THistPainter.cxx:2956
 THistPainter.cxx:2957
 THistPainter.cxx:2958
 THistPainter.cxx:2959
 THistPainter.cxx:2960
 THistPainter.cxx:2961
 THistPainter.cxx:2962
 THistPainter.cxx:2963
 THistPainter.cxx:2964
 THistPainter.cxx:2965
 THistPainter.cxx:2966
 THistPainter.cxx:2967
 THistPainter.cxx:2968
 THistPainter.cxx:2969
 THistPainter.cxx:2970
 THistPainter.cxx:2971
 THistPainter.cxx:2972
 THistPainter.cxx:2973
 THistPainter.cxx:2974
 THistPainter.cxx:2975
 THistPainter.cxx:2976
 THistPainter.cxx:2977
 THistPainter.cxx:2978
 THistPainter.cxx:2979
 THistPainter.cxx:2980
 THistPainter.cxx:2981
 THistPainter.cxx:2982
 THistPainter.cxx:2983
 THistPainter.cxx:2984
 THistPainter.cxx:2985
 THistPainter.cxx:2986
 THistPainter.cxx:2987
 THistPainter.cxx:2988
 THistPainter.cxx:2989
 THistPainter.cxx:2990
 THistPainter.cxx:2991
 THistPainter.cxx:2992
 THistPainter.cxx:2993
 THistPainter.cxx:2994
 THistPainter.cxx:2995
 THistPainter.cxx:2996
 THistPainter.cxx:2997
 THistPainter.cxx:2998
 THistPainter.cxx:2999
 THistPainter.cxx:3000
 THistPainter.cxx:3001
 THistPainter.cxx:3002
 THistPainter.cxx:3003
 THistPainter.cxx:3004
 THistPainter.cxx:3005
 THistPainter.cxx:3006
 THistPainter.cxx:3007
 THistPainter.cxx:3008
 THistPainter.cxx:3009
 THistPainter.cxx:3010
 THistPainter.cxx:3011
 THistPainter.cxx:3012
 THistPainter.cxx:3013
 THistPainter.cxx:3014
 THistPainter.cxx:3015
 THistPainter.cxx:3016
 THistPainter.cxx:3017
 THistPainter.cxx:3018
 THistPainter.cxx:3019
 THistPainter.cxx:3020
 THistPainter.cxx:3021
 THistPainter.cxx:3022
 THistPainter.cxx:3023
 THistPainter.cxx:3024
 THistPainter.cxx:3025
 THistPainter.cxx:3026
 THistPainter.cxx:3027
 THistPainter.cxx:3028
 THistPainter.cxx:3029
 THistPainter.cxx:3030
 THistPainter.cxx:3031
 THistPainter.cxx:3032
 THistPainter.cxx:3033
 THistPainter.cxx:3034
 THistPainter.cxx:3035
 THistPainter.cxx:3036
 THistPainter.cxx:3037
 THistPainter.cxx:3038
 THistPainter.cxx:3039
 THistPainter.cxx:3040
 THistPainter.cxx:3041
 THistPainter.cxx:3042
 THistPainter.cxx:3043
 THistPainter.cxx:3044
 THistPainter.cxx:3045
 THistPainter.cxx:3046
 THistPainter.cxx:3047
 THistPainter.cxx:3048
 THistPainter.cxx:3049
 THistPainter.cxx:3050
 THistPainter.cxx:3051
 THistPainter.cxx:3052
 THistPainter.cxx:3053
 THistPainter.cxx:3054
 THistPainter.cxx:3055
 THistPainter.cxx:3056
 THistPainter.cxx:3057
 THistPainter.cxx:3058
 THistPainter.cxx:3059
 THistPainter.cxx:3060
 THistPainter.cxx:3061
 THistPainter.cxx:3062
 THistPainter.cxx:3063
 THistPainter.cxx:3064
 THistPainter.cxx:3065
 THistPainter.cxx:3066
 THistPainter.cxx:3067
 THistPainter.cxx:3068
 THistPainter.cxx:3069
 THistPainter.cxx:3070
 THistPainter.cxx:3071
 THistPainter.cxx:3072
 THistPainter.cxx:3073
 THistPainter.cxx:3074
 THistPainter.cxx:3075
 THistPainter.cxx:3076
 THistPainter.cxx:3077
 THistPainter.cxx:3078
 THistPainter.cxx:3079
 THistPainter.cxx:3080
 THistPainter.cxx:3081
 THistPainter.cxx:3082
 THistPainter.cxx:3083
 THistPainter.cxx:3084
 THistPainter.cxx:3085
 THistPainter.cxx:3086
 THistPainter.cxx:3087
 THistPainter.cxx:3088
 THistPainter.cxx:3089
 THistPainter.cxx:3090
 THistPainter.cxx:3091
 THistPainter.cxx:3092
 THistPainter.cxx:3093
 THistPainter.cxx:3094
 THistPainter.cxx:3095
 THistPainter.cxx:3096
 THistPainter.cxx:3097
 THistPainter.cxx:3098
 THistPainter.cxx:3099
 THistPainter.cxx:3100
 THistPainter.cxx:3101
 THistPainter.cxx:3102
 THistPainter.cxx:3103
 THistPainter.cxx:3104
 THistPainter.cxx:3105
 THistPainter.cxx:3106
 THistPainter.cxx:3107
 THistPainter.cxx:3108
 THistPainter.cxx:3109
 THistPainter.cxx:3110
 THistPainter.cxx:3111
 THistPainter.cxx:3112
 THistPainter.cxx:3113
 THistPainter.cxx:3114
 THistPainter.cxx:3115
 THistPainter.cxx:3116
 THistPainter.cxx:3117
 THistPainter.cxx:3118
 THistPainter.cxx:3119
 THistPainter.cxx:3120
 THistPainter.cxx:3121
 THistPainter.cxx:3122
 THistPainter.cxx:3123
 THistPainter.cxx:3124
 THistPainter.cxx:3125
 THistPainter.cxx:3126
 THistPainter.cxx:3127
 THistPainter.cxx:3128
 THistPainter.cxx:3129
 THistPainter.cxx:3130
 THistPainter.cxx:3131
 THistPainter.cxx:3132
 THistPainter.cxx:3133
 THistPainter.cxx:3134
 THistPainter.cxx:3135
 THistPainter.cxx:3136
 THistPainter.cxx:3137
 THistPainter.cxx:3138
 THistPainter.cxx:3139
 THistPainter.cxx:3140
 THistPainter.cxx:3141
 THistPainter.cxx:3142
 THistPainter.cxx:3143
 THistPainter.cxx:3144
 THistPainter.cxx:3145
 THistPainter.cxx:3146
 THistPainter.cxx:3147
 THistPainter.cxx:3148
 THistPainter.cxx:3149
 THistPainter.cxx:3150
 THistPainter.cxx:3151
 THistPainter.cxx:3152
 THistPainter.cxx:3153
 THistPainter.cxx:3154
 THistPainter.cxx:3155
 THistPainter.cxx:3156
 THistPainter.cxx:3157
 THistPainter.cxx:3158
 THistPainter.cxx:3159
 THistPainter.cxx:3160
 THistPainter.cxx:3161
 THistPainter.cxx:3162
 THistPainter.cxx:3163
 THistPainter.cxx:3164
 THistPainter.cxx:3165
 THistPainter.cxx:3166
 THistPainter.cxx:3167
 THistPainter.cxx:3168
 THistPainter.cxx:3169
 THistPainter.cxx:3170
 THistPainter.cxx:3171
 THistPainter.cxx:3172
 THistPainter.cxx:3173
 THistPainter.cxx:3174
 THistPainter.cxx:3175
 THistPainter.cxx:3176
 THistPainter.cxx:3177
 THistPainter.cxx:3178
 THistPainter.cxx:3179
 THistPainter.cxx:3180
 THistPainter.cxx:3181
 THistPainter.cxx:3182
 THistPainter.cxx:3183
 THistPainter.cxx:3184
 THistPainter.cxx:3185
 THistPainter.cxx:3186
 THistPainter.cxx:3187
 THistPainter.cxx:3188
 THistPainter.cxx:3189
 THistPainter.cxx:3190
 THistPainter.cxx:3191
 THistPainter.cxx:3192
 THistPainter.cxx:3193
 THistPainter.cxx:3194
 THistPainter.cxx:3195
 THistPainter.cxx:3196
 THistPainter.cxx:3197
 THistPainter.cxx:3198
 THistPainter.cxx:3199
 THistPainter.cxx:3200
 THistPainter.cxx:3201
 THistPainter.cxx:3202
 THistPainter.cxx:3203
 THistPainter.cxx:3204
 THistPainter.cxx:3205
 THistPainter.cxx:3206
 THistPainter.cxx:3207
 THistPainter.cxx:3208
 THistPainter.cxx:3209
 THistPainter.cxx:3210
 THistPainter.cxx:3211
 THistPainter.cxx:3212
 THistPainter.cxx:3213
 THistPainter.cxx:3214
 THistPainter.cxx:3215
 THistPainter.cxx:3216
 THistPainter.cxx:3217
 THistPainter.cxx:3218
 THistPainter.cxx:3219
 THistPainter.cxx:3220
 THistPainter.cxx:3221
 THistPainter.cxx:3222
 THistPainter.cxx:3223
 THistPainter.cxx:3224
 THistPainter.cxx:3225
 THistPainter.cxx:3226
 THistPainter.cxx:3227
 THistPainter.cxx:3228
 THistPainter.cxx:3229
 THistPainter.cxx:3230
 THistPainter.cxx:3231
 THistPainter.cxx:3232
 THistPainter.cxx:3233
 THistPainter.cxx:3234
 THistPainter.cxx:3235
 THistPainter.cxx:3236
 THistPainter.cxx:3237
 THistPainter.cxx:3238
 THistPainter.cxx:3239
 THistPainter.cxx:3240
 THistPainter.cxx:3241
 THistPainter.cxx:3242
 THistPainter.cxx:3243
 THistPainter.cxx:3244
 THistPainter.cxx:3245
 THistPainter.cxx:3246
 THistPainter.cxx:3247
 THistPainter.cxx:3248
 THistPainter.cxx:3249
 THistPainter.cxx:3250
 THistPainter.cxx:3251
 THistPainter.cxx:3252
 THistPainter.cxx:3253
 THistPainter.cxx:3254
 THistPainter.cxx:3255
 THistPainter.cxx:3256
 THistPainter.cxx:3257
 THistPainter.cxx:3258
 THistPainter.cxx:3259
 THistPainter.cxx:3260
 THistPainter.cxx:3261
 THistPainter.cxx:3262
 THistPainter.cxx:3263
 THistPainter.cxx:3264
 THistPainter.cxx:3265
 THistPainter.cxx:3266
 THistPainter.cxx:3267
 THistPainter.cxx:3268
 THistPainter.cxx:3269
 THistPainter.cxx:3270
 THistPainter.cxx:3271
 THistPainter.cxx:3272
 THistPainter.cxx:3273
 THistPainter.cxx:3274
 THistPainter.cxx:3275
 THistPainter.cxx:3276
 THistPainter.cxx:3277
 THistPainter.cxx:3278
 THistPainter.cxx:3279
 THistPainter.cxx:3280
 THistPainter.cxx:3281
 THistPainter.cxx:3282
 THistPainter.cxx:3283
 THistPainter.cxx:3284
 THistPainter.cxx:3285
 THistPainter.cxx:3286
 THistPainter.cxx:3287
 THistPainter.cxx:3288
 THistPainter.cxx:3289
 THistPainter.cxx:3290
 THistPainter.cxx:3291
 THistPainter.cxx:3292
 THistPainter.cxx:3293
 THistPainter.cxx:3294
 THistPainter.cxx:3295
 THistPainter.cxx:3296
 THistPainter.cxx:3297
 THistPainter.cxx:3298
 THistPainter.cxx:3299
 THistPainter.cxx:3300
 THistPainter.cxx:3301
 THistPainter.cxx:3302
 THistPainter.cxx:3303
 THistPainter.cxx:3304
 THistPainter.cxx:3305
 THistPainter.cxx:3306
 THistPainter.cxx:3307
 THistPainter.cxx:3308
 THistPainter.cxx:3309
 THistPainter.cxx:3310
 THistPainter.cxx:3311
 THistPainter.cxx:3312
 THistPainter.cxx:3313
 THistPainter.cxx:3314
 THistPainter.cxx:3315
 THistPainter.cxx:3316
 THistPainter.cxx:3317
 THistPainter.cxx:3318
 THistPainter.cxx:3319
 THistPainter.cxx:3320
 THistPainter.cxx:3321
 THistPainter.cxx:3322
 THistPainter.cxx:3323
 THistPainter.cxx:3324
 THistPainter.cxx:3325
 THistPainter.cxx:3326
 THistPainter.cxx:3327
 THistPainter.cxx:3328
 THistPainter.cxx:3329
 THistPainter.cxx:3330
 THistPainter.cxx:3331
 THistPainter.cxx:3332
 THistPainter.cxx:3333
 THistPainter.cxx:3334
 THistPainter.cxx:3335
 THistPainter.cxx:3336
 THistPainter.cxx:3337
 THistPainter.cxx:3338
 THistPainter.cxx:3339
 THistPainter.cxx:3340
 THistPainter.cxx:3341
 THistPainter.cxx:3342
 THistPainter.cxx:3343
 THistPainter.cxx:3344
 THistPainter.cxx:3345
 THistPainter.cxx:3346
 THistPainter.cxx:3347
 THistPainter.cxx:3348
 THistPainter.cxx:3349
 THistPainter.cxx:3350
 THistPainter.cxx:3351
 THistPainter.cxx:3352
 THistPainter.cxx:3353
 THistPainter.cxx:3354
 THistPainter.cxx:3355
 THistPainter.cxx:3356
 THistPainter.cxx:3357
 THistPainter.cxx:3358
 THistPainter.cxx:3359
 THistPainter.cxx:3360
 THistPainter.cxx:3361
 THistPainter.cxx:3362
 THistPainter.cxx:3363
 THistPainter.cxx:3364
 THistPainter.cxx:3365
 THistPainter.cxx:3366
 THistPainter.cxx:3367
 THistPainter.cxx:3368
 THistPainter.cxx:3369
 THistPainter.cxx:3370
 THistPainter.cxx:3371
 THistPainter.cxx:3372
 THistPainter.cxx:3373
 THistPainter.cxx:3374
 THistPainter.cxx:3375
 THistPainter.cxx:3376
 THistPainter.cxx:3377
 THistPainter.cxx:3378
 THistPainter.cxx:3379
 THistPainter.cxx:3380
 THistPainter.cxx:3381
 THistPainter.cxx:3382
 THistPainter.cxx:3383
 THistPainter.cxx:3384
 THistPainter.cxx:3385
 THistPainter.cxx:3386
 THistPainter.cxx:3387
 THistPainter.cxx:3388
 THistPainter.cxx:3389
 THistPainter.cxx:3390
 THistPainter.cxx:3391
 THistPainter.cxx:3392
 THistPainter.cxx:3393
 THistPainter.cxx:3394
 THistPainter.cxx:3395
 THistPainter.cxx:3396
 THistPainter.cxx:3397
 THistPainter.cxx:3398
 THistPainter.cxx:3399
 THistPainter.cxx:3400
 THistPainter.cxx:3401
 THistPainter.cxx:3402
 THistPainter.cxx:3403
 THistPainter.cxx:3404
 THistPainter.cxx:3405
 THistPainter.cxx:3406
 THistPainter.cxx:3407
 THistPainter.cxx:3408
 THistPainter.cxx:3409
 THistPainter.cxx:3410
 THistPainter.cxx:3411
 THistPainter.cxx:3412
 THistPainter.cxx:3413
 THistPainter.cxx:3414
 THistPainter.cxx:3415
 THistPainter.cxx:3416
 THistPainter.cxx:3417
 THistPainter.cxx:3418
 THistPainter.cxx:3419
 THistPainter.cxx:3420
 THistPainter.cxx:3421
 THistPainter.cxx:3422
 THistPainter.cxx:3423
 THistPainter.cxx:3424
 THistPainter.cxx:3425
 THistPainter.cxx:3426
 THistPainter.cxx:3427
 THistPainter.cxx:3428
 THistPainter.cxx:3429
 THistPainter.cxx:3430
 THistPainter.cxx:3431
 THistPainter.cxx:3432
 THistPainter.cxx:3433
 THistPainter.cxx:3434
 THistPainter.cxx:3435
 THistPainter.cxx:3436
 THistPainter.cxx:3437
 THistPainter.cxx:3438
 THistPainter.cxx:3439
 THistPainter.cxx:3440
 THistPainter.cxx:3441
 THistPainter.cxx:3442
 THistPainter.cxx:3443
 THistPainter.cxx:3444
 THistPainter.cxx:3445
 THistPainter.cxx:3446
 THistPainter.cxx:3447
 THistPainter.cxx:3448
 THistPainter.cxx:3449
 THistPainter.cxx:3450
 THistPainter.cxx:3451
 THistPainter.cxx:3452
 THistPainter.cxx:3453
 THistPainter.cxx:3454
 THistPainter.cxx:3455
 THistPainter.cxx:3456
 THistPainter.cxx:3457
 THistPainter.cxx:3458
 THistPainter.cxx:3459
 THistPainter.cxx:3460
 THistPainter.cxx:3461
 THistPainter.cxx:3462
 THistPainter.cxx:3463
 THistPainter.cxx:3464
 THistPainter.cxx:3465
 THistPainter.cxx:3466
 THistPainter.cxx:3467
 THistPainter.cxx:3468
 THistPainter.cxx:3469
 THistPainter.cxx:3470
 THistPainter.cxx:3471
 THistPainter.cxx:3472
 THistPainter.cxx:3473
 THistPainter.cxx:3474
 THistPainter.cxx:3475
 THistPainter.cxx:3476
 THistPainter.cxx:3477
 THistPainter.cxx:3478
 THistPainter.cxx:3479
 THistPainter.cxx:3480
 THistPainter.cxx:3481
 THistPainter.cxx:3482
 THistPainter.cxx:3483
 THistPainter.cxx:3484
 THistPainter.cxx:3485
 THistPainter.cxx:3486
 THistPainter.cxx:3487
 THistPainter.cxx:3488
 THistPainter.cxx:3489
 THistPainter.cxx:3490
 THistPainter.cxx:3491
 THistPainter.cxx:3492
 THistPainter.cxx:3493
 THistPainter.cxx:3494
 THistPainter.cxx:3495
 THistPainter.cxx:3496
 THistPainter.cxx:3497
 THistPainter.cxx:3498
 THistPainter.cxx:3499
 THistPainter.cxx:3500
 THistPainter.cxx:3501
 THistPainter.cxx:3502
 THistPainter.cxx:3503
 THistPainter.cxx:3504
 THistPainter.cxx:3505
 THistPainter.cxx:3506
 THistPainter.cxx:3507
 THistPainter.cxx:3508
 THistPainter.cxx:3509
 THistPainter.cxx:3510
 THistPainter.cxx:3511
 THistPainter.cxx:3512
 THistPainter.cxx:3513
 THistPainter.cxx:3514
 THistPainter.cxx:3515
 THistPainter.cxx:3516
 THistPainter.cxx:3517
 THistPainter.cxx:3518
 THistPainter.cxx:3519
 THistPainter.cxx:3520
 THistPainter.cxx:3521
 THistPainter.cxx:3522
 THistPainter.cxx:3523
 THistPainter.cxx:3524
 THistPainter.cxx:3525
 THistPainter.cxx:3526
 THistPainter.cxx:3527
 THistPainter.cxx:3528
 THistPainter.cxx:3529
 THistPainter.cxx:3530
 THistPainter.cxx:3531
 THistPainter.cxx:3532
 THistPainter.cxx:3533
 THistPainter.cxx:3534
 THistPainter.cxx:3535
 THistPainter.cxx:3536
 THistPainter.cxx:3537
 THistPainter.cxx:3538
 THistPainter.cxx:3539
 THistPainter.cxx:3540
 THistPainter.cxx:3541
 THistPainter.cxx:3542
 THistPainter.cxx:3543
 THistPainter.cxx:3544
 THistPainter.cxx:3545
 THistPainter.cxx:3546
 THistPainter.cxx:3547
 THistPainter.cxx:3548
 THistPainter.cxx:3549
 THistPainter.cxx:3550
 THistPainter.cxx:3551
 THistPainter.cxx:3552
 THistPainter.cxx:3553
 THistPainter.cxx:3554
 THistPainter.cxx:3555
 THistPainter.cxx:3556
 THistPainter.cxx:3557
 THistPainter.cxx:3558
 THistPainter.cxx:3559
 THistPainter.cxx:3560
 THistPainter.cxx:3561
 THistPainter.cxx:3562
 THistPainter.cxx:3563
 THistPainter.cxx:3564
 THistPainter.cxx:3565
 THistPainter.cxx:3566
 THistPainter.cxx:3567
 THistPainter.cxx:3568
 THistPainter.cxx:3569
 THistPainter.cxx:3570
 THistPainter.cxx:3571
 THistPainter.cxx:3572
 THistPainter.cxx:3573
 THistPainter.cxx:3574
 THistPainter.cxx:3575
 THistPainter.cxx:3576
 THistPainter.cxx:3577
 THistPainter.cxx:3578
 THistPainter.cxx:3579
 THistPainter.cxx:3580
 THistPainter.cxx:3581
 THistPainter.cxx:3582
 THistPainter.cxx:3583
 THistPainter.cxx:3584
 THistPainter.cxx:3585
 THistPainter.cxx:3586
 THistPainter.cxx:3587
 THistPainter.cxx:3588
 THistPainter.cxx:3589
 THistPainter.cxx:3590
 THistPainter.cxx:3591
 THistPainter.cxx:3592
 THistPainter.cxx:3593
 THistPainter.cxx:3594
 THistPainter.cxx:3595
 THistPainter.cxx:3596
 THistPainter.cxx:3597
 THistPainter.cxx:3598
 THistPainter.cxx:3599
 THistPainter.cxx:3600
 THistPainter.cxx:3601
 THistPainter.cxx:3602
 THistPainter.cxx:3603
 THistPainter.cxx:3604
 THistPainter.cxx:3605
 THistPainter.cxx:3606
 THistPainter.cxx:3607
 THistPainter.cxx:3608
 THistPainter.cxx:3609
 THistPainter.cxx:3610
 THistPainter.cxx:3611
 THistPainter.cxx:3612
 THistPainter.cxx:3613
 THistPainter.cxx:3614
 THistPainter.cxx:3615
 THistPainter.cxx:3616
 THistPainter.cxx:3617
 THistPainter.cxx:3618
 THistPainter.cxx:3619
 THistPainter.cxx:3620
 THistPainter.cxx:3621
 THistPainter.cxx:3622
 THistPainter.cxx:3623
 THistPainter.cxx:3624
 THistPainter.cxx:3625
 THistPainter.cxx:3626
 THistPainter.cxx:3627
 THistPainter.cxx:3628
 THistPainter.cxx:3629
 THistPainter.cxx:3630
 THistPainter.cxx:3631
 THistPainter.cxx:3632
 THistPainter.cxx:3633
 THistPainter.cxx:3634
 THistPainter.cxx:3635
 THistPainter.cxx:3636
 THistPainter.cxx:3637
 THistPainter.cxx:3638
 THistPainter.cxx:3639
 THistPainter.cxx:3640
 THistPainter.cxx:3641
 THistPainter.cxx:3642
 THistPainter.cxx:3643
 THistPainter.cxx:3644
 THistPainter.cxx:3645
 THistPainter.cxx:3646
 THistPainter.cxx:3647
 THistPainter.cxx:3648
 THistPainter.cxx:3649
 THistPainter.cxx:3650
 THistPainter.cxx:3651
 THistPainter.cxx:3652
 THistPainter.cxx:3653
 THistPainter.cxx:3654
 THistPainter.cxx:3655
 THistPainter.cxx:3656
 THistPainter.cxx:3657
 THistPainter.cxx:3658
 THistPainter.cxx:3659
 THistPainter.cxx:3660
 THistPainter.cxx:3661
 THistPainter.cxx:3662
 THistPainter.cxx:3663
 THistPainter.cxx:3664
 THistPainter.cxx:3665
 THistPainter.cxx:3666
 THistPainter.cxx:3667
 THistPainter.cxx:3668
 THistPainter.cxx:3669
 THistPainter.cxx:3670
 THistPainter.cxx:3671
 THistPainter.cxx:3672
 THistPainter.cxx:3673
 THistPainter.cxx:3674
 THistPainter.cxx:3675
 THistPainter.cxx:3676
 THistPainter.cxx:3677
 THistPainter.cxx:3678
 THistPainter.cxx:3679
 THistPainter.cxx:3680
 THistPainter.cxx:3681
 THistPainter.cxx:3682
 THistPainter.cxx:3683
 THistPainter.cxx:3684
 THistPainter.cxx:3685
 THistPainter.cxx:3686
 THistPainter.cxx:3687
 THistPainter.cxx:3688
 THistPainter.cxx:3689
 THistPainter.cxx:3690
 THistPainter.cxx:3691
 THistPainter.cxx:3692
 THistPainter.cxx:3693
 THistPainter.cxx:3694
 THistPainter.cxx:3695
 THistPainter.cxx:3696
 THistPainter.cxx:3697
 THistPainter.cxx:3698
 THistPainter.cxx:3699
 THistPainter.cxx:3700
 THistPainter.cxx:3701
 THistPainter.cxx:3702
 THistPainter.cxx:3703
 THistPainter.cxx:3704
 THistPainter.cxx:3705
 THistPainter.cxx:3706
 THistPainter.cxx:3707
 THistPainter.cxx:3708
 THistPainter.cxx:3709
 THistPainter.cxx:3710
 THistPainter.cxx:3711
 THistPainter.cxx:3712
 THistPainter.cxx:3713
 THistPainter.cxx:3714
 THistPainter.cxx:3715
 THistPainter.cxx:3716
 THistPainter.cxx:3717
 THistPainter.cxx:3718
 THistPainter.cxx:3719
 THistPainter.cxx:3720
 THistPainter.cxx:3721
 THistPainter.cxx:3722
 THistPainter.cxx:3723
 THistPainter.cxx:3724
 THistPainter.cxx:3725
 THistPainter.cxx:3726
 THistPainter.cxx:3727
 THistPainter.cxx:3728
 THistPainter.cxx:3729
 THistPainter.cxx:3730
 THistPainter.cxx:3731
 THistPainter.cxx:3732
 THistPainter.cxx:3733
 THistPainter.cxx:3734
 THistPainter.cxx:3735
 THistPainter.cxx:3736
 THistPainter.cxx:3737
 THistPainter.cxx:3738
 THistPainter.cxx:3739
 THistPainter.cxx:3740
 THistPainter.cxx:3741
 THistPainter.cxx:3742
 THistPainter.cxx:3743
 THistPainter.cxx:3744
 THistPainter.cxx:3745
 THistPainter.cxx:3746
 THistPainter.cxx:3747
 THistPainter.cxx:3748
 THistPainter.cxx:3749
 THistPainter.cxx:3750
 THistPainter.cxx:3751
 THistPainter.cxx:3752
 THistPainter.cxx:3753
 THistPainter.cxx:3754
 THistPainter.cxx:3755
 THistPainter.cxx:3756
 THistPainter.cxx:3757
 THistPainter.cxx:3758
 THistPainter.cxx:3759
 THistPainter.cxx:3760
 THistPainter.cxx:3761
 THistPainter.cxx:3762
 THistPainter.cxx:3763
 THistPainter.cxx:3764
 THistPainter.cxx:3765
 THistPainter.cxx:3766
 THistPainter.cxx:3767
 THistPainter.cxx:3768
 THistPainter.cxx:3769
 THistPainter.cxx:3770
 THistPainter.cxx:3771
 THistPainter.cxx:3772
 THistPainter.cxx:3773
 THistPainter.cxx:3774
 THistPainter.cxx:3775
 THistPainter.cxx:3776
 THistPainter.cxx:3777
 THistPainter.cxx:3778
 THistPainter.cxx:3779
 THistPainter.cxx:3780
 THistPainter.cxx:3781
 THistPainter.cxx:3782
 THistPainter.cxx:3783
 THistPainter.cxx:3784
 THistPainter.cxx:3785
 THistPainter.cxx:3786
 THistPainter.cxx:3787
 THistPainter.cxx:3788
 THistPainter.cxx:3789
 THistPainter.cxx:3790
 THistPainter.cxx:3791
 THistPainter.cxx:3792
 THistPainter.cxx:3793
 THistPainter.cxx:3794
 THistPainter.cxx:3795
 THistPainter.cxx:3796
 THistPainter.cxx:3797
 THistPainter.cxx:3798
 THistPainter.cxx:3799
 THistPainter.cxx:3800
 THistPainter.cxx:3801
 THistPainter.cxx:3802
 THistPainter.cxx:3803
 THistPainter.cxx:3804
 THistPainter.cxx:3805
 THistPainter.cxx:3806
 THistPainter.cxx:3807
 THistPainter.cxx:3808
 THistPainter.cxx:3809
 THistPainter.cxx:3810
 THistPainter.cxx:3811
 THistPainter.cxx:3812
 THistPainter.cxx:3813
 THistPainter.cxx:3814
 THistPainter.cxx:3815
 THistPainter.cxx:3816
 THistPainter.cxx:3817
 THistPainter.cxx:3818
 THistPainter.cxx:3819
 THistPainter.cxx:3820
 THistPainter.cxx:3821
 THistPainter.cxx:3822
 THistPainter.cxx:3823
 THistPainter.cxx:3824
 THistPainter.cxx:3825
 THistPainter.cxx:3826
 THistPainter.cxx:3827
 THistPainter.cxx:3828
 THistPainter.cxx:3829
 THistPainter.cxx:3830
 THistPainter.cxx:3831
 THistPainter.cxx:3832
 THistPainter.cxx:3833
 THistPainter.cxx:3834
 THistPainter.cxx:3835
 THistPainter.cxx:3836
 THistPainter.cxx:3837
 THistPainter.cxx:3838
 THistPainter.cxx:3839
 THistPainter.cxx:3840
 THistPainter.cxx:3841
 THistPainter.cxx:3842
 THistPainter.cxx:3843
 THistPainter.cxx:3844
 THistPainter.cxx:3845
 THistPainter.cxx:3846
 THistPainter.cxx:3847
 THistPainter.cxx:3848
 THistPainter.cxx:3849
 THistPainter.cxx:3850
 THistPainter.cxx:3851
 THistPainter.cxx:3852
 THistPainter.cxx:3853
 THistPainter.cxx:3854
 THistPainter.cxx:3855
 THistPainter.cxx:3856
 THistPainter.cxx:3857
 THistPainter.cxx:3858
 THistPainter.cxx:3859
 THistPainter.cxx:3860
 THistPainter.cxx:3861
 THistPainter.cxx:3862
 THistPainter.cxx:3863
 THistPainter.cxx:3864
 THistPainter.cxx:3865
 THistPainter.cxx:3866
 THistPainter.cxx:3867
 THistPainter.cxx:3868
 THistPainter.cxx:3869
 THistPainter.cxx:3870
 THistPainter.cxx:3871
 THistPainter.cxx:3872
 THistPainter.cxx:3873
 THistPainter.cxx:3874
 THistPainter.cxx:3875
 THistPainter.cxx:3876
 THistPainter.cxx:3877
 THistPainter.cxx:3878
 THistPainter.cxx:3879
 THistPainter.cxx:3880
 THistPainter.cxx:3881
 THistPainter.cxx:3882
 THistPainter.cxx:3883
 THistPainter.cxx:3884
 THistPainter.cxx:3885
 THistPainter.cxx:3886
 THistPainter.cxx:3887
 THistPainter.cxx:3888
 THistPainter.cxx:3889
 THistPainter.cxx:3890
 THistPainter.cxx:3891
 THistPainter.cxx:3892
 THistPainter.cxx:3893
 THistPainter.cxx:3894
 THistPainter.cxx:3895
 THistPainter.cxx:3896
 THistPainter.cxx:3897
 THistPainter.cxx:3898
 THistPainter.cxx:3899
 THistPainter.cxx:3900
 THistPainter.cxx:3901
 THistPainter.cxx:3902
 THistPainter.cxx:3903
 THistPainter.cxx:3904
 THistPainter.cxx:3905
 THistPainter.cxx:3906
 THistPainter.cxx:3907
 THistPainter.cxx:3908
 THistPainter.cxx:3909
 THistPainter.cxx:3910
 THistPainter.cxx:3911
 THistPainter.cxx:3912
 THistPainter.cxx:3913
 THistPainter.cxx:3914
 THistPainter.cxx:3915
 THistPainter.cxx:3916
 THistPainter.cxx:3917
 THistPainter.cxx:3918
 THistPainter.cxx:3919
 THistPainter.cxx:3920
 THistPainter.cxx:3921
 THistPainter.cxx:3922
 THistPainter.cxx:3923
 THistPainter.cxx:3924
 THistPainter.cxx:3925
 THistPainter.cxx:3926
 THistPainter.cxx:3927
 THistPainter.cxx:3928
 THistPainter.cxx:3929
 THistPainter.cxx:3930
 THistPainter.cxx:3931
 THistPainter.cxx:3932
 THistPainter.cxx:3933
 THistPainter.cxx:3934
 THistPainter.cxx:3935
 THistPainter.cxx:3936
 THistPainter.cxx:3937
 THistPainter.cxx:3938
 THistPainter.cxx:3939
 THistPainter.cxx:3940
 THistPainter.cxx:3941
 THistPainter.cxx:3942
 THistPainter.cxx:3943
 THistPainter.cxx:3944
 THistPainter.cxx:3945
 THistPainter.cxx:3946
 THistPainter.cxx:3947
 THistPainter.cxx:3948
 THistPainter.cxx:3949
 THistPainter.cxx:3950
 THistPainter.cxx:3951
 THistPainter.cxx:3952
 THistPainter.cxx:3953
 THistPainter.cxx:3954
 THistPainter.cxx:3955
 THistPainter.cxx:3956
 THistPainter.cxx:3957
 THistPainter.cxx:3958
 THistPainter.cxx:3959
 THistPainter.cxx:3960
 THistPainter.cxx:3961
 THistPainter.cxx:3962
 THistPainter.cxx:3963
 THistPainter.cxx:3964
 THistPainter.cxx:3965
 THistPainter.cxx:3966
 THistPainter.cxx:3967
 THistPainter.cxx:3968
 THistPainter.cxx:3969
 THistPainter.cxx:3970
 THistPainter.cxx:3971
 THistPainter.cxx:3972
 THistPainter.cxx:3973
 THistPainter.cxx:3974
 THistPainter.cxx:3975
 THistPainter.cxx:3976
 THistPainter.cxx:3977
 THistPainter.cxx:3978
 THistPainter.cxx:3979
 THistPainter.cxx:3980
 THistPainter.cxx:3981
 THistPainter.cxx:3982
 THistPainter.cxx:3983
 THistPainter.cxx:3984
 THistPainter.cxx:3985
 THistPainter.cxx:3986
 THistPainter.cxx:3987
 THistPainter.cxx:3988
 THistPainter.cxx:3989
 THistPainter.cxx:3990
 THistPainter.cxx:3991
 THistPainter.cxx:3992
 THistPainter.cxx:3993
 THistPainter.cxx:3994
 THistPainter.cxx:3995
 THistPainter.cxx:3996
 THistPainter.cxx:3997
 THistPainter.cxx:3998
 THistPainter.cxx:3999
 THistPainter.cxx:4000
 THistPainter.cxx:4001
 THistPainter.cxx:4002
 THistPainter.cxx:4003
 THistPainter.cxx:4004
 THistPainter.cxx:4005
 THistPainter.cxx:4006
 THistPainter.cxx:4007
 THistPainter.cxx:4008
 THistPainter.cxx:4009
 THistPainter.cxx:4010
 THistPainter.cxx:4011
 THistPainter.cxx:4012
 THistPainter.cxx:4013
 THistPainter.cxx:4014
 THistPainter.cxx:4015
 THistPainter.cxx:4016
 THistPainter.cxx:4017
 THistPainter.cxx:4018
 THistPainter.cxx:4019
 THistPainter.cxx:4020
 THistPainter.cxx:4021
 THistPainter.cxx:4022
 THistPainter.cxx:4023
 THistPainter.cxx:4024
 THistPainter.cxx:4025
 THistPainter.cxx:4026
 THistPainter.cxx:4027
 THistPainter.cxx:4028
 THistPainter.cxx:4029
 THistPainter.cxx:4030
 THistPainter.cxx:4031
 THistPainter.cxx:4032
 THistPainter.cxx:4033
 THistPainter.cxx:4034
 THistPainter.cxx:4035
 THistPainter.cxx:4036
 THistPainter.cxx:4037
 THistPainter.cxx:4038
 THistPainter.cxx:4039
 THistPainter.cxx:4040
 THistPainter.cxx:4041
 THistPainter.cxx:4042
 THistPainter.cxx:4043
 THistPainter.cxx:4044
 THistPainter.cxx:4045
 THistPainter.cxx:4046
 THistPainter.cxx:4047
 THistPainter.cxx:4048
 THistPainter.cxx:4049
 THistPainter.cxx:4050
 THistPainter.cxx:4051
 THistPainter.cxx:4052
 THistPainter.cxx:4053
 THistPainter.cxx:4054
 THistPainter.cxx:4055
 THistPainter.cxx:4056
 THistPainter.cxx:4057
 THistPainter.cxx:4058
 THistPainter.cxx:4059
 THistPainter.cxx:4060
 THistPainter.cxx:4061
 THistPainter.cxx:4062
 THistPainter.cxx:4063
 THistPainter.cxx:4064
 THistPainter.cxx:4065
 THistPainter.cxx:4066
 THistPainter.cxx:4067
 THistPainter.cxx:4068
 THistPainter.cxx:4069
 THistPainter.cxx:4070
 THistPainter.cxx:4071
 THistPainter.cxx:4072
 THistPainter.cxx:4073
 THistPainter.cxx:4074
 THistPainter.cxx:4075
 THistPainter.cxx:4076
 THistPainter.cxx:4077
 THistPainter.cxx:4078
 THistPainter.cxx:4079
 THistPainter.cxx:4080
 THistPainter.cxx:4081
 THistPainter.cxx:4082
 THistPainter.cxx:4083
 THistPainter.cxx:4084
 THistPainter.cxx:4085
 THistPainter.cxx:4086
 THistPainter.cxx:4087
 THistPainter.cxx:4088
 THistPainter.cxx:4089
 THistPainter.cxx:4090
 THistPainter.cxx:4091
 THistPainter.cxx:4092
 THistPainter.cxx:4093
 THistPainter.cxx:4094
 THistPainter.cxx:4095
 THistPainter.cxx:4096
 THistPainter.cxx:4097
 THistPainter.cxx:4098
 THistPainter.cxx:4099
 THistPainter.cxx:4100
 THistPainter.cxx:4101
 THistPainter.cxx:4102
 THistPainter.cxx:4103
 THistPainter.cxx:4104
 THistPainter.cxx:4105
 THistPainter.cxx:4106
 THistPainter.cxx:4107
 THistPainter.cxx:4108
 THistPainter.cxx:4109
 THistPainter.cxx:4110
 THistPainter.cxx:4111
 THistPainter.cxx:4112
 THistPainter.cxx:4113
 THistPainter.cxx:4114
 THistPainter.cxx:4115
 THistPainter.cxx:4116
 THistPainter.cxx:4117
 THistPainter.cxx:4118
 THistPainter.cxx:4119
 THistPainter.cxx:4120
 THistPainter.cxx:4121
 THistPainter.cxx:4122
 THistPainter.cxx:4123
 THistPainter.cxx:4124
 THistPainter.cxx:4125
 THistPainter.cxx:4126
 THistPainter.cxx:4127
 THistPainter.cxx:4128
 THistPainter.cxx:4129
 THistPainter.cxx:4130
 THistPainter.cxx:4131
 THistPainter.cxx:4132
 THistPainter.cxx:4133
 THistPainter.cxx:4134
 THistPainter.cxx:4135
 THistPainter.cxx:4136
 THistPainter.cxx:4137
 THistPainter.cxx:4138
 THistPainter.cxx:4139
 THistPainter.cxx:4140
 THistPainter.cxx:4141
 THistPainter.cxx:4142
 THistPainter.cxx:4143
 THistPainter.cxx:4144
 THistPainter.cxx:4145
 THistPainter.cxx:4146
 THistPainter.cxx:4147
 THistPainter.cxx:4148
 THistPainter.cxx:4149
 THistPainter.cxx:4150
 THistPainter.cxx:4151
 THistPainter.cxx:4152
 THistPainter.cxx:4153
 THistPainter.cxx:4154
 THistPainter.cxx:4155
 THistPainter.cxx:4156
 THistPainter.cxx:4157
 THistPainter.cxx:4158
 THistPainter.cxx:4159
 THistPainter.cxx:4160
 THistPainter.cxx:4161
 THistPainter.cxx:4162
 THistPainter.cxx:4163
 THistPainter.cxx:4164
 THistPainter.cxx:4165
 THistPainter.cxx:4166
 THistPainter.cxx:4167
 THistPainter.cxx:4168
 THistPainter.cxx:4169
 THistPainter.cxx:4170
 THistPainter.cxx:4171
 THistPainter.cxx:4172
 THistPainter.cxx:4173
 THistPainter.cxx:4174
 THistPainter.cxx:4175
 THistPainter.cxx:4176
 THistPainter.cxx:4177
 THistPainter.cxx:4178
 THistPainter.cxx:4179
 THistPainter.cxx:4180
 THistPainter.cxx:4181
 THistPainter.cxx:4182
 THistPainter.cxx:4183
 THistPainter.cxx:4184
 THistPainter.cxx:4185
 THistPainter.cxx:4186
 THistPainter.cxx:4187
 THistPainter.cxx:4188
 THistPainter.cxx:4189
 THistPainter.cxx:4190
 THistPainter.cxx:4191
 THistPainter.cxx:4192
 THistPainter.cxx:4193
 THistPainter.cxx:4194
 THistPainter.cxx:4195
 THistPainter.cxx:4196
 THistPainter.cxx:4197
 THistPainter.cxx:4198
 THistPainter.cxx:4199
 THistPainter.cxx:4200
 THistPainter.cxx:4201
 THistPainter.cxx:4202
 THistPainter.cxx:4203
 THistPainter.cxx:4204
 THistPainter.cxx:4205
 THistPainter.cxx:4206
 THistPainter.cxx:4207
 THistPainter.cxx:4208
 THistPainter.cxx:4209
 THistPainter.cxx:4210
 THistPainter.cxx:4211
 THistPainter.cxx:4212
 THistPainter.cxx:4213
 THistPainter.cxx:4214
 THistPainter.cxx:4215
 THistPainter.cxx:4216
 THistPainter.cxx:4217
 THistPainter.cxx:4218
 THistPainter.cxx:4219
 THistPainter.cxx:4220
 THistPainter.cxx:4221
 THistPainter.cxx:4222
 THistPainter.cxx:4223
 THistPainter.cxx:4224
 THistPainter.cxx:4225
 THistPainter.cxx:4226
 THistPainter.cxx:4227
 THistPainter.cxx:4228
 THistPainter.cxx:4229
 THistPainter.cxx:4230
 THistPainter.cxx:4231
 THistPainter.cxx:4232
 THistPainter.cxx:4233
 THistPainter.cxx:4234
 THistPainter.cxx:4235
 THistPainter.cxx:4236
 THistPainter.cxx:4237
 THistPainter.cxx:4238
 THistPainter.cxx:4239
 THistPainter.cxx:4240
 THistPainter.cxx:4241
 THistPainter.cxx:4242
 THistPainter.cxx:4243
 THistPainter.cxx:4244
 THistPainter.cxx:4245
 THistPainter.cxx:4246
 THistPainter.cxx:4247
 THistPainter.cxx:4248
 THistPainter.cxx:4249
 THistPainter.cxx:4250
 THistPainter.cxx:4251
 THistPainter.cxx:4252
 THistPainter.cxx:4253
 THistPainter.cxx:4254
 THistPainter.cxx:4255
 THistPainter.cxx:4256
 THistPainter.cxx:4257
 THistPainter.cxx:4258
 THistPainter.cxx:4259
 THistPainter.cxx:4260
 THistPainter.cxx:4261
 THistPainter.cxx:4262
 THistPainter.cxx:4263
 THistPainter.cxx:4264
 THistPainter.cxx:4265
 THistPainter.cxx:4266
 THistPainter.cxx:4267
 THistPainter.cxx:4268
 THistPainter.cxx:4269
 THistPainter.cxx:4270
 THistPainter.cxx:4271
 THistPainter.cxx:4272
 THistPainter.cxx:4273
 THistPainter.cxx:4274
 THistPainter.cxx:4275
 THistPainter.cxx:4276
 THistPainter.cxx:4277
 THistPainter.cxx:4278
 THistPainter.cxx:4279
 THistPainter.cxx:4280
 THistPainter.cxx:4281
 THistPainter.cxx:4282
 THistPainter.cxx:4283
 THistPainter.cxx:4284
 THistPainter.cxx:4285
 THistPainter.cxx:4286
 THistPainter.cxx:4287
 THistPainter.cxx:4288
 THistPainter.cxx:4289
 THistPainter.cxx:4290
 THistPainter.cxx:4291
 THistPainter.cxx:4292
 THistPainter.cxx:4293
 THistPainter.cxx:4294
 THistPainter.cxx:4295
 THistPainter.cxx:4296
 THistPainter.cxx:4297
 THistPainter.cxx:4298
 THistPainter.cxx:4299
 THistPainter.cxx:4300
 THistPainter.cxx:4301
 THistPainter.cxx:4302
 THistPainter.cxx:4303
 THistPainter.cxx:4304
 THistPainter.cxx:4305
 THistPainter.cxx:4306
 THistPainter.cxx:4307
 THistPainter.cxx:4308
 THistPainter.cxx:4309
 THistPainter.cxx:4310
 THistPainter.cxx:4311
 THistPainter.cxx:4312
 THistPainter.cxx:4313
 THistPainter.cxx:4314
 THistPainter.cxx:4315
 THistPainter.cxx:4316
 THistPainter.cxx:4317
 THistPainter.cxx:4318
 THistPainter.cxx:4319
 THistPainter.cxx:4320
 THistPainter.cxx:4321
 THistPainter.cxx:4322
 THistPainter.cxx:4323
 THistPainter.cxx:4324
 THistPainter.cxx:4325
 THistPainter.cxx:4326
 THistPainter.cxx:4327
 THistPainter.cxx:4328
 THistPainter.cxx:4329
 THistPainter.cxx:4330
 THistPainter.cxx:4331
 THistPainter.cxx:4332
 THistPainter.cxx:4333
 THistPainter.cxx:4334
 THistPainter.cxx:4335
 THistPainter.cxx:4336
 THistPainter.cxx:4337
 THistPainter.cxx:4338
 THistPainter.cxx:4339
 THistPainter.cxx:4340
 THistPainter.cxx:4341
 THistPainter.cxx:4342
 THistPainter.cxx:4343
 THistPainter.cxx:4344
 THistPainter.cxx:4345
 THistPainter.cxx:4346
 THistPainter.cxx:4347
 THistPainter.cxx:4348
 THistPainter.cxx:4349
 THistPainter.cxx:4350
 THistPainter.cxx:4351
 THistPainter.cxx:4352
 THistPainter.cxx:4353
 THistPainter.cxx:4354
 THistPainter.cxx:4355
 THistPainter.cxx:4356
 THistPainter.cxx:4357
 THistPainter.cxx:4358
 THistPainter.cxx:4359
 THistPainter.cxx:4360
 THistPainter.cxx:4361
 THistPainter.cxx:4362
 THistPainter.cxx:4363
 THistPainter.cxx:4364
 THistPainter.cxx:4365
 THistPainter.cxx:4366
 THistPainter.cxx:4367
 THistPainter.cxx:4368
 THistPainter.cxx:4369
 THistPainter.cxx:4370
 THistPainter.cxx:4371
 THistPainter.cxx:4372
 THistPainter.cxx:4373
 THistPainter.cxx:4374
 THistPainter.cxx:4375
 THistPainter.cxx:4376
 THistPainter.cxx:4377
 THistPainter.cxx:4378
 THistPainter.cxx:4379
 THistPainter.cxx:4380
 THistPainter.cxx:4381
 THistPainter.cxx:4382
 THistPainter.cxx:4383
 THistPainter.cxx:4384
 THistPainter.cxx:4385
 THistPainter.cxx:4386
 THistPainter.cxx:4387
 THistPainter.cxx:4388
 THistPainter.cxx:4389
 THistPainter.cxx:4390
 THistPainter.cxx:4391
 THistPainter.cxx:4392
 THistPainter.cxx:4393
 THistPainter.cxx:4394
 THistPainter.cxx:4395
 THistPainter.cxx:4396
 THistPainter.cxx:4397
 THistPainter.cxx:4398
 THistPainter.cxx:4399
 THistPainter.cxx:4400
 THistPainter.cxx:4401
 THistPainter.cxx:4402
 THistPainter.cxx:4403
 THistPainter.cxx:4404
 THistPainter.cxx:4405
 THistPainter.cxx:4406
 THistPainter.cxx:4407
 THistPainter.cxx:4408
 THistPainter.cxx:4409
 THistPainter.cxx:4410
 THistPainter.cxx:4411
 THistPainter.cxx:4412
 THistPainter.cxx:4413
 THistPainter.cxx:4414
 THistPainter.cxx:4415
 THistPainter.cxx:4416
 THistPainter.cxx:4417
 THistPainter.cxx:4418
 THistPainter.cxx:4419
 THistPainter.cxx:4420
 THistPainter.cxx:4421
 THistPainter.cxx:4422
 THistPainter.cxx:4423
 THistPainter.cxx:4424
 THistPainter.cxx:4425
 THistPainter.cxx:4426
 THistPainter.cxx:4427
 THistPainter.cxx:4428
 THistPainter.cxx:4429
 THistPainter.cxx:4430
 THistPainter.cxx:4431
 THistPainter.cxx:4432
 THistPainter.cxx:4433
 THistPainter.cxx:4434
 THistPainter.cxx:4435
 THistPainter.cxx:4436
 THistPainter.cxx:4437
 THistPainter.cxx:4438
 THistPainter.cxx:4439
 THistPainter.cxx:4440
 THistPainter.cxx:4441
 THistPainter.cxx:4442
 THistPainter.cxx:4443
 THistPainter.cxx:4444
 THistPainter.cxx:4445
 THistPainter.cxx:4446
 THistPainter.cxx:4447
 THistPainter.cxx:4448
 THistPainter.cxx:4449
 THistPainter.cxx:4450
 THistPainter.cxx:4451
 THistPainter.cxx:4452
 THistPainter.cxx:4453
 THistPainter.cxx:4454
 THistPainter.cxx:4455
 THistPainter.cxx:4456
 THistPainter.cxx:4457
 THistPainter.cxx:4458
 THistPainter.cxx:4459
 THistPainter.cxx:4460
 THistPainter.cxx:4461
 THistPainter.cxx:4462
 THistPainter.cxx:4463
 THistPainter.cxx:4464
 THistPainter.cxx:4465
 THistPainter.cxx:4466
 THistPainter.cxx:4467
 THistPainter.cxx:4468
 THistPainter.cxx:4469
 THistPainter.cxx:4470
 THistPainter.cxx:4471
 THistPainter.cxx:4472
 THistPainter.cxx:4473
 THistPainter.cxx:4474
 THistPainter.cxx:4475
 THistPainter.cxx:4476
 THistPainter.cxx:4477
 THistPainter.cxx:4478
 THistPainter.cxx:4479
 THistPainter.cxx:4480
 THistPainter.cxx:4481
 THistPainter.cxx:4482
 THistPainter.cxx:4483
 THistPainter.cxx:4484
 THistPainter.cxx:4485
 THistPainter.cxx:4486
 THistPainter.cxx:4487
 THistPainter.cxx:4488
 THistPainter.cxx:4489
 THistPainter.cxx:4490
 THistPainter.cxx:4491
 THistPainter.cxx:4492
 THistPainter.cxx:4493
 THistPainter.cxx:4494
 THistPainter.cxx:4495
 THistPainter.cxx:4496
 THistPainter.cxx:4497
 THistPainter.cxx:4498
 THistPainter.cxx:4499
 THistPainter.cxx:4500
 THistPainter.cxx:4501
 THistPainter.cxx:4502
 THistPainter.cxx:4503
 THistPainter.cxx:4504
 THistPainter.cxx:4505
 THistPainter.cxx:4506
 THistPainter.cxx:4507
 THistPainter.cxx:4508
 THistPainter.cxx:4509
 THistPainter.cxx:4510
 THistPainter.cxx:4511
 THistPainter.cxx:4512
 THistPainter.cxx:4513
 THistPainter.cxx:4514
 THistPainter.cxx:4515
 THistPainter.cxx:4516
 THistPainter.cxx:4517
 THistPainter.cxx:4518
 THistPainter.cxx:4519
 THistPainter.cxx:4520
 THistPainter.cxx:4521
 THistPainter.cxx:4522
 THistPainter.cxx:4523
 THistPainter.cxx:4524
 THistPainter.cxx:4525
 THistPainter.cxx:4526
 THistPainter.cxx:4527
 THistPainter.cxx:4528
 THistPainter.cxx:4529
 THistPainter.cxx:4530
 THistPainter.cxx:4531
 THistPainter.cxx:4532
 THistPainter.cxx:4533
 THistPainter.cxx:4534
 THistPainter.cxx:4535
 THistPainter.cxx:4536
 THistPainter.cxx:4537
 THistPainter.cxx:4538
 THistPainter.cxx:4539
 THistPainter.cxx:4540
 THistPainter.cxx:4541
 THistPainter.cxx:4542
 THistPainter.cxx:4543
 THistPainter.cxx:4544
 THistPainter.cxx:4545
 THistPainter.cxx:4546
 THistPainter.cxx:4547
 THistPainter.cxx:4548
 THistPainter.cxx:4549
 THistPainter.cxx:4550
 THistPainter.cxx:4551
 THistPainter.cxx:4552
 THistPainter.cxx:4553
 THistPainter.cxx:4554
 THistPainter.cxx:4555
 THistPainter.cxx:4556
 THistPainter.cxx:4557
 THistPainter.cxx:4558
 THistPainter.cxx:4559
 THistPainter.cxx:4560
 THistPainter.cxx:4561
 THistPainter.cxx:4562
 THistPainter.cxx:4563
 THistPainter.cxx:4564
 THistPainter.cxx:4565
 THistPainter.cxx:4566
 THistPainter.cxx:4567
 THistPainter.cxx:4568
 THistPainter.cxx:4569
 THistPainter.cxx:4570
 THistPainter.cxx:4571
 THistPainter.cxx:4572
 THistPainter.cxx:4573
 THistPainter.cxx:4574
 THistPainter.cxx:4575
 THistPainter.cxx:4576
 THistPainter.cxx:4577
 THistPainter.cxx:4578
 THistPainter.cxx:4579
 THistPainter.cxx:4580
 THistPainter.cxx:4581
 THistPainter.cxx:4582
 THistPainter.cxx:4583
 THistPainter.cxx:4584
 THistPainter.cxx:4585
 THistPainter.cxx:4586
 THistPainter.cxx:4587
 THistPainter.cxx:4588
 THistPainter.cxx:4589
 THistPainter.cxx:4590
 THistPainter.cxx:4591
 THistPainter.cxx:4592
 THistPainter.cxx:4593
 THistPainter.cxx:4594
 THistPainter.cxx:4595
 THistPainter.cxx:4596
 THistPainter.cxx:4597
 THistPainter.cxx:4598
 THistPainter.cxx:4599
 THistPainter.cxx:4600
 THistPainter.cxx:4601
 THistPainter.cxx:4602
 THistPainter.cxx:4603
 THistPainter.cxx:4604
 THistPainter.cxx:4605
 THistPainter.cxx:4606
 THistPainter.cxx:4607
 THistPainter.cxx:4608
 THistPainter.cxx:4609
 THistPainter.cxx:4610
 THistPainter.cxx:4611
 THistPainter.cxx:4612
 THistPainter.cxx:4613
 THistPainter.cxx:4614
 THistPainter.cxx:4615
 THistPainter.cxx:4616
 THistPainter.cxx:4617
 THistPainter.cxx:4618
 THistPainter.cxx:4619
 THistPainter.cxx:4620
 THistPainter.cxx:4621
 THistPainter.cxx:4622
 THistPainter.cxx:4623
 THistPainter.cxx:4624
 THistPainter.cxx:4625
 THistPainter.cxx:4626
 THistPainter.cxx:4627
 THistPainter.cxx:4628
 THistPainter.cxx:4629
 THistPainter.cxx:4630
 THistPainter.cxx:4631
 THistPainter.cxx:4632
 THistPainter.cxx:4633
 THistPainter.cxx:4634
 THistPainter.cxx:4635
 THistPainter.cxx:4636
 THistPainter.cxx:4637
 THistPainter.cxx:4638
 THistPainter.cxx:4639
 THistPainter.cxx:4640
 THistPainter.cxx:4641
 THistPainter.cxx:4642
 THistPainter.cxx:4643
 THistPainter.cxx:4644
 THistPainter.cxx:4645
 THistPainter.cxx:4646
 THistPainter.cxx:4647
 THistPainter.cxx:4648
 THistPainter.cxx:4649
 THistPainter.cxx:4650
 THistPainter.cxx:4651
 THistPainter.cxx:4652
 THistPainter.cxx:4653
 THistPainter.cxx:4654
 THistPainter.cxx:4655
 THistPainter.cxx:4656
 THistPainter.cxx:4657
 THistPainter.cxx:4658
 THistPainter.cxx:4659
 THistPainter.cxx:4660
 THistPainter.cxx:4661
 THistPainter.cxx:4662
 THistPainter.cxx:4663
 THistPainter.cxx:4664
 THistPainter.cxx:4665
 THistPainter.cxx:4666
 THistPainter.cxx:4667
 THistPainter.cxx:4668
 THistPainter.cxx:4669
 THistPainter.cxx:4670
 THistPainter.cxx:4671
 THistPainter.cxx:4672
 THistPainter.cxx:4673
 THistPainter.cxx:4674
 THistPainter.cxx:4675
 THistPainter.cxx:4676
 THistPainter.cxx:4677
 THistPainter.cxx:4678
 THistPainter.cxx:4679
 THistPainter.cxx:4680
 THistPainter.cxx:4681
 THistPainter.cxx:4682
 THistPainter.cxx:4683
 THistPainter.cxx:4684
 THistPainter.cxx:4685
 THistPainter.cxx:4686
 THistPainter.cxx:4687
 THistPainter.cxx:4688
 THistPainter.cxx:4689
 THistPainter.cxx:4690
 THistPainter.cxx:4691
 THistPainter.cxx:4692
 THistPainter.cxx:4693
 THistPainter.cxx:4694
 THistPainter.cxx:4695
 THistPainter.cxx:4696
 THistPainter.cxx:4697
 THistPainter.cxx:4698
 THistPainter.cxx:4699
 THistPainter.cxx:4700
 THistPainter.cxx:4701
 THistPainter.cxx:4702
 THistPainter.cxx:4703
 THistPainter.cxx:4704
 THistPainter.cxx:4705
 THistPainter.cxx:4706
 THistPainter.cxx:4707
 THistPainter.cxx:4708
 THistPainter.cxx:4709
 THistPainter.cxx:4710
 THistPainter.cxx:4711
 THistPainter.cxx:4712
 THistPainter.cxx:4713
 THistPainter.cxx:4714
 THistPainter.cxx:4715
 THistPainter.cxx:4716
 THistPainter.cxx:4717
 THistPainter.cxx:4718
 THistPainter.cxx:4719
 THistPainter.cxx:4720
 THistPainter.cxx:4721
 THistPainter.cxx:4722
 THistPainter.cxx:4723
 THistPainter.cxx:4724
 THistPainter.cxx:4725
 THistPainter.cxx:4726
 THistPainter.cxx:4727
 THistPainter.cxx:4728
 THistPainter.cxx:4729
 THistPainter.cxx:4730
 THistPainter.cxx:4731
 THistPainter.cxx:4732
 THistPainter.cxx:4733
 THistPainter.cxx:4734
 THistPainter.cxx:4735
 THistPainter.cxx:4736
 THistPainter.cxx:4737
 THistPainter.cxx:4738
 THistPainter.cxx:4739
 THistPainter.cxx:4740
 THistPainter.cxx:4741
 THistPainter.cxx:4742
 THistPainter.cxx:4743
 THistPainter.cxx:4744
 THistPainter.cxx:4745
 THistPainter.cxx:4746
 THistPainter.cxx:4747
 THistPainter.cxx:4748
 THistPainter.cxx:4749
 THistPainter.cxx:4750
 THistPainter.cxx:4751
 THistPainter.cxx:4752
 THistPainter.cxx:4753
 THistPainter.cxx:4754
 THistPainter.cxx:4755
 THistPainter.cxx:4756
 THistPainter.cxx:4757
 THistPainter.cxx:4758
 THistPainter.cxx:4759
 THistPainter.cxx:4760
 THistPainter.cxx:4761
 THistPainter.cxx:4762
 THistPainter.cxx:4763
 THistPainter.cxx:4764
 THistPainter.cxx:4765
 THistPainter.cxx:4766
 THistPainter.cxx:4767
 THistPainter.cxx:4768
 THistPainter.cxx:4769
 THistPainter.cxx:4770
 THistPainter.cxx:4771
 THistPainter.cxx:4772
 THistPainter.cxx:4773
 THistPainter.cxx:4774
 THistPainter.cxx:4775
 THistPainter.cxx:4776
 THistPainter.cxx:4777
 THistPainter.cxx:4778
 THistPainter.cxx:4779
 THistPainter.cxx:4780
 THistPainter.cxx:4781
 THistPainter.cxx:4782
 THistPainter.cxx:4783
 THistPainter.cxx:4784
 THistPainter.cxx:4785
 THistPainter.cxx:4786
 THistPainter.cxx:4787
 THistPainter.cxx:4788
 THistPainter.cxx:4789
 THistPainter.cxx:4790
 THistPainter.cxx:4791
 THistPainter.cxx:4792
 THistPainter.cxx:4793
 THistPainter.cxx:4794
 THistPainter.cxx:4795
 THistPainter.cxx:4796
 THistPainter.cxx:4797
 THistPainter.cxx:4798
 THistPainter.cxx:4799
 THistPainter.cxx:4800
 THistPainter.cxx:4801
 THistPainter.cxx:4802
 THistPainter.cxx:4803
 THistPainter.cxx:4804
 THistPainter.cxx:4805
 THistPainter.cxx:4806
 THistPainter.cxx:4807
 THistPainter.cxx:4808
 THistPainter.cxx:4809
 THistPainter.cxx:4810
 THistPainter.cxx:4811
 THistPainter.cxx:4812
 THistPainter.cxx:4813
 THistPainter.cxx:4814
 THistPainter.cxx:4815
 THistPainter.cxx:4816
 THistPainter.cxx:4817
 THistPainter.cxx:4818
 THistPainter.cxx:4819
 THistPainter.cxx:4820
 THistPainter.cxx:4821
 THistPainter.cxx:4822
 THistPainter.cxx:4823
 THistPainter.cxx:4824
 THistPainter.cxx:4825
 THistPainter.cxx:4826
 THistPainter.cxx:4827
 THistPainter.cxx:4828
 THistPainter.cxx:4829
 THistPainter.cxx:4830
 THistPainter.cxx:4831
 THistPainter.cxx:4832
 THistPainter.cxx:4833
 THistPainter.cxx:4834
 THistPainter.cxx:4835
 THistPainter.cxx:4836
 THistPainter.cxx:4837
 THistPainter.cxx:4838
 THistPainter.cxx:4839
 THistPainter.cxx:4840
 THistPainter.cxx:4841
 THistPainter.cxx:4842
 THistPainter.cxx:4843
 THistPainter.cxx:4844
 THistPainter.cxx:4845
 THistPainter.cxx:4846
 THistPainter.cxx:4847
 THistPainter.cxx:4848
 THistPainter.cxx:4849
 THistPainter.cxx:4850
 THistPainter.cxx:4851
 THistPainter.cxx:4852
 THistPainter.cxx:4853
 THistPainter.cxx:4854
 THistPainter.cxx:4855
 THistPainter.cxx:4856
 THistPainter.cxx:4857
 THistPainter.cxx:4858
 THistPainter.cxx:4859
 THistPainter.cxx:4860
 THistPainter.cxx:4861
 THistPainter.cxx:4862
 THistPainter.cxx:4863
 THistPainter.cxx:4864
 THistPainter.cxx:4865
 THistPainter.cxx:4866
 THistPainter.cxx:4867
 THistPainter.cxx:4868
 THistPainter.cxx:4869
 THistPainter.cxx:4870
 THistPainter.cxx:4871
 THistPainter.cxx:4872
 THistPainter.cxx:4873
 THistPainter.cxx:4874
 THistPainter.cxx:4875
 THistPainter.cxx:4876
 THistPainter.cxx:4877
 THistPainter.cxx:4878
 THistPainter.cxx:4879
 THistPainter.cxx:4880
 THistPainter.cxx:4881
 THistPainter.cxx:4882
 THistPainter.cxx:4883
 THistPainter.cxx:4884
 THistPainter.cxx:4885
 THistPainter.cxx:4886
 THistPainter.cxx:4887
 THistPainter.cxx:4888
 THistPainter.cxx:4889
 THistPainter.cxx:4890
 THistPainter.cxx:4891
 THistPainter.cxx:4892
 THistPainter.cxx:4893
 THistPainter.cxx:4894
 THistPainter.cxx:4895
 THistPainter.cxx:4896
 THistPainter.cxx:4897
 THistPainter.cxx:4898
 THistPainter.cxx:4899
 THistPainter.cxx:4900
 THistPainter.cxx:4901
 THistPainter.cxx:4902
 THistPainter.cxx:4903
 THistPainter.cxx:4904
 THistPainter.cxx:4905
 THistPainter.cxx:4906
 THistPainter.cxx:4907
 THistPainter.cxx:4908
 THistPainter.cxx:4909
 THistPainter.cxx:4910
 THistPainter.cxx:4911
 THistPainter.cxx:4912
 THistPainter.cxx:4913
 THistPainter.cxx:4914
 THistPainter.cxx:4915
 THistPainter.cxx:4916
 THistPainter.cxx:4917
 THistPainter.cxx:4918
 THistPainter.cxx:4919
 THistPainter.cxx:4920
 THistPainter.cxx:4921
 THistPainter.cxx:4922
 THistPainter.cxx:4923
 THistPainter.cxx:4924
 THistPainter.cxx:4925
 THistPainter.cxx:4926
 THistPainter.cxx:4927
 THistPainter.cxx:4928
 THistPainter.cxx:4929
 THistPainter.cxx:4930
 THistPainter.cxx:4931
 THistPainter.cxx:4932
 THistPainter.cxx:4933
 THistPainter.cxx:4934
 THistPainter.cxx:4935
 THistPainter.cxx:4936
 THistPainter.cxx:4937
 THistPainter.cxx:4938
 THistPainter.cxx:4939
 THistPainter.cxx:4940
 THistPainter.cxx:4941
 THistPainter.cxx:4942
 THistPainter.cxx:4943
 THistPainter.cxx:4944
 THistPainter.cxx:4945
 THistPainter.cxx:4946
 THistPainter.cxx:4947
 THistPainter.cxx:4948
 THistPainter.cxx:4949
 THistPainter.cxx:4950
 THistPainter.cxx:4951
 THistPainter.cxx:4952
 THistPainter.cxx:4953
 THistPainter.cxx:4954
 THistPainter.cxx:4955
 THistPainter.cxx:4956
 THistPainter.cxx:4957
 THistPainter.cxx:4958
 THistPainter.cxx:4959
 THistPainter.cxx:4960
 THistPainter.cxx:4961
 THistPainter.cxx:4962
 THistPainter.cxx:4963
 THistPainter.cxx:4964
 THistPainter.cxx:4965
 THistPainter.cxx:4966
 THistPainter.cxx:4967
 THistPainter.cxx:4968
 THistPainter.cxx:4969
 THistPainter.cxx:4970
 THistPainter.cxx:4971
 THistPainter.cxx:4972
 THistPainter.cxx:4973
 THistPainter.cxx:4974
 THistPainter.cxx:4975
 THistPainter.cxx:4976
 THistPainter.cxx:4977
 THistPainter.cxx:4978
 THistPainter.cxx:4979
 THistPainter.cxx:4980
 THistPainter.cxx:4981
 THistPainter.cxx:4982
 THistPainter.cxx:4983
 THistPainter.cxx:4984
 THistPainter.cxx:4985
 THistPainter.cxx:4986
 THistPainter.cxx:4987
 THistPainter.cxx:4988
 THistPainter.cxx:4989
 THistPainter.cxx:4990
 THistPainter.cxx:4991
 THistPainter.cxx:4992
 THistPainter.cxx:4993
 THistPainter.cxx:4994
 THistPainter.cxx:4995
 THistPainter.cxx:4996
 THistPainter.cxx:4997
 THistPainter.cxx:4998
 THistPainter.cxx:4999
 THistPainter.cxx:5000
 THistPainter.cxx:5001
 THistPainter.cxx:5002
 THistPainter.cxx:5003
 THistPainter.cxx:5004
 THistPainter.cxx:5005
 THistPainter.cxx:5006
 THistPainter.cxx:5007
 THistPainter.cxx:5008
 THistPainter.cxx:5009
 THistPainter.cxx:5010
 THistPainter.cxx:5011
 THistPainter.cxx:5012
 THistPainter.cxx:5013
 THistPainter.cxx:5014
 THistPainter.cxx:5015
 THistPainter.cxx:5016
 THistPainter.cxx:5017
 THistPainter.cxx:5018
 THistPainter.cxx:5019
 THistPainter.cxx:5020
 THistPainter.cxx:5021
 THistPainter.cxx:5022
 THistPainter.cxx:5023
 THistPainter.cxx:5024
 THistPainter.cxx:5025
 THistPainter.cxx:5026
 THistPainter.cxx:5027
 THistPainter.cxx:5028
 THistPainter.cxx:5029
 THistPainter.cxx:5030
 THistPainter.cxx:5031
 THistPainter.cxx:5032
 THistPainter.cxx:5033
 THistPainter.cxx:5034
 THistPainter.cxx:5035
 THistPainter.cxx:5036
 THistPainter.cxx:5037
 THistPainter.cxx:5038
 THistPainter.cxx:5039
 THistPainter.cxx:5040
 THistPainter.cxx:5041
 THistPainter.cxx:5042
 THistPainter.cxx:5043
 THistPainter.cxx:5044
 THistPainter.cxx:5045
 THistPainter.cxx:5046
 THistPainter.cxx:5047
 THistPainter.cxx:5048
 THistPainter.cxx:5049
 THistPainter.cxx:5050
 THistPainter.cxx:5051
 THistPainter.cxx:5052
 THistPainter.cxx:5053
 THistPainter.cxx:5054
 THistPainter.cxx:5055
 THistPainter.cxx:5056
 THistPainter.cxx:5057
 THistPainter.cxx:5058
 THistPainter.cxx:5059
 THistPainter.cxx:5060
 THistPainter.cxx:5061
 THistPainter.cxx:5062
 THistPainter.cxx:5063
 THistPainter.cxx:5064
 THistPainter.cxx:5065
 THistPainter.cxx:5066
 THistPainter.cxx:5067
 THistPainter.cxx:5068
 THistPainter.cxx:5069
 THistPainter.cxx:5070
 THistPainter.cxx:5071
 THistPainter.cxx:5072
 THistPainter.cxx:5073
 THistPainter.cxx:5074
 THistPainter.cxx:5075
 THistPainter.cxx:5076
 THistPainter.cxx:5077
 THistPainter.cxx:5078
 THistPainter.cxx:5079
 THistPainter.cxx:5080
 THistPainter.cxx:5081
 THistPainter.cxx:5082
 THistPainter.cxx:5083
 THistPainter.cxx:5084
 THistPainter.cxx:5085
 THistPainter.cxx:5086
 THistPainter.cxx:5087
 THistPainter.cxx:5088
 THistPainter.cxx:5089
 THistPainter.cxx:5090
 THistPainter.cxx:5091
 THistPainter.cxx:5092
 THistPainter.cxx:5093
 THistPainter.cxx:5094
 THistPainter.cxx:5095
 THistPainter.cxx:5096
 THistPainter.cxx:5097
 THistPainter.cxx:5098
 THistPainter.cxx:5099
 THistPainter.cxx:5100
 THistPainter.cxx:5101
 THistPainter.cxx:5102
 THistPainter.cxx:5103
 THistPainter.cxx:5104
 THistPainter.cxx:5105
 THistPainter.cxx:5106
 THistPainter.cxx:5107
 THistPainter.cxx:5108
 THistPainter.cxx:5109
 THistPainter.cxx:5110
 THistPainter.cxx:5111
 THistPainter.cxx:5112
 THistPainter.cxx:5113
 THistPainter.cxx:5114
 THistPainter.cxx:5115
 THistPainter.cxx:5116
 THistPainter.cxx:5117
 THistPainter.cxx:5118
 THistPainter.cxx:5119
 THistPainter.cxx:5120
 THistPainter.cxx:5121
 THistPainter.cxx:5122
 THistPainter.cxx:5123
 THistPainter.cxx:5124
 THistPainter.cxx:5125
 THistPainter.cxx:5126
 THistPainter.cxx:5127
 THistPainter.cxx:5128
 THistPainter.cxx:5129
 THistPainter.cxx:5130
 THistPainter.cxx:5131
 THistPainter.cxx:5132
 THistPainter.cxx:5133
 THistPainter.cxx:5134
 THistPainter.cxx:5135
 THistPainter.cxx:5136
 THistPainter.cxx:5137
 THistPainter.cxx:5138
 THistPainter.cxx:5139
 THistPainter.cxx:5140
 THistPainter.cxx:5141
 THistPainter.cxx:5142
 THistPainter.cxx:5143
 THistPainter.cxx:5144
 THistPainter.cxx:5145
 THistPainter.cxx:5146
 THistPainter.cxx:5147
 THistPainter.cxx:5148
 THistPainter.cxx:5149
 THistPainter.cxx:5150
 THistPainter.cxx:5151
 THistPainter.cxx:5152
 THistPainter.cxx:5153
 THistPainter.cxx:5154
 THistPainter.cxx:5155
 THistPainter.cxx:5156
 THistPainter.cxx:5157
 THistPainter.cxx:5158
 THistPainter.cxx:5159
 THistPainter.cxx:5160
 THistPainter.cxx:5161
 THistPainter.cxx:5162
 THistPainter.cxx:5163
 THistPainter.cxx:5164
 THistPainter.cxx:5165
 THistPainter.cxx:5166
 THistPainter.cxx:5167
 THistPainter.cxx:5168
 THistPainter.cxx:5169
 THistPainter.cxx:5170
 THistPainter.cxx:5171
 THistPainter.cxx:5172
 THistPainter.cxx:5173
 THistPainter.cxx:5174
 THistPainter.cxx:5175
 THistPainter.cxx:5176
 THistPainter.cxx:5177
 THistPainter.cxx:5178
 THistPainter.cxx:5179
 THistPainter.cxx:5180
 THistPainter.cxx:5181
 THistPainter.cxx:5182
 THistPainter.cxx:5183
 THistPainter.cxx:5184
 THistPainter.cxx:5185
 THistPainter.cxx:5186
 THistPainter.cxx:5187
 THistPainter.cxx:5188
 THistPainter.cxx:5189
 THistPainter.cxx:5190
 THistPainter.cxx:5191
 THistPainter.cxx:5192
 THistPainter.cxx:5193
 THistPainter.cxx:5194
 THistPainter.cxx:5195
 THistPainter.cxx:5196
 THistPainter.cxx:5197
 THistPainter.cxx:5198
 THistPainter.cxx:5199
 THistPainter.cxx:5200
 THistPainter.cxx:5201
 THistPainter.cxx:5202
 THistPainter.cxx:5203
 THistPainter.cxx:5204
 THistPainter.cxx:5205
 THistPainter.cxx:5206
 THistPainter.cxx:5207
 THistPainter.cxx:5208
 THistPainter.cxx:5209
 THistPainter.cxx:5210
 THistPainter.cxx:5211
 THistPainter.cxx:5212
 THistPainter.cxx:5213
 THistPainter.cxx:5214
 THistPainter.cxx:5215
 THistPainter.cxx:5216
 THistPainter.cxx:5217
 THistPainter.cxx:5218
 THistPainter.cxx:5219
 THistPainter.cxx:5220
 THistPainter.cxx:5221
 THistPainter.cxx:5222
 THistPainter.cxx:5223
 THistPainter.cxx:5224
 THistPainter.cxx:5225
 THistPainter.cxx:5226
 THistPainter.cxx:5227
 THistPainter.cxx:5228
 THistPainter.cxx:5229
 THistPainter.cxx:5230
 THistPainter.cxx:5231
 THistPainter.cxx:5232
 THistPainter.cxx:5233
 THistPainter.cxx:5234
 THistPainter.cxx:5235
 THistPainter.cxx:5236
 THistPainter.cxx:5237
 THistPainter.cxx:5238
 THistPainter.cxx:5239
 THistPainter.cxx:5240
 THistPainter.cxx:5241
 THistPainter.cxx:5242
 THistPainter.cxx:5243
 THistPainter.cxx:5244
 THistPainter.cxx:5245
 THistPainter.cxx:5246
 THistPainter.cxx:5247
 THistPainter.cxx:5248
 THistPainter.cxx:5249
 THistPainter.cxx:5250
 THistPainter.cxx:5251
 THistPainter.cxx:5252
 THistPainter.cxx:5253
 THistPainter.cxx:5254
 THistPainter.cxx:5255
 THistPainter.cxx:5256
 THistPainter.cxx:5257
 THistPainter.cxx:5258
 THistPainter.cxx:5259
 THistPainter.cxx:5260
 THistPainter.cxx:5261
 THistPainter.cxx:5262
 THistPainter.cxx:5263
 THistPainter.cxx:5264
 THistPainter.cxx:5265
 THistPainter.cxx:5266
 THistPainter.cxx:5267
 THistPainter.cxx:5268
 THistPainter.cxx:5269
 THistPainter.cxx:5270
 THistPainter.cxx:5271
 THistPainter.cxx:5272
 THistPainter.cxx:5273
 THistPainter.cxx:5274
 THistPainter.cxx:5275
 THistPainter.cxx:5276
 THistPainter.cxx:5277
 THistPainter.cxx:5278
 THistPainter.cxx:5279
 THistPainter.cxx:5280
 THistPainter.cxx:5281
 THistPainter.cxx:5282
 THistPainter.cxx:5283
 THistPainter.cxx:5284
 THistPainter.cxx:5285
 THistPainter.cxx:5286
 THistPainter.cxx:5287
 THistPainter.cxx:5288
 THistPainter.cxx:5289
 THistPainter.cxx:5290
 THistPainter.cxx:5291
 THistPainter.cxx:5292
 THistPainter.cxx:5293
 THistPainter.cxx:5294
 THistPainter.cxx:5295
 THistPainter.cxx:5296
 THistPainter.cxx:5297
 THistPainter.cxx:5298
 THistPainter.cxx:5299
 THistPainter.cxx:5300
 THistPainter.cxx:5301
 THistPainter.cxx:5302
 THistPainter.cxx:5303
 THistPainter.cxx:5304
 THistPainter.cxx:5305
 THistPainter.cxx:5306
 THistPainter.cxx:5307
 THistPainter.cxx:5308
 THistPainter.cxx:5309
 THistPainter.cxx:5310
 THistPainter.cxx:5311
 THistPainter.cxx:5312
 THistPainter.cxx:5313
 THistPainter.cxx:5314
 THistPainter.cxx:5315
 THistPainter.cxx:5316
 THistPainter.cxx:5317
 THistPainter.cxx:5318
 THistPainter.cxx:5319
 THistPainter.cxx:5320
 THistPainter.cxx:5321
 THistPainter.cxx:5322
 THistPainter.cxx:5323
 THistPainter.cxx:5324
 THistPainter.cxx:5325
 THistPainter.cxx:5326
 THistPainter.cxx:5327
 THistPainter.cxx:5328
 THistPainter.cxx:5329
 THistPainter.cxx:5330
 THistPainter.cxx:5331
 THistPainter.cxx:5332
 THistPainter.cxx:5333
 THistPainter.cxx:5334
 THistPainter.cxx:5335
 THistPainter.cxx:5336
 THistPainter.cxx:5337
 THistPainter.cxx:5338
 THistPainter.cxx:5339
 THistPainter.cxx:5340
 THistPainter.cxx:5341
 THistPainter.cxx:5342
 THistPainter.cxx:5343
 THistPainter.cxx:5344
 THistPainter.cxx:5345
 THistPainter.cxx:5346
 THistPainter.cxx:5347
 THistPainter.cxx:5348
 THistPainter.cxx:5349
 THistPainter.cxx:5350
 THistPainter.cxx:5351
 THistPainter.cxx:5352
 THistPainter.cxx:5353
 THistPainter.cxx:5354
 THistPainter.cxx:5355
 THistPainter.cxx:5356
 THistPainter.cxx:5357
 THistPainter.cxx:5358
 THistPainter.cxx:5359
 THistPainter.cxx:5360
 THistPainter.cxx:5361
 THistPainter.cxx:5362
 THistPainter.cxx:5363
 THistPainter.cxx:5364
 THistPainter.cxx:5365
 THistPainter.cxx:5366
 THistPainter.cxx:5367
 THistPainter.cxx:5368
 THistPainter.cxx:5369
 THistPainter.cxx:5370
 THistPainter.cxx:5371
 THistPainter.cxx:5372
 THistPainter.cxx:5373
 THistPainter.cxx:5374
 THistPainter.cxx:5375
 THistPainter.cxx:5376
 THistPainter.cxx:5377
 THistPainter.cxx:5378
 THistPainter.cxx:5379
 THistPainter.cxx:5380
 THistPainter.cxx:5381
 THistPainter.cxx:5382
 THistPainter.cxx:5383
 THistPainter.cxx:5384
 THistPainter.cxx:5385
 THistPainter.cxx:5386
 THistPainter.cxx:5387
 THistPainter.cxx:5388
 THistPainter.cxx:5389
 THistPainter.cxx:5390
 THistPainter.cxx:5391
 THistPainter.cxx:5392
 THistPainter.cxx:5393
 THistPainter.cxx:5394
 THistPainter.cxx:5395
 THistPainter.cxx:5396
 THistPainter.cxx:5397
 THistPainter.cxx:5398
 THistPainter.cxx:5399
 THistPainter.cxx:5400
 THistPainter.cxx:5401
 THistPainter.cxx:5402
 THistPainter.cxx:5403
 THistPainter.cxx:5404
 THistPainter.cxx:5405
 THistPainter.cxx:5406
 THistPainter.cxx:5407
 THistPainter.cxx:5408
 THistPainter.cxx:5409
 THistPainter.cxx:5410
 THistPainter.cxx:5411
 THistPainter.cxx:5412
 THistPainter.cxx:5413
 THistPainter.cxx:5414
 THistPainter.cxx:5415
 THistPainter.cxx:5416
 THistPainter.cxx:5417
 THistPainter.cxx:5418
 THistPainter.cxx:5419
 THistPainter.cxx:5420
 THistPainter.cxx:5421
 THistPainter.cxx:5422
 THistPainter.cxx:5423
 THistPainter.cxx:5424
 THistPainter.cxx:5425
 THistPainter.cxx:5426
 THistPainter.cxx:5427
 THistPainter.cxx:5428
 THistPainter.cxx:5429
 THistPainter.cxx:5430
 THistPainter.cxx:5431
 THistPainter.cxx:5432
 THistPainter.cxx:5433
 THistPainter.cxx:5434
 THistPainter.cxx:5435
 THistPainter.cxx:5436
 THistPainter.cxx:5437
 THistPainter.cxx:5438
 THistPainter.cxx:5439
 THistPainter.cxx:5440
 THistPainter.cxx:5441
 THistPainter.cxx:5442
 THistPainter.cxx:5443
 THistPainter.cxx:5444
 THistPainter.cxx:5445
 THistPainter.cxx:5446
 THistPainter.cxx:5447
 THistPainter.cxx:5448
 THistPainter.cxx:5449
 THistPainter.cxx:5450
 THistPainter.cxx:5451
 THistPainter.cxx:5452
 THistPainter.cxx:5453
 THistPainter.cxx:5454
 THistPainter.cxx:5455
 THistPainter.cxx:5456
 THistPainter.cxx:5457
 THistPainter.cxx:5458
 THistPainter.cxx:5459
 THistPainter.cxx:5460
 THistPainter.cxx:5461
 THistPainter.cxx:5462
 THistPainter.cxx:5463
 THistPainter.cxx:5464
 THistPainter.cxx:5465
 THistPainter.cxx:5466
 THistPainter.cxx:5467
 THistPainter.cxx:5468
 THistPainter.cxx:5469
 THistPainter.cxx:5470
 THistPainter.cxx:5471
 THistPainter.cxx:5472
 THistPainter.cxx:5473
 THistPainter.cxx:5474
 THistPainter.cxx:5475
 THistPainter.cxx:5476
 THistPainter.cxx:5477
 THistPainter.cxx:5478
 THistPainter.cxx:5479
 THistPainter.cxx:5480
 THistPainter.cxx:5481
 THistPainter.cxx:5482
 THistPainter.cxx:5483
 THistPainter.cxx:5484
 THistPainter.cxx:5485
 THistPainter.cxx:5486
 THistPainter.cxx:5487
 THistPainter.cxx:5488
 THistPainter.cxx:5489
 THistPainter.cxx:5490
 THistPainter.cxx:5491
 THistPainter.cxx:5492
 THistPainter.cxx:5493
 THistPainter.cxx:5494
 THistPainter.cxx:5495
 THistPainter.cxx:5496
 THistPainter.cxx:5497
 THistPainter.cxx:5498
 THistPainter.cxx:5499
 THistPainter.cxx:5500
 THistPainter.cxx:5501
 THistPainter.cxx:5502
 THistPainter.cxx:5503
 THistPainter.cxx:5504
 THistPainter.cxx:5505
 THistPainter.cxx:5506
 THistPainter.cxx:5507
 THistPainter.cxx:5508
 THistPainter.cxx:5509
 THistPainter.cxx:5510
 THistPainter.cxx:5511
 THistPainter.cxx:5512
 THistPainter.cxx:5513
 THistPainter.cxx:5514
 THistPainter.cxx:5515
 THistPainter.cxx:5516
 THistPainter.cxx:5517
 THistPainter.cxx:5518
 THistPainter.cxx:5519
 THistPainter.cxx:5520
 THistPainter.cxx:5521
 THistPainter.cxx:5522
 THistPainter.cxx:5523
 THistPainter.cxx:5524
 THistPainter.cxx:5525
 THistPainter.cxx:5526
 THistPainter.cxx:5527
 THistPainter.cxx:5528
 THistPainter.cxx:5529
 THistPainter.cxx:5530
 THistPainter.cxx:5531
 THistPainter.cxx:5532
 THistPainter.cxx:5533
 THistPainter.cxx:5534
 THistPainter.cxx:5535
 THistPainter.cxx:5536
 THistPainter.cxx:5537
 THistPainter.cxx:5538
 THistPainter.cxx:5539
 THistPainter.cxx:5540
 THistPainter.cxx:5541
 THistPainter.cxx:5542
 THistPainter.cxx:5543
 THistPainter.cxx:5544
 THistPainter.cxx:5545
 THistPainter.cxx:5546
 THistPainter.cxx:5547
 THistPainter.cxx:5548
 THistPainter.cxx:5549
 THistPainter.cxx:5550
 THistPainter.cxx:5551
 THistPainter.cxx:5552
 THistPainter.cxx:5553
 THistPainter.cxx:5554
 THistPainter.cxx:5555
 THistPainter.cxx:5556
 THistPainter.cxx:5557
 THistPainter.cxx:5558
 THistPainter.cxx:5559
 THistPainter.cxx:5560
 THistPainter.cxx:5561
 THistPainter.cxx:5562
 THistPainter.cxx:5563
 THistPainter.cxx:5564
 THistPainter.cxx:5565
 THistPainter.cxx:5566
 THistPainter.cxx:5567
 THistPainter.cxx:5568
 THistPainter.cxx:5569
 THistPainter.cxx:5570
 THistPainter.cxx:5571
 THistPainter.cxx:5572
 THistPainter.cxx:5573
 THistPainter.cxx:5574
 THistPainter.cxx:5575
 THistPainter.cxx:5576
 THistPainter.cxx:5577
 THistPainter.cxx:5578
 THistPainter.cxx:5579
 THistPainter.cxx:5580
 THistPainter.cxx:5581
 THistPainter.cxx:5582
 THistPainter.cxx:5583
 THistPainter.cxx:5584
 THistPainter.cxx:5585
 THistPainter.cxx:5586
 THistPainter.cxx:5587
 THistPainter.cxx:5588
 THistPainter.cxx:5589
 THistPainter.cxx:5590
 THistPainter.cxx:5591
 THistPainter.cxx:5592
 THistPainter.cxx:5593
 THistPainter.cxx:5594
 THistPainter.cxx:5595
 THistPainter.cxx:5596
 THistPainter.cxx:5597
 THistPainter.cxx:5598
 THistPainter.cxx:5599
 THistPainter.cxx:5600
 THistPainter.cxx:5601
 THistPainter.cxx:5602
 THistPainter.cxx:5603
 THistPainter.cxx:5604
 THistPainter.cxx:5605
 THistPainter.cxx:5606
 THistPainter.cxx:5607
 THistPainter.cxx:5608
 THistPainter.cxx:5609
 THistPainter.cxx:5610
 THistPainter.cxx:5611
 THistPainter.cxx:5612
 THistPainter.cxx:5613
 THistPainter.cxx:5614
 THistPainter.cxx:5615
 THistPainter.cxx:5616
 THistPainter.cxx:5617
 THistPainter.cxx:5618
 THistPainter.cxx:5619
 THistPainter.cxx:5620
 THistPainter.cxx:5621
 THistPainter.cxx:5622
 THistPainter.cxx:5623
 THistPainter.cxx:5624
 THistPainter.cxx:5625
 THistPainter.cxx:5626
 THistPainter.cxx:5627
 THistPainter.cxx:5628
 THistPainter.cxx:5629
 THistPainter.cxx:5630
 THistPainter.cxx:5631
 THistPainter.cxx:5632
 THistPainter.cxx:5633
 THistPainter.cxx:5634
 THistPainter.cxx:5635
 THistPainter.cxx:5636
 THistPainter.cxx:5637
 THistPainter.cxx:5638
 THistPainter.cxx:5639
 THistPainter.cxx:5640
 THistPainter.cxx:5641
 THistPainter.cxx:5642
 THistPainter.cxx:5643
 THistPainter.cxx:5644
 THistPainter.cxx:5645
 THistPainter.cxx:5646
 THistPainter.cxx:5647
 THistPainter.cxx:5648
 THistPainter.cxx:5649
 THistPainter.cxx:5650
 THistPainter.cxx:5651
 THistPainter.cxx:5652
 THistPainter.cxx:5653
 THistPainter.cxx:5654
 THistPainter.cxx:5655
 THistPainter.cxx:5656
 THistPainter.cxx:5657
 THistPainter.cxx:5658
 THistPainter.cxx:5659
 THistPainter.cxx:5660
 THistPainter.cxx:5661
 THistPainter.cxx:5662
 THistPainter.cxx:5663
 THistPainter.cxx:5664
 THistPainter.cxx:5665
 THistPainter.cxx:5666
 THistPainter.cxx:5667
 THistPainter.cxx:5668
 THistPainter.cxx:5669
 THistPainter.cxx:5670
 THistPainter.cxx:5671
 THistPainter.cxx:5672
 THistPainter.cxx:5673
 THistPainter.cxx:5674
 THistPainter.cxx:5675
 THistPainter.cxx:5676
 THistPainter.cxx:5677
 THistPainter.cxx:5678
 THistPainter.cxx:5679
 THistPainter.cxx:5680
 THistPainter.cxx:5681
 THistPainter.cxx:5682
 THistPainter.cxx:5683
 THistPainter.cxx:5684
 THistPainter.cxx:5685
 THistPainter.cxx:5686
 THistPainter.cxx:5687
 THistPainter.cxx:5688
 THistPainter.cxx:5689
 THistPainter.cxx:5690
 THistPainter.cxx:5691
 THistPainter.cxx:5692
 THistPainter.cxx:5693
 THistPainter.cxx:5694
 THistPainter.cxx:5695
 THistPainter.cxx:5696
 THistPainter.cxx:5697
 THistPainter.cxx:5698
 THistPainter.cxx:5699
 THistPainter.cxx:5700
 THistPainter.cxx:5701
 THistPainter.cxx:5702
 THistPainter.cxx:5703
 THistPainter.cxx:5704
 THistPainter.cxx:5705
 THistPainter.cxx:5706
 THistPainter.cxx:5707
 THistPainter.cxx:5708
 THistPainter.cxx:5709
 THistPainter.cxx:5710
 THistPainter.cxx:5711
 THistPainter.cxx:5712
 THistPainter.cxx:5713
 THistPainter.cxx:5714
 THistPainter.cxx:5715
 THistPainter.cxx:5716
 THistPainter.cxx:5717
 THistPainter.cxx:5718
 THistPainter.cxx:5719
 THistPainter.cxx:5720
 THistPainter.cxx:5721
 THistPainter.cxx:5722
 THistPainter.cxx:5723
 THistPainter.cxx:5724
 THistPainter.cxx:5725
 THistPainter.cxx:5726
 THistPainter.cxx:5727
 THistPainter.cxx:5728
 THistPainter.cxx:5729
 THistPainter.cxx:5730
 THistPainter.cxx:5731
 THistPainter.cxx:5732
 THistPainter.cxx:5733
 THistPainter.cxx:5734
 THistPainter.cxx:5735
 THistPainter.cxx:5736
 THistPainter.cxx:5737
 THistPainter.cxx:5738
 THistPainter.cxx:5739
 THistPainter.cxx:5740
 THistPainter.cxx:5741
 THistPainter.cxx:5742
 THistPainter.cxx:5743
 THistPainter.cxx:5744
 THistPainter.cxx:5745
 THistPainter.cxx:5746
 THistPainter.cxx:5747
 THistPainter.cxx:5748
 THistPainter.cxx:5749
 THistPainter.cxx:5750
 THistPainter.cxx:5751
 THistPainter.cxx:5752
 THistPainter.cxx:5753
 THistPainter.cxx:5754
 THistPainter.cxx:5755
 THistPainter.cxx:5756
 THistPainter.cxx:5757
 THistPainter.cxx:5758
 THistPainter.cxx:5759
 THistPainter.cxx:5760
 THistPainter.cxx:5761
 THistPainter.cxx:5762
 THistPainter.cxx:5763
 THistPainter.cxx:5764
 THistPainter.cxx:5765
 THistPainter.cxx:5766
 THistPainter.cxx:5767
 THistPainter.cxx:5768
 THistPainter.cxx:5769
 THistPainter.cxx:5770
 THistPainter.cxx:5771
 THistPainter.cxx:5772
 THistPainter.cxx:5773
 THistPainter.cxx:5774
 THistPainter.cxx:5775
 THistPainter.cxx:5776
 THistPainter.cxx:5777
 THistPainter.cxx:5778
 THistPainter.cxx:5779
 THistPainter.cxx:5780
 THistPainter.cxx:5781
 THistPainter.cxx:5782
 THistPainter.cxx:5783
 THistPainter.cxx:5784
 THistPainter.cxx:5785
 THistPainter.cxx:5786
 THistPainter.cxx:5787
 THistPainter.cxx:5788
 THistPainter.cxx:5789
 THistPainter.cxx:5790
 THistPainter.cxx:5791
 THistPainter.cxx:5792
 THistPainter.cxx:5793
 THistPainter.cxx:5794
 THistPainter.cxx:5795
 THistPainter.cxx:5796
 THistPainter.cxx:5797
 THistPainter.cxx:5798
 THistPainter.cxx:5799
 THistPainter.cxx:5800
 THistPainter.cxx:5801
 THistPainter.cxx:5802
 THistPainter.cxx:5803
 THistPainter.cxx:5804
 THistPainter.cxx:5805
 THistPainter.cxx:5806
 THistPainter.cxx:5807
 THistPainter.cxx:5808
 THistPainter.cxx:5809
 THistPainter.cxx:5810
 THistPainter.cxx:5811
 THistPainter.cxx:5812
 THistPainter.cxx:5813
 THistPainter.cxx:5814
 THistPainter.cxx:5815
 THistPainter.cxx:5816
 THistPainter.cxx:5817
 THistPainter.cxx:5818
 THistPainter.cxx:5819
 THistPainter.cxx:5820
 THistPainter.cxx:5821
 THistPainter.cxx:5822
 THistPainter.cxx:5823
 THistPainter.cxx:5824
 THistPainter.cxx:5825
 THistPainter.cxx:5826
 THistPainter.cxx:5827
 THistPainter.cxx:5828
 THistPainter.cxx:5829
 THistPainter.cxx:5830
 THistPainter.cxx:5831
 THistPainter.cxx:5832
 THistPainter.cxx:5833
 THistPainter.cxx:5834
 THistPainter.cxx:5835
 THistPainter.cxx:5836
 THistPainter.cxx:5837
 THistPainter.cxx:5838
 THistPainter.cxx:5839
 THistPainter.cxx:5840
 THistPainter.cxx:5841
 THistPainter.cxx:5842
 THistPainter.cxx:5843
 THistPainter.cxx:5844
 THistPainter.cxx:5845
 THistPainter.cxx:5846
 THistPainter.cxx:5847
 THistPainter.cxx:5848
 THistPainter.cxx:5849
 THistPainter.cxx:5850
 THistPainter.cxx:5851
 THistPainter.cxx:5852
 THistPainter.cxx:5853
 THistPainter.cxx:5854
 THistPainter.cxx:5855
 THistPainter.cxx:5856
 THistPainter.cxx:5857
 THistPainter.cxx:5858
 THistPainter.cxx:5859
 THistPainter.cxx:5860
 THistPainter.cxx:5861
 THistPainter.cxx:5862
 THistPainter.cxx:5863
 THistPainter.cxx:5864
 THistPainter.cxx:5865
 THistPainter.cxx:5866
 THistPainter.cxx:5867
 THistPainter.cxx:5868
 THistPainter.cxx:5869
 THistPainter.cxx:5870
 THistPainter.cxx:5871
 THistPainter.cxx:5872
 THistPainter.cxx:5873
 THistPainter.cxx:5874
 THistPainter.cxx:5875
 THistPainter.cxx:5876
 THistPainter.cxx:5877
 THistPainter.cxx:5878
 THistPainter.cxx:5879
 THistPainter.cxx:5880
 THistPainter.cxx:5881
 THistPainter.cxx:5882
 THistPainter.cxx:5883
 THistPainter.cxx:5884
 THistPainter.cxx:5885
 THistPainter.cxx:5886
 THistPainter.cxx:5887
 THistPainter.cxx:5888
 THistPainter.cxx:5889
 THistPainter.cxx:5890
 THistPainter.cxx:5891
 THistPainter.cxx:5892
 THistPainter.cxx:5893
 THistPainter.cxx:5894
 THistPainter.cxx:5895
 THistPainter.cxx:5896
 THistPainter.cxx:5897
 THistPainter.cxx:5898
 THistPainter.cxx:5899
 THistPainter.cxx:5900
 THistPainter.cxx:5901
 THistPainter.cxx:5902
 THistPainter.cxx:5903
 THistPainter.cxx:5904
 THistPainter.cxx:5905
 THistPainter.cxx:5906
 THistPainter.cxx:5907
 THistPainter.cxx:5908
 THistPainter.cxx:5909
 THistPainter.cxx:5910
 THistPainter.cxx:5911
 THistPainter.cxx:5912
 THistPainter.cxx:5913
 THistPainter.cxx:5914
 THistPainter.cxx:5915
 THistPainter.cxx:5916
 THistPainter.cxx:5917
 THistPainter.cxx:5918
 THistPainter.cxx:5919
 THistPainter.cxx:5920
 THistPainter.cxx:5921
 THistPainter.cxx:5922
 THistPainter.cxx:5923
 THistPainter.cxx:5924
 THistPainter.cxx:5925
 THistPainter.cxx:5926
 THistPainter.cxx:5927
 THistPainter.cxx:5928
 THistPainter.cxx:5929
 THistPainter.cxx:5930
 THistPainter.cxx:5931
 THistPainter.cxx:5932
 THistPainter.cxx:5933
 THistPainter.cxx:5934
 THistPainter.cxx:5935
 THistPainter.cxx:5936
 THistPainter.cxx:5937
 THistPainter.cxx:5938
 THistPainter.cxx:5939
 THistPainter.cxx:5940
 THistPainter.cxx:5941
 THistPainter.cxx:5942
 THistPainter.cxx:5943
 THistPainter.cxx:5944
 THistPainter.cxx:5945
 THistPainter.cxx:5946
 THistPainter.cxx:5947
 THistPainter.cxx:5948
 THistPainter.cxx:5949
 THistPainter.cxx:5950
 THistPainter.cxx:5951
 THistPainter.cxx:5952
 THistPainter.cxx:5953
 THistPainter.cxx:5954
 THistPainter.cxx:5955
 THistPainter.cxx:5956
 THistPainter.cxx:5957
 THistPainter.cxx:5958
 THistPainter.cxx:5959
 THistPainter.cxx:5960
 THistPainter.cxx:5961
 THistPainter.cxx:5962
 THistPainter.cxx:5963
 THistPainter.cxx:5964
 THistPainter.cxx:5965
 THistPainter.cxx:5966
 THistPainter.cxx:5967
 THistPainter.cxx:5968
 THistPainter.cxx:5969
 THistPainter.cxx:5970
 THistPainter.cxx:5971
 THistPainter.cxx:5972
 THistPainter.cxx:5973
 THistPainter.cxx:5974
 THistPainter.cxx:5975
 THistPainter.cxx:5976
 THistPainter.cxx:5977
 THistPainter.cxx:5978
 THistPainter.cxx:5979
 THistPainter.cxx:5980
 THistPainter.cxx:5981
 THistPainter.cxx:5982
 THistPainter.cxx:5983
 THistPainter.cxx:5984
 THistPainter.cxx:5985
 THistPainter.cxx:5986
 THistPainter.cxx:5987
 THistPainter.cxx:5988
 THistPainter.cxx:5989
 THistPainter.cxx:5990
 THistPainter.cxx:5991
 THistPainter.cxx:5992
 THistPainter.cxx:5993
 THistPainter.cxx:5994
 THistPainter.cxx:5995
 THistPainter.cxx:5996
 THistPainter.cxx:5997
 THistPainter.cxx:5998
 THistPainter.cxx:5999
 THistPainter.cxx:6000
 THistPainter.cxx:6001
 THistPainter.cxx:6002
 THistPainter.cxx:6003
 THistPainter.cxx:6004
 THistPainter.cxx:6005
 THistPainter.cxx:6006
 THistPainter.cxx:6007
 THistPainter.cxx:6008
 THistPainter.cxx:6009
 THistPainter.cxx:6010
 THistPainter.cxx:6011
 THistPainter.cxx:6012
 THistPainter.cxx:6013
 THistPainter.cxx:6014
 THistPainter.cxx:6015
 THistPainter.cxx:6016
 THistPainter.cxx:6017
 THistPainter.cxx:6018
 THistPainter.cxx:6019
 THistPainter.cxx:6020
 THistPainter.cxx:6021
 THistPainter.cxx:6022
 THistPainter.cxx:6023
 THistPainter.cxx:6024
 THistPainter.cxx:6025
 THistPainter.cxx:6026
 THistPainter.cxx:6027
 THistPainter.cxx:6028
 THistPainter.cxx:6029
 THistPainter.cxx:6030
 THistPainter.cxx:6031
 THistPainter.cxx:6032
 THistPainter.cxx:6033
 THistPainter.cxx:6034
 THistPainter.cxx:6035
 THistPainter.cxx:6036
 THistPainter.cxx:6037
 THistPainter.cxx:6038
 THistPainter.cxx:6039
 THistPainter.cxx:6040
 THistPainter.cxx:6041
 THistPainter.cxx:6042
 THistPainter.cxx:6043
 THistPainter.cxx:6044
 THistPainter.cxx:6045
 THistPainter.cxx:6046
 THistPainter.cxx:6047
 THistPainter.cxx:6048
 THistPainter.cxx:6049
 THistPainter.cxx:6050
 THistPainter.cxx:6051
 THistPainter.cxx:6052
 THistPainter.cxx:6053
 THistPainter.cxx:6054
 THistPainter.cxx:6055
 THistPainter.cxx:6056
 THistPainter.cxx:6057
 THistPainter.cxx:6058
 THistPainter.cxx:6059
 THistPainter.cxx:6060
 THistPainter.cxx:6061
 THistPainter.cxx:6062
 THistPainter.cxx:6063
 THistPainter.cxx:6064
 THistPainter.cxx:6065
 THistPainter.cxx:6066
 THistPainter.cxx:6067
 THistPainter.cxx:6068
 THistPainter.cxx:6069
 THistPainter.cxx:6070
 THistPainter.cxx:6071
 THistPainter.cxx:6072
 THistPainter.cxx:6073
 THistPainter.cxx:6074
 THistPainter.cxx:6075
 THistPainter.cxx:6076
 THistPainter.cxx:6077
 THistPainter.cxx:6078
 THistPainter.cxx:6079
 THistPainter.cxx:6080
 THistPainter.cxx:6081
 THistPainter.cxx:6082
 THistPainter.cxx:6083
 THistPainter.cxx:6084
 THistPainter.cxx:6085
 THistPainter.cxx:6086
 THistPainter.cxx:6087
 THistPainter.cxx:6088
 THistPainter.cxx:6089
 THistPainter.cxx:6090
 THistPainter.cxx:6091
 THistPainter.cxx:6092
 THistPainter.cxx:6093
 THistPainter.cxx:6094
 THistPainter.cxx:6095
 THistPainter.cxx:6096
 THistPainter.cxx:6097
 THistPainter.cxx:6098
 THistPainter.cxx:6099
 THistPainter.cxx:6100
 THistPainter.cxx:6101
 THistPainter.cxx:6102
 THistPainter.cxx:6103
 THistPainter.cxx:6104
 THistPainter.cxx:6105
 THistPainter.cxx:6106
 THistPainter.cxx:6107
 THistPainter.cxx:6108
 THistPainter.cxx:6109
 THistPainter.cxx:6110
 THistPainter.cxx:6111
 THistPainter.cxx:6112
 THistPainter.cxx:6113
 THistPainter.cxx:6114
 THistPainter.cxx:6115
 THistPainter.cxx:6116
 THistPainter.cxx:6117
 THistPainter.cxx:6118
 THistPainter.cxx:6119
 THistPainter.cxx:6120
 THistPainter.cxx:6121
 THistPainter.cxx:6122
 THistPainter.cxx:6123
 THistPainter.cxx:6124
 THistPainter.cxx:6125
 THistPainter.cxx:6126
 THistPainter.cxx:6127
 THistPainter.cxx:6128
 THistPainter.cxx:6129
 THistPainter.cxx:6130
 THistPainter.cxx:6131
 THistPainter.cxx:6132
 THistPainter.cxx:6133
 THistPainter.cxx:6134
 THistPainter.cxx:6135
 THistPainter.cxx:6136
 THistPainter.cxx:6137
 THistPainter.cxx:6138
 THistPainter.cxx:6139
 THistPainter.cxx:6140
 THistPainter.cxx:6141
 THistPainter.cxx:6142
 THistPainter.cxx:6143
 THistPainter.cxx:6144
 THistPainter.cxx:6145
 THistPainter.cxx:6146
 THistPainter.cxx:6147
 THistPainter.cxx:6148
 THistPainter.cxx:6149
 THistPainter.cxx:6150
 THistPainter.cxx:6151
 THistPainter.cxx:6152
 THistPainter.cxx:6153
 THistPainter.cxx:6154
 THistPainter.cxx:6155
 THistPainter.cxx:6156
 THistPainter.cxx:6157
 THistPainter.cxx:6158
 THistPainter.cxx:6159
 THistPainter.cxx:6160
 THistPainter.cxx:6161
 THistPainter.cxx:6162
 THistPainter.cxx:6163
 THistPainter.cxx:6164
 THistPainter.cxx:6165
 THistPainter.cxx:6166
 THistPainter.cxx:6167
 THistPainter.cxx:6168
 THistPainter.cxx:6169
 THistPainter.cxx:6170
 THistPainter.cxx:6171
 THistPainter.cxx:6172
 THistPainter.cxx:6173
 THistPainter.cxx:6174
 THistPainter.cxx:6175
 THistPainter.cxx:6176
 THistPainter.cxx:6177
 THistPainter.cxx:6178
 THistPainter.cxx:6179
 THistPainter.cxx:6180
 THistPainter.cxx:6181
 THistPainter.cxx:6182
 THistPainter.cxx:6183
 THistPainter.cxx:6184
 THistPainter.cxx:6185
 THistPainter.cxx:6186
 THistPainter.cxx:6187
 THistPainter.cxx:6188
 THistPainter.cxx:6189
 THistPainter.cxx:6190
 THistPainter.cxx:6191
 THistPainter.cxx:6192
 THistPainter.cxx:6193
 THistPainter.cxx:6194
 THistPainter.cxx:6195
 THistPainter.cxx:6196
 THistPainter.cxx:6197
 THistPainter.cxx:6198
 THistPainter.cxx:6199
 THistPainter.cxx:6200
 THistPainter.cxx:6201
 THistPainter.cxx:6202
 THistPainter.cxx:6203
 THistPainter.cxx:6204
 THistPainter.cxx:6205
 THistPainter.cxx:6206
 THistPainter.cxx:6207
 THistPainter.cxx:6208
 THistPainter.cxx:6209
 THistPainter.cxx:6210
 THistPainter.cxx:6211
 THistPainter.cxx:6212
 THistPainter.cxx:6213
 THistPainter.cxx:6214
 THistPainter.cxx:6215
 THistPainter.cxx:6216
 THistPainter.cxx:6217
 THistPainter.cxx:6218
 THistPainter.cxx:6219
 THistPainter.cxx:6220
 THistPainter.cxx:6221
 THistPainter.cxx:6222
 THistPainter.cxx:6223
 THistPainter.cxx:6224
 THistPainter.cxx:6225
 THistPainter.cxx:6226
 THistPainter.cxx:6227
 THistPainter.cxx:6228
 THistPainter.cxx:6229
 THistPainter.cxx:6230
 THistPainter.cxx:6231
 THistPainter.cxx:6232
 THistPainter.cxx:6233
 THistPainter.cxx:6234
 THistPainter.cxx:6235
 THistPainter.cxx:6236
 THistPainter.cxx:6237
 THistPainter.cxx:6238
 THistPainter.cxx:6239
 THistPainter.cxx:6240
 THistPainter.cxx:6241
 THistPainter.cxx:6242
 THistPainter.cxx:6243
 THistPainter.cxx:6244
 THistPainter.cxx:6245
 THistPainter.cxx:6246
 THistPainter.cxx:6247
 THistPainter.cxx:6248
 THistPainter.cxx:6249
 THistPainter.cxx:6250
 THistPainter.cxx:6251
 THistPainter.cxx:6252
 THistPainter.cxx:6253
 THistPainter.cxx:6254
 THistPainter.cxx:6255
 THistPainter.cxx:6256
 THistPainter.cxx:6257
 THistPainter.cxx:6258
 THistPainter.cxx:6259
 THistPainter.cxx:6260
 THistPainter.cxx:6261
 THistPainter.cxx:6262
 THistPainter.cxx:6263
 THistPainter.cxx:6264
 THistPainter.cxx:6265
 THistPainter.cxx:6266
 THistPainter.cxx:6267
 THistPainter.cxx:6268
 THistPainter.cxx:6269
 THistPainter.cxx:6270
 THistPainter.cxx:6271
 THistPainter.cxx:6272
 THistPainter.cxx:6273
 THistPainter.cxx:6274
 THistPainter.cxx:6275
 THistPainter.cxx:6276
 THistPainter.cxx:6277
 THistPainter.cxx:6278
 THistPainter.cxx:6279
 THistPainter.cxx:6280
 THistPainter.cxx:6281
 THistPainter.cxx:6282
 THistPainter.cxx:6283
 THistPainter.cxx:6284
 THistPainter.cxx:6285
 THistPainter.cxx:6286
 THistPainter.cxx:6287
 THistPainter.cxx:6288
 THistPainter.cxx:6289
 THistPainter.cxx:6290
 THistPainter.cxx:6291
 THistPainter.cxx:6292
 THistPainter.cxx:6293
 THistPainter.cxx:6294
 THistPainter.cxx:6295
 THistPainter.cxx:6296
 THistPainter.cxx:6297
 THistPainter.cxx:6298
 THistPainter.cxx:6299
 THistPainter.cxx:6300
 THistPainter.cxx:6301
 THistPainter.cxx:6302
 THistPainter.cxx:6303
 THistPainter.cxx:6304
 THistPainter.cxx:6305
 THistPainter.cxx:6306
 THistPainter.cxx:6307
 THistPainter.cxx:6308
 THistPainter.cxx:6309
 THistPainter.cxx:6310
 THistPainter.cxx:6311
 THistPainter.cxx:6312
 THistPainter.cxx:6313
 THistPainter.cxx:6314
 THistPainter.cxx:6315
 THistPainter.cxx:6316
 THistPainter.cxx:6317
 THistPainter.cxx:6318
 THistPainter.cxx:6319
 THistPainter.cxx:6320
 THistPainter.cxx:6321
 THistPainter.cxx:6322
 THistPainter.cxx:6323
 THistPainter.cxx:6324
 THistPainter.cxx:6325
 THistPainter.cxx:6326
 THistPainter.cxx:6327
 THistPainter.cxx:6328
 THistPainter.cxx:6329
 THistPainter.cxx:6330
 THistPainter.cxx:6331
 THistPainter.cxx:6332
 THistPainter.cxx:6333
 THistPainter.cxx:6334
 THistPainter.cxx:6335
 THistPainter.cxx:6336
 THistPainter.cxx:6337
 THistPainter.cxx:6338
 THistPainter.cxx:6339
 THistPainter.cxx:6340
 THistPainter.cxx:6341
 THistPainter.cxx:6342
 THistPainter.cxx:6343
 THistPainter.cxx:6344
 THistPainter.cxx:6345
 THistPainter.cxx:6346
 THistPainter.cxx:6347
 THistPainter.cxx:6348
 THistPainter.cxx:6349
 THistPainter.cxx:6350
 THistPainter.cxx:6351
 THistPainter.cxx:6352
 THistPainter.cxx:6353
 THistPainter.cxx:6354
 THistPainter.cxx:6355
 THistPainter.cxx:6356
 THistPainter.cxx:6357
 THistPainter.cxx:6358
 THistPainter.cxx:6359
 THistPainter.cxx:6360
 THistPainter.cxx:6361
 THistPainter.cxx:6362
 THistPainter.cxx:6363
 THistPainter.cxx:6364
 THistPainter.cxx:6365
 THistPainter.cxx:6366
 THistPainter.cxx:6367
 THistPainter.cxx:6368
 THistPainter.cxx:6369
 THistPainter.cxx:6370
 THistPainter.cxx:6371
 THistPainter.cxx:6372
 THistPainter.cxx:6373
 THistPainter.cxx:6374
 THistPainter.cxx:6375
 THistPainter.cxx:6376
 THistPainter.cxx:6377
 THistPainter.cxx:6378
 THistPainter.cxx:6379
 THistPainter.cxx:6380
 THistPainter.cxx:6381
 THistPainter.cxx:6382
 THistPainter.cxx:6383
 THistPainter.cxx:6384
 THistPainter.cxx:6385
 THistPainter.cxx:6386
 THistPainter.cxx:6387
 THistPainter.cxx:6388
 THistPainter.cxx:6389
 THistPainter.cxx:6390
 THistPainter.cxx:6391
 THistPainter.cxx:6392
 THistPainter.cxx:6393
 THistPainter.cxx:6394
 THistPainter.cxx:6395
 THistPainter.cxx:6396
 THistPainter.cxx:6397
 THistPainter.cxx:6398
 THistPainter.cxx:6399
 THistPainter.cxx:6400
 THistPainter.cxx:6401
 THistPainter.cxx:6402
 THistPainter.cxx:6403
 THistPainter.cxx:6404
 THistPainter.cxx:6405
 THistPainter.cxx:6406
 THistPainter.cxx:6407
 THistPainter.cxx:6408
 THistPainter.cxx:6409
 THistPainter.cxx:6410
 THistPainter.cxx:6411
 THistPainter.cxx:6412
 THistPainter.cxx:6413
 THistPainter.cxx:6414
 THistPainter.cxx:6415
 THistPainter.cxx:6416
 THistPainter.cxx:6417
 THistPainter.cxx:6418
 THistPainter.cxx:6419
 THistPainter.cxx:6420
 THistPainter.cxx:6421
 THistPainter.cxx:6422
 THistPainter.cxx:6423
 THistPainter.cxx:6424
 THistPainter.cxx:6425
 THistPainter.cxx:6426
 THistPainter.cxx:6427
 THistPainter.cxx:6428
 THistPainter.cxx:6429
 THistPainter.cxx:6430
 THistPainter.cxx:6431
 THistPainter.cxx:6432
 THistPainter.cxx:6433
 THistPainter.cxx:6434
 THistPainter.cxx:6435
 THistPainter.cxx:6436
 THistPainter.cxx:6437
 THistPainter.cxx:6438
 THistPainter.cxx:6439
 THistPainter.cxx:6440
 THistPainter.cxx:6441
 THistPainter.cxx:6442
 THistPainter.cxx:6443
 THistPainter.cxx:6444
 THistPainter.cxx:6445
 THistPainter.cxx:6446
 THistPainter.cxx:6447
 THistPainter.cxx:6448
 THistPainter.cxx:6449
 THistPainter.cxx:6450
 THistPainter.cxx:6451
 THistPainter.cxx:6452
 THistPainter.cxx:6453
 THistPainter.cxx:6454
 THistPainter.cxx:6455
 THistPainter.cxx:6456
 THistPainter.cxx:6457
 THistPainter.cxx:6458
 THistPainter.cxx:6459
 THistPainter.cxx:6460
 THistPainter.cxx:6461
 THistPainter.cxx:6462
 THistPainter.cxx:6463
 THistPainter.cxx:6464
 THistPainter.cxx:6465
 THistPainter.cxx:6466
 THistPainter.cxx:6467
 THistPainter.cxx:6468
 THistPainter.cxx:6469
 THistPainter.cxx:6470
 THistPainter.cxx:6471
 THistPainter.cxx:6472
 THistPainter.cxx:6473
 THistPainter.cxx:6474
 THistPainter.cxx:6475
 THistPainter.cxx:6476
 THistPainter.cxx:6477
 THistPainter.cxx:6478
 THistPainter.cxx:6479
 THistPainter.cxx:6480
 THistPainter.cxx:6481
 THistPainter.cxx:6482
 THistPainter.cxx:6483
 THistPainter.cxx:6484
 THistPainter.cxx:6485
 THistPainter.cxx:6486
 THistPainter.cxx:6487
 THistPainter.cxx:6488
 THistPainter.cxx:6489
 THistPainter.cxx:6490
 THistPainter.cxx:6491
 THistPainter.cxx:6492
 THistPainter.cxx:6493
 THistPainter.cxx:6494
 THistPainter.cxx:6495
 THistPainter.cxx:6496
 THistPainter.cxx:6497
 THistPainter.cxx:6498
 THistPainter.cxx:6499
 THistPainter.cxx:6500
 THistPainter.cxx:6501
 THistPainter.cxx:6502
 THistPainter.cxx:6503
 THistPainter.cxx:6504
 THistPainter.cxx:6505
 THistPainter.cxx:6506
 THistPainter.cxx:6507
 THistPainter.cxx:6508
 THistPainter.cxx:6509
 THistPainter.cxx:6510
 THistPainter.cxx:6511
 THistPainter.cxx:6512
 THistPainter.cxx:6513
 THistPainter.cxx:6514
 THistPainter.cxx:6515
 THistPainter.cxx:6516
 THistPainter.cxx:6517
 THistPainter.cxx:6518
 THistPainter.cxx:6519
 THistPainter.cxx:6520
 THistPainter.cxx:6521
 THistPainter.cxx:6522
 THistPainter.cxx:6523
 THistPainter.cxx:6524
 THistPainter.cxx:6525
 THistPainter.cxx:6526
 THistPainter.cxx:6527
 THistPainter.cxx:6528
 THistPainter.cxx:6529
 THistPainter.cxx:6530
 THistPainter.cxx:6531
 THistPainter.cxx:6532
 THistPainter.cxx:6533
 THistPainter.cxx:6534
 THistPainter.cxx:6535
 THistPainter.cxx:6536
 THistPainter.cxx:6537
 THistPainter.cxx:6538
 THistPainter.cxx:6539
 THistPainter.cxx:6540
 THistPainter.cxx:6541
 THistPainter.cxx:6542
 THistPainter.cxx:6543
 THistPainter.cxx:6544
 THistPainter.cxx:6545
 THistPainter.cxx:6546
 THistPainter.cxx:6547
 THistPainter.cxx:6548
 THistPainter.cxx:6549
 THistPainter.cxx:6550
 THistPainter.cxx:6551
 THistPainter.cxx:6552
 THistPainter.cxx:6553
 THistPainter.cxx:6554
 THistPainter.cxx:6555
 THistPainter.cxx:6556
 THistPainter.cxx:6557
 THistPainter.cxx:6558
 THistPainter.cxx:6559
 THistPainter.cxx:6560
 THistPainter.cxx:6561
 THistPainter.cxx:6562
 THistPainter.cxx:6563
 THistPainter.cxx:6564
 THistPainter.cxx:6565
 THistPainter.cxx:6566
 THistPainter.cxx:6567
 THistPainter.cxx:6568
 THistPainter.cxx:6569
 THistPainter.cxx:6570
 THistPainter.cxx:6571
 THistPainter.cxx:6572
 THistPainter.cxx:6573
 THistPainter.cxx:6574
 THistPainter.cxx:6575
 THistPainter.cxx:6576
 THistPainter.cxx:6577
 THistPainter.cxx:6578
 THistPainter.cxx:6579
 THistPainter.cxx:6580
 THistPainter.cxx:6581
 THistPainter.cxx:6582
 THistPainter.cxx:6583
 THistPainter.cxx:6584
 THistPainter.cxx:6585
 THistPainter.cxx:6586
 THistPainter.cxx:6587
 THistPainter.cxx:6588
 THistPainter.cxx:6589
 THistPainter.cxx:6590
 THistPainter.cxx:6591
 THistPainter.cxx:6592
 THistPainter.cxx:6593
 THistPainter.cxx:6594
 THistPainter.cxx:6595
 THistPainter.cxx:6596
 THistPainter.cxx:6597
 THistPainter.cxx:6598
 THistPainter.cxx:6599
 THistPainter.cxx:6600
 THistPainter.cxx:6601
 THistPainter.cxx:6602
 THistPainter.cxx:6603
 THistPainter.cxx:6604
 THistPainter.cxx:6605
 THistPainter.cxx:6606
 THistPainter.cxx:6607
 THistPainter.cxx:6608
 THistPainter.cxx:6609
 THistPainter.cxx:6610
 THistPainter.cxx:6611
 THistPainter.cxx:6612
 THistPainter.cxx:6613
 THistPainter.cxx:6614
 THistPainter.cxx:6615
 THistPainter.cxx:6616
 THistPainter.cxx:6617
 THistPainter.cxx:6618
 THistPainter.cxx:6619
 THistPainter.cxx:6620
 THistPainter.cxx:6621
 THistPainter.cxx:6622
 THistPainter.cxx:6623
 THistPainter.cxx:6624
 THistPainter.cxx:6625
 THistPainter.cxx:6626
 THistPainter.cxx:6627
 THistPainter.cxx:6628
 THistPainter.cxx:6629
 THistPainter.cxx:6630
 THistPainter.cxx:6631
 THistPainter.cxx:6632
 THistPainter.cxx:6633
 THistPainter.cxx:6634
 THistPainter.cxx:6635
 THistPainter.cxx:6636
 THistPainter.cxx:6637
 THistPainter.cxx:6638
 THistPainter.cxx:6639
 THistPainter.cxx:6640
 THistPainter.cxx:6641
 THistPainter.cxx:6642
 THistPainter.cxx:6643
 THistPainter.cxx:6644
 THistPainter.cxx:6645
 THistPainter.cxx:6646
 THistPainter.cxx:6647
 THistPainter.cxx:6648
 THistPainter.cxx:6649
 THistPainter.cxx:6650
 THistPainter.cxx:6651
 THistPainter.cxx:6652
 THistPainter.cxx:6653
 THistPainter.cxx:6654
 THistPainter.cxx:6655
 THistPainter.cxx:6656
 THistPainter.cxx:6657
 THistPainter.cxx:6658
 THistPainter.cxx:6659
 THistPainter.cxx:6660
 THistPainter.cxx:6661
 THistPainter.cxx:6662
 THistPainter.cxx:6663
 THistPainter.cxx:6664
 THistPainter.cxx:6665
 THistPainter.cxx:6666
 THistPainter.cxx:6667
 THistPainter.cxx:6668
 THistPainter.cxx:6669
 THistPainter.cxx:6670
 THistPainter.cxx:6671
 THistPainter.cxx:6672
 THistPainter.cxx:6673
 THistPainter.cxx:6674
 THistPainter.cxx:6675
 THistPainter.cxx:6676
 THistPainter.cxx:6677
 THistPainter.cxx:6678
 THistPainter.cxx:6679
 THistPainter.cxx:6680
 THistPainter.cxx:6681
 THistPainter.cxx:6682
 THistPainter.cxx:6683
 THistPainter.cxx:6684
 THistPainter.cxx:6685
 THistPainter.cxx:6686
 THistPainter.cxx:6687
 THistPainter.cxx:6688
 THistPainter.cxx:6689
 THistPainter.cxx:6690
 THistPainter.cxx:6691
 THistPainter.cxx:6692
 THistPainter.cxx:6693
 THistPainter.cxx:6694
 THistPainter.cxx:6695
 THistPainter.cxx:6696
 THistPainter.cxx:6697
 THistPainter.cxx:6698
 THistPainter.cxx:6699
 THistPainter.cxx:6700
 THistPainter.cxx:6701
 THistPainter.cxx:6702
 THistPainter.cxx:6703
 THistPainter.cxx:6704
 THistPainter.cxx:6705
 THistPainter.cxx:6706
 THistPainter.cxx:6707
 THistPainter.cxx:6708
 THistPainter.cxx:6709
 THistPainter.cxx:6710
 THistPainter.cxx:6711
 THistPainter.cxx:6712
 THistPainter.cxx:6713
 THistPainter.cxx:6714
 THistPainter.cxx:6715
 THistPainter.cxx:6716
 THistPainter.cxx:6717
 THistPainter.cxx:6718
 THistPainter.cxx:6719
 THistPainter.cxx:6720
 THistPainter.cxx:6721
 THistPainter.cxx:6722
 THistPainter.cxx:6723
 THistPainter.cxx:6724
 THistPainter.cxx:6725
 THistPainter.cxx:6726
 THistPainter.cxx:6727
 THistPainter.cxx:6728
 THistPainter.cxx:6729
 THistPainter.cxx:6730
 THistPainter.cxx:6731
 THistPainter.cxx:6732
 THistPainter.cxx:6733
 THistPainter.cxx:6734
 THistPainter.cxx:6735
 THistPainter.cxx:6736
 THistPainter.cxx:6737
 THistPainter.cxx:6738
 THistPainter.cxx:6739
 THistPainter.cxx:6740
 THistPainter.cxx:6741
 THistPainter.cxx:6742
 THistPainter.cxx:6743
 THistPainter.cxx:6744
 THistPainter.cxx:6745
 THistPainter.cxx:6746
 THistPainter.cxx:6747
 THistPainter.cxx:6748
 THistPainter.cxx:6749
 THistPainter.cxx:6750
 THistPainter.cxx:6751
 THistPainter.cxx:6752
 THistPainter.cxx:6753
 THistPainter.cxx:6754
 THistPainter.cxx:6755
 THistPainter.cxx:6756
 THistPainter.cxx:6757
 THistPainter.cxx:6758
 THistPainter.cxx:6759
 THistPainter.cxx:6760
 THistPainter.cxx:6761
 THistPainter.cxx:6762
 THistPainter.cxx:6763
 THistPainter.cxx:6764
 THistPainter.cxx:6765
 THistPainter.cxx:6766
 THistPainter.cxx:6767
 THistPainter.cxx:6768
 THistPainter.cxx:6769
 THistPainter.cxx:6770
 THistPainter.cxx:6771
 THistPainter.cxx:6772
 THistPainter.cxx:6773
 THistPainter.cxx:6774
 THistPainter.cxx:6775
 THistPainter.cxx:6776
 THistPainter.cxx:6777
 THistPainter.cxx:6778
 THistPainter.cxx:6779
 THistPainter.cxx:6780
 THistPainter.cxx:6781
 THistPainter.cxx:6782
 THistPainter.cxx:6783
 THistPainter.cxx:6784
 THistPainter.cxx:6785
 THistPainter.cxx:6786
 THistPainter.cxx:6787
 THistPainter.cxx:6788
 THistPainter.cxx:6789
 THistPainter.cxx:6790
 THistPainter.cxx:6791
 THistPainter.cxx:6792
 THistPainter.cxx:6793
 THistPainter.cxx:6794
 THistPainter.cxx:6795
 THistPainter.cxx:6796
 THistPainter.cxx:6797
 THistPainter.cxx:6798
 THistPainter.cxx:6799
 THistPainter.cxx:6800
 THistPainter.cxx:6801
 THistPainter.cxx:6802
 THistPainter.cxx:6803
 THistPainter.cxx:6804
 THistPainter.cxx:6805
 THistPainter.cxx:6806
 THistPainter.cxx:6807
 THistPainter.cxx:6808
 THistPainter.cxx:6809
 THistPainter.cxx:6810
 THistPainter.cxx:6811
 THistPainter.cxx:6812
 THistPainter.cxx:6813
 THistPainter.cxx:6814
 THistPainter.cxx:6815
 THistPainter.cxx:6816
 THistPainter.cxx:6817
 THistPainter.cxx:6818
 THistPainter.cxx:6819
 THistPainter.cxx:6820
 THistPainter.cxx:6821
 THistPainter.cxx:6822
 THistPainter.cxx:6823
 THistPainter.cxx:6824
 THistPainter.cxx:6825
 THistPainter.cxx:6826
 THistPainter.cxx:6827
 THistPainter.cxx:6828
 THistPainter.cxx:6829
 THistPainter.cxx:6830
 THistPainter.cxx:6831
 THistPainter.cxx:6832
 THistPainter.cxx:6833
 THistPainter.cxx:6834
 THistPainter.cxx:6835
 THistPainter.cxx:6836
 THistPainter.cxx:6837
 THistPainter.cxx:6838
 THistPainter.cxx:6839
 THistPainter.cxx:6840
 THistPainter.cxx:6841
 THistPainter.cxx:6842
 THistPainter.cxx:6843
 THistPainter.cxx:6844
 THistPainter.cxx:6845
 THistPainter.cxx:6846
 THistPainter.cxx:6847
 THistPainter.cxx:6848
 THistPainter.cxx:6849
 THistPainter.cxx:6850
 THistPainter.cxx:6851
 THistPainter.cxx:6852
 THistPainter.cxx:6853
 THistPainter.cxx:6854
 THistPainter.cxx:6855
 THistPainter.cxx:6856
 THistPainter.cxx:6857
 THistPainter.cxx:6858
 THistPainter.cxx:6859
 THistPainter.cxx:6860
 THistPainter.cxx:6861
 THistPainter.cxx:6862
 THistPainter.cxx:6863
 THistPainter.cxx:6864
 THistPainter.cxx:6865
 THistPainter.cxx:6866
 THistPainter.cxx:6867
 THistPainter.cxx:6868
 THistPainter.cxx:6869
 THistPainter.cxx:6870
 THistPainter.cxx:6871
 THistPainter.cxx:6872
 THistPainter.cxx:6873
 THistPainter.cxx:6874
 THistPainter.cxx:6875
 THistPainter.cxx:6876
 THistPainter.cxx:6877
 THistPainter.cxx:6878
 THistPainter.cxx:6879
 THistPainter.cxx:6880
 THistPainter.cxx:6881
 THistPainter.cxx:6882
 THistPainter.cxx:6883
 THistPainter.cxx:6884
 THistPainter.cxx:6885
 THistPainter.cxx:6886
 THistPainter.cxx:6887
 THistPainter.cxx:6888
 THistPainter.cxx:6889
 THistPainter.cxx:6890
 THistPainter.cxx:6891
 THistPainter.cxx:6892
 THistPainter.cxx:6893
 THistPainter.cxx:6894
 THistPainter.cxx:6895
 THistPainter.cxx:6896
 THistPainter.cxx:6897
 THistPainter.cxx:6898
 THistPainter.cxx:6899
 THistPainter.cxx:6900
 THistPainter.cxx:6901
 THistPainter.cxx:6902
 THistPainter.cxx:6903
 THistPainter.cxx:6904
 THistPainter.cxx:6905
 THistPainter.cxx:6906
 THistPainter.cxx:6907
 THistPainter.cxx:6908
 THistPainter.cxx:6909
 THistPainter.cxx:6910
 THistPainter.cxx:6911
 THistPainter.cxx:6912
 THistPainter.cxx:6913
 THistPainter.cxx:6914
 THistPainter.cxx:6915
 THistPainter.cxx:6916
 THistPainter.cxx:6917
 THistPainter.cxx:6918
 THistPainter.cxx:6919
 THistPainter.cxx:6920
 THistPainter.cxx:6921
 THistPainter.cxx:6922
 THistPainter.cxx:6923
 THistPainter.cxx:6924
 THistPainter.cxx:6925
 THistPainter.cxx:6926
 THistPainter.cxx:6927
 THistPainter.cxx:6928
 THistPainter.cxx:6929
 THistPainter.cxx:6930
 THistPainter.cxx:6931
 THistPainter.cxx:6932
 THistPainter.cxx:6933
 THistPainter.cxx:6934
 THistPainter.cxx:6935
 THistPainter.cxx:6936
 THistPainter.cxx:6937
 THistPainter.cxx:6938
 THistPainter.cxx:6939
 THistPainter.cxx:6940
 THistPainter.cxx:6941
 THistPainter.cxx:6942
 THistPainter.cxx:6943
 THistPainter.cxx:6944
 THistPainter.cxx:6945
 THistPainter.cxx:6946
 THistPainter.cxx:6947
 THistPainter.cxx:6948
 THistPainter.cxx:6949
 THistPainter.cxx:6950
 THistPainter.cxx:6951
 THistPainter.cxx:6952
 THistPainter.cxx:6953
 THistPainter.cxx:6954
 THistPainter.cxx:6955
 THistPainter.cxx:6956
 THistPainter.cxx:6957
 THistPainter.cxx:6958
 THistPainter.cxx:6959
 THistPainter.cxx:6960
 THistPainter.cxx:6961
 THistPainter.cxx:6962
 THistPainter.cxx:6963
 THistPainter.cxx:6964
 THistPainter.cxx:6965
 THistPainter.cxx:6966
 THistPainter.cxx:6967
 THistPainter.cxx:6968
 THistPainter.cxx:6969
 THistPainter.cxx:6970
 THistPainter.cxx:6971
 THistPainter.cxx:6972
 THistPainter.cxx:6973
 THistPainter.cxx:6974
 THistPainter.cxx:6975
 THistPainter.cxx:6976
 THistPainter.cxx:6977
 THistPainter.cxx:6978
 THistPainter.cxx:6979
 THistPainter.cxx:6980
 THistPainter.cxx:6981
 THistPainter.cxx:6982
 THistPainter.cxx:6983
 THistPainter.cxx:6984
 THistPainter.cxx:6985
 THistPainter.cxx:6986
 THistPainter.cxx:6987
 THistPainter.cxx:6988
 THistPainter.cxx:6989
 THistPainter.cxx:6990
 THistPainter.cxx:6991
 THistPainter.cxx:6992
 THistPainter.cxx:6993
 THistPainter.cxx:6994
 THistPainter.cxx:6995
 THistPainter.cxx:6996
 THistPainter.cxx:6997
 THistPainter.cxx:6998
 THistPainter.cxx:6999
 THistPainter.cxx:7000
 THistPainter.cxx:7001
 THistPainter.cxx:7002
 THistPainter.cxx:7003
 THistPainter.cxx:7004
 THistPainter.cxx:7005
 THistPainter.cxx:7006
 THistPainter.cxx:7007
 THistPainter.cxx:7008
 THistPainter.cxx:7009
 THistPainter.cxx:7010
 THistPainter.cxx:7011
 THistPainter.cxx:7012
 THistPainter.cxx:7013
 THistPainter.cxx:7014
 THistPainter.cxx:7015
 THistPainter.cxx:7016
 THistPainter.cxx:7017
 THistPainter.cxx:7018
 THistPainter.cxx:7019
 THistPainter.cxx:7020
 THistPainter.cxx:7021
 THistPainter.cxx:7022
 THistPainter.cxx:7023
 THistPainter.cxx:7024
 THistPainter.cxx:7025
 THistPainter.cxx:7026
 THistPainter.cxx:7027
 THistPainter.cxx:7028
 THistPainter.cxx:7029
 THistPainter.cxx:7030
 THistPainter.cxx:7031
 THistPainter.cxx:7032
 THistPainter.cxx:7033
 THistPainter.cxx:7034
 THistPainter.cxx:7035
 THistPainter.cxx:7036
 THistPainter.cxx:7037
 THistPainter.cxx:7038
 THistPainter.cxx:7039
 THistPainter.cxx:7040
 THistPainter.cxx:7041
 THistPainter.cxx:7042
 THistPainter.cxx:7043
 THistPainter.cxx:7044
 THistPainter.cxx:7045
 THistPainter.cxx:7046
 THistPainter.cxx:7047
 THistPainter.cxx:7048
 THistPainter.cxx:7049
 THistPainter.cxx:7050
 THistPainter.cxx:7051
 THistPainter.cxx:7052
 THistPainter.cxx:7053
 THistPainter.cxx:7054
 THistPainter.cxx:7055
 THistPainter.cxx:7056
 THistPainter.cxx:7057
 THistPainter.cxx:7058
 THistPainter.cxx:7059
 THistPainter.cxx:7060
 THistPainter.cxx:7061
 THistPainter.cxx:7062
 THistPainter.cxx:7063
 THistPainter.cxx:7064
 THistPainter.cxx:7065
 THistPainter.cxx:7066
 THistPainter.cxx:7067
 THistPainter.cxx:7068
 THistPainter.cxx:7069
 THistPainter.cxx:7070
 THistPainter.cxx:7071
 THistPainter.cxx:7072
 THistPainter.cxx:7073
 THistPainter.cxx:7074
 THistPainter.cxx:7075
 THistPainter.cxx:7076
 THistPainter.cxx:7077
 THistPainter.cxx:7078
 THistPainter.cxx:7079
 THistPainter.cxx:7080
 THistPainter.cxx:7081
 THistPainter.cxx:7082
 THistPainter.cxx:7083
 THistPainter.cxx:7084
 THistPainter.cxx:7085
 THistPainter.cxx:7086
 THistPainter.cxx:7087
 THistPainter.cxx:7088
 THistPainter.cxx:7089
 THistPainter.cxx:7090
 THistPainter.cxx:7091
 THistPainter.cxx:7092
 THistPainter.cxx:7093
 THistPainter.cxx:7094
 THistPainter.cxx:7095
 THistPainter.cxx:7096
 THistPainter.cxx:7097
 THistPainter.cxx:7098
 THistPainter.cxx:7099
 THistPainter.cxx:7100
 THistPainter.cxx:7101
 THistPainter.cxx:7102
 THistPainter.cxx:7103
 THistPainter.cxx:7104
 THistPainter.cxx:7105
 THistPainter.cxx:7106
 THistPainter.cxx:7107
 THistPainter.cxx:7108
 THistPainter.cxx:7109
 THistPainter.cxx:7110
 THistPainter.cxx:7111
 THistPainter.cxx:7112
 THistPainter.cxx:7113
 THistPainter.cxx:7114
 THistPainter.cxx:7115
 THistPainter.cxx:7116
 THistPainter.cxx:7117
 THistPainter.cxx:7118
 THistPainter.cxx:7119
 THistPainter.cxx:7120
 THistPainter.cxx:7121
 THistPainter.cxx:7122
 THistPainter.cxx:7123
 THistPainter.cxx:7124
 THistPainter.cxx:7125
 THistPainter.cxx:7126
 THistPainter.cxx:7127
 THistPainter.cxx:7128
 THistPainter.cxx:7129
 THistPainter.cxx:7130
 THistPainter.cxx:7131
 THistPainter.cxx:7132
 THistPainter.cxx:7133
 THistPainter.cxx:7134
 THistPainter.cxx:7135
 THistPainter.cxx:7136
 THistPainter.cxx:7137
 THistPainter.cxx:7138
 THistPainter.cxx:7139
 THistPainter.cxx:7140
 THistPainter.cxx:7141
 THistPainter.cxx:7142
 THistPainter.cxx:7143
 THistPainter.cxx:7144
 THistPainter.cxx:7145
 THistPainter.cxx:7146
 THistPainter.cxx:7147
 THistPainter.cxx:7148
 THistPainter.cxx:7149
 THistPainter.cxx:7150
 THistPainter.cxx:7151
 THistPainter.cxx:7152
 THistPainter.cxx:7153
 THistPainter.cxx:7154
 THistPainter.cxx:7155
 THistPainter.cxx:7156
 THistPainter.cxx:7157
 THistPainter.cxx:7158
 THistPainter.cxx:7159
 THistPainter.cxx:7160
 THistPainter.cxx:7161
 THistPainter.cxx:7162
 THistPainter.cxx:7163
 THistPainter.cxx:7164
 THistPainter.cxx:7165
 THistPainter.cxx:7166
 THistPainter.cxx:7167
 THistPainter.cxx:7168
 THistPainter.cxx:7169
 THistPainter.cxx:7170
 THistPainter.cxx:7171
 THistPainter.cxx:7172
 THistPainter.cxx:7173
 THistPainter.cxx:7174
 THistPainter.cxx:7175
 THistPainter.cxx:7176
 THistPainter.cxx:7177
 THistPainter.cxx:7178
 THistPainter.cxx:7179
 THistPainter.cxx:7180
 THistPainter.cxx:7181
 THistPainter.cxx:7182
 THistPainter.cxx:7183
 THistPainter.cxx:7184
 THistPainter.cxx:7185
 THistPainter.cxx:7186
 THistPainter.cxx:7187
 THistPainter.cxx:7188
 THistPainter.cxx:7189
 THistPainter.cxx:7190
 THistPainter.cxx:7191
 THistPainter.cxx:7192
 THistPainter.cxx:7193
 THistPainter.cxx:7194
 THistPainter.cxx:7195
 THistPainter.cxx:7196
 THistPainter.cxx:7197
 THistPainter.cxx:7198
 THistPainter.cxx:7199
 THistPainter.cxx:7200
 THistPainter.cxx:7201
 THistPainter.cxx:7202
 THistPainter.cxx:7203
 THistPainter.cxx:7204
 THistPainter.cxx:7205
 THistPainter.cxx:7206
 THistPainter.cxx:7207
 THistPainter.cxx:7208
 THistPainter.cxx:7209
 THistPainter.cxx:7210
 THistPainter.cxx:7211
 THistPainter.cxx:7212
 THistPainter.cxx:7213
 THistPainter.cxx:7214
 THistPainter.cxx:7215
 THistPainter.cxx:7216
 THistPainter.cxx:7217
 THistPainter.cxx:7218
 THistPainter.cxx:7219
 THistPainter.cxx:7220
 THistPainter.cxx:7221
 THistPainter.cxx:7222
 THistPainter.cxx:7223
 THistPainter.cxx:7224
 THistPainter.cxx:7225
 THistPainter.cxx:7226
 THistPainter.cxx:7227
 THistPainter.cxx:7228
 THistPainter.cxx:7229
 THistPainter.cxx:7230
 THistPainter.cxx:7231
 THistPainter.cxx:7232
 THistPainter.cxx:7233
 THistPainter.cxx:7234
 THistPainter.cxx:7235
 THistPainter.cxx:7236
 THistPainter.cxx:7237
 THistPainter.cxx:7238
 THistPainter.cxx:7239
 THistPainter.cxx:7240
 THistPainter.cxx:7241
 THistPainter.cxx:7242
 THistPainter.cxx:7243
 THistPainter.cxx:7244
 THistPainter.cxx:7245
 THistPainter.cxx:7246
 THistPainter.cxx:7247
 THistPainter.cxx:7248
 THistPainter.cxx:7249
 THistPainter.cxx:7250
 THistPainter.cxx:7251
 THistPainter.cxx:7252
 THistPainter.cxx:7253
 THistPainter.cxx:7254
 THistPainter.cxx:7255
 THistPainter.cxx:7256
 THistPainter.cxx:7257
 THistPainter.cxx:7258
 THistPainter.cxx:7259
 THistPainter.cxx:7260
 THistPainter.cxx:7261
 THistPainter.cxx:7262
 THistPainter.cxx:7263
 THistPainter.cxx:7264
 THistPainter.cxx:7265
 THistPainter.cxx:7266
 THistPainter.cxx:7267
 THistPainter.cxx:7268
 THistPainter.cxx:7269
 THistPainter.cxx:7270
 THistPainter.cxx:7271
 THistPainter.cxx:7272
 THistPainter.cxx:7273
 THistPainter.cxx:7274
 THistPainter.cxx:7275
 THistPainter.cxx:7276
 THistPainter.cxx:7277
 THistPainter.cxx:7278
 THistPainter.cxx:7279
 THistPainter.cxx:7280
 THistPainter.cxx:7281
 THistPainter.cxx:7282
 THistPainter.cxx:7283
 THistPainter.cxx:7284
 THistPainter.cxx:7285
 THistPainter.cxx:7286
 THistPainter.cxx:7287
 THistPainter.cxx:7288
 THistPainter.cxx:7289
 THistPainter.cxx:7290
 THistPainter.cxx:7291
 THistPainter.cxx:7292
 THistPainter.cxx:7293
 THistPainter.cxx:7294
 THistPainter.cxx:7295
 THistPainter.cxx:7296
 THistPainter.cxx:7297
 THistPainter.cxx:7298
 THistPainter.cxx:7299
 THistPainter.cxx:7300
 THistPainter.cxx:7301
 THistPainter.cxx:7302
 THistPainter.cxx:7303
 THistPainter.cxx:7304
 THistPainter.cxx:7305
 THistPainter.cxx:7306
 THistPainter.cxx:7307
 THistPainter.cxx:7308
 THistPainter.cxx:7309
 THistPainter.cxx:7310
 THistPainter.cxx:7311
 THistPainter.cxx:7312
 THistPainter.cxx:7313
 THistPainter.cxx:7314
 THistPainter.cxx:7315
 THistPainter.cxx:7316
 THistPainter.cxx:7317
 THistPainter.cxx:7318
 THistPainter.cxx:7319
 THistPainter.cxx:7320
 THistPainter.cxx:7321
 THistPainter.cxx:7322
 THistPainter.cxx:7323
 THistPainter.cxx:7324
 THistPainter.cxx:7325
 THistPainter.cxx:7326
 THistPainter.cxx:7327
 THistPainter.cxx:7328
 THistPainter.cxx:7329
 THistPainter.cxx:7330
 THistPainter.cxx:7331
 THistPainter.cxx:7332
 THistPainter.cxx:7333
 THistPainter.cxx:7334
 THistPainter.cxx:7335
 THistPainter.cxx:7336
 THistPainter.cxx:7337
 THistPainter.cxx:7338
 THistPainter.cxx:7339
 THistPainter.cxx:7340
 THistPainter.cxx:7341
 THistPainter.cxx:7342
 THistPainter.cxx:7343
 THistPainter.cxx:7344
 THistPainter.cxx:7345
 THistPainter.cxx:7346
 THistPainter.cxx:7347
 THistPainter.cxx:7348
 THistPainter.cxx:7349
 THistPainter.cxx:7350
 THistPainter.cxx:7351
 THistPainter.cxx:7352
 THistPainter.cxx:7353
 THistPainter.cxx:7354
 THistPainter.cxx:7355
 THistPainter.cxx:7356
 THistPainter.cxx:7357
 THistPainter.cxx:7358
 THistPainter.cxx:7359
 THistPainter.cxx:7360
 THistPainter.cxx:7361
 THistPainter.cxx:7362
 THistPainter.cxx:7363
 THistPainter.cxx:7364
 THistPainter.cxx:7365
 THistPainter.cxx:7366
 THistPainter.cxx:7367
 THistPainter.cxx:7368
 THistPainter.cxx:7369
 THistPainter.cxx:7370
 THistPainter.cxx:7371
 THistPainter.cxx:7372
 THistPainter.cxx:7373
 THistPainter.cxx:7374
 THistPainter.cxx:7375
 THistPainter.cxx:7376
 THistPainter.cxx:7377
 THistPainter.cxx:7378
 THistPainter.cxx:7379
 THistPainter.cxx:7380
 THistPainter.cxx:7381
 THistPainter.cxx:7382
 THistPainter.cxx:7383
 THistPainter.cxx:7384
 THistPainter.cxx:7385
 THistPainter.cxx:7386
 THistPainter.cxx:7387
 THistPainter.cxx:7388
 THistPainter.cxx:7389
 THistPainter.cxx:7390
 THistPainter.cxx:7391
 THistPainter.cxx:7392
 THistPainter.cxx:7393
 THistPainter.cxx:7394
 THistPainter.cxx:7395
 THistPainter.cxx:7396
 THistPainter.cxx:7397
 THistPainter.cxx:7398
 THistPainter.cxx:7399
 THistPainter.cxx:7400
 THistPainter.cxx:7401
 THistPainter.cxx:7402
 THistPainter.cxx:7403
 THistPainter.cxx:7404
 THistPainter.cxx:7405
 THistPainter.cxx:7406
 THistPainter.cxx:7407
 THistPainter.cxx:7408
 THistPainter.cxx:7409
 THistPainter.cxx:7410
 THistPainter.cxx:7411
 THistPainter.cxx:7412
 THistPainter.cxx:7413
 THistPainter.cxx:7414
 THistPainter.cxx:7415
 THistPainter.cxx:7416
 THistPainter.cxx:7417
 THistPainter.cxx:7418
 THistPainter.cxx:7419
 THistPainter.cxx:7420
 THistPainter.cxx:7421
 THistPainter.cxx:7422
 THistPainter.cxx:7423
 THistPainter.cxx:7424
 THistPainter.cxx:7425
 THistPainter.cxx:7426
 THistPainter.cxx:7427
 THistPainter.cxx:7428
 THistPainter.cxx:7429
 THistPainter.cxx:7430
 THistPainter.cxx:7431
 THistPainter.cxx:7432
 THistPainter.cxx:7433
 THistPainter.cxx:7434
 THistPainter.cxx:7435
 THistPainter.cxx:7436
 THistPainter.cxx:7437
 THistPainter.cxx:7438
 THistPainter.cxx:7439
 THistPainter.cxx:7440
 THistPainter.cxx:7441
 THistPainter.cxx:7442
 THistPainter.cxx:7443
 THistPainter.cxx:7444
 THistPainter.cxx:7445
 THistPainter.cxx:7446
 THistPainter.cxx:7447
 THistPainter.cxx:7448
 THistPainter.cxx:7449
 THistPainter.cxx:7450
 THistPainter.cxx:7451
 THistPainter.cxx:7452
 THistPainter.cxx:7453
 THistPainter.cxx:7454
 THistPainter.cxx:7455
 THistPainter.cxx:7456
 THistPainter.cxx:7457
 THistPainter.cxx:7458
 THistPainter.cxx:7459
 THistPainter.cxx:7460
 THistPainter.cxx:7461
 THistPainter.cxx:7462
 THistPainter.cxx:7463
 THistPainter.cxx:7464
 THistPainter.cxx:7465
 THistPainter.cxx:7466
 THistPainter.cxx:7467
 THistPainter.cxx:7468
 THistPainter.cxx:7469
 THistPainter.cxx:7470
 THistPainter.cxx:7471
 THistPainter.cxx:7472
 THistPainter.cxx:7473
 THistPainter.cxx:7474
 THistPainter.cxx:7475
 THistPainter.cxx:7476
 THistPainter.cxx:7477
 THistPainter.cxx:7478
 THistPainter.cxx:7479
 THistPainter.cxx:7480
 THistPainter.cxx:7481
 THistPainter.cxx:7482
 THistPainter.cxx:7483
 THistPainter.cxx:7484
 THistPainter.cxx:7485
 THistPainter.cxx:7486
 THistPainter.cxx:7487
 THistPainter.cxx:7488
 THistPainter.cxx:7489
 THistPainter.cxx:7490
 THistPainter.cxx:7491
 THistPainter.cxx:7492
 THistPainter.cxx:7493
 THistPainter.cxx:7494
 THistPainter.cxx:7495
 THistPainter.cxx:7496
 THistPainter.cxx:7497
 THistPainter.cxx:7498
 THistPainter.cxx:7499
 THistPainter.cxx:7500
 THistPainter.cxx:7501
 THistPainter.cxx:7502
 THistPainter.cxx:7503
 THistPainter.cxx:7504
 THistPainter.cxx:7505
 THistPainter.cxx:7506
 THistPainter.cxx:7507
 THistPainter.cxx:7508
 THistPainter.cxx:7509
 THistPainter.cxx:7510
 THistPainter.cxx:7511
 THistPainter.cxx:7512
 THistPainter.cxx:7513
 THistPainter.cxx:7514
 THistPainter.cxx:7515
 THistPainter.cxx:7516
 THistPainter.cxx:7517
 THistPainter.cxx:7518
 THistPainter.cxx:7519
 THistPainter.cxx:7520
 THistPainter.cxx:7521
 THistPainter.cxx:7522
 THistPainter.cxx:7523
 THistPainter.cxx:7524
 THistPainter.cxx:7525
 THistPainter.cxx:7526
 THistPainter.cxx:7527
 THistPainter.cxx:7528
 THistPainter.cxx:7529
 THistPainter.cxx:7530
 THistPainter.cxx:7531
 THistPainter.cxx:7532
 THistPainter.cxx:7533
 THistPainter.cxx:7534
 THistPainter.cxx:7535
 THistPainter.cxx:7536
 THistPainter.cxx:7537
 THistPainter.cxx:7538
 THistPainter.cxx:7539
 THistPainter.cxx:7540
 THistPainter.cxx:7541
 THistPainter.cxx:7542
 THistPainter.cxx:7543
 THistPainter.cxx:7544
 THistPainter.cxx:7545
 THistPainter.cxx:7546
 THistPainter.cxx:7547
 THistPainter.cxx:7548
 THistPainter.cxx:7549
 THistPainter.cxx:7550
 THistPainter.cxx:7551
 THistPainter.cxx:7552
 THistPainter.cxx:7553
 THistPainter.cxx:7554
 THistPainter.cxx:7555
 THistPainter.cxx:7556
 THistPainter.cxx:7557
 THistPainter.cxx:7558
 THistPainter.cxx:7559
 THistPainter.cxx:7560
 THistPainter.cxx:7561
 THistPainter.cxx:7562
 THistPainter.cxx:7563
 THistPainter.cxx:7564
 THistPainter.cxx:7565
 THistPainter.cxx:7566
 THistPainter.cxx:7567
 THistPainter.cxx:7568
 THistPainter.cxx:7569
 THistPainter.cxx:7570
 THistPainter.cxx:7571
 THistPainter.cxx:7572
 THistPainter.cxx:7573
 THistPainter.cxx:7574
 THistPainter.cxx:7575
 THistPainter.cxx:7576
 THistPainter.cxx:7577
 THistPainter.cxx:7578
 THistPainter.cxx:7579
 THistPainter.cxx:7580
 THistPainter.cxx:7581
 THistPainter.cxx:7582
 THistPainter.cxx:7583
 THistPainter.cxx:7584
 THistPainter.cxx:7585
 THistPainter.cxx:7586
 THistPainter.cxx:7587
 THistPainter.cxx:7588
 THistPainter.cxx:7589
 THistPainter.cxx:7590
 THistPainter.cxx:7591
 THistPainter.cxx:7592
 THistPainter.cxx:7593
 THistPainter.cxx:7594
 THistPainter.cxx:7595
 THistPainter.cxx:7596
 THistPainter.cxx:7597
 THistPainter.cxx:7598
 THistPainter.cxx:7599
 THistPainter.cxx:7600
 THistPainter.cxx:7601
 THistPainter.cxx:7602
 THistPainter.cxx:7603
 THistPainter.cxx:7604
 THistPainter.cxx:7605
 THistPainter.cxx:7606
 THistPainter.cxx:7607
 THistPainter.cxx:7608
 THistPainter.cxx:7609
 THistPainter.cxx:7610
 THistPainter.cxx:7611
 THistPainter.cxx:7612
 THistPainter.cxx:7613
 THistPainter.cxx:7614
 THistPainter.cxx:7615
 THistPainter.cxx:7616
 THistPainter.cxx:7617
 THistPainter.cxx:7618
 THistPainter.cxx:7619
 THistPainter.cxx:7620
 THistPainter.cxx:7621
 THistPainter.cxx:7622
 THistPainter.cxx:7623
 THistPainter.cxx:7624
 THistPainter.cxx:7625
 THistPainter.cxx:7626
 THistPainter.cxx:7627
 THistPainter.cxx:7628
 THistPainter.cxx:7629
 THistPainter.cxx:7630
 THistPainter.cxx:7631
 THistPainter.cxx:7632
 THistPainter.cxx:7633
 THistPainter.cxx:7634
 THistPainter.cxx:7635
 THistPainter.cxx:7636
 THistPainter.cxx:7637
 THistPainter.cxx:7638
 THistPainter.cxx:7639
 THistPainter.cxx:7640
 THistPainter.cxx:7641
 THistPainter.cxx:7642
 THistPainter.cxx:7643
 THistPainter.cxx:7644
 THistPainter.cxx:7645
 THistPainter.cxx:7646
 THistPainter.cxx:7647
 THistPainter.cxx:7648
 THistPainter.cxx:7649
 THistPainter.cxx:7650
 THistPainter.cxx:7651
 THistPainter.cxx:7652
 THistPainter.cxx:7653
 THistPainter.cxx:7654
 THistPainter.cxx:7655
 THistPainter.cxx:7656
 THistPainter.cxx:7657
 THistPainter.cxx:7658
 THistPainter.cxx:7659
 THistPainter.cxx:7660
 THistPainter.cxx:7661
 THistPainter.cxx:7662
 THistPainter.cxx:7663
 THistPainter.cxx:7664
 THistPainter.cxx:7665
 THistPainter.cxx:7666
 THistPainter.cxx:7667
 THistPainter.cxx:7668
 THistPainter.cxx:7669
 THistPainter.cxx:7670
 THistPainter.cxx:7671
 THistPainter.cxx:7672
 THistPainter.cxx:7673
 THistPainter.cxx:7674
 THistPainter.cxx:7675
 THistPainter.cxx:7676
 THistPainter.cxx:7677
 THistPainter.cxx:7678
 THistPainter.cxx:7679
 THistPainter.cxx:7680
 THistPainter.cxx:7681
 THistPainter.cxx:7682
 THistPainter.cxx:7683
 THistPainter.cxx:7684
 THistPainter.cxx:7685
 THistPainter.cxx:7686
 THistPainter.cxx:7687
 THistPainter.cxx:7688
 THistPainter.cxx:7689
 THistPainter.cxx:7690
 THistPainter.cxx:7691
 THistPainter.cxx:7692
 THistPainter.cxx:7693
 THistPainter.cxx:7694
 THistPainter.cxx:7695
 THistPainter.cxx:7696
 THistPainter.cxx:7697
 THistPainter.cxx:7698
 THistPainter.cxx:7699
 THistPainter.cxx:7700
 THistPainter.cxx:7701
 THistPainter.cxx:7702
 THistPainter.cxx:7703
 THistPainter.cxx:7704
 THistPainter.cxx:7705
 THistPainter.cxx:7706
 THistPainter.cxx:7707
 THistPainter.cxx:7708
 THistPainter.cxx:7709
 THistPainter.cxx:7710
 THistPainter.cxx:7711
 THistPainter.cxx:7712
 THistPainter.cxx:7713
 THistPainter.cxx:7714
 THistPainter.cxx:7715
 THistPainter.cxx:7716
 THistPainter.cxx:7717
 THistPainter.cxx:7718
 THistPainter.cxx:7719
 THistPainter.cxx:7720
 THistPainter.cxx:7721
 THistPainter.cxx:7722
 THistPainter.cxx:7723
 THistPainter.cxx:7724
 THistPainter.cxx:7725
 THistPainter.cxx:7726
 THistPainter.cxx:7727
 THistPainter.cxx:7728
 THistPainter.cxx:7729
 THistPainter.cxx:7730
 THistPainter.cxx:7731
 THistPainter.cxx:7732
 THistPainter.cxx:7733
 THistPainter.cxx:7734
 THistPainter.cxx:7735
 THistPainter.cxx:7736
 THistPainter.cxx:7737
 THistPainter.cxx:7738
 THistPainter.cxx:7739
 THistPainter.cxx:7740
 THistPainter.cxx:7741
 THistPainter.cxx:7742
 THistPainter.cxx:7743
 THistPainter.cxx:7744
 THistPainter.cxx:7745
 THistPainter.cxx:7746
 THistPainter.cxx:7747
 THistPainter.cxx:7748
 THistPainter.cxx:7749
 THistPainter.cxx:7750
 THistPainter.cxx:7751
 THistPainter.cxx:7752
 THistPainter.cxx:7753
 THistPainter.cxx:7754
 THistPainter.cxx:7755
 THistPainter.cxx:7756
 THistPainter.cxx:7757
 THistPainter.cxx:7758
 THistPainter.cxx:7759
 THistPainter.cxx:7760
 THistPainter.cxx:7761
 THistPainter.cxx:7762
 THistPainter.cxx:7763
 THistPainter.cxx:7764
 THistPainter.cxx:7765
 THistPainter.cxx:7766
 THistPainter.cxx:7767
 THistPainter.cxx:7768
 THistPainter.cxx:7769
 THistPainter.cxx:7770
 THistPainter.cxx:7771
 THistPainter.cxx:7772
 THistPainter.cxx:7773
 THistPainter.cxx:7774
 THistPainter.cxx:7775
 THistPainter.cxx:7776
 THistPainter.cxx:7777
 THistPainter.cxx:7778
 THistPainter.cxx:7779
 THistPainter.cxx:7780
 THistPainter.cxx:7781
 THistPainter.cxx:7782
 THistPainter.cxx:7783
 THistPainter.cxx:7784
 THistPainter.cxx:7785
 THistPainter.cxx:7786
 THistPainter.cxx:7787
 THistPainter.cxx:7788
 THistPainter.cxx:7789
 THistPainter.cxx:7790
 THistPainter.cxx:7791
 THistPainter.cxx:7792
 THistPainter.cxx:7793
 THistPainter.cxx:7794
 THistPainter.cxx:7795
 THistPainter.cxx:7796
 THistPainter.cxx:7797
 THistPainter.cxx:7798
 THistPainter.cxx:7799
 THistPainter.cxx:7800
 THistPainter.cxx:7801
 THistPainter.cxx:7802
 THistPainter.cxx:7803
 THistPainter.cxx:7804
 THistPainter.cxx:7805
 THistPainter.cxx:7806
 THistPainter.cxx:7807
 THistPainter.cxx:7808
 THistPainter.cxx:7809
 THistPainter.cxx:7810
 THistPainter.cxx:7811
 THistPainter.cxx:7812
 THistPainter.cxx:7813
 THistPainter.cxx:7814
 THistPainter.cxx:7815
 THistPainter.cxx:7816
 THistPainter.cxx:7817
 THistPainter.cxx:7818
 THistPainter.cxx:7819
 THistPainter.cxx:7820
 THistPainter.cxx:7821
 THistPainter.cxx:7822
 THistPainter.cxx:7823
 THistPainter.cxx:7824
 THistPainter.cxx:7825
 THistPainter.cxx:7826
 THistPainter.cxx:7827
 THistPainter.cxx:7828
 THistPainter.cxx:7829
 THistPainter.cxx:7830
 THistPainter.cxx:7831
 THistPainter.cxx:7832
 THistPainter.cxx:7833
 THistPainter.cxx:7834
 THistPainter.cxx:7835
 THistPainter.cxx:7836
 THistPainter.cxx:7837
 THistPainter.cxx:7838
 THistPainter.cxx:7839
 THistPainter.cxx:7840
 THistPainter.cxx:7841
 THistPainter.cxx:7842
 THistPainter.cxx:7843
 THistPainter.cxx:7844
 THistPainter.cxx:7845
 THistPainter.cxx:7846
 THistPainter.cxx:7847
 THistPainter.cxx:7848
 THistPainter.cxx:7849
 THistPainter.cxx:7850
 THistPainter.cxx:7851
 THistPainter.cxx:7852
 THistPainter.cxx:7853
 THistPainter.cxx:7854
 THistPainter.cxx:7855
 THistPainter.cxx:7856
 THistPainter.cxx:7857
 THistPainter.cxx:7858
 THistPainter.cxx:7859
 THistPainter.cxx:7860
 THistPainter.cxx:7861
 THistPainter.cxx:7862
 THistPainter.cxx:7863
 THistPainter.cxx:7864
 THistPainter.cxx:7865
 THistPainter.cxx:7866
 THistPainter.cxx:7867
 THistPainter.cxx:7868
 THistPainter.cxx:7869
 THistPainter.cxx:7870
 THistPainter.cxx:7871
 THistPainter.cxx:7872
 THistPainter.cxx:7873
 THistPainter.cxx:7874
 THistPainter.cxx:7875
 THistPainter.cxx:7876
 THistPainter.cxx:7877
 THistPainter.cxx:7878
 THistPainter.cxx:7879
 THistPainter.cxx:7880
 THistPainter.cxx:7881
 THistPainter.cxx:7882
 THistPainter.cxx:7883
 THistPainter.cxx:7884
 THistPainter.cxx:7885
 THistPainter.cxx:7886
 THistPainter.cxx:7887
 THistPainter.cxx:7888
 THistPainter.cxx:7889
 THistPainter.cxx:7890
 THistPainter.cxx:7891
 THistPainter.cxx:7892
 THistPainter.cxx:7893
 THistPainter.cxx:7894
 THistPainter.cxx:7895
 THistPainter.cxx:7896
 THistPainter.cxx:7897
 THistPainter.cxx:7898
 THistPainter.cxx:7899
 THistPainter.cxx:7900
 THistPainter.cxx:7901
 THistPainter.cxx:7902
 THistPainter.cxx:7903
 THistPainter.cxx:7904
 THistPainter.cxx:7905
 THistPainter.cxx:7906
 THistPainter.cxx:7907
 THistPainter.cxx:7908
 THistPainter.cxx:7909
 THistPainter.cxx:7910
 THistPainter.cxx:7911
 THistPainter.cxx:7912
 THistPainter.cxx:7913
 THistPainter.cxx:7914
 THistPainter.cxx:7915
 THistPainter.cxx:7916
 THistPainter.cxx:7917
 THistPainter.cxx:7918
 THistPainter.cxx:7919
 THistPainter.cxx:7920
 THistPainter.cxx:7921
 THistPainter.cxx:7922
 THistPainter.cxx:7923
 THistPainter.cxx:7924
 THistPainter.cxx:7925
 THistPainter.cxx:7926
 THistPainter.cxx:7927
 THistPainter.cxx:7928
 THistPainter.cxx:7929
 THistPainter.cxx:7930
 THistPainter.cxx:7931
 THistPainter.cxx:7932
 THistPainter.cxx:7933
 THistPainter.cxx:7934
 THistPainter.cxx:7935
 THistPainter.cxx:7936
 THistPainter.cxx:7937
 THistPainter.cxx:7938
 THistPainter.cxx:7939
 THistPainter.cxx:7940
 THistPainter.cxx:7941
 THistPainter.cxx:7942
 THistPainter.cxx:7943
 THistPainter.cxx:7944
 THistPainter.cxx:7945
 THistPainter.cxx:7946
 THistPainter.cxx:7947
 THistPainter.cxx:7948
 THistPainter.cxx:7949
 THistPainter.cxx:7950
 THistPainter.cxx:7951
 THistPainter.cxx:7952
 THistPainter.cxx:7953
 THistPainter.cxx:7954
 THistPainter.cxx:7955
 THistPainter.cxx:7956
 THistPainter.cxx:7957
 THistPainter.cxx:7958
 THistPainter.cxx:7959
 THistPainter.cxx:7960
 THistPainter.cxx:7961
 THistPainter.cxx:7962
 THistPainter.cxx:7963
 THistPainter.cxx:7964
 THistPainter.cxx:7965
 THistPainter.cxx:7966
 THistPainter.cxx:7967
 THistPainter.cxx:7968
 THistPainter.cxx:7969
 THistPainter.cxx:7970
 THistPainter.cxx:7971
 THistPainter.cxx:7972
 THistPainter.cxx:7973
 THistPainter.cxx:7974
 THistPainter.cxx:7975
 THistPainter.cxx:7976
 THistPainter.cxx:7977
 THistPainter.cxx:7978
 THistPainter.cxx:7979
 THistPainter.cxx:7980
 THistPainter.cxx:7981
 THistPainter.cxx:7982
 THistPainter.cxx:7983
 THistPainter.cxx:7984
 THistPainter.cxx:7985
 THistPainter.cxx:7986
 THistPainter.cxx:7987
 THistPainter.cxx:7988
 THistPainter.cxx:7989
 THistPainter.cxx:7990
 THistPainter.cxx:7991
 THistPainter.cxx:7992
 THistPainter.cxx:7993
 THistPainter.cxx:7994
 THistPainter.cxx:7995
 THistPainter.cxx:7996
 THistPainter.cxx:7997
 THistPainter.cxx:7998
 THistPainter.cxx:7999
 THistPainter.cxx:8000
 THistPainter.cxx:8001
 THistPainter.cxx:8002
 THistPainter.cxx:8003
 THistPainter.cxx:8004
 THistPainter.cxx:8005
 THistPainter.cxx:8006
 THistPainter.cxx:8007
 THistPainter.cxx:8008
 THistPainter.cxx:8009
 THistPainter.cxx:8010
 THistPainter.cxx:8011
 THistPainter.cxx:8012
 THistPainter.cxx:8013
 THistPainter.cxx:8014
 THistPainter.cxx:8015
 THistPainter.cxx:8016
 THistPainter.cxx:8017
 THistPainter.cxx:8018
 THistPainter.cxx:8019
 THistPainter.cxx:8020
 THistPainter.cxx:8021
 THistPainter.cxx:8022
 THistPainter.cxx:8023
 THistPainter.cxx:8024
 THistPainter.cxx:8025
 THistPainter.cxx:8026
 THistPainter.cxx:8027
 THistPainter.cxx:8028
 THistPainter.cxx:8029
 THistPainter.cxx:8030
 THistPainter.cxx:8031
 THistPainter.cxx:8032
 THistPainter.cxx:8033
 THistPainter.cxx:8034
 THistPainter.cxx:8035
 THistPainter.cxx:8036
 THistPainter.cxx:8037
 THistPainter.cxx:8038
 THistPainter.cxx:8039
 THistPainter.cxx:8040
 THistPainter.cxx:8041
 THistPainter.cxx:8042
 THistPainter.cxx:8043
 THistPainter.cxx:8044
 THistPainter.cxx:8045
 THistPainter.cxx:8046
 THistPainter.cxx:8047
 THistPainter.cxx:8048
 THistPainter.cxx:8049
 THistPainter.cxx:8050
 THistPainter.cxx:8051
 THistPainter.cxx:8052
 THistPainter.cxx:8053
 THistPainter.cxx:8054
 THistPainter.cxx:8055
 THistPainter.cxx:8056
 THistPainter.cxx:8057
 THistPainter.cxx:8058
 THistPainter.cxx:8059
 THistPainter.cxx:8060
 THistPainter.cxx:8061
 THistPainter.cxx:8062
 THistPainter.cxx:8063
 THistPainter.cxx:8064
 THistPainter.cxx:8065
 THistPainter.cxx:8066
 THistPainter.cxx:8067
 THistPainter.cxx:8068
 THistPainter.cxx:8069
 THistPainter.cxx:8070
 THistPainter.cxx:8071
 THistPainter.cxx:8072
 THistPainter.cxx:8073
 THistPainter.cxx:8074
 THistPainter.cxx:8075
 THistPainter.cxx:8076
 THistPainter.cxx:8077
 THistPainter.cxx:8078
 THistPainter.cxx:8079
 THistPainter.cxx:8080
 THistPainter.cxx:8081
 THistPainter.cxx:8082
 THistPainter.cxx:8083
 THistPainter.cxx:8084
 THistPainter.cxx:8085
 THistPainter.cxx:8086
 THistPainter.cxx:8087
 THistPainter.cxx:8088
 THistPainter.cxx:8089
 THistPainter.cxx:8090
 THistPainter.cxx:8091
 THistPainter.cxx:8092
 THistPainter.cxx:8093
 THistPainter.cxx:8094
 THistPainter.cxx:8095
 THistPainter.cxx:8096
 THistPainter.cxx:8097
 THistPainter.cxx:8098
 THistPainter.cxx:8099
 THistPainter.cxx:8100
 THistPainter.cxx:8101
 THistPainter.cxx:8102
 THistPainter.cxx:8103
 THistPainter.cxx:8104
 THistPainter.cxx:8105
 THistPainter.cxx:8106
 THistPainter.cxx:8107
 THistPainter.cxx:8108
 THistPainter.cxx:8109
 THistPainter.cxx:8110
 THistPainter.cxx:8111
 THistPainter.cxx:8112
 THistPainter.cxx:8113
 THistPainter.cxx:8114
 THistPainter.cxx:8115
 THistPainter.cxx:8116
 THistPainter.cxx:8117
 THistPainter.cxx:8118
 THistPainter.cxx:8119
 THistPainter.cxx:8120
 THistPainter.cxx:8121
 THistPainter.cxx:8122
 THistPainter.cxx:8123
 THistPainter.cxx:8124
 THistPainter.cxx:8125
 THistPainter.cxx:8126
 THistPainter.cxx:8127
 THistPainter.cxx:8128
 THistPainter.cxx:8129
 THistPainter.cxx:8130
 THistPainter.cxx:8131
 THistPainter.cxx:8132
 THistPainter.cxx:8133
 THistPainter.cxx:8134
 THistPainter.cxx:8135
 THistPainter.cxx:8136
 THistPainter.cxx:8137
 THistPainter.cxx:8138
 THistPainter.cxx:8139
 THistPainter.cxx:8140
 THistPainter.cxx:8141
 THistPainter.cxx:8142
 THistPainter.cxx:8143
 THistPainter.cxx:8144
 THistPainter.cxx:8145
 THistPainter.cxx:8146
 THistPainter.cxx:8147
 THistPainter.cxx:8148
 THistPainter.cxx:8149
 THistPainter.cxx:8150
 THistPainter.cxx:8151
 THistPainter.cxx:8152
 THistPainter.cxx:8153
 THistPainter.cxx:8154
 THistPainter.cxx:8155
 THistPainter.cxx:8156
 THistPainter.cxx:8157
 THistPainter.cxx:8158
 THistPainter.cxx:8159
 THistPainter.cxx:8160
 THistPainter.cxx:8161
 THistPainter.cxx:8162
 THistPainter.cxx:8163
 THistPainter.cxx:8164
 THistPainter.cxx:8165
 THistPainter.cxx:8166
 THistPainter.cxx:8167
 THistPainter.cxx:8168
 THistPainter.cxx:8169
 THistPainter.cxx:8170
 THistPainter.cxx:8171
 THistPainter.cxx:8172
 THistPainter.cxx:8173
 THistPainter.cxx:8174
 THistPainter.cxx:8175
 THistPainter.cxx:8176
 THistPainter.cxx:8177
 THistPainter.cxx:8178
 THistPainter.cxx:8179
 THistPainter.cxx:8180
 THistPainter.cxx:8181
 THistPainter.cxx:8182
 THistPainter.cxx:8183
 THistPainter.cxx:8184
 THistPainter.cxx:8185
 THistPainter.cxx:8186
 THistPainter.cxx:8187
 THistPainter.cxx:8188
 THistPainter.cxx:8189
 THistPainter.cxx:8190
 THistPainter.cxx:8191
 THistPainter.cxx:8192
 THistPainter.cxx:8193
 THistPainter.cxx:8194
 THistPainter.cxx:8195
 THistPainter.cxx:8196
 THistPainter.cxx:8197
 THistPainter.cxx:8198
 THistPainter.cxx:8199
 THistPainter.cxx:8200
 THistPainter.cxx:8201
 THistPainter.cxx:8202
 THistPainter.cxx:8203
 THistPainter.cxx:8204
 THistPainter.cxx:8205
 THistPainter.cxx:8206
 THistPainter.cxx:8207
 THistPainter.cxx:8208
 THistPainter.cxx:8209
 THistPainter.cxx:8210
 THistPainter.cxx:8211
 THistPainter.cxx:8212
 THistPainter.cxx:8213
 THistPainter.cxx:8214
 THistPainter.cxx:8215
 THistPainter.cxx:8216
 THistPainter.cxx:8217
 THistPainter.cxx:8218
 THistPainter.cxx:8219
 THistPainter.cxx:8220
 THistPainter.cxx:8221
 THistPainter.cxx:8222
 THistPainter.cxx:8223
 THistPainter.cxx:8224
 THistPainter.cxx:8225
 THistPainter.cxx:8226
 THistPainter.cxx:8227
 THistPainter.cxx:8228
 THistPainter.cxx:8229
 THistPainter.cxx:8230
 THistPainter.cxx:8231
 THistPainter.cxx:8232
 THistPainter.cxx:8233
 THistPainter.cxx:8234
 THistPainter.cxx:8235
 THistPainter.cxx:8236
 THistPainter.cxx:8237
 THistPainter.cxx:8238
 THistPainter.cxx:8239
 THistPainter.cxx:8240
 THistPainter.cxx:8241
 THistPainter.cxx:8242
 THistPainter.cxx:8243
 THistPainter.cxx:8244
 THistPainter.cxx:8245
 THistPainter.cxx:8246
 THistPainter.cxx:8247
 THistPainter.cxx:8248
 THistPainter.cxx:8249
 THistPainter.cxx:8250
 THistPainter.cxx:8251
 THistPainter.cxx:8252
 THistPainter.cxx:8253
 THistPainter.cxx:8254
 THistPainter.cxx:8255
 THistPainter.cxx:8256
 THistPainter.cxx:8257
 THistPainter.cxx:8258
 THistPainter.cxx:8259
 THistPainter.cxx:8260
 THistPainter.cxx:8261
 THistPainter.cxx:8262
 THistPainter.cxx:8263
 THistPainter.cxx:8264
 THistPainter.cxx:8265
 THistPainter.cxx:8266
 THistPainter.cxx:8267
 THistPainter.cxx:8268
 THistPainter.cxx:8269
 THistPainter.cxx:8270
 THistPainter.cxx:8271
 THistPainter.cxx:8272
 THistPainter.cxx:8273
 THistPainter.cxx:8274
 THistPainter.cxx:8275
 THistPainter.cxx:8276
 THistPainter.cxx:8277
 THistPainter.cxx:8278
 THistPainter.cxx:8279
 THistPainter.cxx:8280
 THistPainter.cxx:8281
 THistPainter.cxx:8282
 THistPainter.cxx:8283
 THistPainter.cxx:8284
 THistPainter.cxx:8285
 THistPainter.cxx:8286
 THistPainter.cxx:8287
 THistPainter.cxx:8288
 THistPainter.cxx:8289
 THistPainter.cxx:8290
 THistPainter.cxx:8291
 THistPainter.cxx:8292
 THistPainter.cxx:8293
 THistPainter.cxx:8294
 THistPainter.cxx:8295
 THistPainter.cxx:8296
 THistPainter.cxx:8297
 THistPainter.cxx:8298
 THistPainter.cxx:8299
 THistPainter.cxx:8300
 THistPainter.cxx:8301
 THistPainter.cxx:8302
 THistPainter.cxx:8303
 THistPainter.cxx:8304
 THistPainter.cxx:8305
 THistPainter.cxx:8306
 THistPainter.cxx:8307
 THistPainter.cxx:8308
 THistPainter.cxx:8309
 THistPainter.cxx:8310
 THistPainter.cxx:8311
 THistPainter.cxx:8312
 THistPainter.cxx:8313
 THistPainter.cxx:8314
 THistPainter.cxx:8315
 THistPainter.cxx:8316
 THistPainter.cxx:8317
 THistPainter.cxx:8318
 THistPainter.cxx:8319
 THistPainter.cxx:8320
 THistPainter.cxx:8321
 THistPainter.cxx:8322
 THistPainter.cxx:8323
 THistPainter.cxx:8324
 THistPainter.cxx:8325
 THistPainter.cxx:8326
 THistPainter.cxx:8327
 THistPainter.cxx:8328
 THistPainter.cxx:8329
 THistPainter.cxx:8330
 THistPainter.cxx:8331
 THistPainter.cxx:8332
 THistPainter.cxx:8333
 THistPainter.cxx:8334
 THistPainter.cxx:8335
 THistPainter.cxx:8336
 THistPainter.cxx:8337
 THistPainter.cxx:8338
 THistPainter.cxx:8339
 THistPainter.cxx:8340
 THistPainter.cxx:8341
 THistPainter.cxx:8342
 THistPainter.cxx:8343
 THistPainter.cxx:8344
 THistPainter.cxx:8345
 THistPainter.cxx:8346
 THistPainter.cxx:8347
 THistPainter.cxx:8348
 THistPainter.cxx:8349
 THistPainter.cxx:8350
 THistPainter.cxx:8351
 THistPainter.cxx:8352
 THistPainter.cxx:8353
 THistPainter.cxx:8354
 THistPainter.cxx:8355
 THistPainter.cxx:8356
 THistPainter.cxx:8357
 THistPainter.cxx:8358
 THistPainter.cxx:8359
 THistPainter.cxx:8360
 THistPainter.cxx:8361
 THistPainter.cxx:8362
 THistPainter.cxx:8363
 THistPainter.cxx:8364
 THistPainter.cxx:8365
 THistPainter.cxx:8366
 THistPainter.cxx:8367
 THistPainter.cxx:8368
 THistPainter.cxx:8369
 THistPainter.cxx:8370
 THistPainter.cxx:8371
 THistPainter.cxx:8372
 THistPainter.cxx:8373
 THistPainter.cxx:8374
 THistPainter.cxx:8375
 THistPainter.cxx:8376
 THistPainter.cxx:8377
 THistPainter.cxx:8378
 THistPainter.cxx:8379
 THistPainter.cxx:8380
 THistPainter.cxx:8381
 THistPainter.cxx:8382
 THistPainter.cxx:8383
 THistPainter.cxx:8384
 THistPainter.cxx:8385
 THistPainter.cxx:8386
 THistPainter.cxx:8387
 THistPainter.cxx:8388
 THistPainter.cxx:8389
 THistPainter.cxx:8390
 THistPainter.cxx:8391
 THistPainter.cxx:8392
 THistPainter.cxx:8393
 THistPainter.cxx:8394
 THistPainter.cxx:8395
 THistPainter.cxx:8396
 THistPainter.cxx:8397
 THistPainter.cxx:8398
 THistPainter.cxx:8399
 THistPainter.cxx:8400
 THistPainter.cxx:8401
 THistPainter.cxx:8402
 THistPainter.cxx:8403
 THistPainter.cxx:8404
 THistPainter.cxx:8405
 THistPainter.cxx:8406
 THistPainter.cxx:8407
 THistPainter.cxx:8408
 THistPainter.cxx:8409
 THistPainter.cxx:8410
 THistPainter.cxx:8411
 THistPainter.cxx:8412
 THistPainter.cxx:8413
 THistPainter.cxx:8414
 THistPainter.cxx:8415
 THistPainter.cxx:8416
 THistPainter.cxx:8417
 THistPainter.cxx:8418
 THistPainter.cxx:8419
 THistPainter.cxx:8420
 THistPainter.cxx:8421
 THistPainter.cxx:8422
 THistPainter.cxx:8423
 THistPainter.cxx:8424
 THistPainter.cxx:8425
 THistPainter.cxx:8426
 THistPainter.cxx:8427
 THistPainter.cxx:8428
 THistPainter.cxx:8429
 THistPainter.cxx:8430
 THistPainter.cxx:8431
 THistPainter.cxx:8432
 THistPainter.cxx:8433
 THistPainter.cxx:8434
 THistPainter.cxx:8435
 THistPainter.cxx:8436
 THistPainter.cxx:8437
 THistPainter.cxx:8438
 THistPainter.cxx:8439
 THistPainter.cxx:8440
 THistPainter.cxx:8441
 THistPainter.cxx:8442
 THistPainter.cxx:8443
 THistPainter.cxx:8444
 THistPainter.cxx:8445
 THistPainter.cxx:8446
 THistPainter.cxx:8447
 THistPainter.cxx:8448
 THistPainter.cxx:8449
 THistPainter.cxx:8450
 THistPainter.cxx:8451
 THistPainter.cxx:8452
 THistPainter.cxx:8453
 THistPainter.cxx:8454
 THistPainter.cxx:8455
 THistPainter.cxx:8456
 THistPainter.cxx:8457
 THistPainter.cxx:8458
 THistPainter.cxx:8459
 THistPainter.cxx:8460
 THistPainter.cxx:8461
 THistPainter.cxx:8462
 THistPainter.cxx:8463
 THistPainter.cxx:8464
 THistPainter.cxx:8465
 THistPainter.cxx:8466
 THistPainter.cxx:8467
 THistPainter.cxx:8468
 THistPainter.cxx:8469
 THistPainter.cxx:8470
 THistPainter.cxx:8471
 THistPainter.cxx:8472
 THistPainter.cxx:8473
 THistPainter.cxx:8474
 THistPainter.cxx:8475
 THistPainter.cxx:8476
 THistPainter.cxx:8477
 THistPainter.cxx:8478
 THistPainter.cxx:8479
 THistPainter.cxx:8480
 THistPainter.cxx:8481
 THistPainter.cxx:8482
 THistPainter.cxx:8483
 THistPainter.cxx:8484
 THistPainter.cxx:8485
 THistPainter.cxx:8486
 THistPainter.cxx:8487
 THistPainter.cxx:8488
 THistPainter.cxx:8489
 THistPainter.cxx:8490
 THistPainter.cxx:8491
 THistPainter.cxx:8492
 THistPainter.cxx:8493
 THistPainter.cxx:8494
 THistPainter.cxx:8495
 THistPainter.cxx:8496
 THistPainter.cxx:8497
 THistPainter.cxx:8498
 THistPainter.cxx:8499
 THistPainter.cxx:8500
 THistPainter.cxx:8501
 THistPainter.cxx:8502
 THistPainter.cxx:8503
 THistPainter.cxx:8504
 THistPainter.cxx:8505
 THistPainter.cxx:8506
 THistPainter.cxx:8507
 THistPainter.cxx:8508
 THistPainter.cxx:8509
 THistPainter.cxx:8510
 THistPainter.cxx:8511
 THistPainter.cxx:8512
 THistPainter.cxx:8513
 THistPainter.cxx:8514
 THistPainter.cxx:8515
 THistPainter.cxx:8516
 THistPainter.cxx:8517
 THistPainter.cxx:8518
 THistPainter.cxx:8519
 THistPainter.cxx:8520
 THistPainter.cxx:8521
 THistPainter.cxx:8522
 THistPainter.cxx:8523
 THistPainter.cxx:8524
 THistPainter.cxx:8525
 THistPainter.cxx:8526
 THistPainter.cxx:8527
 THistPainter.cxx:8528
 THistPainter.cxx:8529
 THistPainter.cxx:8530
 THistPainter.cxx:8531
 THistPainter.cxx:8532
 THistPainter.cxx:8533
 THistPainter.cxx:8534
 THistPainter.cxx:8535
 THistPainter.cxx:8536
 THistPainter.cxx:8537
 THistPainter.cxx:8538
 THistPainter.cxx:8539
 THistPainter.cxx:8540
 THistPainter.cxx:8541
 THistPainter.cxx:8542
 THistPainter.cxx:8543
 THistPainter.cxx:8544
 THistPainter.cxx:8545
 THistPainter.cxx:8546
 THistPainter.cxx:8547
 THistPainter.cxx:8548
 THistPainter.cxx:8549
 THistPainter.cxx:8550
 THistPainter.cxx:8551
 THistPainter.cxx:8552
 THistPainter.cxx:8553
 THistPainter.cxx:8554
 THistPainter.cxx:8555
 THistPainter.cxx:8556
 THistPainter.cxx:8557
 THistPainter.cxx:8558
 THistPainter.cxx:8559
 THistPainter.cxx:8560
 THistPainter.cxx:8561
 THistPainter.cxx:8562
 THistPainter.cxx:8563
 THistPainter.cxx:8564
 THistPainter.cxx:8565
 THistPainter.cxx:8566
 THistPainter.cxx:8567
 THistPainter.cxx:8568
 THistPainter.cxx:8569
 THistPainter.cxx:8570
 THistPainter.cxx:8571
 THistPainter.cxx:8572
 THistPainter.cxx:8573
 THistPainter.cxx:8574
 THistPainter.cxx:8575
 THistPainter.cxx:8576
 THistPainter.cxx:8577
 THistPainter.cxx:8578
 THistPainter.cxx:8579
 THistPainter.cxx:8580
 THistPainter.cxx:8581
 THistPainter.cxx:8582
 THistPainter.cxx:8583
 THistPainter.cxx:8584
 THistPainter.cxx:8585
 THistPainter.cxx:8586
 THistPainter.cxx:8587
 THistPainter.cxx:8588
 THistPainter.cxx:8589
 THistPainter.cxx:8590
 THistPainter.cxx:8591
 THistPainter.cxx:8592
 THistPainter.cxx:8593
 THistPainter.cxx:8594
 THistPainter.cxx:8595
 THistPainter.cxx:8596
 THistPainter.cxx:8597
 THistPainter.cxx:8598
 THistPainter.cxx:8599
 THistPainter.cxx:8600
 THistPainter.cxx:8601
 THistPainter.cxx:8602
 THistPainter.cxx:8603
 THistPainter.cxx:8604
 THistPainter.cxx:8605
 THistPainter.cxx:8606
 THistPainter.cxx:8607
 THistPainter.cxx:8608
 THistPainter.cxx:8609
 THistPainter.cxx:8610
 THistPainter.cxx:8611
 THistPainter.cxx:8612
 THistPainter.cxx:8613
 THistPainter.cxx:8614
 THistPainter.cxx:8615
 THistPainter.cxx:8616
 THistPainter.cxx:8617
 THistPainter.cxx:8618
 THistPainter.cxx:8619
 THistPainter.cxx:8620
 THistPainter.cxx:8621
 THistPainter.cxx:8622
 THistPainter.cxx:8623
 THistPainter.cxx:8624
 THistPainter.cxx:8625
 THistPainter.cxx:8626
 THistPainter.cxx:8627
 THistPainter.cxx:8628
 THistPainter.cxx:8629
 THistPainter.cxx:8630
 THistPainter.cxx:8631
 THistPainter.cxx:8632
 THistPainter.cxx:8633
 THistPainter.cxx:8634
 THistPainter.cxx:8635
 THistPainter.cxx:8636
 THistPainter.cxx:8637
 THistPainter.cxx:8638
 THistPainter.cxx:8639
 THistPainter.cxx:8640
 THistPainter.cxx:8641
 THistPainter.cxx:8642
 THistPainter.cxx:8643
 THistPainter.cxx:8644
 THistPainter.cxx:8645
 THistPainter.cxx:8646
 THistPainter.cxx:8647
 THistPainter.cxx:8648
 THistPainter.cxx:8649
 THistPainter.cxx:8650
 THistPainter.cxx:8651
 THistPainter.cxx:8652
 THistPainter.cxx:8653
 THistPainter.cxx:8654
 THistPainter.cxx:8655
 THistPainter.cxx:8656
 THistPainter.cxx:8657
 THistPainter.cxx:8658
 THistPainter.cxx:8659
 THistPainter.cxx:8660
 THistPainter.cxx:8661
 THistPainter.cxx:8662
 THistPainter.cxx:8663
 THistPainter.cxx:8664
 THistPainter.cxx:8665
 THistPainter.cxx:8666
 THistPainter.cxx:8667
 THistPainter.cxx:8668
 THistPainter.cxx:8669
 THistPainter.cxx:8670
 THistPainter.cxx:8671
 THistPainter.cxx:8672
 THistPainter.cxx:8673
 THistPainter.cxx:8674
 THistPainter.cxx:8675
 THistPainter.cxx:8676
 THistPainter.cxx:8677
 THistPainter.cxx:8678
 THistPainter.cxx:8679
 THistPainter.cxx:8680
 THistPainter.cxx:8681
 THistPainter.cxx:8682
 THistPainter.cxx:8683
 THistPainter.cxx:8684
 THistPainter.cxx:8685
 THistPainter.cxx:8686
 THistPainter.cxx:8687
 THistPainter.cxx:8688
 THistPainter.cxx:8689
 THistPainter.cxx:8690
 THistPainter.cxx:8691
 THistPainter.cxx:8692
 THistPainter.cxx:8693
 THistPainter.cxx:8694
 THistPainter.cxx:8695
 THistPainter.cxx:8696
 THistPainter.cxx:8697
 THistPainter.cxx:8698
 THistPainter.cxx:8699
 THistPainter.cxx:8700
 THistPainter.cxx:8701
 THistPainter.cxx:8702
 THistPainter.cxx:8703
 THistPainter.cxx:8704
 THistPainter.cxx:8705
 THistPainter.cxx:8706
 THistPainter.cxx:8707
 THistPainter.cxx:8708
 THistPainter.cxx:8709
 THistPainter.cxx:8710
 THistPainter.cxx:8711
 THistPainter.cxx:8712
 THistPainter.cxx:8713
 THistPainter.cxx:8714
 THistPainter.cxx:8715
 THistPainter.cxx:8716
 THistPainter.cxx:8717
 THistPainter.cxx:8718
 THistPainter.cxx:8719
 THistPainter.cxx:8720
 THistPainter.cxx:8721
 THistPainter.cxx:8722
 THistPainter.cxx:8723
 THistPainter.cxx:8724
 THistPainter.cxx:8725
 THistPainter.cxx:8726
 THistPainter.cxx:8727
 THistPainter.cxx:8728
 THistPainter.cxx:8729
 THistPainter.cxx:8730
 THistPainter.cxx:8731
 THistPainter.cxx:8732
 THistPainter.cxx:8733
 THistPainter.cxx:8734
 THistPainter.cxx:8735
 THistPainter.cxx:8736
 THistPainter.cxx:8737
 THistPainter.cxx:8738
 THistPainter.cxx:8739
 THistPainter.cxx:8740
 THistPainter.cxx:8741
 THistPainter.cxx:8742
 THistPainter.cxx:8743
 THistPainter.cxx:8744
 THistPainter.cxx:8745
 THistPainter.cxx:8746
 THistPainter.cxx:8747
 THistPainter.cxx:8748
 THistPainter.cxx:8749
 THistPainter.cxx:8750
 THistPainter.cxx:8751
 THistPainter.cxx:8752
 THistPainter.cxx:8753
 THistPainter.cxx:8754
 THistPainter.cxx:8755
 THistPainter.cxx:8756
 THistPainter.cxx:8757
 THistPainter.cxx:8758
 THistPainter.cxx:8759
 THistPainter.cxx:8760
 THistPainter.cxx:8761
 THistPainter.cxx:8762
 THistPainter.cxx:8763
 THistPainter.cxx:8764
 THistPainter.cxx:8765
 THistPainter.cxx:8766
 THistPainter.cxx:8767
 THistPainter.cxx:8768
 THistPainter.cxx:8769
 THistPainter.cxx:8770
 THistPainter.cxx:8771
 THistPainter.cxx:8772
 THistPainter.cxx:8773
 THistPainter.cxx:8774
 THistPainter.cxx:8775
 THistPainter.cxx:8776
 THistPainter.cxx:8777
 THistPainter.cxx:8778
 THistPainter.cxx:8779
 THistPainter.cxx:8780
 THistPainter.cxx:8781
 THistPainter.cxx:8782
 THistPainter.cxx:8783
 THistPainter.cxx:8784
 THistPainter.cxx:8785
 THistPainter.cxx:8786
 THistPainter.cxx:8787
 THistPainter.cxx:8788
 THistPainter.cxx:8789
 THistPainter.cxx:8790
 THistPainter.cxx:8791
 THistPainter.cxx:8792
 THistPainter.cxx:8793
 THistPainter.cxx:8794
 THistPainter.cxx:8795
 THistPainter.cxx:8796
 THistPainter.cxx:8797
 THistPainter.cxx:8798
 THistPainter.cxx:8799
 THistPainter.cxx:8800
 THistPainter.cxx:8801
 THistPainter.cxx:8802
 THistPainter.cxx:8803
 THistPainter.cxx:8804
 THistPainter.cxx:8805
 THistPainter.cxx:8806
 THistPainter.cxx:8807
 THistPainter.cxx:8808
 THistPainter.cxx:8809
 THistPainter.cxx:8810
 THistPainter.cxx:8811
 THistPainter.cxx:8812
 THistPainter.cxx:8813
 THistPainter.cxx:8814
 THistPainter.cxx:8815
 THistPainter.cxx:8816
 THistPainter.cxx:8817
 THistPainter.cxx:8818
 THistPainter.cxx:8819
 THistPainter.cxx:8820
 THistPainter.cxx:8821
 THistPainter.cxx:8822
 THistPainter.cxx:8823
 THistPainter.cxx:8824
 THistPainter.cxx:8825
 THistPainter.cxx:8826
 THistPainter.cxx:8827
 THistPainter.cxx:8828
 THistPainter.cxx:8829
 THistPainter.cxx:8830
 THistPainter.cxx:8831
 THistPainter.cxx:8832
 THistPainter.cxx:8833
 THistPainter.cxx:8834
 THistPainter.cxx:8835
 THistPainter.cxx:8836
 THistPainter.cxx:8837
 THistPainter.cxx:8838
 THistPainter.cxx:8839
 THistPainter.cxx:8840
 THistPainter.cxx:8841
 THistPainter.cxx:8842
 THistPainter.cxx:8843
 THistPainter.cxx:8844
 THistPainter.cxx:8845
 THistPainter.cxx:8846
 THistPainter.cxx:8847
 THistPainter.cxx:8848
 THistPainter.cxx:8849
 THistPainter.cxx:8850
 THistPainter.cxx:8851
 THistPainter.cxx:8852
 THistPainter.cxx:8853
 THistPainter.cxx:8854
 THistPainter.cxx:8855
 THistPainter.cxx:8856
 THistPainter.cxx:8857
 THistPainter.cxx:8858
 THistPainter.cxx:8859
 THistPainter.cxx:8860
 THistPainter.cxx:8861
 THistPainter.cxx:8862
 THistPainter.cxx:8863
 THistPainter.cxx:8864
 THistPainter.cxx:8865
 THistPainter.cxx:8866
 THistPainter.cxx:8867
 THistPainter.cxx:8868
 THistPainter.cxx:8869
 THistPainter.cxx:8870
 THistPainter.cxx:8871
 THistPainter.cxx:8872
 THistPainter.cxx:8873
 THistPainter.cxx:8874
 THistPainter.cxx:8875
 THistPainter.cxx:8876
 THistPainter.cxx:8877
 THistPainter.cxx:8878
 THistPainter.cxx:8879
 THistPainter.cxx:8880
 THistPainter.cxx:8881
 THistPainter.cxx:8882
 THistPainter.cxx:8883
 THistPainter.cxx:8884
 THistPainter.cxx:8885
 THistPainter.cxx:8886
 THistPainter.cxx:8887
 THistPainter.cxx:8888
 THistPainter.cxx:8889
 THistPainter.cxx:8890
 THistPainter.cxx:8891
 THistPainter.cxx:8892
 THistPainter.cxx:8893
 THistPainter.cxx:8894
 THistPainter.cxx:8895
 THistPainter.cxx:8896
 THistPainter.cxx:8897
 THistPainter.cxx:8898
 THistPainter.cxx:8899
 THistPainter.cxx:8900
 THistPainter.cxx:8901
 THistPainter.cxx:8902
 THistPainter.cxx:8903
 THistPainter.cxx:8904
 THistPainter.cxx:8905
 THistPainter.cxx:8906
 THistPainter.cxx:8907
 THistPainter.cxx:8908
 THistPainter.cxx:8909
 THistPainter.cxx:8910
 THistPainter.cxx:8911
 THistPainter.cxx:8912
 THistPainter.cxx:8913
 THistPainter.cxx:8914
 THistPainter.cxx:8915
 THistPainter.cxx:8916
 THistPainter.cxx:8917
 THistPainter.cxx:8918
 THistPainter.cxx:8919
 THistPainter.cxx:8920
 THistPainter.cxx:8921
 THistPainter.cxx:8922
 THistPainter.cxx:8923
 THistPainter.cxx:8924
 THistPainter.cxx:8925
 THistPainter.cxx:8926
 THistPainter.cxx:8927
 THistPainter.cxx:8928
 THistPainter.cxx:8929
 THistPainter.cxx:8930
 THistPainter.cxx:8931
 THistPainter.cxx:8932
 THistPainter.cxx:8933
 THistPainter.cxx:8934
 THistPainter.cxx:8935
 THistPainter.cxx:8936
 THistPainter.cxx:8937
 THistPainter.cxx:8938
 THistPainter.cxx:8939
 THistPainter.cxx:8940
 THistPainter.cxx:8941
 THistPainter.cxx:8942
 THistPainter.cxx:8943
 THistPainter.cxx:8944
 THistPainter.cxx:8945
 THistPainter.cxx:8946
 THistPainter.cxx:8947
 THistPainter.cxx:8948
 THistPainter.cxx:8949
 THistPainter.cxx:8950
 THistPainter.cxx:8951
 THistPainter.cxx:8952
 THistPainter.cxx:8953
 THistPainter.cxx:8954
 THistPainter.cxx:8955
 THistPainter.cxx:8956
 THistPainter.cxx:8957
 THistPainter.cxx:8958
 THistPainter.cxx:8959
 THistPainter.cxx:8960
 THistPainter.cxx:8961
 THistPainter.cxx:8962
 THistPainter.cxx:8963
 THistPainter.cxx:8964
 THistPainter.cxx:8965
 THistPainter.cxx:8966
 THistPainter.cxx:8967
 THistPainter.cxx:8968
 THistPainter.cxx:8969
 THistPainter.cxx:8970
 THistPainter.cxx:8971
 THistPainter.cxx:8972
 THistPainter.cxx:8973
 THistPainter.cxx:8974
 THistPainter.cxx:8975
 THistPainter.cxx:8976
 THistPainter.cxx:8977
 THistPainter.cxx:8978
 THistPainter.cxx:8979
 THistPainter.cxx:8980
 THistPainter.cxx:8981
 THistPainter.cxx:8982
 THistPainter.cxx:8983
 THistPainter.cxx:8984
 THistPainter.cxx:8985
 THistPainter.cxx:8986
 THistPainter.cxx:8987
 THistPainter.cxx:8988
 THistPainter.cxx:8989
 THistPainter.cxx:8990
 THistPainter.cxx:8991
 THistPainter.cxx:8992
 THistPainter.cxx:8993
 THistPainter.cxx:8994
 THistPainter.cxx:8995
 THistPainter.cxx:8996
 THistPainter.cxx:8997
 THistPainter.cxx:8998
 THistPainter.cxx:8999
 THistPainter.cxx:9000
 THistPainter.cxx:9001
 THistPainter.cxx:9002
 THistPainter.cxx:9003
 THistPainter.cxx:9004
 THistPainter.cxx:9005
 THistPainter.cxx:9006
 THistPainter.cxx:9007
 THistPainter.cxx:9008
 THistPainter.cxx:9009
 THistPainter.cxx:9010
 THistPainter.cxx:9011
 THistPainter.cxx:9012
 THistPainter.cxx:9013
 THistPainter.cxx:9014
 THistPainter.cxx:9015
 THistPainter.cxx:9016
 THistPainter.cxx:9017
 THistPainter.cxx:9018
 THistPainter.cxx:9019
 THistPainter.cxx:9020
 THistPainter.cxx:9021
 THistPainter.cxx:9022
 THistPainter.cxx:9023
 THistPainter.cxx:9024
 THistPainter.cxx:9025
 THistPainter.cxx:9026
 THistPainter.cxx:9027
 THistPainter.cxx:9028
 THistPainter.cxx:9029
 THistPainter.cxx:9030
 THistPainter.cxx:9031
 THistPainter.cxx:9032
 THistPainter.cxx:9033
 THistPainter.cxx:9034
 THistPainter.cxx:9035
 THistPainter.cxx:9036
 THistPainter.cxx:9037
 THistPainter.cxx:9038
 THistPainter.cxx:9039
 THistPainter.cxx:9040
 THistPainter.cxx:9041
 THistPainter.cxx:9042
 THistPainter.cxx:9043
 THistPainter.cxx:9044
 THistPainter.cxx:9045
 THistPainter.cxx:9046
 THistPainter.cxx:9047
 THistPainter.cxx:9048
 THistPainter.cxx:9049
 THistPainter.cxx:9050
 THistPainter.cxx:9051
 THistPainter.cxx:9052
 THistPainter.cxx:9053
 THistPainter.cxx:9054
 THistPainter.cxx:9055
 THistPainter.cxx:9056
 THistPainter.cxx:9057
 THistPainter.cxx:9058
 THistPainter.cxx:9059
 THistPainter.cxx:9060
 THistPainter.cxx:9061
 THistPainter.cxx:9062
 THistPainter.cxx:9063
 THistPainter.cxx:9064
 THistPainter.cxx:9065
 THistPainter.cxx:9066
 THistPainter.cxx:9067
 THistPainter.cxx:9068
 THistPainter.cxx:9069
 THistPainter.cxx:9070
 THistPainter.cxx:9071
 THistPainter.cxx:9072
 THistPainter.cxx:9073
 THistPainter.cxx:9074
 THistPainter.cxx:9075
 THistPainter.cxx:9076
 THistPainter.cxx:9077
 THistPainter.cxx:9078
 THistPainter.cxx:9079
 THistPainter.cxx:9080
 THistPainter.cxx:9081
 THistPainter.cxx:9082
 THistPainter.cxx:9083
 THistPainter.cxx:9084
 THistPainter.cxx:9085
 THistPainter.cxx:9086
 THistPainter.cxx:9087
 THistPainter.cxx:9088
 THistPainter.cxx:9089
 THistPainter.cxx:9090
 THistPainter.cxx:9091
 THistPainter.cxx:9092
 THistPainter.cxx:9093
 THistPainter.cxx:9094
 THistPainter.cxx:9095
 THistPainter.cxx:9096
 THistPainter.cxx:9097
 THistPainter.cxx:9098
 THistPainter.cxx:9099
 THistPainter.cxx:9100
 THistPainter.cxx:9101
 THistPainter.cxx:9102
 THistPainter.cxx:9103
 THistPainter.cxx:9104
 THistPainter.cxx:9105
 THistPainter.cxx:9106
 THistPainter.cxx:9107
 THistPainter.cxx:9108
 THistPainter.cxx:9109
 THistPainter.cxx:9110
 THistPainter.cxx:9111
 THistPainter.cxx:9112
 THistPainter.cxx:9113
 THistPainter.cxx:9114
 THistPainter.cxx:9115
 THistPainter.cxx:9116
 THistPainter.cxx:9117
 THistPainter.cxx:9118
 THistPainter.cxx:9119
 THistPainter.cxx:9120
 THistPainter.cxx:9121
 THistPainter.cxx:9122
 THistPainter.cxx:9123
 THistPainter.cxx:9124
 THistPainter.cxx:9125
 THistPainter.cxx:9126
 THistPainter.cxx:9127
 THistPainter.cxx:9128
 THistPainter.cxx:9129
 THistPainter.cxx:9130
 THistPainter.cxx:9131
 THistPainter.cxx:9132
 THistPainter.cxx:9133
 THistPainter.cxx:9134
 THistPainter.cxx:9135
 THistPainter.cxx:9136
 THistPainter.cxx:9137
 THistPainter.cxx:9138
 THistPainter.cxx:9139
 THistPainter.cxx:9140
 THistPainter.cxx:9141
 THistPainter.cxx:9142
 THistPainter.cxx:9143
 THistPainter.cxx:9144
 THistPainter.cxx:9145
 THistPainter.cxx:9146
 THistPainter.cxx:9147
 THistPainter.cxx:9148
 THistPainter.cxx:9149
 THistPainter.cxx:9150
 THistPainter.cxx:9151
 THistPainter.cxx:9152
 THistPainter.cxx:9153
 THistPainter.cxx:9154
 THistPainter.cxx:9155
 THistPainter.cxx:9156
 THistPainter.cxx:9157
 THistPainter.cxx:9158
 THistPainter.cxx:9159
 THistPainter.cxx:9160
 THistPainter.cxx:9161
 THistPainter.cxx:9162
 THistPainter.cxx:9163
 THistPainter.cxx:9164
 THistPainter.cxx:9165
 THistPainter.cxx:9166
 THistPainter.cxx:9167
 THistPainter.cxx:9168
 THistPainter.cxx:9169
 THistPainter.cxx:9170
 THistPainter.cxx:9171
 THistPainter.cxx:9172
 THistPainter.cxx:9173
 THistPainter.cxx:9174
 THistPainter.cxx:9175
 THistPainter.cxx:9176
 THistPainter.cxx:9177
 THistPainter.cxx:9178
 THistPainter.cxx:9179
 THistPainter.cxx:9180
 THistPainter.cxx:9181
 THistPainter.cxx:9182
 THistPainter.cxx:9183
 THistPainter.cxx:9184
 THistPainter.cxx:9185
 THistPainter.cxx:9186
 THistPainter.cxx:9187
 THistPainter.cxx:9188
 THistPainter.cxx:9189
 THistPainter.cxx:9190
 THistPainter.cxx:9191
 THistPainter.cxx:9192
 THistPainter.cxx:9193
 THistPainter.cxx:9194
 THistPainter.cxx:9195
 THistPainter.cxx:9196
 THistPainter.cxx:9197
 THistPainter.cxx:9198
 THistPainter.cxx:9199
 THistPainter.cxx:9200
 THistPainter.cxx:9201
 THistPainter.cxx:9202
 THistPainter.cxx:9203
 THistPainter.cxx:9204
 THistPainter.cxx:9205
 THistPainter.cxx:9206
 THistPainter.cxx:9207
 THistPainter.cxx:9208
 THistPainter.cxx:9209
 THistPainter.cxx:9210
 THistPainter.cxx:9211
 THistPainter.cxx:9212
 THistPainter.cxx:9213
 THistPainter.cxx:9214
 THistPainter.cxx:9215
 THistPainter.cxx:9216
 THistPainter.cxx:9217
 THistPainter.cxx:9218
 THistPainter.cxx:9219
 THistPainter.cxx:9220
 THistPainter.cxx:9221
 THistPainter.cxx:9222
 THistPainter.cxx:9223
 THistPainter.cxx:9224
 THistPainter.cxx:9225
 THistPainter.cxx:9226
 THistPainter.cxx:9227
 THistPainter.cxx:9228
 THistPainter.cxx:9229
 THistPainter.cxx:9230
 THistPainter.cxx:9231
 THistPainter.cxx:9232
 THistPainter.cxx:9233
 THistPainter.cxx:9234
 THistPainter.cxx:9235
 THistPainter.cxx:9236
 THistPainter.cxx:9237
 THistPainter.cxx:9238
 THistPainter.cxx:9239
 THistPainter.cxx:9240
 THistPainter.cxx:9241
 THistPainter.cxx:9242
 THistPainter.cxx:9243
 THistPainter.cxx:9244
 THistPainter.cxx:9245
 THistPainter.cxx:9246
 THistPainter.cxx:9247
 THistPainter.cxx:9248
 THistPainter.cxx:9249
 THistPainter.cxx:9250
 THistPainter.cxx:9251
 THistPainter.cxx:9252
 THistPainter.cxx:9253
 THistPainter.cxx:9254
 THistPainter.cxx:9255
 THistPainter.cxx:9256
 THistPainter.cxx:9257
 THistPainter.cxx:9258
 THistPainter.cxx:9259
 THistPainter.cxx:9260
 THistPainter.cxx:9261
 THistPainter.cxx:9262
 THistPainter.cxx:9263
 THistPainter.cxx:9264
 THistPainter.cxx:9265
 THistPainter.cxx:9266
 THistPainter.cxx:9267
 THistPainter.cxx:9268
 THistPainter.cxx:9269
 THistPainter.cxx:9270
 THistPainter.cxx:9271
 THistPainter.cxx:9272
 THistPainter.cxx:9273
 THistPainter.cxx:9274
 THistPainter.cxx:9275
 THistPainter.cxx:9276
 THistPainter.cxx:9277
 THistPainter.cxx:9278
 THistPainter.cxx:9279
 THistPainter.cxx:9280
 THistPainter.cxx:9281
 THistPainter.cxx:9282
 THistPainter.cxx:9283
 THistPainter.cxx:9284
 THistPainter.cxx:9285
 THistPainter.cxx:9286
 THistPainter.cxx:9287
 THistPainter.cxx:9288
 THistPainter.cxx:9289
 THistPainter.cxx:9290
 THistPainter.cxx:9291
 THistPainter.cxx:9292
 THistPainter.cxx:9293
 THistPainter.cxx:9294
 THistPainter.cxx:9295
 THistPainter.cxx:9296
 THistPainter.cxx:9297
 THistPainter.cxx:9298
 THistPainter.cxx:9299
 THistPainter.cxx:9300
 THistPainter.cxx:9301
 THistPainter.cxx:9302
 THistPainter.cxx:9303
 THistPainter.cxx:9304
 THistPainter.cxx:9305
 THistPainter.cxx:9306
 THistPainter.cxx:9307
 THistPainter.cxx:9308
 THistPainter.cxx:9309
 THistPainter.cxx:9310
 THistPainter.cxx:9311
 THistPainter.cxx:9312
 THistPainter.cxx:9313
 THistPainter.cxx:9314
 THistPainter.cxx:9315
 THistPainter.cxx:9316
 THistPainter.cxx:9317
 THistPainter.cxx:9318
 THistPainter.cxx:9319
 THistPainter.cxx:9320
 THistPainter.cxx:9321
 THistPainter.cxx:9322
 THistPainter.cxx:9323
 THistPainter.cxx:9324
 THistPainter.cxx:9325
 THistPainter.cxx:9326
 THistPainter.cxx:9327
 THistPainter.cxx:9328
 THistPainter.cxx:9329
 THistPainter.cxx:9330
 THistPainter.cxx:9331
 THistPainter.cxx:9332
 THistPainter.cxx:9333
 THistPainter.cxx:9334
 THistPainter.cxx:9335
 THistPainter.cxx:9336
 THistPainter.cxx:9337
 THistPainter.cxx:9338
 THistPainter.cxx:9339
 THistPainter.cxx:9340
 THistPainter.cxx:9341
 THistPainter.cxx:9342
 THistPainter.cxx:9343
 THistPainter.cxx:9344
 THistPainter.cxx:9345
 THistPainter.cxx:9346
 THistPainter.cxx:9347
 THistPainter.cxx:9348
 THistPainter.cxx:9349
 THistPainter.cxx:9350
 THistPainter.cxx:9351
 THistPainter.cxx:9352
 THistPainter.cxx:9353
 THistPainter.cxx:9354
 THistPainter.cxx:9355
 THistPainter.cxx:9356
 THistPainter.cxx:9357
 THistPainter.cxx:9358
 THistPainter.cxx:9359
 THistPainter.cxx:9360
 THistPainter.cxx:9361
 THistPainter.cxx:9362
 THistPainter.cxx:9363
 THistPainter.cxx:9364
 THistPainter.cxx:9365
 THistPainter.cxx:9366
 THistPainter.cxx:9367
 THistPainter.cxx:9368
 THistPainter.cxx:9369
 THistPainter.cxx:9370
 THistPainter.cxx:9371
 THistPainter.cxx:9372
 THistPainter.cxx:9373
 THistPainter.cxx:9374
 THistPainter.cxx:9375
 THistPainter.cxx:9376
 THistPainter.cxx:9377
 THistPainter.cxx:9378
 THistPainter.cxx:9379
 THistPainter.cxx:9380
 THistPainter.cxx:9381
 THistPainter.cxx:9382
 THistPainter.cxx:9383
 THistPainter.cxx:9384
 THistPainter.cxx:9385
 THistPainter.cxx:9386
 THistPainter.cxx:9387
 THistPainter.cxx:9388
 THistPainter.cxx:9389
 THistPainter.cxx:9390
 THistPainter.cxx:9391
 THistPainter.cxx:9392
 THistPainter.cxx:9393
 THistPainter.cxx:9394
 THistPainter.cxx:9395
 THistPainter.cxx:9396
 THistPainter.cxx:9397
 THistPainter.cxx:9398
 THistPainter.cxx:9399
 THistPainter.cxx:9400
 THistPainter.cxx:9401
 THistPainter.cxx:9402
 THistPainter.cxx:9403
 THistPainter.cxx:9404
 THistPainter.cxx:9405
 THistPainter.cxx:9406
 THistPainter.cxx:9407
 THistPainter.cxx:9408
 THistPainter.cxx:9409
 THistPainter.cxx:9410
 THistPainter.cxx:9411
 THistPainter.cxx:9412
 THistPainter.cxx:9413
 THistPainter.cxx:9414
 THistPainter.cxx:9415
 THistPainter.cxx:9416
 THistPainter.cxx:9417
 THistPainter.cxx:9418
 THistPainter.cxx:9419
 THistPainter.cxx:9420
 THistPainter.cxx:9421
 THistPainter.cxx:9422
 THistPainter.cxx:9423
 THistPainter.cxx:9424
 THistPainter.cxx:9425
 THistPainter.cxx:9426
 THistPainter.cxx:9427
 THistPainter.cxx:9428
 THistPainter.cxx:9429
 THistPainter.cxx:9430
 THistPainter.cxx:9431
 THistPainter.cxx:9432
 THistPainter.cxx:9433
 THistPainter.cxx:9434
 THistPainter.cxx:9435
 THistPainter.cxx:9436
 THistPainter.cxx:9437
 THistPainter.cxx:9438
 THistPainter.cxx:9439
 THistPainter.cxx:9440
 THistPainter.cxx:9441
 THistPainter.cxx:9442
 THistPainter.cxx:9443
 THistPainter.cxx:9444
 THistPainter.cxx:9445
 THistPainter.cxx:9446
 THistPainter.cxx:9447
 THistPainter.cxx:9448
 THistPainter.cxx:9449
 THistPainter.cxx:9450
 THistPainter.cxx:9451
 THistPainter.cxx:9452
 THistPainter.cxx:9453
 THistPainter.cxx:9454
 THistPainter.cxx:9455
 THistPainter.cxx:9456
 THistPainter.cxx:9457
 THistPainter.cxx:9458
 THistPainter.cxx:9459
 THistPainter.cxx:9460
 THistPainter.cxx:9461
 THistPainter.cxx:9462
 THistPainter.cxx:9463
 THistPainter.cxx:9464
 THistPainter.cxx:9465
 THistPainter.cxx:9466
 THistPainter.cxx:9467
 THistPainter.cxx:9468
 THistPainter.cxx:9469
 THistPainter.cxx:9470
 THistPainter.cxx:9471
 THistPainter.cxx:9472
 THistPainter.cxx:9473
 THistPainter.cxx:9474
 THistPainter.cxx:9475
 THistPainter.cxx:9476
 THistPainter.cxx:9477
 THistPainter.cxx:9478
 THistPainter.cxx:9479
 THistPainter.cxx:9480
 THistPainter.cxx:9481
 THistPainter.cxx:9482
 THistPainter.cxx:9483
 THistPainter.cxx:9484
 THistPainter.cxx:9485
 THistPainter.cxx:9486
 THistPainter.cxx:9487
 THistPainter.cxx:9488
 THistPainter.cxx:9489
 THistPainter.cxx:9490
 THistPainter.cxx:9491
 THistPainter.cxx:9492
 THistPainter.cxx:9493
 THistPainter.cxx:9494
 THistPainter.cxx:9495
 THistPainter.cxx:9496
 THistPainter.cxx:9497
 THistPainter.cxx:9498
 THistPainter.cxx:9499
 THistPainter.cxx:9500
 THistPainter.cxx:9501
 THistPainter.cxx:9502
 THistPainter.cxx:9503
 THistPainter.cxx:9504
 THistPainter.cxx:9505
 THistPainter.cxx:9506
 THistPainter.cxx:9507
 THistPainter.cxx:9508
 THistPainter.cxx:9509
 THistPainter.cxx:9510
 THistPainter.cxx:9511
 THistPainter.cxx:9512
 THistPainter.cxx:9513
 THistPainter.cxx:9514
 THistPainter.cxx:9515
 THistPainter.cxx:9516
 THistPainter.cxx:9517
 THistPainter.cxx:9518
 THistPainter.cxx:9519
 THistPainter.cxx:9520
 THistPainter.cxx:9521
 THistPainter.cxx:9522
 THistPainter.cxx:9523
 THistPainter.cxx:9524
 THistPainter.cxx:9525
 THistPainter.cxx:9526
 THistPainter.cxx:9527
 THistPainter.cxx:9528
 THistPainter.cxx:9529
 THistPainter.cxx:9530
 THistPainter.cxx:9531
 THistPainter.cxx:9532
 THistPainter.cxx:9533
 THistPainter.cxx:9534
 THistPainter.cxx:9535
 THistPainter.cxx:9536
 THistPainter.cxx:9537
 THistPainter.cxx:9538
 THistPainter.cxx:9539
 THistPainter.cxx:9540
 THistPainter.cxx:9541
 THistPainter.cxx:9542
 THistPainter.cxx:9543
 THistPainter.cxx:9544
 THistPainter.cxx:9545
 THistPainter.cxx:9546
 THistPainter.cxx:9547
 THistPainter.cxx:9548
 THistPainter.cxx:9549
 THistPainter.cxx:9550
 THistPainter.cxx:9551
 THistPainter.cxx:9552
 THistPainter.cxx:9553
 THistPainter.cxx:9554
 THistPainter.cxx:9555
 THistPainter.cxx:9556
 THistPainter.cxx:9557
 THistPainter.cxx:9558
 THistPainter.cxx:9559
 THistPainter.cxx:9560
 THistPainter.cxx:9561
 THistPainter.cxx:9562
 THistPainter.cxx:9563
 THistPainter.cxx:9564
 THistPainter.cxx:9565
 THistPainter.cxx:9566
 THistPainter.cxx:9567
 THistPainter.cxx:9568
 THistPainter.cxx:9569
 THistPainter.cxx:9570
 THistPainter.cxx:9571
 THistPainter.cxx:9572
 THistPainter.cxx:9573
 THistPainter.cxx:9574
 THistPainter.cxx:9575
 THistPainter.cxx:9576
 THistPainter.cxx:9577
 THistPainter.cxx:9578
 THistPainter.cxx:9579
 THistPainter.cxx:9580
 THistPainter.cxx:9581
 THistPainter.cxx:9582
 THistPainter.cxx:9583
 THistPainter.cxx:9584
 THistPainter.cxx:9585
 THistPainter.cxx:9586
 THistPainter.cxx:9587
 THistPainter.cxx:9588
 THistPainter.cxx:9589
 THistPainter.cxx:9590
 THistPainter.cxx:9591
 THistPainter.cxx:9592
 THistPainter.cxx:9593
 THistPainter.cxx:9594
 THistPainter.cxx:9595
 THistPainter.cxx:9596
 THistPainter.cxx:9597
 THistPainter.cxx:9598
 THistPainter.cxx:9599
 THistPainter.cxx:9600
 THistPainter.cxx:9601
 THistPainter.cxx:9602
 THistPainter.cxx:9603
 THistPainter.cxx:9604
 THistPainter.cxx:9605
 THistPainter.cxx:9606
 THistPainter.cxx:9607
 THistPainter.cxx:9608
 THistPainter.cxx:9609
 THistPainter.cxx:9610
 THistPainter.cxx:9611
 THistPainter.cxx:9612
 THistPainter.cxx:9613
 THistPainter.cxx:9614
 THistPainter.cxx:9615
 THistPainter.cxx:9616
 THistPainter.cxx:9617
 THistPainter.cxx:9618
 THistPainter.cxx:9619
 THistPainter.cxx:9620
 THistPainter.cxx:9621
 THistPainter.cxx:9622
 THistPainter.cxx:9623
 THistPainter.cxx:9624
 THistPainter.cxx:9625
 THistPainter.cxx:9626
 THistPainter.cxx:9627
 THistPainter.cxx:9628
 THistPainter.cxx:9629
 THistPainter.cxx:9630
 THistPainter.cxx:9631
 THistPainter.cxx:9632
 THistPainter.cxx:9633
 THistPainter.cxx:9634
 THistPainter.cxx:9635
 THistPainter.cxx:9636
 THistPainter.cxx:9637
 THistPainter.cxx:9638
 THistPainter.cxx:9639
 THistPainter.cxx:9640
 THistPainter.cxx:9641
 THistPainter.cxx:9642
 THistPainter.cxx:9643
 THistPainter.cxx:9644
 THistPainter.cxx:9645
 THistPainter.cxx:9646
 THistPainter.cxx:9647
 THistPainter.cxx:9648
 THistPainter.cxx:9649
 THistPainter.cxx:9650
 THistPainter.cxx:9651
 THistPainter.cxx:9652
 THistPainter.cxx:9653
 THistPainter.cxx:9654
 THistPainter.cxx:9655
 THistPainter.cxx:9656
 THistPainter.cxx:9657
 THistPainter.cxx:9658
 THistPainter.cxx:9659
 THistPainter.cxx:9660
 THistPainter.cxx:9661
 THistPainter.cxx:9662
 THistPainter.cxx:9663
 THistPainter.cxx:9664
 THistPainter.cxx:9665
 THistPainter.cxx:9666
 THistPainter.cxx:9667
 THistPainter.cxx:9668
 THistPainter.cxx:9669
 THistPainter.cxx:9670
 THistPainter.cxx:9671
 THistPainter.cxx:9672
 THistPainter.cxx:9673
 THistPainter.cxx:9674
 THistPainter.cxx:9675
 THistPainter.cxx:9676
 THistPainter.cxx:9677
 THistPainter.cxx:9678
 THistPainter.cxx:9679
 THistPainter.cxx:9680
 THistPainter.cxx:9681
 THistPainter.cxx:9682
 THistPainter.cxx:9683
 THistPainter.cxx:9684
 THistPainter.cxx:9685
 THistPainter.cxx:9686
 THistPainter.cxx:9687
 THistPainter.cxx:9688
 THistPainter.cxx:9689
 THistPainter.cxx:9690
 THistPainter.cxx:9691
 THistPainter.cxx:9692
 THistPainter.cxx:9693
 THistPainter.cxx:9694
 THistPainter.cxx:9695
 THistPainter.cxx:9696
 THistPainter.cxx:9697
 THistPainter.cxx:9698
 THistPainter.cxx:9699
 THistPainter.cxx:9700
 THistPainter.cxx:9701
 THistPainter.cxx:9702
 THistPainter.cxx:9703
 THistPainter.cxx:9704
 THistPainter.cxx:9705
 THistPainter.cxx:9706
 THistPainter.cxx:9707
 THistPainter.cxx:9708
 THistPainter.cxx:9709
 THistPainter.cxx:9710
 THistPainter.cxx:9711
 THistPainter.cxx:9712
 THistPainter.cxx:9713
 THistPainter.cxx:9714
 THistPainter.cxx:9715
 THistPainter.cxx:9716
 THistPainter.cxx:9717
 THistPainter.cxx:9718
 THistPainter.cxx:9719
 THistPainter.cxx:9720
 THistPainter.cxx:9721
 THistPainter.cxx:9722
 THistPainter.cxx:9723
 THistPainter.cxx:9724
 THistPainter.cxx:9725
 THistPainter.cxx:9726
 THistPainter.cxx:9727
 THistPainter.cxx:9728
 THistPainter.cxx:9729
 THistPainter.cxx:9730
 THistPainter.cxx:9731
 THistPainter.cxx:9732
 THistPainter.cxx:9733
 THistPainter.cxx:9734
 THistPainter.cxx:9735
 THistPainter.cxx:9736
 THistPainter.cxx:9737
 THistPainter.cxx:9738
 THistPainter.cxx:9739
 THistPainter.cxx:9740
 THistPainter.cxx:9741
 THistPainter.cxx:9742
 THistPainter.cxx:9743
 THistPainter.cxx:9744
 THistPainter.cxx:9745
 THistPainter.cxx:9746
 THistPainter.cxx:9747
 THistPainter.cxx:9748
 THistPainter.cxx:9749
 THistPainter.cxx:9750
 THistPainter.cxx:9751
 THistPainter.cxx:9752
 THistPainter.cxx:9753
 THistPainter.cxx:9754
 THistPainter.cxx:9755
 THistPainter.cxx:9756
 THistPainter.cxx:9757
 THistPainter.cxx:9758
 THistPainter.cxx:9759
 THistPainter.cxx:9760
 THistPainter.cxx:9761
 THistPainter.cxx:9762
 THistPainter.cxx:9763
 THistPainter.cxx:9764
 THistPainter.cxx:9765
 THistPainter.cxx:9766
 THistPainter.cxx:9767
 THistPainter.cxx:9768
 THistPainter.cxx:9769
 THistPainter.cxx:9770
 THistPainter.cxx:9771
 THistPainter.cxx:9772
 THistPainter.cxx:9773
 THistPainter.cxx:9774
 THistPainter.cxx:9775
 THistPainter.cxx:9776
 THistPainter.cxx:9777
 THistPainter.cxx:9778
 THistPainter.cxx:9779
 THistPainter.cxx:9780
 THistPainter.cxx:9781
 THistPainter.cxx:9782
 THistPainter.cxx:9783
 THistPainter.cxx:9784
 THistPainter.cxx:9785
 THistPainter.cxx:9786
 THistPainter.cxx:9787
 THistPainter.cxx:9788
 THistPainter.cxx:9789
 THistPainter.cxx:9790
 THistPainter.cxx:9791
 THistPainter.cxx:9792
 THistPainter.cxx:9793
 THistPainter.cxx:9794
 THistPainter.cxx:9795
 THistPainter.cxx:9796
 THistPainter.cxx:9797
 THistPainter.cxx:9798
 THistPainter.cxx:9799
 THistPainter.cxx:9800
 THistPainter.cxx:9801
 THistPainter.cxx:9802
 THistPainter.cxx:9803
 THistPainter.cxx:9804
 THistPainter.cxx:9805
 THistPainter.cxx:9806
 THistPainter.cxx:9807
 THistPainter.cxx:9808
 THistPainter.cxx:9809
 THistPainter.cxx:9810
 THistPainter.cxx:9811
 THistPainter.cxx:9812
 THistPainter.cxx:9813
 THistPainter.cxx:9814
 THistPainter.cxx:9815
 THistPainter.cxx:9816
 THistPainter.cxx:9817
 THistPainter.cxx:9818
 THistPainter.cxx:9819
 THistPainter.cxx:9820
 THistPainter.cxx:9821
 THistPainter.cxx:9822
 THistPainter.cxx:9823
 THistPainter.cxx:9824
 THistPainter.cxx:9825
 THistPainter.cxx:9826
 THistPainter.cxx:9827
 THistPainter.cxx:9828
 THistPainter.cxx:9829
 THistPainter.cxx:9830
 THistPainter.cxx:9831
 THistPainter.cxx:9832
 THistPainter.cxx:9833
 THistPainter.cxx:9834
 THistPainter.cxx:9835
 THistPainter.cxx:9836
 THistPainter.cxx:9837
 THistPainter.cxx:9838
 THistPainter.cxx:9839
 THistPainter.cxx:9840
 THistPainter.cxx:9841
 THistPainter.cxx:9842
 THistPainter.cxx:9843
 THistPainter.cxx:9844
 THistPainter.cxx:9845
 THistPainter.cxx:9846
 THistPainter.cxx:9847
 THistPainter.cxx:9848
 THistPainter.cxx:9849
 THistPainter.cxx:9850
 THistPainter.cxx:9851
 THistPainter.cxx:9852
 THistPainter.cxx:9853
 THistPainter.cxx:9854
 THistPainter.cxx:9855
 THistPainter.cxx:9856
 THistPainter.cxx:9857
 THistPainter.cxx:9858
 THistPainter.cxx:9859
 THistPainter.cxx:9860
 THistPainter.cxx:9861
 THistPainter.cxx:9862
 THistPainter.cxx:9863
 THistPainter.cxx:9864
 THistPainter.cxx:9865
 THistPainter.cxx:9866
 THistPainter.cxx:9867
 THistPainter.cxx:9868
 THistPainter.cxx:9869
 THistPainter.cxx:9870
 THistPainter.cxx:9871
 THistPainter.cxx:9872
 THistPainter.cxx:9873
 THistPainter.cxx:9874
 THistPainter.cxx:9875
 THistPainter.cxx:9876
 THistPainter.cxx:9877
 THistPainter.cxx:9878
 THistPainter.cxx:9879
 THistPainter.cxx:9880
 THistPainter.cxx:9881
 THistPainter.cxx:9882
 THistPainter.cxx:9883
 THistPainter.cxx:9884
 THistPainter.cxx:9885
 THistPainter.cxx:9886
 THistPainter.cxx:9887
 THistPainter.cxx:9888
 THistPainter.cxx:9889
 THistPainter.cxx:9890
 THistPainter.cxx:9891
 THistPainter.cxx:9892
 THistPainter.cxx:9893
 THistPainter.cxx:9894
 THistPainter.cxx:9895
 THistPainter.cxx:9896
 THistPainter.cxx:9897
 THistPainter.cxx:9898
 THistPainter.cxx:9899
 THistPainter.cxx:9900
 THistPainter.cxx:9901
 THistPainter.cxx:9902
 THistPainter.cxx:9903
 THistPainter.cxx:9904
 THistPainter.cxx:9905
 THistPainter.cxx:9906
 THistPainter.cxx:9907
 THistPainter.cxx:9908
 THistPainter.cxx:9909
 THistPainter.cxx:9910
 THistPainter.cxx:9911
 THistPainter.cxx:9912
 THistPainter.cxx:9913
 THistPainter.cxx:9914
 THistPainter.cxx:9915
 THistPainter.cxx:9916
 THistPainter.cxx:9917
 THistPainter.cxx:9918
 THistPainter.cxx:9919
 THistPainter.cxx:9920
 THistPainter.cxx:9921
 THistPainter.cxx:9922
 THistPainter.cxx:9923
 THistPainter.cxx:9924
 THistPainter.cxx:9925
 THistPainter.cxx:9926
 THistPainter.cxx:9927
 THistPainter.cxx:9928
 THistPainter.cxx:9929
 THistPainter.cxx:9930
 THistPainter.cxx:9931
 THistPainter.cxx:9932
 THistPainter.cxx:9933
 THistPainter.cxx:9934
 THistPainter.cxx:9935
 THistPainter.cxx:9936
 THistPainter.cxx:9937
 THistPainter.cxx:9938
 THistPainter.cxx:9939
 THistPainter.cxx:9940
 THistPainter.cxx:9941
 THistPainter.cxx:9942
 THistPainter.cxx:9943
 THistPainter.cxx:9944
 THistPainter.cxx:9945
 THistPainter.cxx:9946
 THistPainter.cxx:9947
 THistPainter.cxx:9948
 THistPainter.cxx:9949
 THistPainter.cxx:9950
 THistPainter.cxx:9951
 THistPainter.cxx:9952
 THistPainter.cxx:9953
 THistPainter.cxx:9954
 THistPainter.cxx:9955
 THistPainter.cxx:9956
 THistPainter.cxx:9957
 THistPainter.cxx:9958
 THistPainter.cxx:9959
 THistPainter.cxx:9960
 THistPainter.cxx:9961
 THistPainter.cxx:9962
 THistPainter.cxx:9963
 THistPainter.cxx:9964
 THistPainter.cxx:9965
 THistPainter.cxx:9966
 THistPainter.cxx:9967
 THistPainter.cxx:9968
 THistPainter.cxx:9969
 THistPainter.cxx:9970
 THistPainter.cxx:9971
 THistPainter.cxx:9972
 THistPainter.cxx:9973
 THistPainter.cxx:9974
 THistPainter.cxx:9975
 THistPainter.cxx:9976
 THistPainter.cxx:9977
 THistPainter.cxx:9978
 THistPainter.cxx:9979
 THistPainter.cxx:9980
 THistPainter.cxx:9981
 THistPainter.cxx:9982
 THistPainter.cxx:9983
 THistPainter.cxx:9984
 THistPainter.cxx:9985
 THistPainter.cxx:9986
 THistPainter.cxx:9987
 THistPainter.cxx:9988
 THistPainter.cxx:9989
 THistPainter.cxx:9990
 THistPainter.cxx:9991
 THistPainter.cxx:9992
 THistPainter.cxx:9993
 THistPainter.cxx:9994
 THistPainter.cxx:9995
 THistPainter.cxx:9996
 THistPainter.cxx:9997
 THistPainter.cxx:9998
 THistPainter.cxx:9999
 THistPainter.cxx:10000
 THistPainter.cxx:10001
 THistPainter.cxx:10002
 THistPainter.cxx:10003
 THistPainter.cxx:10004
 THistPainter.cxx:10005
 THistPainter.cxx:10006
 THistPainter.cxx:10007
 THistPainter.cxx:10008
 THistPainter.cxx:10009
 THistPainter.cxx:10010
 THistPainter.cxx:10011
 THistPainter.cxx:10012
 THistPainter.cxx:10013
 THistPainter.cxx:10014
 THistPainter.cxx:10015
 THistPainter.cxx:10016
 THistPainter.cxx:10017
 THistPainter.cxx:10018
 THistPainter.cxx:10019
 THistPainter.cxx:10020
 THistPainter.cxx:10021
 THistPainter.cxx:10022
 THistPainter.cxx:10023
 THistPainter.cxx:10024
 THistPainter.cxx:10025
 THistPainter.cxx:10026
 THistPainter.cxx:10027
 THistPainter.cxx:10028
 THistPainter.cxx:10029
 THistPainter.cxx:10030
 THistPainter.cxx:10031
 THistPainter.cxx:10032
 THistPainter.cxx:10033
 THistPainter.cxx:10034
 THistPainter.cxx:10035
 THistPainter.cxx:10036
 THistPainter.cxx:10037
 THistPainter.cxx:10038
 THistPainter.cxx:10039
 THistPainter.cxx:10040
 THistPainter.cxx:10041
 THistPainter.cxx:10042
 THistPainter.cxx:10043
 THistPainter.cxx:10044
 THistPainter.cxx:10045
 THistPainter.cxx:10046
 THistPainter.cxx:10047
 THistPainter.cxx:10048
 THistPainter.cxx:10049
 THistPainter.cxx:10050
 THistPainter.cxx:10051
 THistPainter.cxx:10052
 THistPainter.cxx:10053
 THistPainter.cxx:10054
 THistPainter.cxx:10055
 THistPainter.cxx:10056
 THistPainter.cxx:10057
 THistPainter.cxx:10058
 THistPainter.cxx:10059
 THistPainter.cxx:10060
 THistPainter.cxx:10061
 THistPainter.cxx:10062
 THistPainter.cxx:10063
 THistPainter.cxx:10064
 THistPainter.cxx:10065
 THistPainter.cxx:10066
 THistPainter.cxx:10067
 THistPainter.cxx:10068
 THistPainter.cxx:10069
 THistPainter.cxx:10070
 THistPainter.cxx:10071
 THistPainter.cxx:10072
 THistPainter.cxx:10073
 THistPainter.cxx:10074
 THistPainter.cxx:10075
 THistPainter.cxx:10076
 THistPainter.cxx:10077
 THistPainter.cxx:10078
 THistPainter.cxx:10079
 THistPainter.cxx:10080
 THistPainter.cxx:10081
 THistPainter.cxx:10082
 THistPainter.cxx:10083
 THistPainter.cxx:10084
 THistPainter.cxx:10085
 THistPainter.cxx:10086
 THistPainter.cxx:10087
 THistPainter.cxx:10088
 THistPainter.cxx:10089
 THistPainter.cxx:10090
 THistPainter.cxx:10091
 THistPainter.cxx:10092
 THistPainter.cxx:10093
 THistPainter.cxx:10094
 THistPainter.cxx:10095
 THistPainter.cxx:10096
 THistPainter.cxx:10097
 THistPainter.cxx:10098
 THistPainter.cxx:10099
 THistPainter.cxx:10100
 THistPainter.cxx:10101
 THistPainter.cxx:10102
 THistPainter.cxx:10103
 THistPainter.cxx:10104
 THistPainter.cxx:10105
 THistPainter.cxx:10106
 THistPainter.cxx:10107
 THistPainter.cxx:10108
 THistPainter.cxx:10109
 THistPainter.cxx:10110
 THistPainter.cxx:10111
 THistPainter.cxx:10112
 THistPainter.cxx:10113
 THistPainter.cxx:10114
 THistPainter.cxx:10115
 THistPainter.cxx:10116
 THistPainter.cxx:10117
 THistPainter.cxx:10118
 THistPainter.cxx:10119
 THistPainter.cxx:10120
 THistPainter.cxx:10121
 THistPainter.cxx:10122
 THistPainter.cxx:10123
 THistPainter.cxx:10124
 THistPainter.cxx:10125
 THistPainter.cxx:10126
 THistPainter.cxx:10127
 THistPainter.cxx:10128
 THistPainter.cxx:10129
 THistPainter.cxx:10130
 THistPainter.cxx:10131
 THistPainter.cxx:10132
 THistPainter.cxx:10133
 THistPainter.cxx:10134
 THistPainter.cxx:10135
 THistPainter.cxx:10136
 THistPainter.cxx:10137
 THistPainter.cxx:10138
 THistPainter.cxx:10139
 THistPainter.cxx:10140
 THistPainter.cxx:10141
 THistPainter.cxx:10142
 THistPainter.cxx:10143
 THistPainter.cxx:10144
 THistPainter.cxx:10145
 THistPainter.cxx:10146
 THistPainter.cxx:10147
 THistPainter.cxx:10148
 THistPainter.cxx:10149
 THistPainter.cxx:10150
 THistPainter.cxx:10151
 THistPainter.cxx:10152
 THistPainter.cxx:10153
 THistPainter.cxx:10154
 THistPainter.cxx:10155
 THistPainter.cxx:10156
 THistPainter.cxx:10157
 THistPainter.cxx:10158
 THistPainter.cxx:10159
 THistPainter.cxx:10160
 THistPainter.cxx:10161
 THistPainter.cxx:10162
 THistPainter.cxx:10163
 THistPainter.cxx:10164
 THistPainter.cxx:10165
 THistPainter.cxx:10166
 THistPainter.cxx:10167
 THistPainter.cxx:10168
 THistPainter.cxx:10169
 THistPainter.cxx:10170
 THistPainter.cxx:10171
 THistPainter.cxx:10172
 THistPainter.cxx:10173
 THistPainter.cxx:10174
 THistPainter.cxx:10175
 THistPainter.cxx:10176
 THistPainter.cxx:10177
 THistPainter.cxx:10178
 THistPainter.cxx:10179
 THistPainter.cxx:10180
 THistPainter.cxx:10181
 THistPainter.cxx:10182
 THistPainter.cxx:10183
 THistPainter.cxx:10184
 THistPainter.cxx:10185
 THistPainter.cxx:10186
 THistPainter.cxx:10187
 THistPainter.cxx:10188
 THistPainter.cxx:10189
 THistPainter.cxx:10190
 THistPainter.cxx:10191
 THistPainter.cxx:10192
 THistPainter.cxx:10193
 THistPainter.cxx:10194
 THistPainter.cxx:10195
 THistPainter.cxx:10196
 THistPainter.cxx:10197
 THistPainter.cxx:10198
 THistPainter.cxx:10199
 THistPainter.cxx:10200
 THistPainter.cxx:10201
 THistPainter.cxx:10202
 THistPainter.cxx:10203
 THistPainter.cxx:10204
 THistPainter.cxx:10205
 THistPainter.cxx:10206
 THistPainter.cxx:10207
 THistPainter.cxx:10208
 THistPainter.cxx:10209
 THistPainter.cxx:10210
 THistPainter.cxx:10211
 THistPainter.cxx:10212
 THistPainter.cxx:10213
 THistPainter.cxx:10214
 THistPainter.cxx:10215
 THistPainter.cxx:10216
 THistPainter.cxx:10217
 THistPainter.cxx:10218
 THistPainter.cxx:10219
 THistPainter.cxx:10220
 THistPainter.cxx:10221
 THistPainter.cxx:10222
 THistPainter.cxx:10223
 THistPainter.cxx:10224
 THistPainter.cxx:10225
 THistPainter.cxx:10226
 THistPainter.cxx:10227
 THistPainter.cxx:10228
 THistPainter.cxx:10229
 THistPainter.cxx:10230
 THistPainter.cxx:10231
 THistPainter.cxx:10232
 THistPainter.cxx:10233
 THistPainter.cxx:10234
 THistPainter.cxx:10235
 THistPainter.cxx:10236
 THistPainter.cxx:10237
 THistPainter.cxx:10238
 THistPainter.cxx:10239
 THistPainter.cxx:10240
 THistPainter.cxx:10241
 THistPainter.cxx:10242
 THistPainter.cxx:10243
 THistPainter.cxx:10244
 THistPainter.cxx:10245
 THistPainter.cxx:10246
 THistPainter.cxx:10247
 THistPainter.cxx:10248
 THistPainter.cxx:10249
 THistPainter.cxx:10250
 THistPainter.cxx:10251
 THistPainter.cxx:10252
 THistPainter.cxx:10253
 THistPainter.cxx:10254
 THistPainter.cxx:10255
 THistPainter.cxx:10256
 THistPainter.cxx:10257
 THistPainter.cxx:10258
 THistPainter.cxx:10259
 THistPainter.cxx:10260
 THistPainter.cxx:10261
 THistPainter.cxx:10262
 THistPainter.cxx:10263
 THistPainter.cxx:10264
 THistPainter.cxx:10265
 THistPainter.cxx:10266
 THistPainter.cxx:10267
 THistPainter.cxx:10268
 THistPainter.cxx:10269
 THistPainter.cxx:10270
 THistPainter.cxx:10271
 THistPainter.cxx:10272
 THistPainter.cxx:10273
 THistPainter.cxx:10274
 THistPainter.cxx:10275
 THistPainter.cxx:10276
 THistPainter.cxx:10277
 THistPainter.cxx:10278
 THistPainter.cxx:10279
 THistPainter.cxx:10280
 THistPainter.cxx:10281
 THistPainter.cxx:10282
 THistPainter.cxx:10283
 THistPainter.cxx:10284
 THistPainter.cxx:10285
 THistPainter.cxx:10286
 THistPainter.cxx:10287
 THistPainter.cxx:10288
 THistPainter.cxx:10289
 THistPainter.cxx:10290
 THistPainter.cxx:10291
 THistPainter.cxx:10292
 THistPainter.cxx:10293
 THistPainter.cxx:10294
 THistPainter.cxx:10295
 THistPainter.cxx:10296
 THistPainter.cxx:10297
 THistPainter.cxx:10298
 THistPainter.cxx:10299
 THistPainter.cxx:10300
 THistPainter.cxx:10301
 THistPainter.cxx:10302
 THistPainter.cxx:10303
 THistPainter.cxx:10304
 THistPainter.cxx:10305
 THistPainter.cxx:10306
 THistPainter.cxx:10307
 THistPainter.cxx:10308
 THistPainter.cxx:10309
 THistPainter.cxx:10310
 THistPainter.cxx:10311
 THistPainter.cxx:10312
 THistPainter.cxx:10313
 THistPainter.cxx:10314
 THistPainter.cxx:10315
 THistPainter.cxx:10316
 THistPainter.cxx:10317
 THistPainter.cxx:10318
 THistPainter.cxx:10319
 THistPainter.cxx:10320
 THistPainter.cxx:10321
 THistPainter.cxx:10322
 THistPainter.cxx:10323
 THistPainter.cxx:10324
 THistPainter.cxx:10325
 THistPainter.cxx:10326
 THistPainter.cxx:10327
 THistPainter.cxx:10328
 THistPainter.cxx:10329
 THistPainter.cxx:10330
 THistPainter.cxx:10331
 THistPainter.cxx:10332
 THistPainter.cxx:10333
 THistPainter.cxx:10334
 THistPainter.cxx:10335
 THistPainter.cxx:10336
 THistPainter.cxx:10337
 THistPainter.cxx:10338
 THistPainter.cxx:10339
 THistPainter.cxx:10340
 THistPainter.cxx:10341
 THistPainter.cxx:10342
 THistPainter.cxx:10343
 THistPainter.cxx:10344
 THistPainter.cxx:10345
 THistPainter.cxx:10346
 THistPainter.cxx:10347
 THistPainter.cxx:10348
 THistPainter.cxx:10349
 THistPainter.cxx:10350
 THistPainter.cxx:10351
 THistPainter.cxx:10352
 THistPainter.cxx:10353
 THistPainter.cxx:10354
 THistPainter.cxx:10355
 THistPainter.cxx:10356
 THistPainter.cxx:10357
 THistPainter.cxx:10358
 THistPainter.cxx:10359
 THistPainter.cxx:10360
 THistPainter.cxx:10361
 THistPainter.cxx:10362
 THistPainter.cxx:10363
 THistPainter.cxx:10364
 THistPainter.cxx:10365
 THistPainter.cxx:10366
 THistPainter.cxx:10367
 THistPainter.cxx:10368
 THistPainter.cxx:10369
 THistPainter.cxx:10370
 THistPainter.cxx:10371
 THistPainter.cxx:10372
 THistPainter.cxx:10373
 THistPainter.cxx:10374
 THistPainter.cxx:10375
 THistPainter.cxx:10376
 THistPainter.cxx:10377
 THistPainter.cxx:10378
 THistPainter.cxx:10379
 THistPainter.cxx:10380
 THistPainter.cxx:10381
 THistPainter.cxx:10382
 THistPainter.cxx:10383
 THistPainter.cxx:10384
 THistPainter.cxx:10385
 THistPainter.cxx:10386
 THistPainter.cxx:10387
 THistPainter.cxx:10388
 THistPainter.cxx:10389
 THistPainter.cxx:10390
 THistPainter.cxx:10391
 THistPainter.cxx:10392
 THistPainter.cxx:10393
 THistPainter.cxx:10394
 THistPainter.cxx:10395
 THistPainter.cxx:10396
 THistPainter.cxx:10397
 THistPainter.cxx:10398
 THistPainter.cxx:10399
 THistPainter.cxx:10400
 THistPainter.cxx:10401
 THistPainter.cxx:10402
 THistPainter.cxx:10403
 THistPainter.cxx:10404
 THistPainter.cxx:10405
 THistPainter.cxx:10406
 THistPainter.cxx:10407
 THistPainter.cxx:10408
 THistPainter.cxx:10409
 THistPainter.cxx:10410
 THistPainter.cxx:10411
 THistPainter.cxx:10412
 THistPainter.cxx:10413
 THistPainter.cxx:10414
 THistPainter.cxx:10415
 THistPainter.cxx:10416
 THistPainter.cxx:10417
 THistPainter.cxx:10418
 THistPainter.cxx:10419
 THistPainter.cxx:10420
 THistPainter.cxx:10421
 THistPainter.cxx:10422
 THistPainter.cxx:10423
 THistPainter.cxx:10424
 THistPainter.cxx:10425
 THistPainter.cxx:10426
 THistPainter.cxx:10427
 THistPainter.cxx:10428
 THistPainter.cxx:10429
 THistPainter.cxx:10430
 THistPainter.cxx:10431
 THistPainter.cxx:10432
 THistPainter.cxx:10433
 THistPainter.cxx:10434
 THistPainter.cxx:10435
 THistPainter.cxx:10436
 THistPainter.cxx:10437
 THistPainter.cxx:10438
 THistPainter.cxx:10439
 THistPainter.cxx:10440
 THistPainter.cxx:10441
 THistPainter.cxx:10442
 THistPainter.cxx:10443
 THistPainter.cxx:10444
 THistPainter.cxx:10445
 THistPainter.cxx:10446
 THistPainter.cxx:10447
 THistPainter.cxx:10448
 THistPainter.cxx:10449
 THistPainter.cxx:10450
 THistPainter.cxx:10451
 THistPainter.cxx:10452
 THistPainter.cxx:10453
 THistPainter.cxx:10454
 THistPainter.cxx:10455
 THistPainter.cxx:10456
 THistPainter.cxx:10457
 THistPainter.cxx:10458
 THistPainter.cxx:10459
 THistPainter.cxx:10460
 THistPainter.cxx:10461
 THistPainter.cxx:10462
 THistPainter.cxx:10463
 THistPainter.cxx:10464
 THistPainter.cxx:10465
 THistPainter.cxx:10466
 THistPainter.cxx:10467
 THistPainter.cxx:10468
 THistPainter.cxx:10469
 THistPainter.cxx:10470
 THistPainter.cxx:10471
 THistPainter.cxx:10472
 THistPainter.cxx:10473
 THistPainter.cxx:10474
 THistPainter.cxx:10475
 THistPainter.cxx:10476
 THistPainter.cxx:10477
 THistPainter.cxx:10478
 THistPainter.cxx:10479
 THistPainter.cxx:10480
 THistPainter.cxx:10481
 THistPainter.cxx:10482
 THistPainter.cxx:10483
 THistPainter.cxx:10484
 THistPainter.cxx:10485
 THistPainter.cxx:10486
 THistPainter.cxx:10487
 THistPainter.cxx:10488
 THistPainter.cxx:10489
 THistPainter.cxx:10490
 THistPainter.cxx:10491
 THistPainter.cxx:10492
 THistPainter.cxx:10493
 THistPainter.cxx:10494
 THistPainter.cxx:10495
 THistPainter.cxx:10496