assigns the ‘legend columns’ option (apgfplots option) and uses ‘font’ for drawing the legend (a TikZ option). The point is: legend columnsneeds to be knownbeforethe legend is typeset whereasfontneeds to be active when the legend is typeset. pgfplotssorts out any key dependencies automatically:
The axis environments will process any knownpgfplots options, and all ‘every’–styles will be parsed forpgfplotsoptions. Every unknown option is assumed to be a TikZ option and will be forwarded to the associated TikZ drawing commands. For example, the ‘font=\Large’ above will be used as argument to the legend matrix, and the ‘font=\Large’ argument in
\pgfplotsset{every axis label/.append style={
ylabel=Error,xlabel=Dof,font=\Large}}
will be used in the nodes for axis labels (but not the axis title, for example).
It is an error if you assign incompatible options to axis labels, for example ‘xmin’ and ‘xmax’ can’t be set inside of ‘every axis label’.
0 0.5 1 1.5 2 0
1 2
3 % Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}
\addplot+[smooth] coordinates {(0,0) (1,2) (2,3)};
\end{axis}
\end{tikzpicture}
4.4.3 Constant Plots
Constant plots draw lines parallel to the x-axis to connect coordinates. The discontinuous edges may be drawn or not, and marks may be placed on left or right ends.
/tikz/const plot (no value)
\addplot+[const plot]
Connects all points with horizontal and vertical lines. Marks are placed left-handed on horizontal line segments, causing the plot to be right-sided continuous at all data points.
0 0.2 0.4 0.6 0.8 1
0.2 0.4 0.6
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}
\addplot+[const plot]
coordinates
{(0,0.1) (0.1,0.15) (0.2,0.5) (0.3,0.62) (0.4,0.56) (0.5,0.58) (0.6,0.65) (0.7,0.6) (0.8,0.58) (0.9,0.55) (1,0.52)};
\end{axis}
\end{tikzpicture}
0 0.2 0.4 0.6 0.8 1
0 0.2 0.4 0.6 0.8
1 % Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[ymin=0,ymax=1,enlargelimits=false]
\addplot
[const plot,fill=blue,draw=black]
coordinates
{(0,0.1) (0.1,0.15) (0.2,0.5) (0.3,0.62) (0.4,0.56) (0.5,0.58) (0.6,0.65) (0.7,0.6) (0.8,0.58) (0.9,0.55) (1,0.52)}
\closedcycle;
\end{axis}
\end{tikzpicture}
/tikz/const plot mark left (no value)
\addplot+[const plot mark left]
An alias for ‘const plot’.
/tikz/const plot mark right (no value)
\addplot+[const plot mark right]
A variant which places marks on the right of each line segment, causing plots to be left-sided continuous at the given coordinates.
0 0.2 0.4 0.6 0.8 1
0.2 0.4 0.6
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}
\addplot+[const plot mark right]
coordinates
{(0,0.1) (0.1,0.15) (0.2,0.5) (0.3,0.62) (0.4,0.56) (0.5,0.58) (0.6,0.65) (0.7,0.6) (0.8,0.58) (0.9,0.55) (1,0.52)};
\end{axis}
\end{tikzpicture}
/tikz/jump mark left (no value)
\addplot+[jump mark left]
A variant of ‘const plot mark left’ which does not draw vertical lines.
−4 −2 0
−50 0 50
100 % Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[samples=8]
\addplot+[jump mark left,domain=-5:0]
{4*x^2 - 5};
\addplot+[jump mark right,domain=-5:0]
{0.7*x^3 + 50};
\end{axis}
\end{tikzpicture}
/tikz/jump mark right (no value)
\addplot+[jump mark right]
A variant of ‘const plot mark right’ which does not draw vertical lines.
4.4.4 Bar Plots
Bar plots place horizontal or vertical bars at coordinates. Multiple bar plots in one axis can be stacked on top of each other or aligned next to each other.
/tikz/xbar (no value)
\addplot+[xbar]
Places horizontal bars between the (y= 0) line and each coordinate.
This option is used on a per-plot basis and configures only the visualization of coordinates. The figure- wide style/pgfplots/xbaralso sets reasonable options for ticks, legends and multiple plots.
2 4 6 0
2 4
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}
\addplot+[xbar] coordinates {(4,0) (1,1) (2,2)
(5,3) (6,4) (1,5)};
\end{axis}
\end{tikzpicture}
Bars are centered at plot coordinates with widthbar width. Using bar plots usually means more than just a different way of how to connect coordinates, for example to draw ticks outside of the axis, change the legend’s appearance or introduce shifts if multiple\addplotcommands appear.
There is a preconfigured style forxbarwhich is installed automatically if you providexbaras argument to the axis environment which provides this functionality.
0 10 20 30
10 20
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[xbar,enlargelimits=0.15]
\addplot
[draw=blue,pattern=horizontal lines light blue]
coordinates
{(10,5) (15,10) (5,15) (24,20) (30,25)};
\addplot
[draw=black,pattern=horizontal lines dark blue]
coordinates
{(3,5) (5,10) (15,15) (20,20) (35,25)};
\end{axis}
\end{tikzpicture}
Herexbaryields/pgfplots/xbarbecause it is an argument to the axis, not to a single plot.
For bar plots, it is quite common to provide textual coordinates or even descriptive nodes near the bars.
This can be realized using thesymbolix y coordsand nodes near coordskeys, respectively:
0 1 2 3 4 5 6 7
no yes
3
7
#participants
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
xbar, xmin=0,
width=12cm, height=3.5cm, enlarge y limits=0.5, xlabel={\#participants},
symbolic y coords={no,yes}, ytick=data,
nodes near coords, nodes near coords align={horizontal}, ]
\addplot coordinates {(3,no) (7,yes)};
\end{axis}
\end{tikzpicture}
The symbolic y coords defines a dictionary of accepted coordinates which are then expected in y coordinates and thenodes near coords key displays values as extra nodes (see their reference docu-
mentations for details). The example employsenlarge y limitsin order to get some more free space since the default spacing is not always appropriate for bar plots.
Note that it might be quite important to includexmin=0explicitly as in the example above. Without it, the lower bound will be used:
1 2 3 4 5 6 7 8 9
no yes
1
9
#participants
Uses lowestxcoords for xmin
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
title=Uses lowest $x$ coords for xmin, xbar,
width=12cm, height=3.5cm, enlarge y limits=0.5, xlabel={\#participants},
symbolic y coords={no,yes}, ytick=data,
nodes near coords, nodes near coords align={horizontal}, ]
\addplot coordinates {(1,no) (9,yes)};
\end{axis}
\end{tikzpicture}
Besides line, fill, and colorstyles, bars can be configured withbar widthandbar shift, see below.
/pgfplots/xbar={hshift for multiple plotsi} (style, default2pt) This style sets/tikz/xbarandsome commonly used options concerning horizontal bars for the complete axis. This is automatically done if you providexbaras argument to an axis argument, see above.
Thexbarstyle defines shifts if multiple plots are placed into one axis. It draws bars adjacent to each other, separated byhshift for multiple plotsi. Furthermore, it sets the style bar cycle listand sets tick and legend appearance options.
The style is defined as follows.
\pgfplotsset{
/pgfplots/xbar/.style={
/tikz/xbar, bar cycle list, tick align=outside, xbar legend, /pgf/bar shift={%
% total width = n*w + (n-1)*skip
% i.e. subtract half for centering
-0.5*(\numplotsofactualtype*\pgfplotbarwidth + (\numplotsofactualtype-1)*#1) +
% the ’0.5*w’ is for centering
(.5+\plotnumofactualtype)*\pgfplotbarwidth + \plotnumofactualtype*#1%
}, }, }
The formula forbar shiftassigns shifts dependent on the total number of plots and the current plot’s number. It is designed to fill a total width ofn·bar width+(n−1)·hshift for multiple plotsi. The 0.5 compensates for centering.
/tikz/ybar (no value)
\addplot+[ybar]
Likexbar, this option generates bar plots. It draws vertical bars between the (x = 0) line and each input coordinate.
0 1 2 3 4 1
2 3
4 % Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}
\addplot+[ybar] plot coordinates {(0,3) (1,2) (2,4) (3,1) (4,2)};
\end{axis}
\end{tikzpicture}
The example above simply changes how input coordinates shall be visualized. As mentioned forxbar, one usually needs modified legends and shifts for multiple bars in the same axis.
There is a predefined style which installs these customizations when provided to the axis environment:
1930 1940 1950 1960 1970 2
4 6
·107
Houses
Population
Far Near Here Annot
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
x tick label style={
/pgf/number format/1000 sep=}, ylabel=Population,
enlargelimits=0.15,
legend style={at={(0.5,-0.15)}, anchor=north,legend columns=-1}, ybar,
bar width=7pt, ]
\addplot
coordinates {(1930,50e6) (1940,33e6) (1950,40e6) (1960,50e6) (1970,70e6)};
\addplot
coordinates {(1930,38e6) (1940,42e6) (1950,43e6) (1960,45e6) (1970,65e6)};
\addplot
coordinates {(1930,15e6) (1940,12e6) (1950,13e6) (1960,25e6) (1970,35e6)};
\addplot[red,sharp plot,update limits=false]
coordinates {(1910,4.3e7) (1990,4.3e7)}
node[above] at (axis cs:1950,4.3e7) {Houses};
\legend{Far,Near,Here,Annot}
\end{axis}
\end{tikzpicture}
Here, ybar yields /pgfplots/ybar because it is an argument to the axis, not to a single plot. The style affects the first three\addplotcommands. Note that it shifts them horizontally around the plot coordinates. The fourth\addplotcommand is some kind of annotation which doesn’tupdate limits.
Theybar style can be combined withsymbolic x coords in a similar way as described forxbar:
tool8 tool9 tool10 0
2 4 6 8 10
7
9
4
4 4 4
1 1 1
#participants
used understood not understood
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
ybar,
enlargelimits=0.15,
legend style={at={(0.5,-0.15)}, anchor=north,legend columns=-1}, ylabel={\#participants},
symbolic x coords={tool8,tool9,tool10}, xtick=data,
nodes near coords,
nodes near coords align={vertical}, ]
\addplot coordinates {(tool8,7) (tool9,9) (tool10,4)};
\addplot coordinates {(tool8,4) (tool9,4) (tool10,4)};
\addplot coordinates {(tool8,1) (tool9,1) (tool10,1)};
\legend{used,understood,not understood}
\end{axis}
\end{tikzpicture}
As forxbar, the bar width and shift can be configured with bar widthandbar shift. However, the bar shift is better provided as argument to/pgfplots/ybarsince this style will overwrite the bar shift.
Thus, prefer/pgfplots/ybar=4pt to set the bar shift.
Sometimes it is useful to write they values directly near the bars. This can be realized using thenodes near coordsmethod:
1930 1940 1950 1960 1970 4
6
·107
5
3.3 4
5 7
3.8
4.2 4.3 4.5 6.5
Population
Far Near
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
x tick label style={
/pgf/number format/1000 sep=}, ylabel=Population,
enlargelimits=0.15,
legend style={at={(0.5,-0.15)}, anchor=north,legend columns=-1}, ybar=5pt,% configures ‘bar shift’
bar width=9pt, nodes near coords,
point meta=y *10^-7 % the displayed number ]
\addplot
coordinates {(1930,50e6) (1940,33e6) (1950,40e6) (1960,50e6) (1970,70e6)};
\addplot
coordinates {(1930,38e6) (1940,42e6) (1950,43e6) (1960,45e6) (1970,65e6)};
\legend{Far,Near}
\end{axis}
\end{tikzpicture}
Any support style changes are possible, of course. A useful example for bar plots might be to use rotated tick labels:
excellen t
good
neutral notgood poor 0
2 4 6 8
0 8
2
0 0
#participants
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
ybar,
enlargelimits=0.15,
legend style={at={(0.5,-0.2)}, anchor=north,legend columns=-1}, ylabel={\#participants},
symbolic x coords={excellent,good,neutral,%
not good,poor}, xtick=data,
nodes near coords,
nodes near coords align={vertical}, x tick label style={rotate=45,anchor=east}, ]
\addplot coordinates {(excellent,0) (good,8) (neutral,2) (not good,0) (poor,0)};
\end{axis}
\end{tikzpicture}
/pgfplots/ybar={hshift for multiple plotsi} (style, default2pt) As/pgfplots/xbar, this style sets the /tikz/ybar option to draw vertical bars, but it also provides commonly used options for vertical bars.
If you supplyybarto an axis environment,/pgfplots/ybarwill be chosen instead of /tikz/ybar.
It changes the legend, draws ticks outside of the axis lines and draws multiple \addplot arguments adjacent to each other; block–centered at thexcoordinate and separated by hshift for multiple plotsi. It will also install thebar shift forevery node near coord. Furthermore, it installs the style bar cycle list. It is defined similarly to/pgfplots/xbar.
/pgfplots/bar cycle list (no value)
A style which installs cycle lists for multiple bar plots.
\pgfplotsset{
/pgfplots/bar cycle list/.style={/pgfplots/cycle list={%
{blue,fill=blue!30!white,mark=none},%
{red,fill=red!30!white,mark=none},%
{brown!60!black,fill=brown!30!white,mark=none},%
{black,fill=gray,mark=none},%
} }, }
/pgf/bar width={hdimensioni} (initially10pt)
Configures the width used byxbarandybar. It is accepted to provide mathematical expressions.
/pgf/bar shift={hdimensioni} (initially0pt)
Configures a shift for xbar and ybar. Usebar shift together withbar width to draw multiple bar plots into the same axis. It is accepted to provide mathematical expressions.
/tikz/ybar interval (no value)
\addplot+[ybar interval]
This plot type produces vertical bars with width (and shift) relatively to intervals of coordinates.
There is one conceptional difference when working with intervals: an interval is defined bytwo coordi- nates. Sinceybar has one value for each interval, theith bar is defined by
1. they value of theith coordinates,
2. thexvalue of theith coordinate as left interval boundary, 3. thexvalue of the (i+ 1)th coordinate as right interval boundary.
Consequently, there isone coordinate too much: the last coordinate willonly be used to determine the interval width; itsy value doesn’t influence the bar appearance.
It is installed on a per-plot basis and configures only the visualization of coordinates. See the style /pgfplots/ybar intervalwhich configures the appearance of the complete figure.
0 0.2 0.4 0.6 0.8 1
1 2 3
4 % Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}
\addplot+[ybar interval] plot coordinates {(0,2) (0.1,1) (0.3,0.5) (0.35,4) (0.5,3)
(0.6,2) (0.7,1.5) (1,1.5)};
\end{axis}
\end{tikzpicture}
0–0.1 0.1–0.3 0.3–0.35 0.35–0.5 0.5–0.6 0.6–0.7 0.7–1 1
2 3 4
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[ybar interval, xtick=data,
xticklabel interval boundaries, x tick label style=
{rotate=90,anchor=east}
]
\addplot coordinates
{(0,2) (0.1,1) (0.3,0.5) (0.35,4) (0.5,3) (0.6,2) (0.7,1.5) (1,1.5)};
\end{axis}
\end{tikzpicture}
1930 1940 1950 1960 2
4 6
·107
Population
Far Near Here
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
x tick label style={
/pgf/number format/1000 sep=}, ylabel=Population,
enlargelimits=0.05,
legend style={at={(0.5,-0.15)}, anchor=north,legend columns=-1}, ybar interval=0.7,
]
\addplot
coordinates {(1930,50e6) (1940,33e6) (1950,40e6) (1960,50e6) (1970,70e6)};
\addplot
coordinates {(1930,38e6) (1940,42e6) (1950,43e6) (1960,45e6) (1970,65e6)};
\addplot
coordinates {(1930,15e6) (1940,12e6) (1950,13e6) (1960,25e6) (1970,35e6)};
\legend{Far,Near,Here}
\end{axis}
\end{tikzpicture}
/pgfplots/ybar interval={hrelative widthi} (style, default 1)
A style which is intended to install options forybar intervalfor a complete figure. This includes tick and legend appearance, management of multiple bar plots in one figure and a more adequate cycle listusing the stylebar cycle list.
/tikz/xbar interval (no value)
\addplot+[xbar interval]
Asybar interval, just for horizontal bars.
0 10 20 30 40 50
5 – 10 10 – 13 13 – 18 18 – 21 21 – 25 25 – 30 30 – 50 50 – 70
Quantity
Age
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
xmin=0,xmax=53, ylabel=Age, xlabel=Quantity, enlargelimits=false, ytick=data,
yticklabel interval boundaries, xbar interval,
]
\addplot
coordinates {(10,5) (10.5,10) (15,13) (24,18) (50,21) (23,25) (10,30) (3,50) (3,70)};
\end{axis}
\end{tikzpicture}
/pgfplots/xbar interval={hrelative widthi} (style, default 1) A style which is intended to install options for xbar interval for a complete figure, see the style /pgfplots/ybar intervalfor details.
/pgfplots/xticklabel interval boundaries (no value)
/pgfplots/yticklabel interval boundaries (no value)
/pgfplots/zticklabel interval boundaries (no value)
These are style keys which setx tick label as interval(see page224for details) and configure the tick appearance to behstarti–hendifor each tick interval.
4.4.5 Histograms
/pgfplots/hist={hoptions with hist/ prefixi}
\addplot+[hist={hoptions with hist/ prefixi}]
A histogram plot takes one-dimensional input data and counts the occurrence of values: it determines the data range [m, m] and subdivides it into N equally sized bins with (N + 1) end–points. Then, it counts the number of points falling into each bin. More precisely, it computes the N + 1 points m=:x0< x1<· · ·< xN :=musingxi:=m+i·(m−m)/N. Then, it creates theN+ 1 coordinates (xi, yi),i= 0, . . . , N−1 by means of
yi:=
(bincount [xi, xi+1)
i < N
yN−1 i=N,
i.e. the value of the last coordinate is replicated. This set of (N+1) interval boundaries is then visualized by anybar intervalplot handler.
1–4 4–7 7–10 2
4 6
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
ybar interval, xticklabel=
\pgfmathprintnumber\tick--\pgfmathprintnumber\nexttick ]
\addplot+[hist={bins=3}]
table[row sep=\\,y index=0] { data\\
1\\ 2\\ 1\\ 5\\ 4\\ 10\\
7\\ 10\\ 9\\ 8\\ 9\\ 9\\
};
\end{axis}
\end{tikzpicture}
We see thathist={bins=3}takes a table with one column as input. The data values fall into the range [1,10] which is partitioned into 3 intervals (of equal lengths). Finally, the number of points falling into each of the three bins is plotted. The xticklabel key shows the range (note that it works only in conjunction withx tick label as intervalwhich has been enabled byybar intervalbefore). We see that there are 3 elements in the range [1,4), 2 elements in the range [4,7) and finally 7 elements in the range [7,10].
The bins are half–open intervals, i.e. the end–point does not belong to the bin. Only the last bin contains its right end point.
[−4,−2)[−2,0) [0,2) [2,4) 0
1,000 2,000
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
ybar interval,
xtick=,% reset from ybar interval xticklabel=
{$[\pgfmathprintnumber\tick,%
\pgfmathprintnumber\nexttick)$}
]]
% a data file containing 8000 normally distributed
% random numbers of mean 0 and variance 1
\addplot+[hist={data=x}]
file {plotdata/pgfplots.randn.dat};
\end{axis}
\end{tikzpicture}
Thehistplot type can be combined withplot expressionas well: provide the usual hexpressionias you would for a line plot. Then, configure the value fordata=hexpressioniin dependence of x,y, orz:
[0,·) [0.1,·) [0.2,·) [0.3,·) [0.4,·) [0.5,·) [0.6,·) [0.7,·) [0.8,·) [0.9,·) 0
5 10 15 20 25
0 1
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
tiny,
height=4cm,width=12cm, ybar interval,
ymin=0, xmin=0,xmax=1, axis on top, extra x ticks={0,1}, extra x tick style={
grid=none,
x tick label as interval=false, xticklabel=$\pgfmathprintnumber\tick$
},
xticklabel={$[\pgfmathprintnumber[fixed]\tick,\cdot)$}
]
\addplot+[samples=200,hist] {rnd};
\end{axis}
\end{tikzpicture}
The example uses therndmethod of pgfwhich defines yto contain uniform random numbers in the range [0,1]. Then, it configures hist. Note thathist has the default data=y such that it uses they coordinate as input. Note furthermore that the xvalue is effectively ignored here. The options after
\begin{axis}[...] are mainly to scale the graphics and to insert the right limits. Theextra x ticks method is inserted to demonstrate how to add further tick marks without affecting the overall layout.
Note that theextra x tick stylesetsx tick label as interval=falseto disable the special tick handling which is active for the rest of the plot.
The following keys configure hist. If they are provided inside of hoptionsi, the common key prefix hist/can be omitted.
/pgfplots/hist/data={hexpressioni} (initiallyy)
Tells hist how to get its data. The common idea is to provide a mathematical hexpressioni which depends on data supplied by the \addplot statement. For example, if you have\addplot expression, the hexpressionimay depend upon x, y or z. In case of an \addplot tableinput routine, thehexpressionican employ\thisrow{hcolnamei}to access the currently active table row in the designated column.
It is also possible to avoid invocations of the math parser. Usehist/data value={hvaluei}instead to do so. Here,hvalueishould be of a numeric constant.
The initial configuration employs what would usually become the finalycoordinate as input (to be more precise, the initial value is data value=\pgfkeysvalueof{/data point/y}).
/pgfplots/hist/data min={hmin valuei} (initially/pgfplots/xmin) /pgfplots/hist/data max={hmax valuei} (initially/pgfplots/xmax)
Allows to provide the min/max values (themandm) values manually.
If empty, these v (walues will be deduced from the input data range.
The resulting interval will be splitted into hist/binsintervals.
The initial configuration uses any provided data limits, i.e. the (natural) choices hist/data min=xminandhist/data max=xmax.
/pgfplots/hist/bins={hnumber of intervalsi} (initially10) Specifies the number of intervals to use.
/pgfplots/hist/intervals={htrue,falsei} (initiallytrue) If intervals=true(the initial configuration), histwill generateN+ 1 coordinates, with
m=x0< x1<· · ·< xN =m
where [m, m] is the data range. In this case, the data points for xN−1 andxN will get the same value, namely the number of elements in the last bin. This is (only) useful in conjunction with const plot orybar interval.
If intervals=false, the last data point will be omitted and exactly N coordinates will be gener- ated. In this case, the right end point is not returned explicitly.
/pgfplots/hist/cumulative={htrue,falsei} (initiallyfalse) Allows to compute a cumulative histogram.
A cumulative histogram uses the sum of all previous bins and the current one as final value.
Here is the example from above, this time withhist/cumulative:
[−4,−2)[−2,0) [0,2) [2,4) 0
2,000 4,000 6,000 8,000
% Preamble:\pgfplotsset{width=7cm,compat=1.4}
\begin{tikzpicture}
\begin{axis}[
ybar interval,
xtick=,% reset from ybar interval xticklabel=
{$[\pgfmathprintnumber\tick,
\pgfmathprintnumber\nexttick)$}
]]
% a data file containing 8000 normally distributed
% random numbers of mean 0 and variance 1
\addplot+[hist={
data=x, cumulative}]
file {plotdata/pgfplots.randn.dat};
\end{axis}
\end{tikzpicture}
/pgfplots/hist/handler (style, initiallyybar interval)
Allows to change the way the generated coordinates are visualized. The hist/handler key is a style, so use hist/handler/.style={const plot}to change it.
/pgfplots/hist/data filter/.code={h...i}
Allows to define coordinate filters, similar to the coordinate filter key x filterdescribed in Sec- tion4.21. The argument#1is the coordinate as it has been found after processinghist/data. The code is supposed to assign \pgfmathresult to contain the result. If \pgfmathresult is empty afterwards, it will be skipped. Otherwise, it is supposed to contain a number.
This filter is applied before the histogram is computed. Note that x filter and y filter are applied after the histogram is computed.
Note that predefined styles likeeach nth pointcan also be applied to hist/dataif 1. an asterisk ‘*’ is appended to the predefined style’s name and
2. the first argument to the style ishist/data.
For example, each nth point*={hist/data}{2}will skip each second input value of hist/data (try it out).
/pgfplots/hist/data coord trafo/.code={h...i} /pgfplots/hist/data coord inv trafo/.code={h...i}
These keys work in the same way as forx coord trafoandx coord inv trafo. They are applied to the hist/data value before the histogram is evaluated and after the result value is assigned, respectively.
Note thathistwill apply the hist/data coord inv trafobefore it visualizes its results. Conse- quently, it may be necessary to assign a similar transformation to x coord trafoas well.
See the documentation of x coord trafofor more information about custom transformations.
/pgfplots/hist/symbolic coords={hlisti}
A style which enables symbolic x coordsfor an axis containinghistplots: