Skip to main content

Digitize plots and extract trajectories.

Project description

[![Build Status](https://travis-ci.org/dilawar/PlotDigitizer.svg?branch=master)](https://travis-ci.org/dilawar/PlotDigitizer) [![PyPI version](https://badge.fury.io/py/PlotDigitizer.svg)](https://badge.fury.io/py/PlotDigitizer)

# PlotDigitizer

A python (python3) script to digitize plot (Under developement)

# Flow

  1. Remove all the text from the image. Only axis and plot should be left.

This is from MacFadden and Koshland, PNAS 1990. ![](./figures/original.png)

It should be trimmed. Ideally you should also remove the top border. You can use gimp or imagemagick or any other tool for cropping.

![](./figures/trimmed.png)

  1. Then we run the script like this.

` ./plotdigitizer.py -i ./figures/trimmed.png -p 0,0 -p 10,0 -p 0,1 `

Option -i accepts the input file. The important options is the repeating -p options. These are the data-points. We need at least 3 of them to map the axis with pixels in image. In this example, we have given three data-points 0,0, 10,0 and 0,1. We are going to click on these three points on the image later. Make sure to click in the same order.

3. The datapoints will be dumped to a csv file. If –plot option is given from command line, it will also plot the omputed data-points. This requires matplotlib.

![](./figures/traj.png)

Notice the errors near the boxes; since we have not trimmed them.

__IMP:__ Left bottom corner of the image is (0,0).

Once you have clicked on these points, the algorithm will extract the trajectory.

If you already know the location of these coordinates, you can pass them via command line using -l options e.g.

` ./plotdigitizer.py -i ./figures/trimmed.png -p 0,0 -p 10,0 -p 0,1 -l 10,10 -l 200,20 -l 10,27 `

# Limitations

Currently this script has following limitations:

  • Background must not be transparent. It might work with transparent background but I’ve not tested it.

  • Only b/w images are supported for now. Color images will be converted to grayscale upon reading.

  • One image should have only one trajectory.

You might be interested in more versatile [WebPlotDigitizer](https://automeris.io/WebPlotDigitizer/) by Ankit Rohatagi.

# Development

If you enhance the script, feel free to send a PR.

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

PlotDigitizer-0.0.2.linux-x86_64.tar.gz (9.5 kB view hashes)

Uploaded Source

Built Distribution

PlotDigitizer-0.0.2-py3-none-any.whl (8.4 kB view hashes)

Uploaded Python 3

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