% Copyright 2019 by Till Tantau % % This file may be distributed and/or modified % % 1. under the LaTeX Project Public License and/or % 2. under the GNU Free Documentation License. % % See the file doc/generic/pgf/licenses/LICENSE for more details. \section{Axes} \label{section-dv-axes} \subsection{Overview} When a data point is visualized, the most obvious way of creating a visual representation of its many attributes is to vary \emph{where} the data point is shown. The data visualization system uses \emph{axes} to turn data point attributes into positions on a page. The simplest -- and most common -- use of axes is to vary the horizontal position of data points according to one attribute and to vary the vertical position according to another attribute. In contrast, in a polar plot one attribute dictates the distance of the data point from the origin and another attribute describes the angle. From the data visualization engine's point of view, in both cases two \emph{axes} are involved. In addition to specifying how the value of a certain attribute is converted into a displacement on the page, an axis is also typically (but not always) visualized (``drawn'') somewhere on the page. In this case, it is also customary to add a visual representation on this axis of which attribute values correspond to which positions on the page -- something commonly known as \emph{ticks}. Similar to ticks, \emph{grid lines} also indicate positions where a certain attribute has a certain value, but instead of just indicating a single position on an axis, a grid line goes through all points that share an attribute value. In the following, in Section~\ref{section-dv-axes-main} we first have a look at how axes can be defined and configured. As you will see, a lot of powerful configurations are available, but you will rarely define and configure an axis from scratch. Rather, it is more common to use a preconfigured axis instead. Section~\ref{section-dv-axis-systems} introduces \emph{axis systems}, which are predefined bundles of axes. You can define your own axis systems, but, again, in most cases it will suffice to just use one of the many preconfigured axis systems and use a few options to configure it so that it fits your need. Section~\ref{section-dv-ticks-and-grids} explains how ticks and grid lines can be configured. Again, several layers of options allow you to configure the way ticks look and where they are placed in great detail. This section documents the standard axis systems that are always available. For polar axis systems, a special library needs to be loaded, which is documented in Section~\ref{section-dv-polar}. \subsection{Basic Configuration of Axes} \label{section-dv-axes-main} Inside the data visualization system, an \emph{axis} is roughly a ``systematic, named way of mapping an attribute to a position on a page''. For instance, the classical ``$x$-axis'' is the ``systematic way of mapping the value of the |x| attribute of data points to a horizontal position on the page''. An axis is \emph{not} its visual representation (such as the horizontal line with the ticks drawn to represent the $x$-axis), but a visual representation can be created once an axis has been defined. The transformation of an attribute value (such as the value |1000000000| for the |x| attribute) to a specific displacement of the corresponding data point on the page involves two steps: % \begin{enumerate} \item First, the range of possible values such as $[-5.6\cdot 10^{12},7.8\cdot 10^{12}]$ must be mapped to a ``reasonable'' interval such as $[0\mathrm{cm},5\mathrm{cm}]$ or $[0^\circ,180^\circ]$. \tikzname's drawing routines will only be able to cope with values from such a ``reasonable'' interval. \item Second, the values from the reasonable interval must be mapped to a transformation. \end{enumerate} % The first step is always the same for all axes, while the second requires different strategies. For this reason, the command |new axis base| is used to create a ``basic'' axis that has a ``scaling mapper'', whose job it is to map the range of values of a specific attribute to a reasonable interval, but such a basic axis does not define an actual transformation object. For this second step, additional objects such as a |linear transformer| need to be created separately. \subsubsection{Usage} To create an axis, the key |new axis base| is used first. Since this key does not create a transformation object, users typically do not use this key directly. Rather, it is used internally by other keys that create ``real'' axes. These keys are listed in Section~\ref{section-dv-reference-axis-types}. \begin{key}{/tikz/data visualization/new axis base=\meta{axis name}} This key defines a new axis for the current data visualization called \meta{name}. This has two effects: % \begin{enumerate} \item A so called \emph{scaling mapper} is created that will monitor a certain attribute, rescale it, and map it to another attribute. (This will be explained in detail in a moment.) \item The \meta{axis name} is made available as a key that can be used to configure the axis: % \begin{key}{/tikz/data visualization/\meta{axis name}=\meta{options}} This key becomes available once |new axis base=|meta{axis name} has been called. It will execute the \meta{options} with the path prefix |/tikz/data visualization/axis options|. % \begin{codeexample}[code only] [new axis base=my axis, my axis={attribute=some attribute}] \end{codeexample} \end{key} \item The \meta{axis name} becomes part of the current set of axes. This set can be accessed through the following key: % \begin{key}{/tikz/data visualization/all axes=\meta{options}} This key passes the \meta{options} to all axes inside the current scope, just as if you had written \meta{some axis name}|=|\meta{options} for each \meta{some axis name} in the current scope, including the just-created name \meta{axis name}. \end{key} \end{enumerate} % There are many \meta{options} that can be passed to a newly created axis. They are explained in the rest of this section. \end{key} Note the |new axis base| does \emph{not} cause attributes to be mapped to positions on a page. Rather, special keys like |new Cartesian axis| first use |new axis base| to create an axis and then create an internal object that performs a linear mapping of the attribute to positions along a vectors. \subsubsection{The Axis Attribute} \label{section-dv-axis-attribute} The first main job of an axis is to map the different values of some attribute to a reasonable interval. To achieve this, the following options are important (recall that these options are passed to the key whose name is the name of the axis): \begin{key}{/tikz/data visualization/axis options/attribute=\meta{attribute}} Specifies that the axis is used to transform the data points according the different values of the key |/data point/|\meta{attribute}. For instance, when we create a classical two-dimensional Cartesian coordinate system, then there are two axes called |x axis| and |y axis| that monitor the values of the attributes |/data point/x| and |/data point/y|, respectively: % \begin{codeexample}[code only] [new axis base=x axis, new axis base=y axis, x axis={attribute=x}, y axis={attribute=y}] \end{codeexample} % In another example, we also create an |x axis| and a |y axis|. However, this time, we want to plot the values of the |/data point/time| attribute on the $x$-axis and, say, the value of the |height| attribute on the $y$-axis: % \begin{codeexample}[code only] [new axis base=x axis, new axis base=y axis, x axis={attribute=time}, y axis={attribute=height}] \end{codeexample} % During the data visualization, the \meta{attribute} will be ``monitored'' during the survey phase. This means that for each data point, the current value of |/data point/|\meta{attribute} is examined and the minimum value of all of these values as well as the maximum value is recorded internally. Note that this works even when very large numbers like |100000000000| are involved. Here is a real-life example. The |scientific axes| create two axes, called |x axis| and |y axis|, respectively. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, x axis={attribute=people, length=2.5cm, ticks=few}, y axis={attribute=year}, visualize as scatter] data { year, people 1900, 100 1910, 200 1950, 200 1960, 250 2000, 150 }; \end{codeexample} % \end{key} \subsubsection{The Axis Attribute Range Interval} Once an attribute has been specified for an axis, the data visualization engine will start monitoring this value. This means that before anything actual visualization is done, a ``survey phase'' is used to determine the range of values encountered for the attribute for all data points. This range of values results in what is called the \emph{attribute range interval}. Its minimum is the smallest value encountered in the data and its maximum is the largest value. Even though the attribute range interval is computed automatically and even though you typically do not need to worry about it, there are some situations where you may wish to set or enlarge the attribute range interval: % \begin{itemize} \item You may wish to start the interval with $0$, even though the range of values contains only positive values. \item You may wish to slightly enlarge the interval so that, say, the maximum is some ``nice'' value like |100| or |60|. \end{itemize} The following keys can be used to influence the size of the attribute range interval: % \begin{key}{/tikz/data visualization/axis options/include value=\meta{list of value}} This key ``fakes'' data points for which the attribute's values are in the comma-separated \meta{list of values}. For instance, when you write |include value=0|, then the attribute range interval is guaranteed to contain |0| -- even if the actual data points are all positive or all negative. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=3cm}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=3cm}, visualize as line, x axis={include value=20}, y axis={include value=0}] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/axis options/min value=\meta{value}} This key allows you to simply set the minimum value, regardless of which values are present in the actual data. This key should be used with care: If there are data points for which the attribute's value is less than \meta{value}, they will still be depicted, but typically outside the normal visualization area. Usually, saying |include value=|\meta{value} will achieve the same as saying |min value=|\meta{value}, but with less danger of creating ill-formed visualizations. \end{key} \begin{key}{/tikz/data visualization/axis options/max value=\meta{value}} Works like |min value|. \end{key} \subsubsection{Scaling: The General Mechanism} The above key allows us specify which attribute should be ``monitored''. The next key is used to specify what should happen with the observed values. \begin{key}{/tikz/data visualization/axis options/scaling=\meta{scaling spec}} The \meta{scaling spec} must have the following form: % \begin{quote} \meta{$s_1$}| at |\meta{$t_1$}| and |\meta{$s_2$}| at |\meta{$t_2$} \end{quote} % This means that monitored values in the interval $[s_1,s_2]$ should be mapped to values the ``reasonable'' interval $[t_1,t_2]$, instead. For instance, we might write % \begin{codeexample}[code only] [y axis = {scaling = 1900 at 0cm and 2000 at 5cm}] \end{codeexample} % in order to map dates between 1900 and 2000 to the dimension interval $[0\mathrm{cm},5\mathrm{cm}]$. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, x axis={attribute=people, length=2.5cm, ticks=few}, y axis={attribute=year, scaling=1900 at 0cm and 2000 at 5cm}, visualize as scatter] data { year, people 1900, 100 1910, 200 1950, 200 1960, 250 2000, 150 }; \end{codeexample} % So much for the basic idea. Let us now have a detailed look at what happens. \medskip \textbf{Number format and the min and max keywords.} The source values $s_1$ and $s_2$ are typically just numbers like |3.14| or |10000000000|. However, as described in Section~\ref{section-dv-expressions}, you can also specify expressions like |(pi/2)|, provided that (currently) you put them in parentheses. Instead of a number, you may alternatively also use the two key words |min| and |max| for $s_1$ and/or $s_2$. In this case, |min| evaluates to the smallest value observed for the attribute in the data, symmetrically |max| evaluates to the largest values. For instance, in the above example with the |year| attribute ranging from |1900| to |2000|, the keyword |min| would stand for |1900| and |max| for |2000|. Similarly, for the |people| attribute |min| stands for |100| and |max| for |250|. Note that |min| and |max| can only be used for $s_1$ and $s_2$, not for $t_1$ and $t_2$. A typical use of the |min| and |max| keywords is to say % \begin{codeexample}[code only] scaling = min at 0cm and max at 5cm \end{codeexample} % to map the complete range of values into an interval of length of 5cm. The interval $[s_1,s_2]$ need not contain all values that the \meta{attribute} may attain. It is permissible that values are less than $s_1$ or more than $s_2$. \medskip \textbf{Linear transformation of the attribute.} As indicated earlier, the main job of an axis is to map values from a ``large'' interval $[s_1,s_2]$ to a more reasonable interval $[t_1,t_2]$. Suppose that for the current data point the value of the key |/data point/|\meta{attribute} is the number $v$. In the simplest case, the following happens: A new value $v'$ is computed so that $v' = t_1$ when $v=s_1$ and $v'=t_2$ when $v=s_2$ and $v'$ is some value in between $t_1$ and $t_2$ then $v$ is some value in between $s_1$ and $s_2$. (Formally, in this basic case $v' = t_1 + (v-s_1)\frac{t_2-t_1}{s_2-s_1}$.) Once $v'$ has been computed, it is stored in the key |/data point/|\meta{attribute}|/scaled|. Thus, the ``reasonable'' value $v'$ does not replace the value of the attribute, but it is placed in a different key. This means that both the original value and the more ``scaled'' values are available when the data point is visualized. As an example, suppose you have written % \begin{codeexample}[code only] [x axis = {attribute = x, scaling=1000 at 20 and 2000 at 30}] \end{codeexample} % Now suppose that |/data point/x| equals |1200| for a data point. Then the key |/data point/x/scaled| will be set to |22| when the data point is being visualized. \medskip \textbf{Nonlinear transformations of the attribute.} By default, the transformation of $[s_1,s_2]$ to $[t_1,t_2]$ is the linear transformation described above. However, in some case you may be interested in a different kind of transformation: For example, in a logarithmic plot, values of an attribute may range between, say, |1| and |1000| and we want an axis of length |3cm|. So, we would write % \begin{codeexample}[code only] [x axis = {attribute = x, scaling=1 at 0cm and 1000 at 3cm}] \end{codeexample} % Indeed, |1| will now be mapped to position |0cm| and |1000| will be mapped to position |3cm|. Now, the value |10| will be mapped to approximately |0.03cm| because it is (almost) at one percent between |1| and |1000|. However, in a logarithmic plot we actually want |10| to be mapped to the position |1cm| rather than |0.03cm| and we want |100| to be mapped to the position |2cm|. Such a mapping a \emph{nonlinear} mapping between the intervals. In order to achieve such a nonlinear mapping, the |function| key can be used, whose syntax is described in a moment. The effect of this key is to specify a function $f \colon \mathbb{R} \to \mathbb{R}$ like, say, the logarithm function. When such a function is specified, the mapping of $v$ to $v'$ is computed as follows: % \begin{align*} v' = t_1 + (f(s_2) - f(v))\frac{t_2 - t_1}{f(s_2)-f(s_1)}. \end{align*} The syntax of the |function| key is described next, but you typically will not call this key directly. Rather, you will use a key like |logarithmic| that installs appropriate code for the |function| key for you. % \begin{key}{/tikz/data visualization/axis options/function=\meta{code}} The \meta{code} should specify a function $f$ that is applied during the transformation of the interval $[s_1,s_2]$ to the interval $[t_1,t_2]$ in the following way: When the \meta{code} is called, the macro |\pgfvalue| will have been set to an internal representation of the to-be-transformed value~$v$. You can then call the commands of the math-micro-kernel of the data visualization system, see Section~\ref{section-dv-math-kernel}, to compute a new value. This new value must once more be stored in |\pgfvalue|. The most common use of this key is to say % \begin{codeexample}[code only] some axis={function=\pgfdvmathln{\pgfvalue}{\pgfvalue}} \end{codeexample} % This specifies that the function $f$ is the logarithm function. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, x axis={ticks={major={at={1,10,100,1000}}}, scaling=1 at 0cm and 1000 at 3cm, function=\pgfdvmathln{\pgfvalue}{\pgfvalue}}, visualize as scatter] data [format=named] { x={1,100,...,1000}, y={1,2,3} }; \end{codeexample} % Another possibility might be to use the square-root function, instead: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, x axis={ticks=few, scaling=1 at 0cm and 1000 at 3cm, function=\pgfdvmathunaryop{\pgfvalue}{sqrt}{\pgfvalue}}, visualize as scatter] data [format=named] { x={0,100,...,1000}, y={1,2,3} }; \end{codeexample} \end{key} \medskip \textbf{Default scaling.} When no scaling is specified, it may seem natural to use $[0,1]$ both as the source and the target interval. However, this would not work when the logarithm function is used as transformations: In this case the logarithm of zero would be computed, leading to an error. Indeed, for a logarithmic axis it is far more natural to use $[1,10]$ as the source interval and $[0,1]$ as the target interval. For these reasons, the default value for the |scaling| that is used when no value is specified explicitly can be set using a special key: % \begin{key}{/tikz/data visualization/axis options/scaling/default=\meta{text}} The \meta{text} is used as |scaling| whenever no other scaling is specified. This key is mainly used when a transformation function is set using |function|; normally, you will not use this key directly. \end{key} \end{key} Most of the time, you will not use neither the |scaling| nor the |function| key directly, but rather you will use one of the following predefined styles documented in the following. \subsubsection{Scaling: Logarithmic Axes} \begin{key}{/tikz/data visualization/axis options/logarithmic} When this key is used with an axis, three things happen: % \begin{enumerate} \item The transformation |function| of the axis is setup to the logarithm. \item The strategy for automatically generating ticks and grid lines is set to the |exponential strategy|, see Section~\ref{section-dv-exponential-strategy} for details. \item The default scaling is setup sensibly. \end{enumerate} % All told, to turn an axis into a logarithmic axis, you just need to add this option to the axis. % \begin{codeexample}[ width=8cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \tikz \datavisualization [scientific axes, x axis={logarithmic}, y axis={logarithmic}, visualize as line] data [format=function] { var x : interval [0.01:100]; func y = \value x * \value x; }; \end{codeexample} % Note that this will work with any axis, including, say, the degrees on a polar axis: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.polar}}] \tikz \datavisualization [new polar axes, angle axis={logarithmic, scaling=1 at 0 and 90 at 90}, radius axis={scaling=0 at 0cm and 100 at 3cm}, visualize as scatter] data [format=named] { angle={1,10,...,90}, radius={1,10,...,100} }; \end{codeexample} % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.polar}}] \tikz \datavisualization [new polar axes, angle axis={degrees}, radius axis={logarithmic, scaling=1 at 0cm and 100 at 3cm}, visualize as scatter] data [format=named] { angle={1,10,...,90}, radius={1,10,...,100} }; \end{codeexample} % \end{key} \subsubsection{Scaling: Setting the Length or Unit Length} \begin{key}{/tikz/data visualization/axis options/length=\meta{dimension}} Sets |scaling| to |min at 0cm and max at |\meta{dimension}. The effect is that the range of all values of the axis's attribute will be mapped to an interval of exact length \meta{dimension}. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, x axis={length=3cm}, y axis={length=2cm}, all axes={ticks=few}, visualize as line] data { x, y 10, 10 20, 20 15, 30 13, 20 }; \end{codeexample} % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, x axis={length=3cm}, y axis={length=4cm}, all axes={ticks=few}, visualize as line] data { x, y 10, 10 20, 20 15, 30 13, 20 }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/axis options/unit length=\meta{dimension}\opt{| per |\meta{number}| units|}} Sets |scaling| to |0 at 0cm and 1 at |\meta{dimension}. In other words, this key allows you to specify how long a single unit should be. This key is particularly useful when you wish to ensure that the same scaling is used across multiple axes or pictures. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, all axes={ticks=few, unit length=1mm}, visualize as line] data { x, y 10, 10 40, 20 15, 30 13, 20 }; \end{codeexample} % The optional |per |\meta{number}| units| allows you to apply more drastic scaling. Suppose that you want to plot a graph where one billion corresponds to one centimeter. Then the unit length would be need to be set to a hundredth of a nanometer -- much too small for \TeX\ to handle as a dimension. In this case, you can write |unit length=1cm per 1000000000 units|: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, x axis={unit length=1mm per 1000000000 units, ticks=few}, visualize as line] data { x, y 10000000000, 10 40000000000, 20 15000000000, 30 13000000000, 20 }; \end{codeexample} % \end{key} % \begin{key}{/tikz/data visualization/axis options/power unit length=\meta{dimension}} This key is used in conjunction with the |logarithmic| setting. It cases the |scaling| to be set to |1 at 0cm and 10 at |\meta{dimension}. This causes a ``power unit'', that is, one power of ten in a logarithmic plot, to get a length of \meta{dimension}. Again, this key is useful for ensuring that the same scaling is used across multiple axes or pictures. % \begin{codeexample}[width=8cm,preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [scientific axes, y axis={logarithmic, power unit length=1mm, grid}, visualize as line] data { x, y 0, 0.0000000001 1, 1 2, 100000 3, 100000000000 4, 10000000000000000000000000000000 5, 500000000 6, 5000000000000000000 }; \end{codeexample} % \end{key} \subsubsection{Axis Label} An axis can have a \emph{label}, which is a textual representation of the attribute according to which the axis varies the position of the page. You can set the attribute using the following key: \begin{key}{/tikz/data visualization/axis options/label=\opt{|\char`\{[|\meta{options}|]|}\meta{text}\opt{|\char`\}|} (default \normalfont axis's label in math mode)% } This key sets the label of an axis to \meta{text}. This text will typically be placed inside a |node| and the \meta{options} can be used to further configure the way this node is rendered. The \meta{options} will be executed with the path prefix |/tikz/data visualization/|, so you need to say |node style| to configure the styling of a node, see Section~\ref{section-dv-style}. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [ scientific axes, x axis = {label, length=2.5cm}, y axis = {label={[node style={fill=blue!20}]{$x^2$}}}, visualize as smooth line] data [format=function] { var x : interval [-3:5]; func y = \value x * \value x; }; \end{codeexample} % \end{key} Note that using the |label| key does not actually cause a node to be created, because it is somewhat unclear where the label should be placed. Instead, the |visualize label| key is used (typically internally by an axis system) to show the label at some sensible position. This key is documented in Section~\ref{section-dv-visualize-label}. \subsubsection{Reference: Axis Types} \label{section-dv-reference-axis-types} As explained earlier, when you use |new axis base| to create a new axis, a powerful scaling and attribute mapping mechanism is installed, but no mapping of values to positions on the page is performed. For this, a \emph{transformation object} must be installed. The following keys take care of this for you. Note, however, that even these keys do not cause a visual representation of the axis to be added to the visualization -- this is the job of an axis system, see Section~\ref{section-dv-axis-systems}. \begin{key}{/tikz/data visualization/new Cartesian axis=\meta{name}} This key creates a new ``Cartesian'' axis, named \meta{name}. For such an axis, the (scaled) values of the axis's attribute are transformed into a displacement on the page along a straight line. The following key is used to configure in which ``direction'' the axis points: % \begin{key}{/tikz/data visualization/axis options/unit vector=\meta{coordinate} (initially {(1pt,0pt)})} Recall that an axis takes the values of an attribute and rescales them so that they fit into a ``reasonable'' interval $[t_1,t_2]$. Suppose that $v'$ is the rescaled dimension in (\TeX) points. Then when the data point is visualized, the coordinate system will be shifted by $v'$ times the \meta{coordinate}. As an example, suppose that you have said |scaling=0 and 10pt and 50 and 20pt|. Then when the underlying attribute has the value |25|, it will be mapped to a $v'$ of $15$ (because |25| lies in the middle of |0| and |50| and |15pt| lies in the middle of |10pt| and |20pt|). This, in turn, causes the data point to be displaced by $15$ times the \meta{coordinate}. The bottom line is that the \meta{coordinate} should usually denote a point that is at distance |1pt| from the origin and that points into the direction of the axis. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \begin{tikzpicture} \draw [help lines] (0,0) grid (3,2); \datavisualization [new Cartesian axis=x axis, x axis={attribute=x}, new Cartesian axis=y axis, y axis={attribute=y}, x axis={unit vector=(0:1pt)}, y axis={unit vector=(60:1pt)}, visualize as scatter] data { x, y 0, 0 1, 0 2, 0 1, 1 2, 1 1, 1.5 2, 1.5 }; \end{tikzpicture} \end{codeexample} \end{key} \end{key} \subsection{Axis Systems} \label{section-dv-axis-systems} An \emph{axis system} is, as the name suggests, a whole family of axes that act in concert. For example, in the ``standard'' axis system there is a horizontal axis called the $x$-axis that monitors the |x| attribute (by default, you can change this easily) and a vertical axis called the $y$-axis. Furthermore, a certain number of ticks are added and labels are placed at sensible positions. \subsubsection{Usage} Using an axis system is usually pretty easy: You just specify a key like |scientific axes| and the necessary axes get initialized with sensible default values. You can then start to modify these default values, if necessary. First, you can (and should) set the attributes to which the difference axes refer. For instance, if the |time| attribute is plotted along the $x$-axis, you would write % \begin{codeexample}[code only] x axis = {attribute = time} \end{codeexample} Second, you may wish to modify the lengths of the axes. For this, you can use keys like |length| or further keys as described in the references later on. Third, you may often wish to modify how many ticks and grid lines are shown. By default, no grid lines are shown, but you can say the following in order to cause grid lines to be shown: % \begin{codeexample}[code only] all axes={grid} \end{codeexample} % Naturally, instead of |all axes| you can also specify a single axis, causing only grid lines to be shown for this axis. In order to change the number of ticks that are shown, you can say % \begin{codeexample}[code only] all axes={ticks=few} \end{codeexample} % or also |many| instead of |few| or even |none|. Far more fine-grained control over the tick placement and rendering is possible, see Section~\ref{section-dv-ticks-and-grids} for details. Fourth, consider adding units (like ``cm'' for centimeters or ``$\mathrm{m}/\mathrm{s}^2$'' for acceleration) to your ticks: % \begin{codeexample}[code only] x axis={ticks={tick unit=cm}}, y axis={ticks={tick unit=m/s^2}} \end{codeexample} Finally, consider adding labels to your axes. For this, use the label option: % \begin{codeexample}[code only] x axes={time $t$ (ms)}, y axis={distance $d$ (mm)} \end{codeexample} Here is an example that employs most of the above features: % \begin{codeexample}[width=8.5cm,preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [ scientific axes=clean, x axis={attribute=time, ticks={tick unit=ms}, label={elapsed time}}, y axis={attribute=v, ticks={tick unit=m/s}, label={speed of disc}}, all axes=grid, visualize as line] data { time, v 0, 0 1, 0.001 2, 0.002 3, 0.004 4, 0.0035 5, 0.0085 6, 0.0135 }; \end{codeexample} \subsubsection{Reference: Scientific Axis Systems} \begin{key}{/tikz/data visualization/scientific axes=\opt{\meta{options}}} This key installs a two-dimensional coordinate system based on the attributes |/data point/x| and |/data point/y|. % \begin{codeexample}[ width=7cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \begin{tikzpicture} \datavisualization [scientific axes, visualize as smooth line] data [format=function] { var x : interval [0:100]; func y = sqrt(\value x); }; \end{tikzpicture} \end{codeexample} This axis system is usually a good choice to depict ``arbitrary two dimensional data''. Because the axes are automatically scaled, you do not need to worry about how large or small the values will be. The name |scientific axes| is intended to indicate that this axis system is often used in scientific publications. You can use the \meta{options} to fine tune the axis system. The \meta{options} will be executed with the following path prefix: % \begin{codeexample}[code only] /tikz/data visualization/scientific axes \end{codeexample} % All keys with this prefix can thus be passed as \meta{options}. This axis system will always distort the relative magnitudes of the units on the two axis. If you wish the units on both axes to be equal, consider directly specifying the unit length ``by hand'': % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \begin{tikzpicture} \datavisualization [visualize as smooth line, scientific axes, all axes={unit length=1cm per 10 units, ticks={few}}] data [format=function] { var x : interval [0:100]; func y = sqrt(\value x); }; \end{tikzpicture} \end{codeexample} The |scientific axes| have the following properties: % \begin{itemize} \item The |x|-values are surveyed and the $x$-axis is then scaled and shifted so that it has the length specified by the following key. % \begin{key}{/tikz/data visualization/scientific axes/width=\meta{dimension} (initially 5cm)} \end{key} % The minimum value is at the left end of the axis and at the canvas origin. The maximum value is at the right end of the axis. \item The |y|-values are surveyed and the $y$-axis is then scaled so that is has the length specified by the following key. % \begin{key}{/tikz/data visualization/scientific axes/height=\meta{dimension}} By default, the |height| is the golden ratio times the |width|. \end{key} % The minimum value is at the bottom of the axis and at the canvas origin. The maximum value is at the top of the axis. \item Lines (forming a frame) are depicted at the minimum and maximum values of the axes in 50\% black. \end{itemize} The following keys are executed by default as options: |outer ticks| and |standard labels|. You can use the following style to overrule the defaults: \begin{stylekey}{/tikz/data visualization/every scientific axes} \end{stylekey} \end{key} The keys described in the following can be used to fine-tune the way the scientific axis system is rendered. \begin{key}{/tikz/data visualization/scientific axes/outer ticks} This causes the ticks to be drawn `` on the outside'' of the frame so that they interfere as little as possible with the data. It is the default. % \begin{codeexample}[ width=7cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \begin{tikzpicture} \datavisualization [scientific axes=outer ticks, visualize as smooth line] data [format=function] { var x : interval [-12:12]; func y = \value x*\value x*\value x; }; \end{tikzpicture} \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/scientific axes/inner ticks} This axis system works like |scientific axes|, only the ticks are on the ``inside'' of the frame. % \begin{codeexample}[ width=7cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \begin{tikzpicture} \datavisualization [scientific axes=inner ticks, visualize as smooth line] data [format=function] { var x : interval [-12:12]; func y = \value x*\value x*\value x; }; \end{tikzpicture} \end{codeexample} This axis system is also common in publications, but the ticks tend to interfere with marks if they are near to the border as can be seen in the following example: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \begin{tikzpicture} \datavisualization [scientific axes={inner ticks, width=3.2cm}, style sheet=cross marks, visualize as scatter/.list={a,b}] data [set=a] { x, y 0, 0 1, 1 0.5, 0.5 2, 1 } data [set=b] { x, y 0.05, 0 1.5, 1 0.5, 0.75 2, 0.5 }; \end{tikzpicture} \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/scientific axes/clean} The axes and the ticks are completely removed from the actual data, making this axis system especially useful for scatter plots, but also for most other scientific plots. % \begin{codeexample}[ width=7.5cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \tikz \datavisualization [ scientific axes=clean, visualize as smooth line] data [format=function] { var x : interval [-12:12]; func y = \value x*\value x*\value x; }; \end{codeexample} The distance of the axes from the actual plot is given by the padding of the axes. \end{key} For all scientific axis systems, different label placement strategies can be specified. They are discussed in the following. \begin{key}{/tikz/data visualization/scientific axes/standard labels} As the name suggests, this is the standard placement strategy. The label of the $x$-axis is placed below the center of the $x$-axis, the label of the $y$-axis is rotated by $90^\circ$ and placed left of the center of the $y$-axis. % \begin{codeexample}[ width=8cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \tikz \datavisualization [scientific axes={clean, standard labels}, visualize as smooth line, x axis={label=degree $d$, ticks={tick unit={}^\circ}}, y axis={label=$\sin d$}] data [format=function] { var x : interval [-10:10] samples 10; func y = sin(\value x); }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/scientific axes/upright labels} Works like |scientific axes standard labels|, only the label of the $y$-axis is not rotated. % \begin{codeexample}[ width=8cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \tikz \datavisualization [ scientific axes={clean, upright labels}, visualize as smooth line, x axis={label=degree $d$, ticks={tick unit={}^\circ}}, y axis={label=$\cos d$, include value=1, ticks={style={ /pgf/number format/precision=4, /pgf/number format/fixed zerofill}}}] data [format=function] { var x : interval [-10:10] samples 10; func y = cos(\value x); }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/scientific axes/end labels} Places the labels at the end of the $x$- and the $y$-axis, similar to the axis labels of a school book axis system. % \begin{codeexample}[ width=8cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \tikz \datavisualization [ scientific axes={clean, end labels}, visualize as smooth line, x axis={label=degree $d$, ticks={tick unit={}^\circ}}, y axis={label=$\tan d$}] data [format=function] { var x : interval [-80:80]; func y = tan(\value x); }; \end{codeexample} % \end{key} \subsubsection{Reference: School Book Axis Systems} \begin{key}{/tikz/data visualization/school book axes=\meta{options}} This axis system is intended to ``look like'' the coordinate systems often used in school books: The axes are drawn in such a way that they intersect to origin. Furthermore, no automatic scaling is done to ensure that the lengths of units are the same in all directions. This axis system must be used with care -- it is nearly always necessary to specify the desired unit length by hand using the option |unit length|. If the magnitudes of the units on the two axes differ, different unit lengths typically need to be specified for the different axes. Finally, if the data is ``far removed'' from the origin, this axis system will also ``look bad''. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \begin{tikzpicture} \datavisualization [school book axes, visualize as smooth line] data [format=function] { var x : interval [-1.3:1.3]; func y = \value x*\value x*\value x; }; \end{tikzpicture} \end{codeexample} The stepping of the ticks is one unit by default. Using keys like |ticks=some| may help to give better steppings. The \meta{options} are executed with the key itself as path prefix. Thus, the following subkeys are permissible options: % \begin{key}{/tikz/data visualization/school book axes/unit=\meta{value}} Sets the scaling so that 1\,cm corresponds to \meta{value} units. At the same time, the stepping of the ticks will also be set to \meta{value}. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \begin{tikzpicture} \datavisualization [school book axes={unit=10}, visualize as smooth line, clean ticks, x axis={label=$x$}, y axis={label=$f(x)$}] data [format=function] { var x : interval [-20:20]; func y = \value x*\value x/10; }; \end{tikzpicture} \end{codeexample} \end{key} \begin{key}{/tikz/data visualization/school book axes/standard labels} This key makes the label of the $x$-axis appear at the right end of this axis and it makes the label of the $y$-axis appear at the top of the $y$-axis. Currently, this is the only supported placement strategy for the school book axis system. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \begin{tikzpicture} \datavisualization [school book axes={standard labels}, visualize as smooth line, clean ticks, x axis={label=$x$}, y axis={label=$f(x)$}] data [format=function] { var x : interval [-1:1]; func y = \value x*\value x + 1; }; \end{tikzpicture} \end{codeexample} \end{key} \end{key} \subsubsection{Advanced Reference: Underlying Cartesian Axis Systems} The axis systems described in the following are typically not used directly by the user. The systems setup \emph{directions} for several axes in some sensible way, but they do not actually draw anything on these axes. For instance, the |xy Cartesian| creates two axes called |x axis| and |y axis| and makes the $x$-axis point right and the $y$-axis point up. In contrast, an axis system like |scientific axes| uses the axis system |xy Cartesian| internally and then proceeds to setup a lot of keys so that the axis lines are drawn, ticks and grid lines are drawn, and labels are placed at the correct positions. \begin{key}{/tikz/data visualization/xy Cartesian} This axis system creates two axes called |x axis| and |y axis| that point right and up, respectively. By default, one unit is mapped to one cm. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \begin{tikzpicture} \datavisualization [xy Cartesian, visualize as smooth line] data [format=function] { var x : interval [-1.25:1.25]; func y = \value x*\value x*\value x; }; \end{tikzpicture} \end{codeexample} \begin{key}{/tikz/data visualization/xy axes=\meta{options}} This key applies the \meta{options} both to the |x axis| and the |y axis|. \end{key} \end{key} \begin{key}{/tikz/data visualization/xyz Cartesian cabinet} This axis system works like |xy Cartesian|, only it \emph{additionally} creates an axis called |z axis| that points left and down. For this axis, one unit corresponds to $\frac{1}{2}\sin 45^\circ\mathrm{cm}$. This is also known as a cabinet projection. \begin{key}{/tikz/data visualization/xyz axes=\meta{options}} This key applies the \meta{options} both to the |x axis| and the |y axis|. \end{key} \end{key} \begin{key}{/tikz/data visualization/uv Cartesian} This axis system works like |xy Cartesian|, but it introduces two axes called |u axis| and |v axis| rather than the |x axis| and the |y axis|. The idea is that in addition to a ``major'' $xy$-coordinate system this is also a ``smaller'' or ``minor'' coordinate system in use for depicting, say, small vectors with respect to this second coordinate system. \begin{key}{/tikz/data visualization/uv axes=\meta{options}} Applies the \meta{options} to both the |u axis| and the |y axis|. \end{key} \end{key} \begin{key}{/tikz/data visualization/uvw Cartesian cabinet} Like |xyz Cartesian cabinet|, but for the $uvw$-system. \begin{key}{/tikz/data visualization/uvw axes=\meta{options}} Like |xyz axes|. \end{key} \end{key} \subsection{Ticks and Grids} \label{section-dv-ticks-and-grids} \subsubsection{Concepts} A \emph{tick} is a small visual indication on an axis of the value of the axis's attribute at the position where the tick is shown. A tick may be accompanied additionally by a textual representation, but it need not. A \emph{grid line} is similar to a tick, but it is not an indication on the axis, but rather a whole line that indicates all positions where the attribute has a certain value. Unlike ticks, grid lines (currently) are not accompanied by a textual representation. Just as for axes, the data visualization system decouples the specification of which ticks are present \emph{in principle} from where they are visualized. In the following, I describe how you specify which ticks and grid lines you would like to be drawn and how they should look like (their styling). The axis system of your choice will then visualize the ticks at a sensible position for the chosen system. For details on how to change where whole axis is shown along with its ticks, see Section~\ref{section-dv-visualize-ticks}. Specifying which ticks you are interested in is done as follows: First, you use |ticks| key (or, for specifying which grid lines should be present, the |grid| key). This key takes several possible options, described in detail in the following, which have different effects: % \begin{enumerate} \item Keys like |step=10| or |minor steps between steps| cause a ``semi-automatic'' computation of possible steps. Here, you explicitly specify the stepping of steps, but the first stepping and their number are computed automatically according to the range of possible values for the attribute. \item Keys like |few|, |some|, or |many| can be passed to |ticks| in order to have \tikzname\ compute good tick positions automatically. This is usually what you want to happen, which is why most axis system will implicitly say |ticks={some}|. \item Keys like |at| or |also at| provide ``absolute control'' over which ticks or grid lines are shown. For these keys, you can not only specify at what value a tick should be shown, but also its styling and also whether it is a major, minor, or subminor tick or grid line. \end{enumerate} In the following, the main keys |ticks| and |grids| are documented first. Then the different kinds of ways of specifying where ticks or grid lines should be shown are explained. \subsubsection{The Main Options: Tick and Grid} \begin{key}{/tikz/data visualization/axis options/ticks=\meta{options} (default some)} This key can be passed to an axis in order to configure which ticks are present for the axis. The possible \meta{options} include, for instance, keys like |step|, which is used to specify a stepping for the ticks, but also keys like |major| or |minor| for specifying the positions of major and minor ticks in detail. The list of possible options is described in the rest of this section. Note that the |ticks| option will only configure which ticks should be shown in principle. The actual rendering is done only when the |visualize ticks| key is used, documented in Section~\ref{section-dv-visualize-ticks}, which is typically done only internally by an axis system. The \meta{options} will be executed with the path prefix |/tikz/data visualization/|. When the |ticks| key is used multiple times for an axis, the \meta{options} accumulate. % \begin{codeexample}[width=6cm,preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [ scientific axes, visualize as line, x axis={ticks={step=24, minor steps between steps=3}, label=hours}] data { x, y 0, 0 10, 0 20, 0.5 30, 0.75 40, 0.7 50, 0.6 60, 0.5 70, 0.45 80, 0.47 }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/axis options/grid=\meta{options} (default at default ticks)} This key is similar to |ticks|, only it is used to configure where grid lines should be shown rather than ticks. In particular, the options that can be passed to the |ticks| key can also be passed to the |grid| key. Just like |ticks|, the \meta{options} only specify which grid lines should be drawn in principle; it is the job of the |visualize grid| key to actually cause any grid lines to be shown. If you do not specify any \meta{options}, the default text |at default ticks| is used. This option causes grid lines to be drawn at all positions where ticks are shown by default. Since this usually exactly what you would like to happen, most of the time you just need to |all axes=grid| to cause a grid to be shown. \end{key} \begin{key}{/tikz/data visualization/axis options/ticks and grid=\meta{options}} This key passes the \meta{options} to both the |ticks| key and also to the |grid| key. This is useful when you want to specify some special points explicitly where you wish a tick to be shown and also a grid line. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, visualize as smooth line, all axes= {grid, unit length=1.25cm}, y axis={ ticks=few }, x axis={ ticks=many, ticks and grid={ major also at={(pi/2) as $\frac{\pi}{2}$}}}] data [format=function] { var x : interval [-pi/2:3*pi] samples 50; func y = sin(\value x r); }; \end{codeexample} % \end{key} \subsubsection{Semi-Automatic Computation of Tick and Grid Line Positions} \label{section-dv-concept-tick-placement-strategies} Consider the following problem: The data visualization engine determines that in a plot the $x$-values vary between $17.4$ and $34.5$. In this case, we certainly do not want, say, ten ticks at exactly ten evenly spaced positions starting with $17.4$ and ending with $34.5$, because this would yield ticks at positions like $32.6$. Ticks should be placed at ``nice'' positions like $20$, $25$, and $30$. Determining which positions are ``nice'' is somewhat difficult. In the above example, the positions $20$, $25$, and $30$ are certainly nice, but only three ticks may be a bit few of them. Better might be the tick positions $17.5$, $20$, $22.5$, through to $32.5$. However, users might prefer even numbers over fractions like $2.5$ as the stepping. A \emph{tick placement strategy} is a method of automatically deciding which positions are \emph{good} for placing ticks. The data visualization engine comes with a number of predefined strategies, but you can also define new ones yourself. When the data visualization is requested to automatically determine ``good'' positions for the placement of ticks on an axis, it uses one of several possible \emph{basic strategies}. These strategies differ dramatically in which tick positions they will choose: For a range of values between $5$ and $1000$, a |linear steps| strategy might place ticks at positions $100$, $200$, through to $1000$, while an |exponential steps| strategy would prefer the tick positions $10$, $100$ and $1000$. The exact number and values of the tick positions chosen by either strategy can be fine-tuned using additional options like |step| or |about|. Here is an example of the different stepping chosen when one varies the tick placement strategy: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \begin{tikzpicture} \datavisualization [scientific axes, visualize as smooth line] data [format=function] { var x : interval [1:11]; func y = \value x*\value x; }; \end{tikzpicture} \qquad \begin{tikzpicture} \datavisualization [scientific axes, visualize as smooth line, y axis={exponential steps}, x axis={ticks={quarter about strategy}}, ] data [format=function] { var x : interval [1:11]; func y = \value x*\value x; }; \end{tikzpicture} \end{codeexample} Two strategies are always available: |linear steps|, which yields (semi)automatic ticks are evenly spaced positions, and |exponential steps|, which yields (semi)automatic steps at positions at exponentially increasing positions -- which is exactly what is needed for logarithmic plots. These strategies are details in Section~\ref{section-dv-strategies}. The following options are used to configure tick placement strategies like |linear steps|. Unlike the basic choice of a placement strategy, which is an axis option, the following should be passed to the option |ticks| or |grid| only. So, you would write things like |x axis={ticks={step=2}}|, but |x axis={linear steps}|. \begin{key}{/tikz/data visualization/step=\meta{value} (initially 1)} The value of this key is used to determine the spacing of the major ticks. The key is used by the |linear steps| and |exponential steps| strategies, see the explanations in Section~\ref{section-dv-strategies} for details. Basically, all ticks are placed at all multiples of \meta{value} that lie in the attribute range interval. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [ school book axes, visualize as smooth line, y axis={ticks={step=1.25}}, ] data [format=function] { var x : interval [0:3]; func y = \value x*\value x/2; }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/minor steps between steps=\meta{number} (default 9)} Specifies that between any two major steps (whose positions are specified by the |step| key), there should be \meta{number} many minor steps. Note that the default of |9| is exactly the right number so that each interval between two minor steps is exactly a tenth of the size of a major step. See also Section~\ref{section-dv-strategies} for further details. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \begin{tikzpicture} \datavisualization [school book axes, visualize as smooth line, x axis={ticks={minor steps between steps=3}}, y axis={ticks={minor steps between steps}}, ] data [format=function] { var x : interval [-1.5:1.5]; func y = \value x*\value x; }; \end{tikzpicture} \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/phase=\meta{value} (initially 0)} See Section~\ref{section-dv-strategies} for details on how the phase of steps influences the tick placement. \end{key} \subsubsection{Automatic Computation of Tick and Grid Line Positions} The |step| option gives you ``total control'' over the stepping of ticks on an axis, but you often do not know the correct stepping in advance. In this case, you may prefer to have a good value for |step| being computed for you automatically. Like the |step| key, these options are passed to the |ticks| option. So, for instance, you would write |x axis={ticks={about=4}}| to request about four ticks to be placed on the $x$-axis. \begin{key}{/tikz/data visualization/about=\meta{number}} This key asks the data visualization to place \emph{about} \meta{number} many ticks on an axis. It is not guaranteed that \emph{exactly} \meta{number} many ticks will be used, rather the actual number will be the closest number of ticks to \meta{number} so that their stepping is still ``good''. For instance, when you say |about=10|, it may happen that exactly |10|, but perhaps even |13| ticks are actually selected, provided that these numbers of ticks lead to good stepping values like |5| or |2.5| rather than numbers like |3.4| or |7|. The method that is used to determine which steppings a deemed to be ``good'' depends on the current tick placement strategy. \medskip \textbf{Linear steps.} Let us start with |linear steps|: First, the difference between the maximum value $v_{\max}$ and the minimum value $v_{\min}$ on the axis is computed; let us call it $r$ for ``range''. Then, $r$ is divided by \meta{number}, yielding a target stepping~$s$. If $s$ is a number like $1$ or $5$ or $10$, then this number could be used directly as the new value of |step|. However, $s$ will typically something strange like $0.023\,45$ or $345\,223.76$, so $s$ must be replaced by a better value like $0.02$ in the first case and perhaps $250\,000$ in the second case. In order to determine which number is to be used, $s$ is rewritten in the form $m \cdot 10^k$ with $1 \le m < 10$ and $k \in \mathbb Z$. For instance, $0.023\,45$ would be rewritten as $2.345 \cdot 10^{-2}$ and $345\,223.76$ as $3.452\,2376 \cdot 10^5$. The next step is to replace the still not-so-good number $m$ like $2.345$ or $3.452\,237$ by a ``good'' value $m'$. For this, the current value of the |about strategy| is used: % \begin{key}{/tikz/data visualization/about strategy=\meta{list}} The \meta{list} is a comma-separated sequence of pairs \meta{threshold}/\meta{value} like for instance |1.5/1.0| or |2.3/2.0|. When a good value $m'$ is sought for a given $m$, we iterate over the list and find the first pair \meta{threshold}/\meta{value} where \meta{threshold} exceeds~$m$. Then $m'$ is set to \meta{value}. For instance, if \meta{list} is |1.5/1.0,2.3/2.0,4/2.5,7/5,11/10|, which is the default, then for $m=3.141$ we would get $m'=2.5$ since $4 > 3.141$, but $2.3 \le 3.141$. For $m=6.3$ we would get $m'=5$. \end{key} % Once $m'$ has been determined, the stepping is set to $s' = m' \cdot 10^k$. % Define an axis type \tikzdatavisualizationset{ one dimensional axis/.style={ new Cartesian axis=axis, axis={ attribute=main, unit vector={(0pt,1pt)}, visualize axis={style=->}, visualize ticks={major={tick text at low},direction axis=perpendicular}, length=3cm }, new Cartesian axis=perpendicular, perpendicular={ attribute=perp, unit vector={(1pt,0pt)}, include value=0, include value=1 } } } \def\showstrategy#1{ % Show the effect for the different strategies \medskip \begin{tikzpicture} \foreach \max/\about [count=\c] in {10/5,20/5,30/5,40/5,50/5,60/5,70/5,80/5,90/5,100/5,100/3,100/10} { \begin{scope}[xshift=\c pt*30] \datavisualization [#1, one dimensional axis, axis={ ticks={about=\about}, include value=0, include value=\max } ]; \node at (0,-5mm) [anchor=mid] {\texttt{\about}}; \end{scope} } \node at (30pt,-5mm) [anchor=mid east] {\texttt{about=\ \ }}; \end{tikzpicture} } The net effect of all this is that for the default strategy the only valid stepping are the values $1$, $2$, $2.5$ and $5$ and every value obtainable by multiplying one of these values by a power of ten. The following example shows the effects of, first, setting |about=5| (corresponding to the |some| option) and then having axes where the minimum value is always |0| and where the maximum value ranges from |10| to |100| and, second, setting |about| to the values from |3| (corresponding to the |few| option) and to |10| (corresponding to the |many| option) while having the minimum at |0| and the maximum at |100|: \showstrategy{standard about strategy} \medskip \textbf{Exponential steps.} For |exponential steps| the strategy for determining a good stepping value is similar to |linear steps|, but with the following differences: % \begin{itemize} \item Naturally, since the stepping value refers to the exponent, the whole computation of a good stepping value needs to be done ``in the exponent''. Mathematically spoken, instead of considering the difference $r = v_{\max} - v_{\min}$, we consider the difference $r = \log v_{\max} - \log v_{\min}$. With this difference, we still compute $s = r / \meta{number}$ and let $s = m \cdot 10^k$ with $1 \le m < 10$. \item It makes no longer sense to use values like $2.5$ for $m'$ since this would yield a fractional exponent. Indeed, the only sensible values for $m'$ seem to be $1$, $3$, $6$, and $10$. Because of this, the |about strategy| is ignored and one of these values or a multiple of one of them by a power of ten is used. \end{itemize} The following example shows the chosen steppings for a maximum varying from $10^1$ to $10^5$ and from $10^{10}$ to $10^{50}$ as well as for $10^{100}$ for |about=3|: \medskip \begin{tikzpicture} \foreach \max [count=\c] in {1,...,5,10,20,...,50,100} { \begin{scope}[xshift=\c pt*40] \datavisualization [ one dimensional axis, axis={ logarithmic, ticks={about=3}, include value=1, include value=1e\max } ]; \end{scope} } \end{tikzpicture} \medskip \textbf{Alternative strategies.} In addition to the standard |about strategy|, there are some additional strategies that you might wish to use instead: \begin{key}{/tikz/data visualization/standard about strategy} Permissible values for $m'$ are: $1$, $2$, $2.5$, and~$5$. This strategy is the default strategy. \end{key} \begin{key}{/tikz/data visualization/euro about strategy} Permissible values for $m'$ are: $1$, $2$, and~$5$. These are the same values as for the Euro coins, hence the name. \showstrategy{euro about strategy} \end{key} \begin{key}{/tikz/data visualization/half about strategy} Permissible values for $m'$: $1$ and $5$. Use this strategy if only powers of $10$ or halves thereof seem logical. \showstrategy{half about strategy} \end{key} \begin{key}{/tikz/data visualization/decimal about strategy} The only permissible value for $m'$ is $1$. This is an even more radical version of the previous strategy. \showstrategy{decimal about strategy} \end{key} \begin{key}{/tikz/data visualization/quarter about strategy} Permissible values for $m'$ are: $1$, $2.5$, and $5$. \showstrategy{quarter about strategy} \end{key} \begin{key}{/tikz/data visualization/int about strategy} Permissible values for $m'$ are: $1$, $2$, $3$, $4$, and $5$. \showstrategy{int about strategy} \end{key} \end{key} \begin{key}{/tikz/data visualization/many} This is an abbreviation for |about=10|. \end{key} \begin{key}{/tikz/data visualization/some} This is an abbreviation for |about=5|. \end{key} \begin{key}{/tikz/data visualization/few} This is an abbreviation for |about=3|. \end{key} \begin{key}{/tikz/data visualization/none} Switches off the automatic step computation. Unless you use |step=| explicitly to set a stepping, no ticks will be (automatically) added. \end{key} \subsubsection{Manual Specification of Tick and Grid Line Positions} The automatic computation of ticks and grid lines will usually do a good job, but not always. For instance, you might wish to have ticks exactly at, say, prime numbers or at Fibonacci numbers or you might wish to have an additional tick at $\pi$. In these cases you need more direct control over the specification of tick positions. First, it is important to understand that the data visualization system differentiates between three kinds of ticks and grid lines: major, minor, and subminor. The major ticks are the most prominent ticks where, typically, a textual representation of the tick is shown; and the major grid lines are the thickest. The minor ticks are smaller, more numerous, and lie between major ticks. They are used, for instance, to indicate positions in the middle between major ticks or at all integer positions between major ticks. Finally, subminor ticks are even smaller than minor ticks and they lie between minor ticks. Four keys are used to configure the different kinds: \begin{key}{/tikz/data visualization/major=\meta{options}} The key can be passed as an option to the |ticks| key and also to the |grid| key, which in turn is passed as an option to an axis. The \meta{options} passed to |major| specify at which positions major ticks/grid lines should be shown (using the |at| option and |also at| option) and also any special styling. The different possible options are described later in this section. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [ school book axes, visualize as smooth line, x axis={ticks={major={at={1, 1.5, 2}}}}] data [format=function] { var x : interval [-1.25:2]; func y = \value x * \value x / 2; }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/minor=\meta{options}} Like |major|, only for minor ticks/grid lines. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [ school book axes, visualize as smooth line, x axis={grid={minor={at={1, 1.5, 2}}}}] data [format=function] { var x : interval [-1.25:2]; func y = \value x * \value x / 2; }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/subminor=\meta{options}} Like |major|, only for subminor ticks/grid lines. \end{key} \begin{key}{/tikz/data visualization/common=\meta{options}} This key allows you to specify \meta{options} that apply to |major|, |minor| and |subminor| alike. It does not make sense to use |common| to specify positions (since you typically do not want both a major and a minor tick at the same position), but it can be useful to configure, say, the size of all kinds of ticks: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [ school book axes, visualize as smooth line, x axis={ticks={minor steps between steps, common={low=0}}} ] data [format=function] { var x : interval [-1.25:2]; func y = \value x * \value x / 2; }; \end{codeexample} % \end{key} The following keys can now be passed to the |major|, |minor|, and |subminor| keys to specify where ticks or grid lines should be shown: \begin{key}{/tikz/data visualization/at=\meta{list}} Basically, the \meta{list} must be a list of values that is processed with the |\foreach| macro (thus, it can contain ellipses to specify ranges of value). Empty values are skipped. The effect of passing |at| to a |major|, |minor|, or |subminor| key is that ticks or grid lines on the axis will be placed exactly at the values in \meta{list}. Here is an example: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [ school book axes, visualize as smooth line, x axis={ticks={major={at={-1,0.5,(pi/2)}}}}] data [format=function] { var x : interval [-1.25:2]; func y = \value x * \value x / 2; }; \end{codeexample} When this option is used, any previously specified tick positions are overwritten by the values in \meta{list}. Automatically computed ticks are also overwritten. Thus, this option gives you complete control over where ticks should be placed. Normally, the individual values inside the \meta{list} are just numbers that are specified in the same way as an attribute value. However, such a value may also contain the keyword |as|, which allows you so specify the styling of the tick in detail. Section~\ref{section-dv-ticks-styling} details how this works. It is often a bit cumbersome that one has to write things like % \begin{codeexample}[code only] some axis = {ticks = {major = {at = {...}}}} \end{codeexample} % A slight simplification is given by the following keys, which can be passed directly to |ticks| and |grid|: % \begin{key}{/tikz/data visualization/major at=\meta{list}} A shorthand for |major={at={|\meta{list}|}}|. \end{key} % \begin{key}{/tikz/data visualization/minor at=\meta{list}} A shorthand for |major={at={|\meta{list}|}}|. \end{key} % \begin{key}{/tikz/data visualization/subminor at=\meta{list}} A shorthand for |major={at={|\meta{list}|}}|. \end{key} \end{key} \begin{key}{/tikz/data visualization/also at=\meta{list}} This key is similar to |at|, but it causes ticks or grid lines to be placed at the positions in the \meta{list} \emph{in addition} to the ticks that have already been specified either directly using |at| or indirectly using keys like |step| or |some|. The effect of multiple calls of this key accumulate. However, when |at| is used after an |also at| key, the |at| key completely resets the positions where ticks or grid lines are shown. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [ school book axes, visualize as smooth line, x axis={grid, ticks and grid={major={also at={0.5}}}}] data [format=function] { var x : interval [-1.25:2]; func y = \value x * \value x / 2; }; \end{codeexample} % As for |at|, there are some shorthands available: % \begin{key}{/tikz/data visualization/major also at=\meta{list}} A shorthand for |major={also at={|\meta{list}|}}|. \end{key} % \begin{key}{/tikz/data visualization/minor also at=\meta{list}} A shorthand for |major={also at={|\meta{list}|}}|. \end{key} % \begin{key}{/tikz/data visualization/subminor also at=\meta{list}} A shorthand for |major={also at={|\meta{list}|}}|. \end{key} \end{key} \subsubsection{Styling Ticks and Grid Lines: Introduction} \label{section-dv-ticks-styling} When a tick, a tick label, or a grid line is visualized on the page, a whole regiment of styles influences the appearance. The reason for this large number of interdependent styles is the fact that we often wish to influence only a very certain part of how a tick is rendered while leaving the other aspects untouched: Sometimes we need to modify just the font of the tick label; sometimes we wish to change the length of the tick label and the tick label position at the same time; sometimes we wish to change the color of grid line, tick, and tick label; and sometimes we wish to generally change the thickness of all ticks. Let us go over the different kinds of things that can be styled (grid lines, ticks, and tick labels) one by one and let us have a look at which styles are involved. We will start with the grid lines, since they turn out to be the most simple, but first let us have a look at the general |style| and |styling| mechanism that is used in many placed in the following: \subsubsection{Styling Ticks and Grid Lines: The Style and Node Style Keys} \label{section-dv-style} All keys of the data visualization system have the path prefix |/tikz/data visualization|. This is not only true for the main keys like |scientific axes| or |visualize as line|, but also for keys that govern how ticks are visualized. In particular, a style like |every major grid| has the path prefix |/tikz/data visualization| and all keys stored in this style are also executed with this path prefix. Normally, this does not cause any trouble since most of the keys and even styles used in a data visualization are intended to configure what is shown in the visualization. However, at some point, we may also with to specify options that no longer configure the visualization in general, but specify the appearance of a line or a node on the \tikzname\ layer. Two keys are used to ``communicate'' with the \tikzname\ layer: \begin{key}{/tikz/data visualization/style=\meta{\tikzname\ options}} This key takes options whose path prefix is |/tikz|, not |/tikz/data visualization|. These options will be \emph{appended} to a current list of such options (thus, multiple calls of this key accumulate). The resulting list of keys is not executed immediately, but it will be executed whenever the data visualization engine calls the \tikzname\ layer to draw something (this placed will be indicated in the following). % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={ticks={style=blue}, length=3cm}, y axis={grid, grid={minor steps between steps, major={style=red}}}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/styling} Executing this key will cause all ``accumulated'' \tikzname\ options from previous calls to the key |/tikz/data visualization/style| to be executed. Thus, you use |style| to set \tikzname\ options, but you use |styling| to actually apply these options. Usually, you do not call this option directly since this application is only done deep inside the data visualization engine. \end{key} Similar to |style| (and |styling|) there also exist the |node style| (and |node styling|) key that takes \tikzname\ options that apply to nodes only -- in addition to the usual |style|. \begin{key}{/tikz/data visualization/node style=\meta{\tikzname\ options}} This key works like |style|, but it has an effect only on nodes that are created during a data visualization. This includes tick labels and axis labels: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={ticks={node style=red}, length=3cm}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % Note that in the example the ticks themselves (the little thicker lines) are not red. \end{key} \begin{key}{/tikz/data visualization/node styling} Executing this key will cause all ``accumulated'' node stylings to be executed. \end{key} \subsubsection{Styling Ticks and Grid Lines: Styling Grid Lines} \label{section-dv-styling-grid-lines} When a grid line is visualized, see Section~\ref{section-dv-visualize-gridlines} for details on when this happens, the following styles are executed in the specified order. % \begin{enumerate} \item |grid layer|. \item |every grid|. \item |every major grid| or |every minor grid| or |every subminor grid|, depending on the kind of grid line. \item locally specified options for the individual grid line, see Section~\ref{section-dv-local-styles}. \item |styling|, see Section~\ref{section-dv-style}. \end{enumerate} All of these keys have the path prefix |/tikz/data visualization|. However, the options stored in the first style (|grid layer|) and also in the last (|styling|) are executed with the path prefix |/tikz| (see Section~\ref{section-dv-style}). Let us now have a look at these keys in detail: \begin{stylekey}{/tikz/data visualization/grid layer (initially on background layer)} \label{section-dv-grid-layer}% This key is used to specified the \emph{layer} on which grid lines should be drawn (layers are explained in Section~\ref{section-tikz-backgrounds}). By default, all grid lines are placed on the |background| layer and thus behind the data visualization. This is a sensible strategy since it avoids obscuring the more important data with the far less important grid lines. However, you can change this style to ``get the grid lines to the front'': % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={ length=3cm, grid, grid={minor steps between steps} }, grid layer/.style=, % none, so on top of data (bad idea) visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % When this style is executed, the keys stored in the style will be executed with the prefix |/tikz|. Normally, you should only set this style to be empty or to |on background layer|. \end{stylekey} \begin{stylekey}{/tikz/data visualization/every grid} This style provides overall configuration options for grid lines. By default, it is set to the following: % \begin{codeexample}[code only] low=min, high=max \end{codeexample} % This causes grid lines to span all possible values when they are visualized, which is usually the desired behavior (the |low| and |high| keys are explained in Section~\ref{section-dv-visualize-ticks}. You can append the |style| key to this style to configure the overall appearance of grid lines. It should be noted that settings to |style| inside |every grid| will take precedence over ones in |every major grid| and |every minor grid|. In the following example we cause all grid lines to be dashed (which is not a good idea in general since it creates a distracting background pattern). % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=3cm, grid}, every grid/.append style={style=densely dashed}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % \end{stylekey} \begin{stylekey}{/tikz/data visualization/every major grid} This style configures the appearance of major grid lines. It does so by calling the |style| key to setup appropriate \tikzname\ options for visualizing major grid lines. The default definition of this style is: % \begin{codeexample}[code only] style = {help lines, thin, black!25} \end{codeexample} % In the following example, we use thin major blue grid lines: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={ length=3cm, grid, grid={minor steps between steps} }, every major grid/.style = {style={blue, thin}}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % As can be seen, this is not exactly visually pleasing. The default settings for the grid lines should work in most situations; you may wish to increase the blackness level, however, when you experience trouble during printing or projecting graphics. \end{stylekey} \begin{stylekey}{/tikz/data visualization/every minor grid} Works like |every major grid|. The default is % \begin{codeexample}[code only] style = {help lines, black!25} \end{codeexample} % \end{stylekey} \begin{stylekey}{/tikz/data visualization/every subminor grid} Works like |every major grid|. The default is % \begin{codeexample}[code only] style = {help lines, black!10} \end{codeexample} % \end{stylekey} \subsubsection{Styling Ticks and Grid Lines: Styling Ticks and Tick Labels} \label{section-dv-styling-ticks} Styling ticks and tick labels is somewhat similar to styling grid lines. Let us start with the tick \emph{mark}, that is, the small line that represents the tick. When this mark is drawn, the following styles are applied: % \begin{enumerate} \item |every ticks|. \item |every major ticks| or |every minor ticks| or |every subminor ticks|, depending on the kind of ticks to be visualized. \item locally specified options for the individual tick, see Section~\ref{section-dv-local-styles}. \item |tick layer| \item |every odd tick| or |every even tick|, see Section~\ref{section-dv-stacking}. \item |draw| \item |styling|, see Section~\ref{section-dv-style}. \end{enumerate} For the tick label node (the node containing the textual representation of the attribute's value at the tick position), the following styles are applied: % \begin{enumerate} \item |every ticks|. \item |every major ticks| or |every minor ticks| or |every subminor ticks|, depending on the kind of ticks to be visualized. \item locally specified options for the individual tick, see Section~\ref{section-dv-local-styles}. \item |tick node layer| \item |every odd tick| or |every even tick|, see Section~\ref{section-dv-stacking}. \item |styling|, see Section~\ref{section-dv-style}. \item |node styling|, see Section~\ref{section-dv-style}. \end{enumerate} \begin{stylekey}{/tikz/data visualization/every ticks} This style allows you to configure the appearance of ticks using the |style| and |node style| key. Here is (roughly) the default definition of this style: % \begin{codeexample}[code only] node style={ font=\footnotesize, inner sep=1pt, outer sep=.1666em, rounded corners=1.5pt } \end{codeexample} % \end{stylekey} \begin{stylekey}{/tikz/data visualization/every major ticks} The default is % \begin{codeexample}[code only] style={line cap=round}, tick length=2pt \end{codeexample} % \end{stylekey} \begin{stylekey}{/tikz/data visualization/every minor ticks} The default is % \begin{codeexample}[code only] style={help lines,thin, line cap=round}, tick length=1.4pt \end{codeexample} % \end{stylekey} \begin{stylekey}{/tikz/data visualization/every subminor ticks} The default is % \begin{codeexample}[code only] style={help lines, line cap=round}, tick length=0.8pt \end{codeexample} % \end{stylekey} \begin{stylekey}{/tikz/data visualization/tick layer (initially on background layer)} Like |grid layer|, this key specifies on which layer the ticks should be placed. \end{stylekey} \begin{stylekey}{/tikz/data visualization/tick node layer (initially \normalfont empty)} Like |tick layer|, but now for the nodes. By default, tick nodes are placed on the main layer and thus on top of the data in case that the tick nodes are inside the data. \end{stylekey} \subsubsection{Styling Ticks and Grid Lines: Exceptional Ticks} You may sometimes wish to style a few ticks differently from the other ticks. For instance, in the axis system |school book axes| there should be a tick label at the |0| position only on one axis and then this label should be offset a bit. In many cases this is easy to achieve: When you add a tick ``by hand'' using the |at| or |also at| option, you can add any special options in square brackets. However, in some situations the special tick position has been computed automatically for you, for instance by the |step| key or by saying |tick=some|. In this case, adding a tick mark with the desired options using |also at| would cause the tick mark with the correct options to be shown in addition to the tick mark with the wrong options. In cases like this one, the following option may be helpful: \begin{key}{/tikz/data visualization/options at=\meta{value} |as [|\meta{options}|]|} This key causes the \meta{options} to be executed for any tick mark(s) at \meta{value} in addition to any options given already for this position: % \begin{codeexample}[ width=7cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \tikz \datavisualization [ scientific axes, visualize as smooth line, x axis={ticks={major={ options at = 3 as [no tick text], also at = (pi) as [{tick text padding=1ex}] $\pi$}}}] data [format=function] { var x : interval[0:2*pi]; func y = sin(\value x r); }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/no tick text at=\meta{value}} Shorthand for |options at=|\meta{value}| as [no tick text]|. \end{key} \subsubsection{Styling Ticks and Grid Lines: Styling and Typesetting a Value} \label{section-dv-local-styles} \label{section-dv-tick-labels} The \todosp{why 2 labels?} |at| and |also at| key allow you to provide a comma-separated \meta{list} of \meta{value}s where ticks or grid lines should be placed. In the simplest case, the \meta{value} is simply a number. However, the general syntax allows three different kinds of \meta{value}s: % \begin{enumerate} \item \meta{value} \item \meta{value} |as| |[|\meta{local options}|]| \item \meta{value} |as| \opt{|[|\meta{local options}|]|} \meta{text} \end{enumerate} In the first case, the \meta{value} is just a number that is interpreted like any other attribute value. In the second case, where the keyword |as| is present, followed by some option in square brackets, but nothing following the closing square bracket, when the tick or grid line at position \meta{value} is shown, the \meta{local options} are executed first. These can use the |style| key or the |node style| key to configure the appearance of this single tick or grid line. You can also use keys like |low| or |high| to influence how large the grid lines or the ticks are or keys like |tick text at low| to explicitly hide or show a tick label. In the third case, which is only important for |ticks| and not for |grid|, the same happens as in the second case, but the text that is shown as tick label is \meta{text} rather than the automatically generated tick label. This automatic generation of tick labels is explained in the following. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes=clean, x axis={length=2.5cm, ticks={major at={ 5, 6 as [style=red], 7 as [{style=blue, low=-1em}], 8 as [style=green] $2^3$, 10 as ten }}}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} A value like ``2'' or ``17'' could just be used as \meta{text} to be displayed in the node of a tick label. However, things are more difficult when the to-be-shown value is $0.0000000015$, because we then would typically (but not always) prefer something like $1.5 \cdot 10^{-9}$ to be shown. Also, we might wish a unit to be added like $23\mathrm{m}/\mathrm{s}$. Finally, we might wish a number like $3.141$ to be replaced by $\pi$. For these reasons, the data visualization system does not simply put the to-be-shown value in a node as plain text. Instead, the number is passed to a \emph{typesetter} whose job it is to typeset this number nicely using \TeX's typesetting capabilities. The only exception is, as indicated above, the third syntax version of the |at| and |also at| keys, where \meta{text} is placed in the tick label's node, regardless of what the typesetting would usually do. The text produced by the automatic typesetting is computed as follows: % \begin{enumerate} \item The current contents of the key |tick prefix| is put into the node. \item This is followed by a call of the key |tick typesetter| which gets the \meta{value} of the tick as its argument in scientific notation. \item This is followed by the contents of the key |tick suffix|. \end{enumerate} Let us have a look at these keys in detail: \begin{key}{/tikz/data visualization/tick prefix=\meta{text} (initially \normalfont empty)} The \meta{text} will be put in front of every typeset tick: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={ticks=few, length=2.5cm}, x axis={ticks={tick prefix=$\langle$, tick suffix=$]$}}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/tick suffix=\meta{text} (initially \normalfont empty)} Works like |tick prefix|. This key is especially useful for adding units like ``cm'' or ``$\mathrm m/\mathrm s$'' to every tick label. For this reason, there is a (near) alias that is easier to memorize: % \begin{key}{/tikz/data visualization/tick unit=\meta{roman math text}} A shorthand for |tick suffix={$\,\rm|\meta{roman math text}|$}|: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=3cm}, x axis={ticks={tick unit=s}}, y axis={ticks={tick unit=m/s^2}}, visualize as line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} \end{key} \end{key} \begin{key}{/tikz/data visualization/tick typesetter=\meta{value}} The key gets called for each number that should be typeset. The argument \meta{value} will be in scientific notation (like |1.0e1| for $10$). By default, this key applies |\pgfmathprintnumber| to its argument. This command is a powerful number printer whose configuration is documented in Section~\ref{pgfmath-numberprinting}. You are invited to code underlying this key so that a different typesetting mechanism is used. Here is a (not quite finished) example that shows how, say, numbers could be printed in terms of multiples of $\pi$: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \def\mytypesetter#1{% \pgfmathparse{#1/pi}% \pgfmathprintnumber{\pgfmathresult}$\pi$% } \tikz \datavisualization [school book axes, all axes={unit length=1.25cm}, x axis={ticks={step=(0.5*pi), tick typesetter/.code=\mytypesetter{##1}}}, y axis={include value={-1,1}}, visualize as smooth line] data [format=function] { var x : interval [0.5:7]; func y = sin(\value x r); }; \end{codeexample} % \end{key} \subsubsection{Stacked Ticks} \label{section-dv-stacking} Sometimes, the text of tick labels are so long or so numerous that the text of adjacent tick labels overlap (or have too little padding): % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=2.5cm}, visualize as smooth line] data [format=function] { var y : interval[-100:100]; func x = \value y*\value y; }; \end{codeexample} % There are two ways to address this problem: % \begin{itemize} \item One can rotate the labels on horizontal axes: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=2.5cm}, x axis={ticks={node style={rotate=90, anchor=east}}}, visualize as smooth line] data [format=function] { var y : interval[-100:100]; func x = \value y*\value y; }; \end{codeexample} % This is often a good solution, but may be hard to read. Also consider rotating labels only by $45^\circ$ or $30^\circ$. \item One can specify different shifts of the nodes for the different ticks, whereby the ticks text no longer overlap. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=2.5cm}, x axis={ticks={major at={0,4000,8000, 2000 as [node style={yshift=-1em}], 6000 as [node style={yshift=-1em}], 10000 as [node style={yshift=-1em}]}}}, visualize as smooth line] data [format=function] { var y : interval[-100:100]; func x = \value y*\value y; }; \end{codeexample} % However, specifying shifts ``by hand'' in the above way is not always an option, especially when the tick positions should be computed automatically. Instead, the |stack| option can be used, which is much easier to use and gives better results: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=2.5cm}, x axis={ticks=stack}, visualize as smooth line] data [format=function] { var y : interval[-100:100]; func x = \value y*\value y; }; \end{codeexample} % \end{itemize} The |stack| option is actually just a style that gives you access to the general even/odd mechanism for ticks with labels. Whenever a tick mark is created where a tick label is also to be drawn, two special things happen: % \begin{enumerate} \item For every odd tick mark, the |every odd tick| style is executed, for every even tick mark the |every even tick|. Here, ``odd'' and ``even'' are with respect to the order in which the ticks have been added to the list of |at| positions for each major, minor, or subminor tick list, not with respect to the order in which they will appear on the axis. Thus, when you write % \begin{codeexample}[code only] ticks={major at={1,2,3,4}, major at={0,-1,-2}, minor at={9,8,7}} \end{codeexample} % then for |1|, |3|, |0|, and |-2| as well as |9| and |7| the key |every odd tick| will be executed, while |every even tick| will be executed for positions |2|, |4|, |-1|, and also |8|. \item When a tick node label is shown at the |low| position of the tick mark, the dimension stored in the key |tick text low even padding| is added to the |low| value. Provided that this padding is not zero (which is the default), the length of the even tick marks will be increased and the tick label node will be placed at a greater distance from the axis. Similar keys exist for padding ticks with labels at high positions and also at even positions. \end{enumerate} \begin{key}{/tikz/data visualization/tick text low even padding=\meta{dimension} (initially 0pt)} When a tick label is shown at the low position of an even tick, the \meta{distance} is added to the |low| value, see also Section~\ref{section-dv-visualize-ticks}. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=2.5cm}, x axis={ticks={tick text low even padding=-1em}}, visualize as smooth line] data [format=function] { var y : interval[-100:100]; func x = \value y*\value y; }; \end{codeexample} % Note that \meta{dimension} should usually be non-positive. \end{key} The following keys work similarly: % \begin{key}{/tikz/data visualization/tick text low odd padding=\meta{dimension} (initially 0pt)} \end{key} % \begin{key}{/tikz/data visualization/tick text high even padding=\meta{dimension} (initially 0pt)} \end{key} % \begin{key}{/tikz/data visualization/tick text high odd padding=\meta{dimension} (initially 0pt)} \end{key} \begin{key}{/tikz/data visualization/tick text odd padding=\meta{dimension}} A shorthand for setting |tick text odd low padding| and |tick text odd high padding| at the same time. \end{key} \begin{key}{/tikz/data visualization/tick text even padding=\meta{dimension}} A shorthand for setting |tick text even low padding| and |tick text even high padding| at the same time. \end{key} \begin{key}{/tikz/data visualization/tick text padding=\meta{dimension}} Sets all text paddings to \meta{dimension}. \end{key} \begin{key}{/tikz/data visualization/stack=\meta{dimension} (default 1em)} Shorthand for |tick text even padding=|\meta{dimension}. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=2.5cm}, x axis={ticks={stack=1.5em}}, visualize as smooth line] data [format=function] { var y : interval[-100:100]; func x = \value y*\value y; }; \end{codeexample} % \end{key} \begin{key}{/tikz/data visualization/stack'=\meta{dimension}} Shorthand for |tick text odd padding=|\meta{dimension}. The difference to |stack| is that the set of value that are ``lowered'' is exactly exchanged with the set of value ``lowered'' by |stack|. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=2.5cm}, x axis={ticks=stack'}, visualize as smooth line] data [format=function] { var y : interval[-100:100]; func x = \value y*\value y; }; \end{codeexample} % \end{key} Note that the above keys have an effect on all tick labels of an axis, also on special ticks that you may have added using the |also at| key. When using the |stack| key, you should specify a |tick text padding| explicitly for such keys: % \begin{codeexample}[ width=7cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \tikz \datavisualization [scientific axes, x axis={ticks={stack, many, major also at= {(pi) as [{tick text padding=2.5em}] $\pi$}}}, visualize as smooth line] data [format=function] { var x : interval[0:(2*pi)]; func y = sin(\value x r); }; \end{codeexample} \subsubsection{Reference: Basic Strategies} \label{section-dv-strategies} \begin{key}{/tikz/data visualization/axis options/linear steps} This strategy places ticks at positions that are evenly spaced by the current value of |step|. In detail, the following happens: Let $a$ be the minimum value of the data values along the axis and let $b$ be the maximum. Let the current \emph{stepping} be $s$ (the stepping is set using the |step| option, see below) and let the current \emph{phasing} be $p$ (set using the |phase|) option. Then ticks are placed all positions $i\cdot s + p$ that lie in the interval $[a,b]$, where $i$ ranges over all integers. The tick positions computed in the way described above are \emph{major} step positions. In addition to these, if the key |minor steps between steps| is set to some number $n$, then $n$ many minor ticks are introduced between each two major ticks (and also before and after the last major tick, provided the values still lie in the interval $[a,b]$). Note that is $n$ is $1$, then one minor tick will be added in the middle between any two major ticks. Use a value of $9$ (not $10$) to partition the interval between two major ticks into ten equally sized minor intervals. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \begin{tikzpicture} \datavisualization [scientific axes={inner ticks, width=3cm}, x axis={ticks={step=3, minor steps between steps=2}}, y axis={ticks={step=.36}}, visualize as scatter] data { x, y 17, 30 34, 32 }; \end{tikzpicture} \end{codeexample} % \end{key} \label{section-dv-exponential-strategy} \begin{key}{/tikz/data visualization/axis options/exponential steps} This strategy produces ticks at positions that are appropriate for logarithmic plots. It is automatically selected when you use the |logarithmic| option with an axis. In detail, the following happens: As for |linear steps| let numbers $a$, $b$, $s$, and $p$ be given. Then, major ticks are placed at all positions $10^{i\cdot s+p}$ that lie in the interval $[a,b]$ for $i \in \mathbb{Z}$. The minor steps are added in the same way as for |linear steps|. In particular, they interpolate \emph{linearly} between major steps. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \begin{tikzpicture} \datavisualization [scientific axes, x axis={logarithmic, length=2cm, ticks={step=1.5}}, y axis={logarithmic, ticks={step=1, minor steps between steps=9}}, visualize as scatter] data { x, y 1, 10 1000, 1000000 }; \end{tikzpicture} \end{codeexample} % \end{key} \subsubsection{Advanced: Defining New Placement Strategies} \begin{key}{/tikz/data visualization/axis options/tick placement strategy=\meta{macro}} This key can be used to install a so-called \emph{tick placement strategy}. Whenever |visualize ticks| is used to request some ticks to be visualized, it is checked whether some automatic ticks should be created. This is the case when the following key is set: % \begin{key}{/tikz/data visualization/compute step=\meta{code}} The \meta{code} should compute a suitable value for the stepping to be used by the \meta{macro} in the tick placement strategy. For instance, the |step| key sets |compute step| to |\def\tikz@lib@dv@step{#1}|. Thus, when you say |step=5|, then the desired stepping of |5| is communicated to the \meta{macro} via the macro |\tikz@lib@dv@step|. \end{key} Provided |compute step| is set to some nonempty value, upon visualization of ticks the \meta{macro} is executed. Typically, \meta{macro} will first call the \meta{code} stored in the key |compute step|. Then, it should implement some strategy then uses the value of the computed or desired stepping to create appropriate |at| commands. To be precise, it should set the keys |major|, |minor|, and/or |subminor| with some appropriate |at| values. Inside the call of \meta{macro}, the macro |\tikzdvaxis| will have been set to the name of the axis for which default ticks need to be computed. This allows you to access the minimum and the maximum value stored in the |scaling mapper| of that axis. % \begin{codeexample}[width=7cm,preamble={\usetikzlibrary{datavisualization}}] \def\silly{ \tikzdatavisualizationset{major={at={ 2,3,5,7,11,13}}} } \begin{tikzpicture} \datavisualization [ scientific axes, visualize as scatter, x axis={tick placement strategy=\silly} ] data { x, y 0, 0 15, 15 }; \end{tikzpicture} \end{codeexample} % \end{key} \subsection{Advanced: Creating New Axis Systems} The |datavisualization| library comes with a number of predefined axis systems, like |scientific axes=clean|, but it is also possible and to define new axis systems. Doing so involves the following steps: % \begin{enumerate} \item Creating a number of axes. \item Configuring attributes of these axes like their length or default scaling. \item Creating visual representations of the axes. \item Creating visual representations of the ticks and grid lines. \end{enumerate} The first step uses |new ... axis| keys to create new axes, the last steps use |visualize ...| keys to create the visual representations of the axes. Note that the axis system has no control over the actual attribute value ranges and neither over which ticks need to be drawn. The axis system can only provide good defaults and then specify \emph{how} the ticks or labels should be drawn and \emph{where} on the page -- but not at which values. In the following, as a running example let us develop an axis system |our system| that does the following: For the $x$-axis is looks like a normal scientific axis system, but there are actually two $y$-axes: One at the left and one at the right, each using a different attribute, but both coexisting in the same picture. \subsubsection{Creating the Axes} A new axis system is created as a style key with the prefix |/tikz/data visualization|. Thus, we would write: % \begin{codeexample}[code only] \tikzset{ data visualization/our system/.style={ ... } } \end{codeexample} In our system we need three axis: The $x$-axis, the left axis and the right axis. Since all of these axes are Cartesian axes, we write the following: % \begin{codeexample}[code only] \tikzset{ data visualization/our system/.style={ new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, x axis={attribute=x}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, } } \end{codeexample} % As can be seen, we also configure things so that the $x$-axis will use the |x| attribute by default (users can later change this by saying |x axis={attribute=|\meta{some other attribute}|}|), but we do not configure the attributes of the |left axis| nor the |right axis|. We also make the left and right axis point upward (the |x axis| needs no configuration here since a Cartesian axis points right by default). The reason is the |left| would not be a particularly good attribute name and this way we ensure that users have to pick names themselves (hopefully good ones). The next step is to define a standard scaling for the axes. Here, we can use the same as for |scientific axes|, so we would add the following keys to the definition of |our system|: % \begin{codeexample}[code only] x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}} \end{codeexample} We now already have enough to try our system, although we will not yet see any axes or ticks, but we will see the correct scaling of the attributes. Let us first define a data group: % \begin{codeexample}[setup code] \tikz \datavisualization data group {people and money} = { data [set=people 1] { time, people 1900, 1000000000 1920, 1500000000 1930, 2000000000 1980, 3000000000 } data [set=people 2] { time, people 1900, 2000000000 1920, 2500000000 1940, 4000000000 2000, 5700000000 } data [set=money 1] { time, money 1910, 1.1 1920, 2 1930, 5 1980, 2 } data [set=money 2] { time, money 1950, 3 1960, 3 1970, 4 1990, 3.5 } }; \end{codeexample} \begin{codeexample}[setup code,hidden] \tikzdatavisualizationset{ our system/.style={ new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, x axis={attribute=x}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}} } } \end{codeexample} % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [ our system, x axis={attribute=time, length=4cm}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}, people 1={style={visualizer color=blue}}, people 2={style={visualizer color=blue!50}}, money 1={style={visualizer color=red}}, money 2={style={visualizer color=red!50}}] data group {people and money}; \end{codeexample} \subsubsection{Visualizing the Axes} \label{section-dv-visualize-axis} We must now show the axes themselves. For this we can use the |visualize axis| key: \begin{key}{/tikz/data visualization/axis options/visualize axis=\meta{options}} This key is passed to an axis as an option. It causes a visual representation of the axis to be created during the data visualization. The \meta{options} are used to determine where the axis should be drawn and how long it should be. We can specify, for instance, that an axis should be drawn at the minimum value of another axis or where another axis has the value |0|. \medskip \textbf{The goto, high, and low Keys.} In our example, the |left axis| should be shown at the left hand side. This is the position where the |x axis| has its minimum value. To specify this, we would use the following code: % \begin{codeexample}[code only] left axis={ visualize axis={ x axis={ goto=min } } \end{codeexample} % As can be seen, we can pass another axis as an \meta{option} to |visualize axis|, where we pass the following key to the axis in turn: % \begin{key}{/tikz/data visualization/axis options/goto=\meta{value}} The key can be passed to an axis. It will set the attribute monitored by the axis to the given \meta{value}, which is usually some number. However, \meta{value} may also be one of the following, which causes a special behavior: % \begin{itemize} \item |min|: The attribute is set to the minimal value that the attribute has attained along this axis. \item |max|: Like |min|. \item |padded min|: This will also set the \meta{attribute} monitored by the axis to the same value as |min|. Additionally, however, the subkey |/data point/|\meta{attribute}|/offset| is set to the current padding for the minimum, see the description of |padding min| later on. The effect of this is that the actual point ``meant'' by the attribute is offset by this padding along the attribute's axis. \item |padded max|: Like |padded min|. \end{itemize} \end{key} The |right axis| would be visualized the same way, only at |goto=max|. The $x$-axis actually needs to be visualized \emph{twice}: Once at the bottom and once at the top. Thus, we need to call |visualize axis| twice for this axis: % \tikzdatavisualizationset{ our system/.style={ new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, x axis={attribute=x}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}} } } \begin{codeexample}[ preamble={\usetikzlibrary{datavisualization}}, pre={\tikzdatavisualizationset{ our system/.style={ new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, x axis={attribute=x}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}} } }}] \tikzset{ data visualization/our system/.append style={ left axis= {visualize axis={x axis= {goto=min}}}, right axis={visualize axis={x axis= {goto=max}}}, x axis= {visualize axis={left axis={goto=min}}, visualize axis={left axis={goto=max}}}, } } \tikz \datavisualization [ our system, x axis={attribute=time, length=4cm}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} There is another key that is similar to |goto|, but has a slightly different semantics: % \begin{key}{/tikz/data visualization/axis options/goto pos=\meta{fraction}} The key works like |goto|, only the \meta{fraction} is not interpreted as a value but as a fraction of the way between the minimum and the maximum value for this axis. Suppose that for an axis the attribute range interval is $[500,1000]$ and the reasonable interval is $[1,3]$. Then for a \meta{fraction} of |0|, the mapping process would choose value $1$ from the reasonable interval, for a \meta{fraction} of |1| the position $3$ from the reasonable interval, and for a \meta{fraction} or |0.25| the position $1.5$ since it is one quarter at the distance from $1$ to $3$. Note that neither the attribute range interval nor the transformation function for the attribute are important for the |goto pos| option -- the \meta{fraction} is computed with respect to the reasonable interval. Also note that the values of the actual attribute corresponding to the fractional positions in the reasonable interval are not computed. % \begin{codeexample}[ preamble={\usetikzlibrary{datavisualization}}, pre={\tikzdatavisualizationset{ our system/.style={ new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, x axis={attribute=x}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}} } }}] \tikzset{ data visualization/our system/.append style={ x axis= {visualize axis={left axis={goto pos=0.25}}, visualize axis={left axis={goto pos=0.5}}}, } } \tikz \datavisualization [ our system, x axis={attribute=time, length=4cm}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} \end{key} By default, when an axis is visualized, it spans the set of all possible values for the monitored attribute, that is, from |min| to |max|. However, there are actually two keys that allow you to adjust this: % \begin{key}{/tikz/data visualization/low=\meta{value}} This is the attribute value where the axis visualization starts. The same special values as for |goto| are permissible (like |min| or |padded min|, but also |0| or |1|). \end{key} % \begin{key}{/tikz/data visualization/high=\meta{value}} Like |low|, only for where the axis ends. \end{key} By default, |low=min| and |high=max| are set for an axis visualization. Another sensible setting is |low=padded min| and |high=padded max|. The following key provides a shorthand for this: % \begin{key}{/tikz/data visualization/padded} Shorthand for |low=padded min, high=padded max|. \end{key} % As an example, consider the |scientific axes=clean|. Here, each axis is actually drawn three times: Once at the minimum, once at the maximum and then once more at the padded minimum. \medskip \textbf{The axis line.} When an axis is drawn, \tikzname\ does not simply draw a straight line from the |low| position to the |high| position. In reality, the data visualization system uses the two commands |\pgfpathdvmoveto| and |\pgfpathdvlineto| internally. These will replace the straight line by a curve in certain situations. For instance, in a polar coordinate system, if an axis should be drawn along an angle axis for a fixed radius, an arc will be used instead of a straight line. \medskip \textbf{Styling the axis.} As can be seen, we now get the axis we want (but without the ticks, visualizing them will be explained later). The axis is, however, simply a black line. We can \emph{style} the axis in a manner similar to styling ticks and grid lines, see Section~\ref{section-dv-style}. In detail, the following styles get executed: % \begin{enumerate} \item |axis layer| \item |every axis| \item |styling| \end{enumerate} % Additionally, even before |every axis| is executed, |low=min| and |high=max| are executed. \begin{stylekey}{/tikz/data visualization/axis layer (initially on background layer)} The layer on which the axis is drawn. See the description of |grid layer| on page~\pageref{section-dv-grid-layer} for details. \end{stylekey} \begin{stylekey}{/tikz/data visualization/every axis} Put styling of the axis here. It is usually a good idea to set this style to |style={black!50}|. \end{stylekey} Recall that the |styling| key is set using the |style| key, see Section~\ref{section-dv-style}. % % TODOsp: codeexamples: What is this empty `\tikzset` good for? \tikzset{ } \begin{codeexample}[ preamble={\usetikzlibrary{datavisualization}}, pre={\tikzdatavisualizationset{ our system/.style={ new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, x axis={attribute=x}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}} } }}] \tikzset{ data visualization/our system/.append style={ every axis/.style={style=black!50}, % make this the default left axis= {visualize axis={x axis= {goto=min}, style=red!75}}, right axis={visualize axis={x axis= {goto=max}, style=blue!75}}, x axis= {visualize axis={left axis={goto=min}}, visualize axis={left axis={goto=max}}}, } } \tikz \datavisualization [ our system, x axis={attribute=time, length=4cm}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} \tikzset{ data visualization/our system/.append style={ every axis/.style={style=black!50}, % make this the default left axis= {visualize axis={x axis= {goto=min}, style=red!75}}, right axis={visualize axis={x axis= {goto=max}, style=blue!75}}, x axis= {visualize axis={left axis={goto=min}}, visualize axis={left axis={goto=max}}}, } } \medskip \textbf{Padding the Axis.} When an axis is visualized, it is often a good idea to make it ``a little bit longer'' or to ``remove it a bit from the border'', because the visualization of an axis should not interfere with the actual data. For this reason, a \emph{padding} can be specified for axes: \begin{key}{/tikz/data visualization/axis options/padding min=\meta{dimension}} This is the dimension that is used whenever |goto=padded min| is used. The \meta{dimension} is then put into the |offset| subkey of the attribute monitored by the axis. When a data point is transformed by a linear transformer and when this subkey is nonzero, this offset is added. (For an angle axis of a polar transformer, the \meta{dimension} is interpreted as an additional angle rather than as an additional distance). Note that \meta{dimension} should typically be negative since ``adding the \meta{dimension}'' will then make the axis longer (because it starts at a smaller value). The standard axis systems set the padding to some default and take its value into account: % \begin{codeexample}[ width=8cm, preamble={\usetikzlibrary{datavisualization.formats.functions}}, ] \begin{tikzpicture} \datavisualization [scientific axes=clean, x axis={padding min=-1cm}, visualize as smooth line] data [format=function] { var x : interval [-3:5]; func y = \value x * \value x; }; \end{tikzpicture} \end{codeexample} Using padded and using the |padded| key, we can visualize our axis ``a little removed from the actual data'': % \begin{codeexample}[ preamble={\usetikzlibrary{datavisualization}}, pre={\tikzdatavisualizationset{ our system/.style={ new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, x axis={attribute=x}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}} } }% \tikzset{ data visualization/our system/.append style={ every axis/.style={style=black!50}, % make this the default left axis= {visualize axis={x axis= {goto=min}, style=red!75}}, right axis={visualize axis={x axis= {goto=max}, style=blue!75}}, x axis= {visualize axis={left axis={goto=min}}, visualize axis={left axis={goto=max}}}, } }}] \tikzset{ data visualization/our system/.append style={ all axes= {padding=.5em}, left axis= {visualize axis={x axis= {goto=padded min}, padded}}, right axis={visualize axis={x axis= {goto=padded max}, padded}}, x axis= {visualize axis={left axis={goto=padded min}, padded}, visualize axis={left axis={goto=padded max}, padded}}, } } \tikz \datavisualization [ our system, x axis={attribute=time, length=3cm}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} \end{key} \begin{key}{/tikz/data visualization/axis options/padding max=\meta{dimension}} Works like |padding min|, but \meta{dimension} should typically be positive. \end{key} \begin{key}{/tikz/data visualization/axis options/padding=\meta{dimension}} Sets both |padding min| to the negated value of \meta{dimension} and |padding max| to \meta{dimension}. \end{key} \end{key} \subsubsection{Visualizing Grid Lines} \label{section-dv-visualize-gridlines} As explained earlier, the |grid| key is used to specify at which positions grid lines should be drawn in principle. However, this key does not actually cause any grid lines to be drawn. Instead, the |visualize grid| key is used by the axis system to specify how grid lines are drawn. \begin{key}{/tikz/data visualization/axis options/visualize grid=\meta{options}} This key is passed to an axis. It causes grid lines to be drawn at the positions specified by the |grid| key for this axis. The \meta{options} govern where and how the grid lines will be drawn. \medskip \textbf{The direction axis.} At first sight, one might expect that the grid lines for an axis should simply be drawn perpendicular to the axis between the minimum and maximum value of the axis. However, things are somewhat more difficult in reality: % \begin{enumerate} \item A grid line is supposed to indicate all positions where a certain attribute attains a fixed value. But, then, a grid line does not really need to be a grid \emph{line}. Consider for instance a three dimensional axis system. A ``grid line'' for the $x$-coordinate |3| would actually be a ``grid plane''. \item For a polar coordinate system and a fixed radius, this set of positions at a certain radius is not a straight line, but an arc. For more complicated coordinate systems such as the one arising from three-dimensional spherical projections, a grid line may well be a fairly involved curve. \end{enumerate} % The |visualize grid| command addresses these complications as follows: % \begin{enumerate} \item A grid line is always a line, not a plane or a volume. This means that in the example of a three dimensional axis system and the $x$-attribute being |3|, one would have to choose whether the grid line should go ``along'' the $y$-axis or ``along'' the $z$-axis for this position. One can, however, call the |visualize grid| command twice, once for each direction, to cause grid lines to be shown for both directions. \item A grid line is created by moving to a start position and then doing a lineto to the target position. However, the ``moveto'' and ``lineto'' are done by calling special commands of the data visualization system. These special commands allow coordinate system to ``notice'' that the line is along an axis and will allow them to replace the straight line by an appropriate curve. The polar axes systems employ this strategy, for instance. \end{enumerate} By the above discussion, in order to create a grid line for attribute $a$ having value $v$, we need to specify an axis ``along'' which the line should be drawn. When there are only two axes, this is usually ``the other axis''. This ``other axis'' is specified using the following key: % \begin{key}{/tikz/data visualization/direction axis=\meta{axis name}} You must pass this key as an \meta{option} each time you use |visualize axis|. When the grid line is drawn, the attribute $a$ is set to $v$ and the axis \meta{axis name}'s attribute is set once to the current value of |low| and once to |high|. Then a line is drawn between these two positions using |\pgfpathdvlineto|. \end{key} % The |low| and |high| keys are the same as the ones used in the |visualize axis| key. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [ xyz Cartesian cabinet, all axes={visualize axis={low=0, style=->}}, x axis={visualize grid={direction axis=y axis}, grid=many}, visualize as scatter] data { x, y, z 0, 0, 1 0, 1, 0 2, 2, 2 }; \end{codeexample} % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [ xyz Cartesian cabinet, all axes={visualize axis={low=0, style=->}, grid=many}, x axis={visualize grid={direction axis=z axis}}, z axis={visualize grid={direction axis=x axis}, visualize grid={direction axis=y axis},}, visualize as scatter] data { x, y, z 0, 0, 1 0, 1, 0 2, 2, 2 }; \end{codeexample} \medskip \textbf{Styling the grid lines.} When a grid line is draw, styles are applied as described in Section~\ref{section-dv-styling-grid-lines}. \medskip \textbf{The major, minor, and subminor grid lines.} The |grid| option allows you to specify for each kind of grid line (major, minor, or subminor) a set of different values for which these grid lines should be drawn. Correspondingly, it is also possible to configure for each kind of grid line how it should be drawn. For this, the |major|, |minor|, |subminor|, and also the |common| keys can be used inside the \meta{options} of |visualize grid|. While as option to |grid| these keys are used to specify |at| values, as options of |visualize grid| they are used to configure the different kinds of grid lines. Most of the time, no special configuration is necessary since all styling is best done by configuring keys like |every major grid|. You need to use a key like |major| only if you wish to configure for instance the |low| or |high| values of a |major| grid line differently from those of |minor| grid lines -- are rather unlikely setting -- or when the styling should deviate from the usual settings. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikz \datavisualization [ xy Cartesian, all axes={visualize axis={low=0, style=->}, grid={some, minor steps between steps}}, x axis= {visualize grid={ direction axis=y axis, minor={low=0.25, high=1.75, style=red!50}}}, visualize as scatter] data { x, y 0, 0 3, 3 }; \end{codeexample} % \end{key} Returning to the example of |our system| with the two axis systems, it is straight-forward to configure the grid lines of the $x$-axis: The direction axis is either of the other two axis (they point in the same direction and they have the same range). For the other two axes, we visualize one grid independently of the other, using different colors. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikzset{ data visualization/our system/.append style={ x axis= {visualize grid={direction axis=left axis}}, left axis= {visualize grid={direction axis=x axis, common={style=red!50}}}, right axis={visualize grid={direction axis=x axis, common={style=blue!50}}}, } } \tikz \datavisualization [ our system, x axis={attribute=time, length=3cm, grid=many}, left axis ={attribute=money, grid=some}, right axis={attribute=people, grid=few}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} \subsubsection{Visualizing the Ticks and Tick Labels} \label{section-dv-visualize-ticks} \begin{key}{/tikz/data visualization/axis options/visualize ticks=\meta{options}} Visualizing a tick involves (possibly) drawing a tick mark and adding (possibly) the tick node. The process is similar to |visualize grid|: Users use the |ticks| key to configure how many ticks they would like for an axis and at which positions. The axis system uses the |visualize ticks| key to specify where these ticks should actually be shown. Unlike grid lines, which are typically only visualized once for each combination of an axis and a direction axis, tick marks might be visualized at different places for the same axis. Consider for instance the |scientific axes|: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=3cm}, x axis={ticks={stack}}, visualize as smooth line] data [format=function] { var x : interval [0:2]; func y = \value x*\value x; }; \end{codeexample} % Have a look at the ticks on the $y$-axis: There are ticks at values |0|, |1|, |2|, |3|, and~|4|. These are visualized both at the left side (where the tick nodes are also shown) and additionally also at the right side, but only as small marks. Similarly, the ticks on the $x$-axis appear at the bottom, but also (in much simpler versions) at the top. Both for the $x$-axis and for the $y$-axis the |visualize ticks| key was called twice. \medskip \textbf{The tick marks.} Drawing a tick mark is quite similar to visualizing a grid line; indeed a tick mark can be thought of as a ``mini grid line'': Just like a grid line it ``points a long an axis''. However, a tick will always be a short straight line -- even when the coordinate system is actually twisted (experimentation has shown that ticks that follow the curvature of the coordinate system like grid lines are hard to recognize). For this reason, the |low| and |high| keys have a different meaning from the one used with the |visualize grid| key. In detail to configure the size and position of a tick mark for the value $v$ of attribute $a$, proceed as follows: % \begin{itemize} \item The |visualize ticks| key will have setup attribute $a$ to be equal to $v$. \item You should now use the |goto| or |goto pos| key together with all \emph{other} axes to configure at which position with respect to these other options the tick mark should be shown. For instance, suppose we want tick marks in |our system| for the $x$-axis at the bottom and at the top. This corresponds to once setting the |left axis| to its minimal value and once to its maximal value: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikzset{ data visualization/our system/.append style={ x axis={visualize ticks={direction axis=left axis, left axis={goto=min}}, visualize ticks={direction axis=left axis, left axis={goto=max}}, } } } \tikz \datavisualization [ our system, x axis={attribute=time, length=3cm, ticks=many}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} % \item In the above example, we may wish to shorten the ticks a bit at the bottom and at the top. For this, we use the |low| and |high| key: % \begin{key}{/tikz/data visualization/low=\meta{dimension}} When used with the |visualize ticks| option, the |low| key contains a dimension that specifies the extend of the tick going ``toward the minimum'' of the direction axis. More precisely, when a tick mark is visualized, a unit tangent vector at the current data point in the direction of the |direction axis| is computed and this vector is multiplied by \meta{dimension} to compute the start position of the tick line. The end position is given by this vector times the |high| value. Note that the \meta{dimension} should usually be negative for the |low| key and positive for the |high| key. For tick marks where a tick label node is shown, the \meta{dimension} is increased by the current values of keys like |tick text even low padding|, see Section~\ref{section-dv-stacking} for details. \end{key} % \begin{key}{/tikz/data visualization/high=\meta{dimension}} Like |low|. \end{key} % \begin{key}{/tikz/data visualization/tick length=\meta{dimension}} Shorthand for |low=-|\meta{dimension}|, high=|\meta{dimension}. \end{key} What we want to happen is that in the upper visualization of the ticks the |low| value is |0pt|, while in the lower one the |high| value is |0pt|: % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikzset{ data visualization/our system/.append style={ x axis={ visualize ticks={direction axis=left axis,high=0pt,left axis={goto=min}}, visualize ticks={direction axis=left axis,low=0pt,left axis={goto=max}}, } } } \tikz \datavisualization [ our system, x axis={attribute=time, length=3cm, ticks=many}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} % \end{itemize} % In order to style the tick mark, use the styling mechanism that is detailed in Section~\ref{section-dv-styling-ticks}. \medskip \textbf{The tick label node.} At certain tick positions, we may wish to add a node indicating the value of the attribute at the given position. The |visualize ticks| command has no influence over which text should be shown at a node -- the text is specified and typeset as explained in Section~\ref{section-dv-tick-labels}. Each time |visualize ticks|, for each tick position up to two tick label nodes will be created: One at the |low| position and one at the |high| position. The following keys are used to configure which of these cases happen: % \begin{key}{/tikz/data visualization/tick text at low=\opt{\meta{true or false}} (default true)} Pass this option to |visualize ticks| when you want tick label nodes to be placed at the |low| position of each tick mark. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization}}] \tikzset{ data visualization/our system/.append style={ x axis={ visualize ticks={direction axis=left axis, left axis={goto=min}, high=0pt, tick text at low, stack}, visualize ticks={direction axis=left axis, left axis={goto=max}, low=0pt, tick text at high, stack} } } } \tikz \datavisualization [ our system, x axis={attribute=time, length=3cm, ticks=some}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} \end{key} % \begin{key}{/tikz/data visualization/tick text at high=\opt{\meta{true or false}} (default true)} Like |tick text at low|. \end{key} \begin{key}{/tikz/data visualization/no tick text} Shorthand for |tick text at low=false, tick text at high=false|. % \begin{codeexample}[preamble={\usetikzlibrary{datavisualization.formats.functions}}] \tikz \datavisualization [scientific axes, all axes={length=3cm}, x axis={ticks={ major also at={6.5 as [no tick text]}}}, visualize as smooth line] data [format=function] { var x : interval [5:10]; func y = \value x * \value x; }; \end{codeexample} \end{key} When a tick label node is to be placed at the low or the high position, the next step is to determine the exact position and the correct anchor of the node. This is done as follows: % \begin{itemize} \item In order to compute an appropriate |anchor|, the tick mark is considered: This is a short line pointing in a certain direction. For a tick label node at the |low| position, the |anchor| attribute is setup in such a way that the node label will be below the |low| position when the tick mark direction points up, it will be to the right when the direction points left, above when it points down, and so on also for diagonal directions. Similarly, for the |high| position, when the direction points up, the node will be placed above the tick mark and so on. This computation is done automatically. \item The tick label node is styled. The styles that are applied are described in Section~\ref{section-dv-styling-ticks}. \item A tick label node for the |low| position is usually anchored at this |low| position, but an additional padding will be added as described in Section~\ref{section-dv-stacking}. \end{itemize} \end{key} \subsubsection{Visualizing the Axis Labels} \label{section-dv-visualize-label} The |label| option can be used with an axis to specify a text should be shown next to the axis to indicates which attribute this axis refers to. Like |ticks| or |grid|, the |label| option does not actually draw the label, this is the job of the |visualize label| key, which is configured by the axis system. \begin{key}{/tikz/data visualization/axis options/visualize label=\meta{options}} The \meta{options} should be used to configure a ``good place'' for the axis label. Usually, you will use the |goto| or the |goto pos| key. For the example of |our system|, we would like the label of the |x axis| to be placed below at the middle of the axis, so we use |goto pos=.5| to determine this position. Concerning the other axes, we want it to be placed at the minimum position of the |left axis| with a lot of padding. % \begin{codeexample}[width=7cm,preamble={\usetikzlibrary{datavisualization}}] \tikzdatavisualizationset{ our system/.append style={ x axis={visualize label={ x axis={goto pos=.5}, left axis={padding=1.5em, goto=padded min}}} } } \tikz \datavisualization [ our system, x axis={attribute=time, ticks=some, label}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={ people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} In the above example, the |padding| of |1.5em| was rather arbitrary and ``suboptimal''. It would be outright wrong if the labels on the |x axis| were larger or if they were missing. It would be better if the vertical position of the |x axis| label were always ``below'' all other options. For such cases a slightly strange approach is useful: You position the node using |node style={at=...}| where |at| is now the normal \tikzname\ option that is used to specify the position of a node. Inside the |...|, you specify that the horizontal position should be the bottom of up-to-now-constructed data visualization and the vertical position should be at the ``origin'', which is, however, the position computed by the |goto| keys for the axes: % \begin{codeexample}[width=7cm,preamble={\usetikzlibrary{datavisualization}}] \tikzdatavisualizationset{ our system/.append style={ x axis={visualize label={ x axis={goto pos=.5}, node style={ at={(0,0 |- data visualization bounding box.south)}, below } } } } } \tikz \datavisualization [ our system, x axis={attribute=time, ticks=some, label=Year}, left axis ={attribute=money}, right axis={attribute=people}, visualize as line/.list={ people 1, people 2, money 1, money 2}] data group {people and money}; \end{codeexample} Two additional keys are useful for positioning axis labels: % \begin{key}{/tikz/data visualization/axis option/anchor at min} When passed to an axis, this key sets the |anchor| so that a node positioned at either the |min| or the |padded min| value of the axis will be placed ``nicely'' with respect to the axis. For instance, if the axis points upwards from the |min| value to the |max| value, the |anchor| would be set to |north| since this gives a label below the axis's start. Similarly, if the axis points right, the anchor would be set to |east|, and so on. \end{key} % \begin{key}{/tikz/data visualization/axis option/anchor at max} Like |anchor at min|. \end{key} \end{key} \subsubsection{The Complete Axis System} Here is the code for the complete axis system developed above and an example of how it is used: % \begin{codeexample}[code only] \tikzdatavisualizationset{ our system/.style={ % The axes new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, % The directions of the axes all axes={padding=.5em}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, % The default attributes, other attributes must be configured x axis={attribute=x}, % The lengths of the axes x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, % The styling of the axes every axis/.style={style=black!50}, % make this the default % Visualizing the axes themselves left axis= {visualize axis={x axis= {goto=padded min}, style=red!75, padded}}, right axis={visualize axis={x axis= {goto=padded max}, style=blue!75,padded}}, x axis= {visualize axis={left axis={goto=padded min}, padded}, visualize axis={left axis={goto=padded max}, padded}}, % Visualizing the grid, when requested x axis= {visualize grid={direction axis=left axis}}, left axis= {visualize grid={direction axis=x axis, common={style=red!50}}}, right axis={visualize grid={direction axis=x axis, common={style=blue!50}}}, % Visualizing the ticks, when requested left axis={visualize ticks={style={red!50!black}, direction axis=x axis, x axis={goto=padded min}, high=0pt, tick text at low}}, right axis={visualize ticks={style={blue!80!black}, direction axis=x axis, x axis={goto=padded max}, low=0pt, tick text at high}}, x axis={visualize ticks={direction axis=left axis, left axis={goto=padded min}, high=0pt, tick text at low}, visualize ticks={direction axis=left axis, left axis={goto=padded max}, low=0pt}}, % By default, there are ticks on all axes all axes={ticks}, % Visualizing the axis labels, when requested x axis={visualize label={x axis={goto pos=.5}, node style={ at={(0,0 |- data visualization bounding box.south)}, below}}}, left axis={visualize label={left axis={goto pos=.5}, node style={ at={(0,0 -| data visualization bounding box.west)}, rotate=90, anchor=south, red!50!black}}}, right axis={visualize label={right axis={goto pos=.5}, node style={ at={(0,0 -| data visualization bounding box.east)}, rotate=-90, anchor=south, blue!80!black}}}, }} \end{codeexample} \begin{codeexample}[ preamble={\usetikzlibrary{datavisualization}}, pre={\tikzdatavisualizationset{ our system/.style={ % The axes new Cartesian axis=x axis, new Cartesian axis=left axis, new Cartesian axis=right axis, % The default attributes, other attributes must be configured x axis={attribute=x}, % The directions of the axes all axes={padding=.5em}, left axis={unit vector={(0cm,1pt)}}, right axis={unit vector={(0cm,1pt)}}, % The lengths of the axes x axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/width}}, left axis ={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, right axis={length=\pgfkeysvalueof{/tikz/data visualization/scientific axes/height}}, % The styling of the axes every axis/.style={style=black!50}, % make this the default % Visualizing the axes themselves left axis= {visualize axis={x axis= {goto=padded min}, style=red!75, padded}}, right axis={visualize axis={x axis= {goto=padded max}, style=blue!75,padded}}, x axis= {visualize axis={left axis={goto=padded min}, padded}, visualize axis={left axis={goto=padded max}, padded}}, % Visualizing the grid, when requested x axis= {visualize grid={direction axis=left axis, padded}}, left axis= {visualize grid={direction axis=x axis, padded, common={style=red!50}}}, right axis={visualize grid={direction axis=x axis, padded, common={style=blue!50}}}, % Visualizing the ticks, when requested left axis={ visualize ticks={style={red!50!black}, direction axis=x axis, x axis={goto=padded min}, high=0pt, tick text at low}}, right axis={ visualize ticks={style={blue!80!black}, direction axis=x axis, x axis={goto=padded max}, low=0pt, tick text at high}}, x axis={ visualize ticks={direction axis=left axis, left axis={goto=padded min}, high=0pt, tick text at low}, visualize ticks={direction axis=left axis, left axis={goto=padded max}, low=0pt} }, % By default, there are ticks on all axes all axes={ticks}, % Visualizing the axis labels, when requested x axis={visualize label={ x axis={goto pos=.5}, node style={at={(0,0 |- data visualization bounding box.south)}, below}}}, left axis={visualize label={ left axis={goto pos=.5}, node style={ at={(0,0 -| data visualization bounding box.west)}, rotate=90, anchor=south, red!50!black}}}, right axis={visualize label={ right axis={goto pos=.5}, node style={ at={(0,0 -| data visualization bounding box.east)}, rotate=-90, anchor=south, blue!80!black}}}, } }}] \tikz \datavisualization [ our system, x axis={attribute=time, label=Year, ticks={tick text padding=2pt, style={/pgf/number format/set thousands separator=}}}, left axis={attribute=money, label=Spending, padding min=0, include value=0, grid, ticks={tick prefix=\$, style={/pgf/number format/fixed, /pgf/number format/fixed zerofill, /pgf/number format/precision=2}}}, right axis={attribute=people, label=Population, padding min=0, include value=0, ticks={style=/pgf/number format/fixed}}, visualize as line/.list={ people 1, people 2, money 1, money 2}, people 1={style={visualizer color=blue}}, people 2={style={visualizer color=blue!50}}, money 1={style={visualizer color=red}}, money 2={style={visualizer color=red!50}} ] data group {people and money}; \end{codeexample} \subsubsection{Using the New Axis System Key} The axis system |our system| that we developed in the course of the previous section is not yet ``configurable''. The only configuration that was possible was to ``misuse'' the |width| and |height| keys of the |scientific axes|. In order to make |our system| configurable so that we can say |our system=|\meta{options}, where \meta{options} are executed with the path prefix % \begin{codeexample}[code only] /tikz/data visualization/our system \end{codeexample} % we can use the following key: \begin{key}{/tikz/data visualization/new axis system=\marg{axis system name}\marg{axis setup}\marg{default options}\\ \marg{application options}% } The |new axis system| key takes four parameters. The first one, \meta{system name}, is the name of the to-be-created axis system, |our system| in our case. The |new axis system| will create the following new key: % \begin{key}{/tikz/data visualization/\meta{axis system name}=\opt{\meta{options}}} When the key \meta{axis system name} is used, the following keys will be executed in the following order: % \begin{enumerate} \item The \meta{axis setup} with the path prefix |/tikz/data visualization/|. \item The \meta{default options} with the same path prefix. \item The following style: % \begin{stylekey}{/tikz/data visualization/every \meta{axis system name}} Even though this style has the path prefix |/tikz/data visualization| itself, the keys stored in this style will be executed with the path prefix |/tikz/data visualization/|\meta{axis system name}. \end{stylekey} \item The \meta{options} with the path prefix |/tikz/data visualization/|\meta{axis system name}. \item The \meta{application options} with the path prefix |/tikz/data visualization/| \end{enumerate} \end{key} Let us now have a look at what all of this means. First, the \meta{axis setup} will contain all options that setup the axis system in all ways that need not be configured. For instance, the \meta{axis setup} for the |scientific axes| will create an |x axis| and also a |y axis| (because these are always present), but will not setup the label visualization (because this can be configured in different ways). For |our system|, which cannot be configured at all, we would place all of our configuration in the \meta{axis setup}. The \meta{default options} can be used to pick default values that would usually be passed to the \meta{options} of the newly created axis system. For instance, for |scientific axis|, the \meta{default options} are set to |outer ticks,standard labels|, because these are the defaults. Finally, the \meta{application options} can be used to actually apply the configuration that has been chosen by the \meta{options}. The idea is that \meta{default options}, \meta{options}, and also |every| \meta{axis system name} all have a chance of changing, re-changing and re-setting all sorts of styles and keys. Then, with the last change ``winning'', the resulting setting of a style can be executed, which may then cause a label visualization to be installed. \end{key}