Skip to main content

A python package to assist visualization of image manipulation signatures

Project description

UNCONCEALED

A series of tools and Jupyter widgets for evaluating images, to aid in forensic investigation or reporting. Unconcealed allows you to apply a series of transformations to a directory of images, allowing you to visualize evidence of image splicing or duplication.

How it works

The primary feature of Unconcealed is a Jupyter widget that lets you select images, apply a mask, then access various transformation and visualization tools via tabs.

Widget mask display Widget noise display

The widget also displays a record of all parameters used during an evaluation, allowing for reproducibility of the work.

A specific feature captures and compares contours of image elements (eg Western Blot bands), revealing similarities that may be the result of image duplication.

Widget band similarity output

Installation

Getting started

The basic installation will need you to open your terminal and run:

pip install unconcealed

If you are using Python environments along with Jupyter, make sure that you install unconcealed into an environment accessible as a Jupyter kernel. You can read more about this from the IPython documentation.

Dependencies

To use the full functionality of unconcealed, you will need to separately install the following dependencies.

  • pdfimages (only if you need to use the image extraction feature)
  • Jupyter, Ipywidgets (if you want to use the interactive widget module)

Usage

  1. Start up your Jupyter notebook
  2. Note the directory/s where the images are located
    1. If you need to, you can use unconcealed.extract_from_pdf() to create a directory containing all images from a PDF, with the ability to filter based on image size. This requires separate installation of pdfimages.
  3. Import the widget module:
from unconcealed import widgets
  1. Prepare and load the widget:
load_evaluation_widget(IMAGE_DIRECTORY)
  1. Navigate through the tabs to perform various transformations of the selected image.
  2. Use the first tab to change directory, and select which image to analyze.

How to contribute

We welcome contributions! Even if it is just letting us know about an issue.

If you would like to contribute changes to the code:

  1. Clone repo and create a new branch:

$ git checkout https://github.com/oxpeter/unconcealed -b name_for_new_branch

  1. Make changes and test
  2. Submit Pull Request with comprehensive description of changes

License

This software has been developed under the MIT license

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

unconcealed-0.4.1.tar.gz (19.6 kB view hashes)

Uploaded Source

Built Distribution

unconcealed-0.4.1-py3-none-any.whl (19.6 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