Skip to content

The idea of the application is color quantization which is to reduce the number of colors in a full-resolution digital color image (24 bits per pixel) to a smaller set of representative colors called a color palette.

Notifications You must be signed in to change notification settings

YousefSameh25/Image_Quantization

Repository files navigation

Image Color Quantization

Table of Contents

What is Image Quantization?

Overview

The idea of color quantization is to reduce the number of colors in a full-resolution digital color image (24 bits per pixel) to a smaller set of representative colors called color palette. Reduction should be performed so that the quantized image differs as little as possible from the original image. The algorithmic optimization task is to find such a color palette that the overall distortion is minimized.

Example of a 24-bit color image quantized to 16 colors:

fig1

Some Usages

  1. Target different devices: Color quantization is critical for displaying images with many colors on devices that can only display a limited number of colors, usually due to memory limitations.

  2. Image compression: by reducing the number of bits per pixel without affecting the image view. It’s used as a step in the compression pipeline of most common formats like JPEG and MPEG.

  3. Image segmentation: is the process of extracting useful objects from an image. It is usually done by assigning a label to every pixel in an image such that pixels with the same label share certain characteristics (e.g. same colors). Examples are shown in the figure below:fig2

Main Steps

Color quantization consists of two main steps:

  1. Palette Generation: A palette generation algorithm finds a smaller representative set of colors C = {c1,c2,c3,…,ck} from the D distinct colors.

  2. Quantization: by mapping the original colors to the palette colors.

Image Quantization Algorithm

To Apply the Single-linkage Clustering algorithm to the Image Quantization Problem, we need to:

1. Find the distinct colors D = {d1, d2, d3 ….dm} from the input image. Can be known from the image histogram.

2. Construct a fully-connected undirected weighted graph G with

  • D vertices (number of distinct colors).

  • Each pair of vertices is connected by a single edge.

  • Edge weight is set as the Euclidean Distance between the RGB values of the 2 vertices.

Example:

fig3

3. Construct a minimum-spanning-tree algorithm (a greedy algorithm in graph theory)

We choose Prim's Algorithm

  • Input: connected undirected weighted graph

  • Output: a tree that keeps the graph connected with minimum total cost

  • Methodology: treats the graph as a forest and each node is initially represented as a tree. A tree is connected to another only and only if it has the least cost among all available.

  • Conclusion: The Minimum Spanning Tree is an implementation of a single linkage clustering Strategy that repeats merging distinct points with minimal distances into a single cluster

After executing the Minimum Spanning tree of the Distinct Color Graph will be: fig4

4. Extract the desired number of clusters (K) with maximum distances between each other.

5. Find the representative color of each cluster.

6. Quantize the image by replacing the colors of each cluster with its representative color.

fig5

About

The idea of the application is color quantization which is to reduce the number of colors in a full-resolution digital color image (24 bits per pixel) to a smaller set of representative colors called a color palette.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages