Skip to main content

An annotation tool to allow binary px-based labels.

Project description

PiPrA (Pixel Precise Annotator)

PyPI Version Documentation Status

PiPrA Logo

PiPrA allows to label data in a binary fashing (fore-and background) pixel-precisely, using painting or flood filling. It opens tiff stacks and videos (as supported by imageio mimread), and can operate on single frames.

To try out the PiPrA tool, simple close the Open File dialog, to get some dummy data.

How to get PiPrA

> pip install pipra

And then you can execute it by just writing

> pipra

Dependencies

  • PyQt5 (in Anaconda)
  • ImageIO (in Anaconda)
  • Scikit-image (in Anaconda)
  • flammkuchen (pip install flammkuchen)
  • PyQtGraph (pip install pyqtgraph)

Works with the latest libraries much better (PyQt5==5.15.4, pyqtgraph==0.12.1, python==3.7.10).

How it works

  1. Open a video or a folder with images (currently, PiPrA is looking for PNGs only)
  2. The brush is by default magenta, the foreground green, you can change these colors in the settings, and you are able to save and restore old settings.
  3. Draw with left mouse click, you can paint a larger surface by keeping the left mouse button pressed. Alternatively: you may use the outline mode for large areas (see shortcuts below) or the GrabCut mode to estimate the foreground in a drawn rectangle.
  4. Remove area with right mouse click with given brush size
  5. Use the mouse wheel to zoom in/out
  6. Adjust contrast/brightness by adjusting the levels on the right hand side. These settings are kept for the entire video.
  7. To move the scene, keep the Shift key pressed.
  8. For flood fill mode, keep Ctrl pressed, and click on the desired seed pixel.

Drawing modalities

Specifically, PiPrA offers four different annotation modalities:

a) brush b) outline c) flood fill d) GrabCut

Different drawing modalities

Saving and Exporting

Everything is stored as HDF5 file, the dimensions are (z/time, x, y), dtype is boolean. Use flammkuchen or PyTables to read the file. Also, when annotating a folder, it contains a list of the filenames in the same order as the masks.

You can also export masks to a more common format, such as TIF files or MP4 (Ctrl+E).

Shortcuts

These shortcuts make your life much easier:

  • X to remove the mask
  • Ctrl+Left Click flood fill, seeded with the clicked px
  • Shift+Left Click+Mouse move Move scene
  • Ctrl+Z go back in history
  • Ctrl+S save mask/segmentation
  • C copy mask from previous frame
  • Q toggle mask on/off
  • W, A, S, D to change frame forward (W, D)/backward (A, S)
  • M change brush from circle to block
  • O change brush to outline mode: Draw outline around ROI, then the inside will be filled
  • P change brush to grabcut mode: Draw rectangle around ROI, GrabCut estimates the foreground
  • 2 make brush smaller (as small as 1 px)
  • 8 make brush bigger

New shortcuts

  • Space pressed+Left Click+Mouse move Move scene (similar to photoshop)
  • Ctrl+Mouse wheel change frame forward (wheel up) and backward (wheel down)
  • Ctrl+E Export segmentation as TIF or MP4
  • Ctrl+O Open file

Acknowledging PiPrA

We have not published PiPrA yet. To acknowledge PiPrA, please use currently the following citation:

Gómez, P.*, Kist, A.M.*, Schlegel, P. et al. BAGLS, a multihospital Benchmark for Automatic Glottis Segmentation. Sci Data 7, 186 (2020). https://doi.org/10.1038/s41597-020-0526-3

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

pipra-0.3.2.tar.gz (15.6 kB view details)

Uploaded Source

Built Distribution

pipra-0.3.2-py3-none-any.whl (26.8 kB view details)

Uploaded Python 3

File details

Details for the file pipra-0.3.2.tar.gz.

File metadata

  • Download URL: pipra-0.3.2.tar.gz
  • Upload date:
  • Size: 15.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.7.10

File hashes

Hashes for pipra-0.3.2.tar.gz
Algorithm Hash digest
SHA256 00496a9cf7e89d5eba0ba8108c3103ce5e2b84595190a782b72539f709e67b23
MD5 59637ca0f5d183b6d0288249e80abbc6
BLAKE2b-256 a69699aae79589a885f93c7100efd73d62b6297deaa00dda53cbc5412ce4ad5b

See more details on using hashes here.

File details

Details for the file pipra-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: pipra-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 26.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.7.10

File hashes

Hashes for pipra-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fbca3cee29081e7541e9886456e175f4f509542e7cee8b9ff726867dc714ba2c
MD5 73ef3c33af9af29c0e286689af3f7fb2
BLAKE2b-256 73da6217ad55a1fa58d3de4e9577b4ff110d2b61fde1da27dc1eb2c8a89c44bf

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