Skip to main content

mpltex is a python package for creating publication-quality plots using matplotlib.

Project description

mpltex is a python package for producing publication quality images using matplotlib, which is inspired by Olga Botvinnik’s python package prettyplotlib. Tutorial can be found at www.yxliu.group.

The internal matplotlib color cycle is replaced by Tableau classic 10 color scheme which looks less saturated and more pleasing to eyes. The colors of this scheme is reordered, which is different from current version of matplotlib v3. Other available color schemes for multi-line plots are ColorBrewer Set 1 and Tableau classic 20. For more information on these color schemes, see documentation of palettable.

mpltex also provide a way to generate highly configurable line styles with colors, line types, and line markers. Hollow markers are supported.

mpltex should work properly both in Python 2 and 3. If not, please file an issue at Github.

Quickstart

1. Install

$ pip install mpltex

Required Packages

  • matplotlib. Can be installed via pip install matplotlib.

  • palettable. Can be installed via pip install palettable.

2. Usage

Examples and sample plots can be found here.

To use mpltex, just add one of mpltex decorators before your plot functions.

import mpltex

@mpltex.acs_decorator
def myplot():
    # plot images by matplotlib ...

    # Save the image. Give a file name without extension.
    # You can also save figure outside your_plot if you like.
    fig.save_fig('/path/to/save/fig/figname')

# Then use your_plot in a normal way.
myplot()

And it will create a plot ready for publishing in journals published by American Chemical Society (ACS).

Available Decorators

  • mpltex.acs_decorator: output EPS images for publishing in ACS (American Chemical Society).

  • mpltex.aps_decorator: output EPS images for publishing in APS (American Physical Society).

  • mpltex.rsc_decorator: output EPS images for publishing in RSC (Royal Society of Chemistry).

  • mpltex.presentation_decorator: output PDF images for presentation slides (Keynote).

  • mpltex.web_decorator: output PNG images for web pages.

mpltex also provides several helper functions to facilitate production of specific type of images. Following codes will produce a set of line arts with cycled line styles with the help of mpltex.linestyle_generator function. Note that since version 0.5, linestyles is a shorthand for linestyle_generator.

import matplotlib.pyplot as plt
import mpltex

@mpltex.acs_decorator
def myplot():
    # ...   # generate data x and y
    fig, ax = plt.subplots(111)

    # The default line style is iterating over
    # color, line, and marker with hollow types.
    linestyles = mpltex.linestyles()
    # equivalently
    # linestyles = mpltex.linestyle_generator()

    for i in range(number_of_lines):
        ax.plot(x[i], y[i], label=str(i), **next(linestyles)

    ax.locator_params(nbins=5)  # limit the number of major ticks
    ax.legend(loc='best')  # show legend in a best location
    fig.tight_layout(pad=0.1)  # make layout as tight as possible
    fig.savefig('/path/to/save/fig/figname')

Contribute

Fork the project at github.com and file a pull request.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mpltex-0.7.tar.gz (11.6 kB view details)

Uploaded Source

File details

Details for the file mpltex-0.7.tar.gz.

File metadata

  • Download URL: mpltex-0.7.tar.gz
  • Upload date:
  • Size: 11.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Python-urllib/3.8

File hashes

Hashes for mpltex-0.7.tar.gz
Algorithm Hash digest
SHA256 e7f5c98b9d87f64a9d8b25b76333f3203c9c16aec36943a472879978d41170f4
MD5 71e59c47494840009581776a06cb1175
BLAKE2b-256 58ff97043f2649a65a8fecd811fe66d076fb9c92a78ed1d642fcd40e472b1d32

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page