各种凝聚聚类算法在数字的2D嵌入上的应用#

此示例展示了在数字数据集的2D嵌入上进行凝聚聚类时各种链接选项的说明。

此示例的目标是直观地展示度量的行为方式,而不是为数字寻找良好的聚类。这就是为什么此示例在2D嵌入上工作的原因。

此示例向我们展示了凝聚聚类“富者愈富”的行为,它倾向于创建不均匀的聚类大小。

这种行为在平均链接策略中尤为明显,最终会产生几个只有少量数据点的聚类。

单链接的情况甚至更病态,有一个非常大的聚类覆盖了大多数数字,一个中等大小(干净)的聚类包含了大多数零数字,而所有其他聚类则来自周围边缘的噪声点。

其他链接策略会产生更均匀分布的聚类,因此对数据集的随机重采样可能不那么敏感。

  • ward linkage
  • average linkage
  • complete linkage
  • single linkage
Computing embedding
Done.
ward :  0.05s
average :       0.05s
complete :      0.05s
single :        0.02s

# Authors: The scikit-learn developers
# SPDX-License-Identifier: BSD-3-Clause

from time import time

import numpy as np
from matplotlib import pyplot as plt

from sklearn import datasets, manifold

digits = datasets.load_digits()
X, y = digits.data, digits.target
n_samples, n_features = X.shape

np.random.seed(0)


# ----------------------------------------------------------------------
# Visualize the clustering
def plot_clustering(X_red, labels, title=None):
    x_min, x_max = np.min(X_red, axis=0), np.max(X_red, axis=0)
    X_red = (X_red - x_min) / (x_max - x_min)

    plt.figure(figsize=(6, 4))
    for digit in digits.target_names:
        plt.scatter(
            *X_red[y == digit].T,
            marker=f"${digit}$",
            s=50,
            c=plt.cm.nipy_spectral(labels[y == digit] / 10),
            alpha=0.5,
        )

    plt.xticks([])
    plt.yticks([])
    if title is not None:
        plt.title(title, size=17)
    plt.axis("off")
    plt.tight_layout(rect=[0, 0.03, 1, 0.95])


# ----------------------------------------------------------------------
# 2D embedding of the digits dataset
print("Computing embedding")
X_red = manifold.SpectralEmbedding(n_components=2).fit_transform(X)
print("Done.")

from sklearn.cluster import AgglomerativeClustering

for linkage in ("ward", "average", "complete", "single"):
    clustering = AgglomerativeClustering(linkage=linkage, n_clusters=10)
    t0 = time()
    clustering.fit(X_red)
    print("%s :\t%.2fs" % (linkage, time() - t0))

    plot_clustering(X_red, clustering.labels_, "%s linkage" % linkage)


plt.show()

脚本总运行时间: (0 minutes 1.543 seconds)

相关示例

在玩具数据集上比较不同的分层链接方法

在玩具数据集上比较不同的分层链接方法

手写数字上的流形学习:局部线性嵌入、Isomap…

手写数字流形学习:局部线性嵌入、Isomap...

有结构和无结构的分层聚类

有结构和无结构的分层聚类

可视化股票市场结构

可视化股票市场结构

由 Sphinx-Gallery 生成的图库