Silhouettenkoeffizient

Silhouettenkoeffizient

Die Silhouette gibt für eine Beobachtung an, wie gut die Zuordnung zu den beiden nächstgelegenen Clustern ist. Der Silhouettenkoeffizient gibt ein von der Cluster-Anzahl unabhängige Maßzahl für die Qualität eines Clusterings an. Der Silhouettenplot visualisiert sowohl alle Silhouetten eines Datensatzes als auch die Silhouettenkoeffizient für die einzelnen Cluster und den Gesamtdatensatz.

Inhaltsverzeichnis

Silhouette

Strukturierung Wertebereich von S(o)
stark 0{,}75<S(o)\leq 1
mittel 0{,}5<S(o)\leq 0{,}75
schwach 0{,}25<S(o)\leq 0{,}5
keine Struktur 0<S(o)\leq0{,}25

Gehört das Objekt o zum Cluster A so ist die Silhouette von o definiert als:

S(o) = \begin{cases} 0 & \text{ wenn } \operatorname{dist}(A,o)=0 \\ \frac{\operatorname{dist}(B,o)-\operatorname{dist}(A,o)}{\max\{\operatorname{dist}(A,o),\,\operatorname{dist}(B,o)\}} & \text{ sonst } \end{cases}

mit \operatorname{dist}(A,o) die Distanz eines Objekts o zum Cluster A und \operatorname{dist}(B,o) die Distanz eines Objekts o zum nächstgelegenen Cluster B. Dabei wird die Differenz des Abstände \operatorname{dist}(B,o)-\operatorname{dist}(A,o) gewichtet mit der maximalen Distanz. Damit folgt, dass S(o) für ein Objekt o zwischen −1 und 1 liegt:

  • Ist die Silhouette S(o) < 0, dann liegen die Objekte des nächstgelegene Clusters B näher an dem Objekt o als die Objekte des Clusters A zu dem das Objekt o gehört. Dies weist darauf hin, dass das Clustering verbessert werden kann.
  • Ist die Silhouette S(o)\approx 0, dann liegt das Objekt zwischen zwei Clustern und
  • ist die Silhouette nahe bei Eins, so liegt das Objekt in einem Cluster.

Die Distanz \operatorname{dist}(A,o) wird berechnet als

\operatorname{dist}(A,o)=\frac{1}{n_A} \sum_{a \in A} \operatorname{dist}(a, o)

als der Mittelwert der Distanz zwischen allen Objekten im Cluster A und dem Objekt o (nA ist die Anzahl der Objekte im Cluster A). Analog wird die Distanz zum nächstgelegenen Cluster B berechnet als die minimale durchschnittliche Distanz

\operatorname{dist}(B,o)=\min_{C\neq A}\underbrace{\left(\frac{1}{n_C} \sum_{c \in C} \operatorname{dist}(c, o)\right)}_{=\operatorname{dist}(C,o)}.

Dabei wird für alle Cluster C, die das Objekt o nicht enthalten, die Distanz \operatorname{dist}(C,o) berechnet. Der nächstgelegene Cluster B ist derjenige, der die kleinste Entfernung \operatorname{dist}(C,o) aufweist.

Silhouettenkoeffizient

Der Silhouettenkoeffizient sC ist definiert als

s_C =\tfrac1{n_C} \sum_{o\in C} s(o)

also als das arithmetische Mittel aller nC Silhouetten des Clusters C definiert. Der Silhouettenkoeffizient kann für jeden Cluster oder für den Gesamtdatensatz berechnet werden.

Beim k-means- oder k-medoid-Algorithmus an kann man mit ihm die Ergebnisse mehrerer Durchläufe des Algorithmus vergleichen um das beste Ergebnis zu behalten. Dies bietet sich insbesondere für die genannten Algorithmen an, da sie randomisiert starten und so unterschiedliche lokale Maxima finden können. Der Einfluss des Parameters k kann so reduziert werden, da der Silhouettenkoeffizient von der Cluster-Anzahl unabhängig ist, und somit Ergebnisse vergleichen kann die mit unterschiedlichen Werten für k erhalten wurden.

Silhouettenplot

Norm silhouette.png

Die grafische Darstellung der Silhouetten erfolgt für alle Beobachtungen gemeinsam in einem Silhouettenplot. Für alle Beobachtungen, die zu einem Cluster gehören, wird der Wert der Silhouette als waagerechte (oder senkrechte) Linie dargestellt. Die Beobachtungen in einem Cluster werden dabei nach der Größe der Silhouetten geordnet.

In der rechten Grafiken werden für vier verschiedene Datensätze die Daten, das Dendrogramm für eine hierarchische Clusteranalyse (euklidische Distanz, Single-Linkage) und der Silhouettenplot für die Lösung mit zwei Clustern dargestellt (von oben nach unten). Die Zuordnung der Datenpunkte durch die hierarchische Clusteranalyse in der Zwei-Clusterlösung wird durch die Farben rot (Zuordnung zu Cluster 1) und blau (Zuordnung zu Cluster 2) symbolisiert.

Je besser die beiden Cluster in den Daten getrennt sind (von links nach rechts), desto besser kann die hierarchische Clusteranalyse die Datenpunkte korrekt zuordnen. Auch der Silhouettenplot verändert sich. Während für den linken Datensatz negative Silhouetten vorkommen, finden sich im ganz rechten Datensatz nur positive Silhouetten. Auch die Silhouettenkoeffizienten werden von links nach ganz rechts, sowohl für die einzelnen Cluster als auch für den gesamten Datensatz größer.

Beispiel

Anderson's Iris data set.png

Der Iris flower-Datensatz besteht aus jeweils 50 Beobachtungen dreier Arten von Schwertlilien (Iris Setosa, Iris Virginica und Iris Versicolor), an denen jeweils vier Attribute der Blüten erhoben wurden: Die Länge und die Breite des Sepalum (Kelchblatt) und des Petalum (Kronblatt). Rechts zeigt eine Streudiagramm-Matrix die Daten für die vier Variablen.

Dendrogramm und Silhouettenplot für eine zwei, drei und vier Clusterlösung.

Für die vier Grössen wurde eine hierarchische Clusteranalyse mit der euklidischen Distanz und der Single-Linkage Methode durchgeführt. Oben sind folgenden Grafiken dargestellt:

  • Links oben: Ein Dendrogramm der Clusterlösung, hier sieht man das eine zwei oder vier Clusterlösung gut wäre.
  • Rechts oben: Grafische Darstellung der Silhouetten der zwei Clusterlösung. Im ersten Cluster sind negative Silhouetten S(o) zu finden, so dass diese Beobachtungen eher falsch zugeordnet sind. Eventuell ist eine Lösung mit mehr Clustern besser geeignet.
  • Links unten: Grafische Darstellung der Silhouetten der drei Clusterlösung. Der erste Cluster in wird in zwei Subcluster zerlegt (78 = 50 + 28); zwar sind im ersten Cluster die negativen Silhouetten verschwunden, jedoch haben Beobachtungen im zweiten Cluster nun negative Silhouetten.
  • Rechts unten: Grafische Darstellung der Silhouetten der vier Clusterlösung. Der zweite Cluster von der zwei Clusterlösung wird nun in zwei Teilcluste aufgeteilt (72 = 60 + 12), es gibt fast keine negativen Silhouetten mehr.

Es ergeben sich folgende Silhouettenkoeffizienten

Silhouettenkoeffizienten
nC / sC
Anzahl Cluster Total
2 150 / 0,52 78 / 0,39 72 / 0,66
3 150 / 0,51 50 / 0,76 28 / 0,59 72 / 0,31
4 150 / 0,50 50 / 0,76 28 / 0,52 60 / 0,27 12 / 0,51

Literatur

Weblinks

  • silhouette: Berechnen von Silhouettenkoeffizienten und -plots mit R.

Wikimedia Foundation.

Игры ⚽ Поможем решить контрольную работу

Schlagen Sie auch in anderen Wörterbüchern nach:

  • Cluster (Informatik) — Als Cluster bezeichnet man in der Informatik und Statistik eine Gruppe von Datenobjekten mit ähnlichen Eigenschaften. Die Menge der in einem Datensatz gefundenen Cluster bezeichnet man als Clustering, Verfahren zur Berechnung einer solchen… …   Deutsch Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”