matplotlib.mathtext
¶mathtext
is a module for parsing a subset of the
TeX math syntax and drawing them to a matplotlib backend.
For a tutorial of its usage see Writing mathematical expressions. This document is primarily concerned with implementation details.
The module uses pyparsing to parse the TeX expression.
The Bakoma distribution of the TeX Computer Modern fonts, and STIX fonts are supported. There is experimental support for using arbitrary fonts, but results may vary without proper tweaking and metrics for those fonts.
matplotlib.mathtext.
Accent
(c, state, math=True)[source]¶Bases: matplotlib.mathtext.Char
The font metrics need to be dealt with differently for accents, since they are already offset correctly from the baseline in TrueType fonts.
matplotlib.mathtext.
AutoHeightChar
(c, height, depth, state, always=False, factor=None)[source]¶Bases: matplotlib.mathtext.Hlist
AutoHeightChar
will create a character as close to the
given height and depth as possible. When using a font with
multiple height versions of some characters (such as the BaKoMa
fonts), the correct glyph will be selected, otherwise this will
always just return a scaled version of the glyph.
matplotlib.mathtext.
AutoWidthChar
(c, width, state, always=False, char_class=<class 'matplotlib.mathtext.Char'>)[source]¶Bases: matplotlib.mathtext.Hlist
AutoWidthChar
will create a character as close to the
given width as possible. When using a font with multiple width
versions of some characters (such as the BaKoMa fonts), the
correct glyph will be selected, otherwise this will always just
return a scaled version of the glyph.
matplotlib.mathtext.
BakomaFonts
(*args, **kwargs)[source]¶Bases: matplotlib.mathtext.TruetypeFonts
Use the Bakoma TrueType fonts for rendering.
Symbols are strewn about a number of font files, each of which has its own proprietary 8-bit encoding.
alias
= '\\]'¶get_sized_alternatives_for_symbol
(fontname, sym)[source]¶Override if your font provides multiple sizes of the same symbol. Should return a list of symbols matching sym in various sizes. The expression renderer will select the most appropriate size for a given situation from this list.
target
= ']'¶matplotlib.mathtext.
Box
(width, height, depth)[source]¶Bases: matplotlib.mathtext.Node
Represents any node with a physical location.
matplotlib.mathtext.
Char
(c, state, math=True)[source]¶Bases: matplotlib.mathtext.Node
Represents a single character. Unlike TeX, the font information
and metrics are stored with each Char
to make it easier
to lookup the font metrics when needed. Note that TeX boxes have
a width, height, and depth, unlike Type1 and Truetype which use a
full bounding box and an advance in the x-direction. The metrics
must be converted to the TeX way, and the advance (if different
from width) must be converted into a Kern
node when the
Char
is added to its parent Hlist
.
matplotlib.mathtext.
ComputerModernFontConstants
[source]¶Bases: matplotlib.mathtext.FontConstantsBase
delta
= 0.075¶delta_integral
= 0.3¶delta_slanted
= 0.3¶script_space
= 0.075¶sub1
= 0.2¶sub2
= 0.3¶subdrop
= 0.2¶sup1
= 0.45¶matplotlib.mathtext.
DejaVuFonts
(*args, **kwargs)[source]¶Bases: matplotlib.mathtext.UnicodeFonts
use_cmex
= False¶matplotlib.mathtext.
DejaVuSansFonts
(*args, **kwargs)[source]¶Bases: matplotlib.mathtext.DejaVuFonts
A font handling class for the DejaVu Sans fonts
If a glyph is not found it will fallback to Stix Sans
matplotlib.mathtext.
DejaVuSerifFonts
(*args, **kwargs)[source]¶Bases: matplotlib.mathtext.DejaVuFonts
A font handling class for the DejaVu Serif fonts
If a glyph is not found it will fallback to Stix Serif
matplotlib.mathtext.
Fil
[source]¶Bases: matplotlib.mathtext.Glue
matplotlib.mathtext.
Fill
[source]¶Bases: matplotlib.mathtext.Glue
matplotlib.mathtext.
Filll
[source]¶Bases: matplotlib.mathtext.Glue
matplotlib.mathtext.
FontConstantsBase
[source]¶Bases: object
A set of constants that controls how certain things, such as sub- and superscripts are laid out. These are all metrics that can't be reliably retrieved from the font metrics in the font itself.
delta
= 0.025¶delta_integral
= 0.1¶delta_slanted
= 0.2¶script_space
= 0.05¶sub1
= 0.3¶sub2
= 0.5¶subdrop
= 0.4¶sup1
= 0.7¶matplotlib.mathtext.
Fonts
(default_font_prop, mathtext_backend)[source]¶Bases: object
An abstract base class for a system of fonts to use for mathtext.
The class must be able to take symbol keys and font file names and return the character metrics. It also delegates to a backend class to do the actual drawing.
default_font_prop: A
FontProperties
object to use
for the default non-math font, or the base font for Unicode
(generic) font rendering.
mathtext_backend: A subclass of MathTextBackend
used to delegate the actual rendering.
get_kern
(font1, fontclass1, sym1, fontsize1, font2, fontclass2, sym2, fontsize2, dpi)[source]¶Get the kerning distance for font between sym1 and sym2.
fontX: one of the TeX font names:
tt, it, rm, cal, sf, bf or default/regular (non-math)
fontclassX: TODO
symX: a symbol in raw TeX form. e.g., '1', 'x' or 'sigma'
fontsizeX: the fontsize in points
dpi: the current dots-per-inch
get_metrics
(font, font_class, sym, fontsize, dpi, math=True)[source]¶font: one of the TeX font names:
tt, it, rm, cal, sf, bf or default/regular (non-math)
font_class: TODO
sym: a symbol in raw TeX form. e.g., '1', 'x' or 'sigma'
fontsize: font size in points
dpi: current dots-per-inch
math: whether sym is a math character
Returns an object with the following attributes:
- advance: The advance distance (in points) of the glyph.
- height: The height of the glyph in points.
- width: The width of the glyph in points.
- xmin, xmax, ymin, ymax - the ink rectangle of the glyph
- iceberg - the distance from the baseline to the top of the glyph. This corresponds to TeX's definition of "height".
get_results
(box)[source]¶Get the data needed by the backend to render the math expression. The return value is backend-specific.
get_sized_alternatives_for_symbol
(fontname, sym)[source]¶Override if your font provides multiple sizes of the same symbol. Should return a list of symbols matching sym in various sizes. The expression renderer will select the most appropriate size for a given situation from this list.
get_underline_thickness
(font, fontsize, dpi)[source]¶Get the line thickness that matches the given font. Used as a base unit for drawing lines such as in a fraction or radical.
get_used_characters
()[source]¶Get the set of characters that were used in the math expression. Used by backends that need to subset fonts so they know which glyphs to include.
matplotlib.mathtext.
Glue
(glue_type, copy=False)[source]¶Bases: matplotlib.mathtext.Node
Most of the information in this object is stored in the underlying
GlueSpec
class, which is shared between multiple glue objects.
(This is a memory optimization which probably doesn't matter anymore, but
it's easier to stick to what TeX does.)
matplotlib.mathtext.
GlueSpec
(width=0.0, stretch=0.0, stretch_order=0, shrink=0.0, shrink_order=0)[source]¶Bases: object
See Glue
.
matplotlib.mathtext.
HCentered
(elements)[source]¶Bases: matplotlib.mathtext.Hlist
A convenience class to create an Hlist
whose contents are
centered within its enclosing box.
matplotlib.mathtext.
Hbox
(width)[source]¶Bases: matplotlib.mathtext.Box
A box with only width (zero height and depth).
matplotlib.mathtext.
Hlist
(elements, w=0.0, m='additional', do_kern=True)[source]¶Bases: matplotlib.mathtext.List
A horizontal list of boxes.
hpack
(w=0.0, m='additional')[source]¶The main duty of hpack()
is to compute the dimensions of
the resulting boxes, and to adjust the glue if one of those
dimensions is pre-specified. The computed sizes normally
enclose all of the material inside the new box; but some items
may stick out if negative glue is used, if the box is
overfull, or if a \vbox
includes other boxes that have
been shifted left.
- w: specifies a width
- m: is either 'exactly' or 'additional'.
Thus, hpack(w, 'exactly')
produces a box whose width is
exactly w, while hpack(w, 'additional')
yields a box
whose width is the natural width plus w. The default values
produce a box with the natural width.
matplotlib.mathtext.
Hrule
(state, thickness=None)[source]¶Bases: matplotlib.mathtext.Rule
Convenience class to create a horizontal rule.
matplotlib.mathtext.
Kern
(width)[source]¶Bases: matplotlib.mathtext.Node
A Kern
node has a width field to specify a (normally
negative) amount of spacing. This spacing correction appears in
horizontal lists between letters like A and V when the font
designer said that it looks better to move them closer together or
further apart. A kern node can also appear in a vertical list,
when its width denotes additional spacing in the vertical
direction.
depth
= 0¶height
= 0¶matplotlib.mathtext.
List
(elements)[source]¶Bases: matplotlib.mathtext.Box
A list of nodes (either horizontal or vertical).
matplotlib.mathtext.
MathTextParser
(output)[source]¶Bases: object
Create a MathTextParser for the given backend output.
get_depth
(texstr, dpi=120, fontsize=14)[source]¶Returns the offset of the baseline from the bottom of the image in pixels.
parse
[source]¶Parse the given math expression s at the given dpi. If
prop is provided, it is a
FontProperties
object
specifying the "default" font to use in the math expression,
used for all non-math text.
The results are cached, so multiple calls to parse()
with the same expression should be fast.
to_mask
(texstr, dpi=120, fontsize=14)[source]¶Returns a tuple (array, depth)
- array is an NxM uint8 alpha ubyte mask array of rasterized tex.
- depth is the offset of the baseline from the bottom of the image in pixels.
to_png
(filename, texstr, color='black', dpi=120, fontsize=14)[source]¶Writes a tex expression to a PNG file.
Returns the offset of the baseline from the bottom of the image in pixels.
Returns the offset of the baseline from the bottom of the image in pixels.
to_rgba
(texstr, color='black', dpi=120, fontsize=14)[source]¶Returns a tuple (array, depth)
- array is an NxM uint8 alpha ubyte mask array of rasterized tex.
- depth is the offset of the baseline from the bottom of the image in pixels.
matplotlib.mathtext.
MathtextBackend
[source]¶Bases: object
The base class for the mathtext backend-specific code. The
purpose of MathtextBackend
subclasses is to interface
between mathtext and a specific matplotlib graphics backend.
Subclasses need to override the following:
And optionally, if you need to use a FreeType hinting style:
get_results
(box)[source]¶Return a backend-specific tuple to return to the backend after all processing is done.
matplotlib.mathtext.
MathtextBackendAgg
[source]¶Bases: matplotlib.mathtext.MathtextBackend
Render glyphs and rectangles to an FTImage buffer, which is later transferred to the Agg image by the Agg backend.
get_results
(box, used_characters)[source]¶Return a backend-specific tuple to return to the backend after all processing is done.
matplotlib.mathtext.
MathtextBackendCairo
[source]¶Bases: matplotlib.mathtext.MathtextBackend
Store information to write a mathtext rendering to the Cairo backend.
matplotlib.mathtext.
MathtextBackendPath
[source]¶Bases: matplotlib.mathtext.MathtextBackend
Store information to write a mathtext rendering to the text path machinery.
matplotlib.mathtext.
MathtextBackendPdf
[source]¶Bases: matplotlib.mathtext.MathtextBackend
Store information to write a mathtext rendering to the PDF backend.
matplotlib.mathtext.
MathtextBackendPs
[source]¶Bases: matplotlib.mathtext.MathtextBackend
Store information to write a mathtext rendering to the PostScript backend.
matplotlib.mathtext.
MathtextBackendSvg
[source]¶Bases: matplotlib.mathtext.MathtextBackend
Store information to write a mathtext rendering to the SVG backend.
matplotlib.mathtext.
NegFil
[source]¶Bases: matplotlib.mathtext.Glue
matplotlib.mathtext.
NegFill
[source]¶Bases: matplotlib.mathtext.Glue
matplotlib.mathtext.
NegFilll
[source]¶Bases: matplotlib.mathtext.Glue
matplotlib.mathtext.
Parser
[source]¶Bases: object
This is the pyparsing-based parser for math expressions. It
actually parses full strings containing math expressions, in
that raw text may also appear outside of pairs of $
.
The grammar is based directly on that in TeX, though it cuts a few corners.
State
(font_output, font, font_class, fontsize, dpi)[source]¶Bases: object
Stores the state of the parser.
States are pushed and popped from a stack as necessary, and the "current" state is always at the top of the stack.
font
¶parse
(s, fonts_object, fontsize, dpi)[source]¶Parse expression s using the given fonts_object for output, at the given fontsize and dpi.
Returns the parse tree of Node
instances.
required_group
(s, loc, toks)¶simple_group
(s, loc, toks)¶snowflake
(s, loc, toks)¶matplotlib.mathtext.
Rule
(width, height, depth, state)[source]¶Bases: matplotlib.mathtext.Box
A Rule
node stands for a solid black rectangle; it has
width, depth, and height fields just as in an
Hlist
. However, if any of these dimensions is inf, the
actual value will be determined by running the rule up to the
boundary of the innermost enclosing box. This is called a "running
dimension." The width is never running in an Hlist
; the
height and depth are never running in a Vlist
.
matplotlib.mathtext.
STIXFontConstants
[source]¶Bases: matplotlib.mathtext.FontConstantsBase
delta
= 0.05¶delta_integral
= 0.3¶delta_slanted
= 0.3¶script_space
= 0.1¶sub2
= 0.6¶sup1
= 0.8¶matplotlib.mathtext.
STIXSansFontConstants
[source]¶Bases: matplotlib.mathtext.FontConstantsBase
delta_integral
= 0.3¶delta_slanted
= 0.6¶script_space
= 0.05¶sup1
= 0.8¶matplotlib.mathtext.
Ship
[source]¶Bases: object
Once the boxes have been set up, this sends them to output. Since
boxes can be inside of boxes inside of boxes, the main work of
Ship
is done by two mutually recursive routines,
hlist_out()
and vlist_out()
, which traverse the
Hlist
nodes and Vlist
nodes inside of horizontal
and vertical boxes. The global variables used in TeX to store
state as it processes have become member variables here.
matplotlib.mathtext.
SsGlue
[source]¶Bases: matplotlib.mathtext.Glue
matplotlib.mathtext.
StandardPsFonts
(default_font_prop)[source]¶Bases: matplotlib.mathtext.Fonts
Use the standard postscript fonts for rendering to backend_ps
Unlike the other font classes, BakomaFont and UnicodeFont, this one requires the Ps backend.
basepath
= '/home/tcaswell/.virtualenvs/sys37/lib/python3.7/site-packages/matplotlib/mpl-data/fonts/afm'¶fontmap
= {'cal': 'pzcmi8a', 'rm': 'pncr8a', 'tt': 'pcrr8a', 'it': 'pncri8a', 'sf': 'phvr8a', 'bf': 'pncb8a', None: 'psyr'}¶get_kern
(font1, fontclass1, sym1, fontsize1, font2, fontclass2, sym2, fontsize2, dpi)[source]¶Get the kerning distance for font between sym1 and sym2.
fontX: one of the TeX font names:
tt, it, rm, cal, sf, bf or default/regular (non-math)
fontclassX: TODO
symX: a symbol in raw TeX form. e.g., '1', 'x' or 'sigma'
fontsizeX: the fontsize in points
dpi: the current dots-per-inch
matplotlib.mathtext.
StixFonts
(*args, **kwargs)[source]¶Bases: matplotlib.mathtext.UnicodeFonts
A font handling class for the STIX fonts.
In addition to what UnicodeFonts provides, this class:
cm_fallback
= False¶get_sized_alternatives_for_symbol
(fontname, sym)[source]¶Override if your font provides multiple sizes of the same symbol. Should return a list of symbols matching sym in various sizes. The expression renderer will select the most appropriate size for a given situation from this list.
use_cmex
= False¶matplotlib.mathtext.
StixSansFonts
(*args, **kwargs)[source]¶Bases: matplotlib.mathtext.StixFonts
A font handling class for the STIX fonts (that uses sans-serif characters by default).
matplotlib.mathtext.
SubSuperCluster
[source]¶Bases: matplotlib.mathtext.Hlist
SubSuperCluster
is a sort of hack to get around that fact
that this code do a two-pass parse like TeX. This lets us store
enough information in the hlist itself, namely the nucleus, sub-
and super-script, such that if another script follows that needs
to be attached, it can be reconfigured on the fly.
matplotlib.mathtext.
TruetypeFonts
(default_font_prop, mathtext_backend)[source]¶Bases: matplotlib.mathtext.Fonts
A generic base class for all font setups that use Truetype fonts (through FT2Font).
get_kern
(font1, fontclass1, sym1, fontsize1, font2, fontclass2, sym2, fontsize2, dpi)[source]¶Get the kerning distance for font between sym1 and sym2.
fontX: one of the TeX font names:
tt, it, rm, cal, sf, bf or default/regular (non-math)
fontclassX: TODO
symX: a symbol in raw TeX form. e.g., '1', 'x' or 'sigma'
fontsizeX: the fontsize in points
dpi: the current dots-per-inch
matplotlib.mathtext.
UnicodeFonts
(*args, **kwargs)[source]¶Bases: matplotlib.mathtext.TruetypeFonts
An abstract base class for handling Unicode fonts.
While some reasonably complete Unicode fonts (such as DejaVu) may work in some situations, the only Unicode font I'm aware of with a complete set of math symbols is STIX.
This class will "fallback" on the Bakoma fonts when a required symbol can not be found in the font.
get_sized_alternatives_for_symbol
(fontname, sym)[source]¶Override if your font provides multiple sizes of the same symbol. Should return a list of symbols matching sym in various sizes. The expression renderer will select the most appropriate size for a given situation from this list.
use_cmex
= True¶matplotlib.mathtext.
VCentered
(elements)[source]¶Bases: matplotlib.mathtext.Hlist
A convenience class to create a Vlist
whose contents are
centered within its enclosing box.
matplotlib.mathtext.
Vbox
(height, depth)[source]¶Bases: matplotlib.mathtext.Box
A box with only height (zero width).
matplotlib.mathtext.
Vlist
(elements, h=0.0, m='additional')[source]¶Bases: matplotlib.mathtext.List
A vertical list of boxes.
vpack
(h=0.0, m='additional', l=inf)[source]¶The main duty of vpack()
is to compute the dimensions of
the resulting boxes, and to adjust the glue if one of those
dimensions is pre-specified.
- h: specifies a height
- m: is either 'exactly' or 'additional'.
- l: a maximum height
Thus, vpack(h, 'exactly')
produces a box whose height is
exactly h, while vpack(h, 'additional')
yields a box
whose height is the natural height plus h. The default
values produce a box with the natural width.
matplotlib.mathtext.
Vrule
(state)[source]¶Bases: matplotlib.mathtext.Rule
Convenience class to create a vertical rule.
matplotlib.mathtext.
get_unicode_index
(symbol[, bool]) → integer[source]¶Return the integer index (from the Unicode table) of symbol. symbol can be a single unicode character, a TeX command (i.e. r'pi'), or a Type1 symbol name (i.e. 'phi'). If math is False, the current symbol should be treated as a non-math symbol.
matplotlib.mathtext.
math_to_image
(s, filename_or_obj, prop=None, dpi=None, format=None)[source]¶Given a math expression, renders it in a closely-clipped bounding box to an image file.