Skip to main content

Color prediction Python library used to find the main colors in an image.

Project description

Python Color Prediction

This project aims to predict the color of an image using Python. It utilizes machine learning algorithms, specifically k-means clustering, to analyze the pixel values of an image and predict the dominant color.

K-means clustering is a popular unsupervised learning algorithm used for clustering data points into groups. In the context of color prediction, k-means clustering is used to group similar pixel values together, allowing us to identify the dominant color in an image. The algorithm works by iteratively assigning each pixel to the cluster with the closest centroid, and then updating the centroids based on the new assignments. This process continues until the centroids no longer change significantly. By applying k-means clustering to the pixel values of an image, we can identify the cluster centroids, which represent the dominant colors. To use this project, simply follow the installation instructions below.

Installation

To get started with the Python color prediction function, simply install the package using pip and follow the provided documentation for configuration and usage instructions. Thereafter, import the function into your own python file. The package can be found on PyPi.

  • installation using pip: pip install uugai_python_color_prediction
  • python import: from uugai_python_color_prediction.ColorPrediction import ColorPrediction

Usage

The find_main_colors function is used to predict the dominant colors of an image. It takes several parameters:

  • image: The input image for color prediction, using cv2.imread(IMAGE_PATH).
  • coding: The colorsystem used, supported is BGR (standard), RGB, BGRA and RGBA.
  • min_clusters and max_clusters: The minimum and maximum number of clusters to use for k-means clustering.
  • downsample_factor: A factor used to downsample the image before color prediction. Default value is 0.
  • increase_elbow: An optional parameter to increase/decrease the elbow point in the k-means clustering algorithm. Default value is 0.
  • verbose: A boolean value indicating whether to print verbose output during color prediction. Default value is False.
  • plot: A boolean value indicating whether to plot the color prediction results. Default value is False.

To use the find_main_colors function, simply pass the required parameters and call the function. The function will return the predicted dominant colors of the image, optimal number of centroids ± the elbow offset and the percentages of pixels belonging to that centroid.

Alpha channel additonal details

  • If RGBA or BGRA is used, pixels with full transparancy are removed for clustering. This allows the color detection to work with for example masked images from segmentation models. For pixels with alpha values different from 0, the color channels are used for clustering in 3D space. This means pixels with the same color but altering alpha values are classified as identical.

  • The downsampling creates artifacts when used together with RGBA or BGRA color systems. It is recommended not to use the build in downsampling method provided for RGBA or BGRA images. This issue may be fixed in later versions.

Usage example

from uugai_python_color_prediction.ColorPrediction import ColorPrediction

IMAGE_PATH = 'python_color_prediction/data/flowers.jpeg'

# Read the image
image = cv2.imread(IMAGE_PATH)

# Call the elbow_method function
optimal_centroids, optimal_k, optimal_percentages = ColorPrediction.find_main_colors(image, min_clusters=1, max_clusters=10, downsample_factor=0.95, increase_elbow=0, verbose=True, plot=True)

This would result in the following output, with verbose = True:

Calculating for k =  1
Calculating for k =  2
Calculating for k =  3
Calculating for k =  4
Calculating for k =  5
Calculating for k =  6
Calculating for k =  7
Calculating for k =  8
Calculating for k =  9
Calculating for k =  10
The optimal number of clusters is:  3
The colors associated with each cluster are: 
 [[ 54  35  24]
 [125  34 209]
 [200 138  98]]
The percentage of points in each cluster are:  [43 29 27]

The plotting parameter enables the creation of a KMeans-clustering inertia plot, which is used for the elbow method. Additionally, it generates a 3D scatter plot of the pixel values, displaying the cluster centroids in their corresponding colors. Finally, it includes a small plot showing the centroid colors along with their respective percentages.

Flowers plot

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

uugai_python_color_prediction-2.1.0.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file uugai_python_color_prediction-2.1.0.tar.gz.

File metadata

File hashes

Hashes for uugai_python_color_prediction-2.1.0.tar.gz
Algorithm Hash digest
SHA256 df32654adb14fe4eb3736b4459187e64d2c05a3699a53d811f82356ecb6b235c
MD5 4f7b36037d9658d5a4c018821eb3b8c8
BLAKE2b-256 1e0bf9c3a01ee1a6e8ec2d8390aa6e012dfce812f17b045bf8a1b0941df5cd4b

See more details on using hashes here.

File details

Details for the file uugai_python_color_prediction-2.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for uugai_python_color_prediction-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 10bb3ec7ac9b3b6d5b1bcd399b4cfbf0eb4e29b17470475cf892e380d396703a
MD5 8c796e229d88338d404dbd83459f546e
BLAKE2b-256 d2ee19c0fabaee4a9d04a285c94f6629681c4884b932c18690bd7888979d1370

See more details on using hashes here.

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