Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

matplotlib-layout

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

matplotlib-layout

A package for laying out figures with geometric constraints

  • 0.0.2
  • PyPI
  • Socket score

Maintainers
1

Project logo

Summary

MPLLayout is a package used to create figure layouts for matplotlib using geometric constraints.

MPLLayout can be used to:

  • align figure elements (axes, text label location, x and y axis, etc.),
  • specify margins around axes,
  • specify the figure size,
  • and more!

Motivation

Matplotlib contains several strategies for creating figure layouts (for example, GridSpec and subplots for grid-based layouts). These strategies work well, however, they can be insufficient for complex figures or if you want precise placement of figure elements. To address this, this package uses geometric primitives and constraints to represent and position figure elements.

It consists of:

  • geometric primitives to represent figure elements (for example, a Quadrilateral primitive represents a figure, a Point represents a text anchor, etc.),
  • geometric constraints to position figure elements (for example, Collinear constraints align lines, Length constraints fix line lengths, etc.),
  • a solver to find primitives that satisfy the constraints,
  • and utilities to generate matplotlib figures and axes from the primitives.

Installation

You can install the package from PyPI using

pip install matplotlib-layout

Alternateively, clone the repository into a local drive. Navigate to the project directory and run

pip install .

The package requires numpy, matplotlib, and jax.

How to use

The tutorial notebook in examples/tutorial.ipynb demonstrates the basic usage of the package and explains some of the commonly used geometric constraints. Other examples are also given in the examples folder. The notebook at examples/ten_simple_rules_demo.ipynb contains an interactive demo to recreate figures from "Ten Simple Rules For Better Figures" (Rougier, Droettboom and Bourne 2014).

A summary of how to use the package is shown in the figure below. The process resembles creating and constraining geometry in computer-aided design programs like AutoCAD, SolidWorks, etc. Project logo

Contributing

This project is a work in progress so there are likely bugs and missing features. If you would like to contribute a bug fix, a feature, refactor etc. thank you! All contributions are welcome.

Motivation and Similar Projects

A similar project with a geometric constraint solver is pygeosolve. There is also another project prototype for a constraint-based layout engine for matplotlib MplLayouter, although it doesn't seem active as of 2023.

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc