clustering ppt

45
Tutorial On Fuzzy Clustering Jan Jantzen Technical University of Denmark [email protected]

Upload: api-3717234

Post on 11-Apr-2015

3.209 views

Category:

Documents


2 download

TRANSCRIPT

Page 1: Clustering Ppt

Tutorial On Fuzzy Clustering

Jan Jantzen

Technical University of Denmark

[email protected]

Page 2: Clustering Ppt

Abstract

Problem: To extract rules from data Method: Fuzzy c-means Results: e.g., finding cancer cells

Page 3: Clustering Ppt

Cluster (www.m-w.com)

A number of similar individuals that occur together as a: two or more consecutive consonants or vowels in a segment of speech b: a group of houses (...) c: an aggregation of stars or galaxies that appear close together in the sky and are gravitationally associated.

Page 4: Clustering Ppt

Cluster analysis (www.m-w.com)

A statistical classification technique for discovering whether the individuals of a population fall into different groups by making quantitative comparisons of multiple characteristics.

Page 5: Clustering Ppt

Vehicle Example

Vehicle Top speedkm/h

Colour Airresistance

WeightKg

V1 220 red 0.30 1300V2 230 black 0.32 1400V3 260 red 0.29 1500V4 140 gray 0.35 800V5 155 blue 0.33 950V6 130 white 0.40 600V7 100 black 0.50 3000V8 105 red 0.60 2500V9 110 gray 0.55 3500

Page 6: Clustering Ppt

Vehicle Clusters

100 150 200 250 300500

1000

1500

2000

2500

3000

3500

Top speed [km/h]

We

igh

t [k

g] Sports cars

Medium market cars

Lorries

Page 7: Clustering Ppt

Terminology

100 150 200 250 300500

1000

1500

2000

2500

3000

3500

Top speed [km/h]

We

igh

t [k

g] Sports cars

Medium market cars

Lorries

Object or data point

feature

feature space

cluster

feature

label

Page 8: Clustering Ppt

Example: Classify cracked tiles

Page 9: Clustering Ppt

475Hz 557Hz Ok? -----+-----+--- 0.958 0.003 Yes 1.043 0.001 Yes 1.907 0.003 Yes 0.780 0.002 Yes 0.579 0.001 Yes 0.003 0.105 No 0.001 1.748 No 0.014 1.839 No 0.007 1.021 No 0.004 0.214 No

Table 1: frequency intensities for ten tiles.

Tiles are made from clay moulded into the right shape, brushed, glazed, and baked. Unfortunately, the baking may produce invisible cracks. Operators can detect the cracks by hitting the tiles with a hammer, and in an automated system the response is recorded with a microphone, filtered, Fourier transformed, and normalised. A small set of data is given in TABLE 1 (adapted from MIT, 1997).

Page 10: Clustering Ppt

Algorithm: hard c-means (HCM)(also known as k means)

Page 11: Clustering Ppt

Plot of tiles by frequencies (logarithms). The whole tiles (o) seem well separated from the cracked tiles (*). The objective is to find the two clusters.

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 12: Clustering Ppt

1. Place two cluster centres (x) at random.2. Assign each data point (* and o) to the nearest cluster centre (x)

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 13: Clustering Ppt

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

1. Compute the new centre of each class2. Move the crosses (x)

Page 14: Clustering Ppt

Iteration 2

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 15: Clustering Ppt

Iteration 3

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 16: Clustering Ppt

Iteration 4 (then stop, because no visible change)Each data point belongs to the cluster defined by the nearest centre

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 17: Clustering Ppt

The membership matrix M: 1. The last five data points (rows) belong to the first cluster (column)2. The first five data points (rows) belong to the second cluster (column)

M =

0.0000 1.0000

0.0000 1.0000

0.0000 1.0000

0.0000 1.0000

0.0000 1.0000

1.0000 0.0000

1.0000 0.0000

1.0000 0.0000

1.0000 0.0000

1.0000 0.0000

Page 18: Clustering Ppt

Membership matrix M

otherwise

ifm jkikik

0

122

cucu

data point k cluster centre i

distance

cluster centre j

Page 19: Clustering Ppt

c-partition

Kc

iallforUCØ

jiallforØCC

UC

i

ji

c

ii

2

1

All clusters C together fills the

whole universe UClusters do not

overlap

A cluster C is never empty and it is

smaller than the whole universe U

There must be at least 2 clusters in a c-partition and

at most as many as the number of data points K

Page 20: Clustering Ppt

Objective function

c

i Ckik

c

ii

ik

JJ1

2

,1 u

cu

Minimise the total sum of all distances

Page 21: Clustering Ppt

Algorithm: fuzzy c-means (FCM)

Page 22: Clustering Ppt

Each data point belongs to two clusters to different degrees

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 23: Clustering Ppt

1. Place two cluster centres

2. Assign a fuzzy membership to each data point depending on distance

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 24: Clustering Ppt

1. Compute the new centre of each class2. Move the crosses (x)

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 25: Clustering Ppt

Iteration 2

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 26: Clustering Ppt

Iteration 5

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 27: Clustering Ppt

Iteration 10

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 28: Clustering Ppt

Iteration 13 (then stop, because no visible change)Each data point belongs to the two clusters to a degree

-8 -6 -4 -2 0 2-8

-7

-6

-5

-4

-3

-2

-1

0

1

2

log(intensity) 475 Hz

log

(in

ten

sity

) 5

57

Hz

Tiles data: o = whole tiles, * = cracked tiles, x = centres

Page 29: Clustering Ppt

The membership matrix M: 1. The last five data points (rows) belong mostly to the first cluster (column)2. The first five data points (rows) belong mostly to the second cluster (column)

M =

0.0025 0.9975

0.0091 0.9909

0.0129 0.9871

0.0001 0.9999

0.0107 0.9893

0.9393 0.0607

0.9638 0.0362

0.9574 0.0426

0.9906 0.0094

0.9807 0.0193

Page 30: Clustering Ppt

Fuzzy membership matrix M

c

j

q

jk

ik

ik

dd

m

1

1/2

1

ikikd cu

Distance from point k to current cluster centre i

Distance from point k to other cluster centres j

Point k’s membership of cluster i

Fuzziness exponent

Page 31: Clustering Ppt

Fuzzy membership matrix M

ikm

1/21/22

1/21

1/2

1/21/2

2

1/2

1

1

1/2

111

1

1

1

qck

qk

qk

qik

q

ck

ik

q

k

ik

q

k

ik

c

j

q

jk

ik

ddd

d

dd

dd

dd

dd

Gravitation to cluster i relative

to total gravitation

Page 32: Clustering Ppt

Electrical Analogy

R1 R2

i1 i2U

I

I

i

iUI

U

RR

RRR

R

RR

RRR

R

RIU

i

i

i

c

i

i

c

11

111

11

1111

21

21

Same form as mik

Page 33: Clustering Ppt

Fuzzy Membership

1 2 3 4 50

0.5

1

Cluster centres

Mem

bers

hip

of te

st p

oint

o is with q = 1.1, * is with q = 2

Data point

Page 34: Clustering Ppt

Fuzzy c-partition

Kc

iallforUCØ

jiallforØCC

UC

i

ji

c

ii

2

1

All clusters C together fill the whole universe U.

Remark: The sum of memberships for a data point

is 1, and the total for all points is K

Not valid: Clusters do overlap

A cluster C is never empty and it is

smaller than the whole universe U

There must be at least 2 clusters in a c-partition and

at most as many as the number of data points K

Page 35: Clustering Ppt

Example: Classify cancer cells

Normal smear Severely dysplastic smear

Using a small brush, cotton stick, or wooden stick, a specimen is taken from the uterin cervix and smeared onto a thin, rectangular glass plate, a slide. The purpose of the smear screening is to diagnose pre-malignant cell changes before they progress to cancer. The smear is stained using the Papanicolau method, hence the name Pap smear. Different characteristics have different colours, easy to distinguish in a microscope. A cyto-technician performs the screening in a microscope. It is time consuming and prone to error, as each slide may contain up to 300.000 cells.

Dysplastic cells have undergone precancerous changes. They generally have longer and darker nuclei, and they have a tendency to cling together in large clusters. Mildly dysplastic cels have enlarged and bright nuclei. Moderately dysplastic cells have larger and darker nuclei. Severely dysplastic cells have large, dark, and often oddly shaped nuclei. The cytoplasm is dark, and it is relatively small.

Page 36: Clustering Ppt

Possible Features

Nucleus and cytoplasm area Nucleus and cyto brightness Nucleus shortest and longest diameter Cyto shortest and longest diameter Nucleus and cyto perimeter Nucleus and cyto no of maxima (...)

Page 37: Clustering Ppt

Classes are nonseparable

Page 38: Clustering Ppt

Hard Classifier (HCM)

Ok light

moderate

severeOk

A cell is either one or the other class defined by a colour.

Page 39: Clustering Ppt

Fuzzy Classifier (FCM)

Ok light

moderate

severeOk

A cell can belong to several classes to aDegree, i.e., one columnmay have several colours.

Page 40: Clustering Ppt

Function approximation

0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1-1.5

-1

-0.5

0

0.5

1

1.5

Input

Ou

tpu

t1

Curve fitting in a multi-dimensional space is also called function approximation. Learning is equivalent to finding a function that best fits the training data.

Page 41: Clustering Ppt

Approximation by fuzzy sets

0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1-2

-1

0

1

2

0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 10

0.2

0.4

0.6

0.8

1

Page 42: Clustering Ppt

Procedure to find a model

1. Acquire data

2. Select structure

3. Find clusters, generate model

4. Validate model

Page 43: Clustering Ppt

Conclusions

Compared to neural networks, fuzzy models can be interpreted by human beings

Applications: system identification, adaptive systems

Page 44: Clustering Ppt

Links J. Jantzen: Neurofuzzy Modelling. Technical University of Denmark:

Oersted-DTU, Tech report no 98-H-874 (nfmod), 1998. URL http://fuzzy.iau.dtu.dk/download/nfmod.pdf

PapSmear tutorial. URL http://fuzzy.iau.dtu.dk/smear/ U. Kaymak: Data Driven Fuzzy Modelling. PowerPoint, URL

http://fuzzy.iau.dtu.dk/tutor/ddfm.htm

Page 45: Clustering Ppt

Exercise: fuzzy clustering (Matlab)

Download and follow the instructions in this text file: http://fuzzy.iau.dtu.dk/tutor/fcm/exerF5.txt

The exercise requires Matlab (no special toolboxes are required)