Skip to main content

A pure python library that implements abstraction of data.

Project description

pyrebel

A pure python library that implements abstraction of data.

Installation

From PyPI

python3 -m pip install --upgrade pyrebel

From source

git clone https://github.com/ps-nithin/pyrebel
cd pyrebel
python3 -m pip install .

Running demo programs

Demo programs are located in 'demo/' directory.
cd demo/

1. Image abstraction demo

Usage:
python3 pyrebel_main.py --input <filename.png>
Optional arguments
--abs_threshold <value> Selects the threshold of abstraction. (Defaults to 5)

For example,
python3 pyrebel_main.py --input images/abc.png --abs_threshold 10
The output is written to 'output.png'

To write layers to file use the following,
python3 pyrebel_main_layers.py --input images/abc.png
This will save the files as layer-3.png, layer-4.png etc.

2. Edge detection demo

This is a demo of edge detection achieved using data abstraction.
Usage:
python3 pyrebel_main_edge.py --input <filename>

For example,
python3 pyrebel_main_edge.py --input images/wildlife.jpg

The output is written to 'output.png'. Below is a sample input image,


Below is the output image,



See how edge detection works here

3. 2D sketch demo

This is a demo of 2D sketch formation using data abstraction.
Usage:
python3 pyrebel_main_vision.py --input <filename>

Optional arguments for tweaking the result,

  1. --edge_threshold <value> Selects the threshold of edge detection.(Defaults to 5)
  2. --abs_threshold <value> Selects the threshold of output abstraction. (Defaults to 10)
  3. --bound_threshold <value> Selects the threshold of boundary size. (Defaults to 100)

For example,
python3 pyrebel_main_vision.py --input images/lotus.jpg

Below is a sample input image,


Below is the output image,

4. Abstract painting

This is a demo of abstract painting using data abstraction. The output of edge detection is painted to obtain the desired output.
Usage:
python3 pyrebel_main_paint.py --input <filename>

Optional arguments for tweaking the result,

  1. --edge_threshold <value> Selects the threshold of edge detection. (Defaults to 10).
  2. --paint_threshold <value> Selects the threshold of painting. (Defaults to 5).
  3. --block_threshold <value> Selects the threshold of block size. (Defaults to 20).

    For example,
    Running python3 pyrebel_main_paint.py --input images/elephant.jpg --edge_threshold 10 --block_threshold 50 --paint_threshold 1

    Below is the sample input image,


    Below is the output image,

5. Pattern recognition demo

This is a demo of pattern recognition achieved using data abstraction.

  1. Learning
    Usage: python3 pyrebel_main_learn_multiple.py --learn /path/to/image/directory/
    For example running python3 pyrebel_main_learn_multiple.py --learn images/train-hand/ learns all the images in the directory and links the filename with the signatures.

  2. Recognition
    Usage: python3 pyrebel_main_learn_multiple.py --recognize <filename>
    For example running python3 pyrebel_main_learn_multiple.py --recognize images/recognize.png displays the symbols recognized in the file 'images/recognize.png'.

Optional arguments,

  1. --abs_threshold <value> Selects the threshold of abstraction. (Defaults to 5)

The output is written to 'output_text.png'. To reset the knowledge base just delete file 'know_base.pkl' in the current working directory.
See how the program learns and recognizes patterns here

Docs here

Read more here

Let the data shine!

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

pyrebel-1.2.6.tar.gz (56.7 kB view details)

Uploaded Source

File details

Details for the file pyrebel-1.2.6.tar.gz.

File metadata

  • Download URL: pyrebel-1.2.6.tar.gz
  • Upload date:
  • Size: 56.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for pyrebel-1.2.6.tar.gz
Algorithm Hash digest
SHA256 094ac54b820b2ab740013e39072b2c8e736c023b6060ae16c4b291e904973132
MD5 b3d17ede19d7d3db8670f484c8e6055e
BLAKE2b-256 efa71666d6157332b03e753668808ae3550097b46b88e131e7757581a0e3e85d

See more details on using hashes here.

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