Skip to main content

An upper bound of the Average Silhouette Width

Project description

Silhouette Upper Bound

An upper bound of the Average Silhouette Width.

Overview

Evaluating clustering quality is a fundamental task in cluster analysis, and the Average Silhouette Width (ASW) is one of the most widely used metrics for this purpose. ASW scores range from $-1$ to $1$, where:

  • Values near 1 indicate well-separated, compact clusters

  • Values around 0 suggest overlapping or ambiguous cluster assignments

  • Values near -1 imply that many points may have been misassigned

Optimizing the Silhouette score is a common objective in clustering workflows. However, since we rarely know the true global ASW-maximum achievable for a dataset, it's difficult to assess how close a given clustering result is to being globally optimal. Simply comparing to the theoretical maximum of 1 is often misleading, as the structure of the dataset imposes inherent limits on what is achievable.

This project introduces a data-dependent upper bound on the ASW that hopefully can provide a more meaningful reference point than the fixed value of 1. The upper bound helps answer a key question: How close is my clustering result to the best possible outcome on this specific data?

To compute the upper bound, the method requires a dissimilarity matrix as input.

Installation

pip install silhouette-upper-bound

Examples

To help you get started, we provide example scripts demonstrating common use cases. You can find these in the demos/ folder.

Quickstart

import numpy as np
from silhouette_upper_bound import upper_bound

if __name__ == '__main__':

    np.random.seed(42)

    # dummy data
    A = np.random.rand(100, 100)
    D = (A + A.T) / 2
    np.fill_diagonal(D, 0)

    # ASW upper bound
    ub = upper_bound(D)

    print(f"There is no clustering of the data points of D that has a higher Silhouette score than {ub}.")

Experimental results

We evaluate the performance of the upper bound using synthetic datasets generated with scikit-learn’s make_blobs() function. Each dataset is identified by a label of the form n_samples-n_features-centers-cluster_std, which corresponds to the parameters used in the data generation.

The code that generates the results below can be found in experiments/table1.py.

Dataset KMeans ASW ASW upper bound Worst-case relative error
400-64-5-6 0.249 0.376 0.38
400-64-2-2 0.673 0.673 .00
400-128-7-3 0.522 0.566 0.08
1000-161-2-13 0.084 0.182 0.54

Note that the upper bound confirms global optimality for KMeans on dataset 400-64-2-2.

Contribution

Contributions are welcome! If you have suggestions for improvements, bug reports, or new features, feel free to open an issue or submit a pull request.

To contribute:

  1. Fork the repository.
  2. Create a new branch for your feature or fix.
  3. Submit a pull request.

Thank you for helping improve this project!

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

silhouette_upper_bound-0.1.0.tar.gz (88.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

silhouette_upper_bound-0.1.0-py3-none-any.whl (5.2 kB view details)

Uploaded Python 3

File details

Details for the file silhouette_upper_bound-0.1.0.tar.gz.

File metadata

  • Download URL: silhouette_upper_bound-0.1.0.tar.gz
  • Upload date:
  • Size: 88.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.11

File hashes

Hashes for silhouette_upper_bound-0.1.0.tar.gz
Algorithm Hash digest
SHA256 5dd47821e5cc8414a9a8b2f73dfd8b022cbbfde9f0a14b960058b2497dba1868
MD5 263e7798d2abc5c31b82403c7e1d6f65
BLAKE2b-256 38b4218dd70247340c903dfc29101f78959cc1508cf8c6dfc8022697785c2413

See more details on using hashes here.

File details

Details for the file silhouette_upper_bound-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for silhouette_upper_bound-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4c21e16c3381017025616e0bcf1cd4f4f21e4893a11acdc9aca28006bdaceba8
MD5 0e9ed3361436e1379127ed9500170d61
BLAKE2b-256 64876d2e0951bb8dbd4bea6f4d4896844c15df4e716f8dbd2040ae5eb739323e

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