This is matplotlib2tikz, a Python tool for converting matplotlib figures into PGFPlots (TikZ) figures like
for native inclusion into LaTeX documents.
The output of matplotlib2tikz is in PGFPlots, a LaTeX library that sits on top of TikZ and describes graphs in terms of axes, data etc. Consequently, the output of matplotlib2tikz retains more information, can be more easily understood, and is more easily editable than raw TikZ output. For example, the matplotlib figure
from matplotlib import pyplot as plt
from matplotlib import style
import numpy as np
fig = plt.figure()
style.use('ggplot')
t = np.arange(0.0, 2.0, 0.1)
s = np.sin(2*np.pi*t)
s2 = np.cos(2*np.pi*t)
plt.plot(t, s, 'o-', lw=4.1)
plt.plot(t, s2, 'o-', lw=4.1)
plt.xlabel('time(s)')
plt.ylabel('Voltage (mV)')
plt.title('Simple plot $\\frac{\\alpha}{2}$')
plt.grid(True)
from matplotlib2tikz import save as tikz_save
tikz_save('test.tex')
(see above) gives
% This file was created by matplotlib2tikz vx.y.z.
\begin{tikzpicture}
\definecolor{color1}{rgb}{0.203921568627451,0.541176470588235,0.741176470588235}
\definecolor{color0}{rgb}{0.886274509803922,0.290196078431373,0.2}
\begin{axis}[
title={Simple plot $\frac{\alpha}{2}$},
xlabel={time(s)},
ylabel={Voltage (mV)},
xmin=0, xmax=2,
ymin=-1, ymax=1,
tick align=outside,
xmajorgrids,
x grid style={white},
ymajorgrids,
y grid style={white},
axis line style={white},
axis background/.style={fill=white!89.803921568627459!black}
]
\addplot [line width=1.64pt, color0, mark=*, mark size=3, mark options={solid,draw=black}]
table {%
0 0
0.1 0.587785252292473
% [...]
1.9 -0.587785252292473
};
\addplot [line width=1.64pt, color1, mark=*, mark size=3, mark options={solid,draw=black}]
table {%
0 1
0.1 0.809016994374947
% [...]
1.9 0.809016994374947
};
\end{axis}
\end{tikzpicture}
Tweaking the plot is straightforward and can be done as part of your LaTeX work flow. The fantastic PGFPlots manual contains great examples of how to make your plot look even better.
matplotlib2tikz is available from the Python Package Index, so simply type
pip install -U matplotlib2tikz
to install/update.
matplotlib2tikz needs matplotlib and NumPy to work. matplotlib2tikz works both with Python 2 and Python 3.
To use the resulting TikZ/PGFPlots figures, your LaTeX installation needs
- TikZ (aka PGF, >=2.00), and
- PGFPlots (>=1.3).
-
Generate your matplotlib plot as usual.
-
Instead of
pyplot.show()
, invoke matplotlib2tikz bytikz_save('mytikz.tex');
to store the TikZ file as
mytikz.tex
. Load the library with:from matplotlib2tikz import save as tikz_save
Optional: The scripts accepts several options, for example
height
,width
,encoding
, and some others. Invoke bytikz_save('mytikz.tex', figureheight='4cm', figurewidth='6cm')
Note that height and width must be set large enough; setting it too low may result in a LaTeX compilation failure along the lines of
Dimension Too Large
orArithmetic Overflow
; see information about these errors in the PGFPlots manual. To specify the dimension of the plot from within the LaTeX document, trytikz_save( 'mytikz.tex', figureheight = '\\figureheight', figurewidth = '\\figurewidth' )
and in the LaTeX source
\newlength\figureheight \newlength\figurewidth \setlength\figureheight{4cm} \setlength\figurewidth{6cm} \input{mytikz.tex}
-
Add the contents of
mytikz.tex
into your LaTeX source code; a convenient way of doing so is via\input{/path/to/mytikz.tex}
. Also make sure that in the header of your document the packages for PGFPlots and proper Unicode support and are included:\usepackage[utf8]{inputenc} \usepackage{pgfplots}
Additionally, with LuaLaTeX
\usepackage{fontspec}
is needed to typeset Unicode characters. Optionally, to use the latest PGFPlots features, insert
\pgfplotsset{compat=newest}
If you experience bugs, would like to contribute, have nice examples of what matplotlib2tikz can do, or if you are just looking for more information, then please visit matplotlib2tikz's GitHub page.
matplotlib2tikz has automatic unit testing to make sure that the software
doesn't accidentally get worse over time. In test/testfunctions/
, a number of
test cases are specified. Those
- run through matplotlib2tikz,
- the resulting LaTeX file is compiled into a PDF (
pdflatex
), - the PDF is converted into a PNG (
pdftoppm
), - a perceptual hash is computed from the PNG and compared to a previously stored version.
To run the tests, just check out this repository and type
pytest
The final pHash may depend on any of the tools used during the process. For example, if your version of Pillow is too old, the pHash function might operate slightly differently and produce a slightly different pHash, resulting in a failing test. If tests are failing on your local machine, you should first make sure to have an up-to-date Pillow.
If you would like to contribute a test, just take a look at the examples in
test/testfunctions/
. Essentially a test consists of three things:
- a description,
- a pHash, and
- a function that creates the image in matplotlib.
Just add your file, add it to test/testfunction/__init__.py
, and run the
tests. A failing test will always print out the pHash, so you can leave it
empty in the first run and fill it in later to make the test pass.
To create a new release
-
bump the
__version__
number, -
publish to PyPi and GitHub:
$ make publish
matplotlib2tikz is published under the MIT license.