Skip to main content

Figure Generator

Project description

Figure Generator

This is an awesome figure generator. It generates figures in pdf-, html- and pptx-format. The following image shows the output of one of our test files ("tests/pool.py"):

This tool might help not only to create final figures, but also to analyze images faster: We offer a bunch of error metrics that allows not only to compare images visually but also mathematically.

Why did we create a figure generator?

In rendering research, it is quite common to create figures of "comparison"-type. Meaning, that we start with a set of generated images, that needs to be compared. Often, one rendered scene is not enough, therefore, we need several comparison figures - preferably in a similar or same style as the other created figures.

We support grids (images that are grid-like arranged) and simple line-plotting. To get a further understanding what grids are, you might want to have a look at our tutorial (Tutorial.ipynb).

Dependencies

Mandatory:

  • Python 3.11+ with opencv-python, simpleimageio, and texsnip

Optional:

  • For the .pdf backend: pdflatex (in path) with at least: tikz, calc, standalone, fontenc, libertine, inputenc.
  • For the .pptx backend: python-pptx
  • To include pdf files as image data: PyPDF2, and pdf2image (which requires poppler).

Quickstart

You can install the figure generator and all mandatory dependencies with a simple:

python -m pip install figuregen

The fastest way to get a first figure is by using an existing template:

import simpleimageio as sio
import figuregen
from figuregen.util.templates import CropComparison
from figuregen.util.image import Cropbox

figure = CropComparison(
    reference_image=sio.read("images/pool/pool.exr"),
    method_images=[
        sio.read("images/pool/pool-60s-path.exr"),
        sio.read("images/pool/pool-60s-upsmcmc.exr"),
        sio.read("images/pool/pool-60s-radiance.exr"),
        sio.read("images/pool/pool-60s-full.exr"),
    ],
    crops=[
        Cropbox(top=100, left=200, height=96, width=128, scale=5),
        Cropbox(top=100, left=450, height=96, width=128, scale=5),
    ],
    scene_name="Pool",
    method_names=["Reference", "Path Tracer", "UPS+MCMC", "Radiance-based", "Ours"]
)

# here you can modify the figure layout and data
# ...

# Generate the figure with the pdflatex backend and default settings
figuregen.figure([figure.figure_row], width_cm=17.7, filename="pool_with_template.pdf")

The template simply creates a list of Grid objects that can be modified and extended arbitrarily before passing it to the figure() function.

Examples and inspiration for creating your own figure layouts can be found in our examples or the Jupyter tutorial.

Examples

Clicking on an image below leads to the test that created the corresponding figure.

Vertical stacks

Split Comparison

Crop Comparison

Plots

Grid with titles, labels, markers, and frames

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

figuregen-1.3.3.tar.gz (68.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

figuregen-1.3.3-py3-none-any.whl (72.3 kB view details)

Uploaded Python 3

File details

Details for the file figuregen-1.3.3.tar.gz.

File metadata

  • Download URL: figuregen-1.3.3.tar.gz
  • Upload date:
  • Size: 68.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for figuregen-1.3.3.tar.gz
Algorithm Hash digest
SHA256 b1f6dd82d5f16fe8ab1dbc46c2f38c98d26af92106480ad487fccc8374aecf5b
MD5 0a340b3a42159825b6a5090897446b7b
BLAKE2b-256 5c85ab57ea6360a32ee0372705269efb6ddc767fd1bcb92c1518c59bef93c9dc

See more details on using hashes here.

Provenance

The following attestation bundles were made for figuregen-1.3.3.tar.gz:

Publisher: publish.yml on Mira-13/figure-gen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file figuregen-1.3.3-py3-none-any.whl.

File metadata

  • Download URL: figuregen-1.3.3-py3-none-any.whl
  • Upload date:
  • Size: 72.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for figuregen-1.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ad94978ce8bfb5201fece6e02a7fb4c72ad73b2fc541b85b6019d97b2386e076
MD5 80e13dde2a3267f6446d8a3a76e30186
BLAKE2b-256 888145852099ccc131aec061cafa2a1e57ed400926085ef329abfcc6d4cd00a1

See more details on using hashes here.

Provenance

The following attestation bundles were made for figuregen-1.3.3-py3-none-any.whl:

Publisher: publish.yml on Mira-13/figure-gen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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