Lightweight package meant to simplify data processing for Deep Learning
Project description
Melon
Melon is a lightweight package meant to simplify data processing for Deep Learning.
It removes the need for boilerplate code to pre-process the data prior to (model) training, testing and inference.
It aims at standardizing data serialization and manipulation approaches.
The default formats align with the requirements by frameworks such as Tensorflow / PyTorch.
The tool also provides various level of customizations depending on the use-case.
Installation
Install and update using pip:
$ pip install melon
Supported in Python >=3.4.0
Examples
Images
With default options:
from melon import ImageReader
def train():
source_dir = "resources/images"
reader = ImageReader(source_dir)
X, Y = reader.read()
...
with tf.Session() as s:
s.run(..., feed_dict = {X_placeholder: X, Y_placeholder: Y})
source_dir directory should contain images that need to be read. See tests/resources/images/sample for a sample directory. In the sample directory there is an optional labels.txt file that is described in Labeling.
Since number of images may be too large to fit into memory the tool supports batch-processing.
from melon import ImageReader
def train():
source_dir = "resources/images"
options = { "batch_size": 32 }
reader = ImageReader(source_dir, options)
while reader.has_next():
X, Y = reader.read()
...
This reads images in the batches of 32 until all images are read. If batch_size is not specified then reader.read() will read all images.
With custom options:
from melon import ImageReader
def train():
source_dir = "resources/images"
options = { "data_format": "channels_last", "normalize": False }
reader = ImageReader(source_dir, options)
...
This changes format of data to channels-last (each sample will be Height x Width x Channel) and doesn’t normalize the data. See options for available options.
Options
Images
- width
Width of the output (pixels). default: 255
- height
Height of the output (pixels). default: 255
- batch_size
Batch size of each read. default: All images in a directory
- data_format
Format of the images data
channels_first - Channel x Height x Width (default)channels_last - Height x Width x Channel- label_format
Format of the labels data
one_hot - as a matrix, with one-hot vector per image (default)label - as a vector, with a single label per image- normalize
Normalize data. default: True
- num_threads - number of threads for parallel processing
default: Number of cores of the machine
Labeling
In supervised learning each image needs to be mapped to a label.
While the tool supports reading images without labels (e.g. for inference) it also provides a way to label them.
Generating labels file
To generate labels file use the following command:
$ melon generate
> Source dir:
After providing source directory the tool will generate labels file in that directory with blank labels.
Final step is to add a label to each row in the generated file.
For reference see tests/resources/images/sample/labels.txt:
#legend
pedestrian:0
cat:1
parrot:2
car:3
apple tree:4
#map
img275.jpg:1
img324.jpg:2
img551.jpg:3
img928.jpg:1
img999.png:0
img736.png:4
#legend section is optional but #map section is required to map a label to an image.
Format of the labels
Label’s format can be specified in Custom options. It defaults to one-hot format.
Roadmap
Support for video data
Support for textual data
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
melon-0.0.6.tar.gz
(7.7 kB
view details)
Built Distribution
melon-0.0.6-py3-none-any.whl
(15.0 kB
view details)
File details
Details for the file melon-0.0.6.tar.gz
.
File metadata
- Download URL: melon-0.0.6.tar.gz
- Upload date:
- Size: 7.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.6.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0401863f9900d1b80c4a5b89e9c87eb79c720585f74223d6eafa0e7d8672ad1e |
|
MD5 | 5e24cd325b66806b486993c66c24ff18 |
|
BLAKE2b-256 | 55680380b173b5e35575c7bf23c4cea928bf4f6f33a140d9a44d85bb48500c85 |
File details
Details for the file melon-0.0.6-py3-none-any.whl
.
File metadata
- Download URL: melon-0.0.6-py3-none-any.whl
- Upload date:
- Size: 15.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.29.0 CPython/3.6.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fff316ad4f54611fe78673644c10fae798b7b7d61950f4e665e968963a366189 |
|
MD5 | a71e8a418be692ef685fefd1a4ba30a1 |
|
BLAKE2b-256 | 93af3ad5023ee63761d051dcfb5a952b58b190af8c00b440b034b2e4dad0c9c4 |