Current File : //usr/share/texlive/texmf-dist/doc/generic/pgf/text-en/pgfmanual-en-math-commands.tex
% Copyright 2018 by Mark Wibrow
%
% 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{Additional Mathematical Commands}
\label{pgfmath-commands}

Instead of parsing and evaluating complex expressions, you can also use the
mathematical engine to evaluate a single mathematical operation. The macros
used for many of these computations are listed above in
Section~\ref{pgfmath-functions}. \pgfname{} also provides some additional
commands which are shown below:


\subsection{Basic arithmetic functions}
\label{pgfmath-commands-basic}

In addition to the commands described in Section~\ref{pgfmath-functions-basic},
the following command is provided:

\begin{command}{\pgfmathreciprocal\marg{x}}
    Defines |\pgfmathresult| as $1\div\meta{x}$. This provides greatest
    accuracy when \mvar{x} is small.
\end{command}


\subsection{Comparison and logical functions}

In addition to the commands described in
Section~\ref{pgfmath-functions-comparison}, the following command was provided
by Christian Feuers\"anger:

\begin{command}{\pgfmathapproxequalto\marg{x}\marg{y}}
    Defines |\pgfmathresult| 1.0 if $ \rvert \meta{x} - \meta{y} \lvert <
    0.0001$, but 0.0 otherwise. As a side-effect, the global boolean
    |\ifpgfmathcomparison| will be set accordingly.
\end{command}


\subsection{Pseudo-Random Numbers}
\label{pgfmath-random}

In addition to the commands described in
Section~\ref{pgfmath-functions-random}, the following commands are provided:

\begin{command}{\pgfmathgeneratepseudorandomnumber}
    Defines |\pgfmathresult| as a pseudo-random integer between 1 and
    $2^{31}-1$. This uses a linear congruency generator, based on ideas of
    Erich Janka.
\end{command}

\begin{command}{\pgfmathrandominteger\marg{macro}\marg{minimum}\marg{maximum}}
    This defines \meta{macro} as a pseudo-randomly generated integer from the
    range \meta{minimum} to \meta{maximum} (inclusive).
    %
\begin{codeexample}[]
\begin{pgfpicture}
   \foreach \x in {1,...,50}{
      \pgfmathrandominteger{\a}{1}{50}
      \pgfmathrandominteger{\b}{1}{50}
      \pgfpathcircle{\pgfpoint{+\a pt}{+\b pt}}{+2pt}
      \color{blue!40!white}
      \pgfsetstrokecolor{blue!80!black}
      \pgfusepath{stroke, fill}
   }
\end{pgfpicture}
\end{codeexample}
    %
\end{command}

\begin{command}{\pgfmathdeclarerandomlist\marg{list name}{\ttfamily\{}\marg{item-1}\marg{item-2}...{\ttfamily\}}}
    This creates a list of items with the name \meta{list name}.
\end{command}

\begin{command}{\pgfmathrandomitem\marg{macro}\marg{list name}}
    Select an item from a random list \meta{list name}. The
    selected item is placed in \meta{macro}.
\end{command}

\begin{codeexample}[]
\begin{pgfpicture}
   \pgfmathdeclarerandomlist{color}{{red}{blue}{green}{yellow}{white}}
   \foreach \a in {1,...,50}{
      \pgfmathrandominteger{\x}{1}{85}
      \pgfmathrandominteger{\y}{1}{85}
      \pgfmathrandominteger{\r}{5}{10}
      \pgfmathrandomitem{\c}{color}
      \pgfpathcircle{\pgfpoint{+\x pt}{+\y pt}}{+\r pt}
      \color{\c!40!white}
      \pgfsetstrokecolor{\c!80!black}
      \pgfusepath{stroke, fill}
   }
\end{pgfpicture}
\end{codeexample}

\begin{command}{\pgfmathsetseed\marg{integer}}
    Explicitly sets the seed for the pseudo-random number generator. By default
    it is set to the value of |\time|$\times$|\year|.
\end{command}


\subsection{Base Conversion}
\label{pgfmath-bases}

\pgfname{} provides limited support for conversion between
\emph{representations} of numbers. Currently the numbers must be positive
integers in the range $0$ to $2^{31}-1$, and the bases in the range $2$ to
$36$. All digits representing numbers greater than 9 (in base ten), are
alphabetic, but may be upper or lower case.

In addition to the commands described in Section~\ref{pgfmath-functions-base},
the following commands are provided:

\begin{command}{\pgfmathbasetodec\marg{macro}\marg{number}\marg{base}}
    Defines \meta{macro} as the result of converting \meta{number} from base
    \meta{base} to base 10. Alphabetic digits can be upper or lower case.

\medskip{\def\medskip{}

\begin{codeexample}[]
\pgfmathbasetodec\mynumber{107f}{16} \mynumber
\end{codeexample}

    \noindent Note that, as usual in \TeX, the braces around an argument can be
    omitted if the argument is just a single token (a macro name is a single
    token).
    %
\begin{codeexample}[]
\pgfmathbasetodec\mynumber{33FC}{20} \mynumber
\end{codeexample}

}\medskip
    %
\end{command}

\begin{command}{\pgfmathdectobase\marg{macro}\marg{number}\marg{base}}
    Defines \meta{macro} as the result of converting \meta{number} from base 10
    to base \meta{base}. Any resulting alphabetic digits are in \emph{lower
    case}.
    %
\begin{codeexample}[]
\pgfmathdectobase\mynumber{65535}{16} \mynumber
\end{codeexample}
    %
\end{command}

\begin{command}{\pgfmathdectoBase\marg{macro}\marg{number}\marg{base}}
    Defines \meta{macro} as the result of converting \meta{number} from base 10
    to base \meta{base}. Any resulting alphabetic digits are in \emph{upper
    case}.
    %
\begin{codeexample}[]
\pgfmathdectoBase\mynumber{65535}{16} \mynumber
\end{codeexample}
    %
\end{command}

\begin{command}{\pgfmathbasetobase\marg{macro}\marg{number}\marg{base-1}\marg{base-2}}
    Defines \meta{macro} as the result of converting \meta{number} from base
    \meta{base-1} to base \meta{base-2}. Alphabetic digits in \meta{number} can
    be upper or lower case, but any resulting alphabetic digits are in
    \emph{lower case}.
    %
\begin{codeexample}[]
\pgfmathbasetobase\mynumber{11011011}{2}{16} \mynumber
\end{codeexample}
    %
\end{command}

\begin{command}{\pgfmathbasetoBase\marg{macro}\marg{number}\marg{base-1}\marg{base-2}}
    Defines \meta{macro} as the result of converting \meta{number} from base
    \meta{base-1} to base \meta{base-2}. Alphabetic digits in \meta{number} can
    be upper or lower case, but any resulting alphabetic digits are in
    \emph{upper case}.
    %
\begin{codeexample}[]
\pgfmathbasetoBase\mynumber{121212}{3}{12} \mynumber
\end{codeexample}
    %
\end{command}

\begin{command}{\pgfmathsetbasenumberlength\marg{integer}}
    Sets the number of digits in the result of a base conversion to
    \meta{integer}. If the result of a conversion has less digits than this
    number, it is prefixed with zeros.
    %
\begin{codeexample}[]
\pgfmathsetbasenumberlength{8}
\pgfmathdectobase\mynumber{15}{2} \mynumber
\end{codeexample}
    %
\end{command}

\begin{command}{\pgfmathtodigitlist\marg{macro}\marg{number}}
    This command converts \meta{number} into a comma-separated list of digits
    and stores the result in \meta{macro}. The \marg{number} is \emph{not}
    parsed before processing.
    %
\begin{codeexample}[]
\pgfmathsetbasenumberlength{8}
\begin{tikzpicture}[x=0.25cm, y=0.25cm]
  \foreach \n [count=\y] in {0, 60, 102, 102, 126, 102, 102, 102, 0}{
    \pgfmathdectobase{\binary}{\n}{2}
    \pgfmathtodigitlist{\digitlist}{\binary}
    \foreach \digit [count=\x, evaluate={\c=\digit*50+15;}] in \digitlist
      \fill [fill=black!\c] (\x, -\y) rectangle ++(1,1);
  }
\end{tikzpicture}
\end{codeexample}
    %
\end{command}


\subsection{Angle Computations}

Unlike the rest of the math engine, which is a ``standalone'' package, the
following commands only work in conjunction with the core of \pgfname.

\begin{command}{\pgfmathanglebetweenpoints\marg{p}\marg{q}}
    Returns the angle of a line from \meta{p} to \meta{q} relative to a line
    going straight right from \meta{p}.
    %
\begin{codeexample}[]
\pgfmathanglebetweenpoints{\pgfpoint{1cm}{3cm}}{\pgfpoint{2cm}{4cm}}
\pgfmathresult
\end{codeexample}
    %
\end{command}

\begin{command}{\pgfmathanglebetweenlines\marg{$p_1$}\marg{$q_1$}\marg{$p_2$}\marg{$q_2$}}
    Returns the clockwise angle between a line going through $p_1$ and $q_1$
    and a line going through $p_2$ and $q_2$.
    %
\begin{codeexample}[]
\pgfmathanglebetweenlines{\pgfpoint{1cm}{3cm}}{\pgfpoint{2cm}{4cm}}
                         {\pgfpoint{0cm}{1cm}}{\pgfpoint{1cm}{0cm}}
\pgfmathresult
\end{codeexample}
    %
\end{command}