Skip to main content

Use interactive matplotlib to label images for classification

Project description

mpl-image-labeller

Binder Documentation Status

License PyPI Python Version

Use Matplotlib to label images for classification. Works anywhere Matplotlib does - from the notebook to a standalone gui!

For more see the documentation.

Install

pip install mpl-image-labeller

Key features

  • Simple interface
  • Uses keys instead of mouse
  • Only depends on Matplotlib
    • Works anywhere - from inside Jupyter to any supported GUI framework
  • Displays images with correct aspect ratio
  • Easily configurable keymap
  • Smart interactions with default Matplotlib keymap
  • Callback System (see examples/callbacks.py)

single class per image

gif of usage for labelling images of cats and dogs

multiple classes per image

gif of usage for labelling images of cats and dogs

Usage

import matplotlib.pyplot as plt
import numpy as np

from mpl_image_labeller import image_labeller

images = np.random.randn(5, 10, 10)
labeller = image_labeller(
    images, classes=["good", "bad", "meh"], label_keymap=["a", "s", "d"]
)
plt.show()

accessing the axis You can further modify the image (e.g. add masks over them) by using the plotting methods on axis object accessible by labeller.ax.

Lazy Loading Images If you want to lazy load your images you can provide a function to give the images. This function should take the integer idx as an argument and return the image that corresponds to that index. If you do this then you must also provide N_images in the constructor to let the object know how many images it should expect. See examples/lazy_loading.py for an example.

Controls

  • <- move one image back
  • -> move one image forward

To label images use the keys defined in the label_keymap argument - default 0, 1, 2...

Get the labels by accessing the labels property.

Overwriting default keymap

Matplotlib has default keybindings that it applied to all figures via rcparams.keymap that allow for actions such as s to save or q to quit. If you inlcude one of these keys as a shortcut for labelling as a class then that default keymap will be disabled for that figure.

Related Projects

This is not the first project to implement easy image labelling but seems to be the first to do so entirely in Matplotlib. The below projects implement varying degrees of complexity and/or additional features in different frameworks.

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

mpl_image_labeller-1.1.2.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

mpl_image_labeller-1.1.2-py2.py3-none-any.whl (11.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file mpl_image_labeller-1.1.2.tar.gz.

File metadata

  • Download URL: mpl_image_labeller-1.1.2.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.0

File hashes

Hashes for mpl_image_labeller-1.1.2.tar.gz
Algorithm Hash digest
SHA256 b858ad13b6fc822ce6ef5319f16cfb81c48af12eeef571d81afb612d05b03181
MD5 6cc220da2a8c4ab440685db7c5b1a4db
BLAKE2b-256 b2a4147e4bc6074e648908c10cf6b39ebd6dcd176752715825be2056c86efc01

See more details on using hashes here.

File details

Details for the file mpl_image_labeller-1.1.2-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for mpl_image_labeller-1.1.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e541208d47253cf337799fa788249aaa9f4088ee75504d847954a8d52e19620a
MD5 6655d2c344fd0452c2b1293b27b32155
BLAKE2b-256 95372a15676e22fd00beb62368886eb47b18de42c89a40d6c279eb5429e37a9a

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