Introduction To Data Mining
Introduction To Data Mining
Introduction To Data Mining
=
=
n
k
k k
q p dist
1
2
) (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Eucl i dean Di st ance
0
1
2
3
0 1 2 3 4 5 6
p1
p2
p3 p4
point x y
p1 0 2
p2 2 0
p3 3 1
p4 5 1
Distance Matrix
p1 p2 p3 p4
p1 0 2.828 3.162 5.099
p2 2.828 0 1.414 3.162
p3 3.162 1.414 0 2
p4 5.099 3.162 2 0
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi nkowski Di st ance
Minkowski Distance is a generalization of Euclidean
Distance
Where r is a parameter, n is the number of dimensions
(attributes) and p
k
and q
k
are, respectively, the kth attributes
(components) or data objects p and q.
r
n
k
r
k k
q p dist
1
1
) | | (
=
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi nkowski Di st ance: Exampl es
r = 1. City block (Manhattan, taxicab, L
1
norm) distance.
A common example of this is the Hamming distance, which is just the
number of bits that are different between two binary vectors
r = 2. Euclidean distance
r . supremum (L
max
norm, L
norm) distance.
This is the maximum difference between any component of the vectors
Do not confuse r with n, i.e., all these distances are
defined for all numbers of dimensions.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi nkowski Di st ance
Distance Matrix
point x y
p1 0 2
p2 2 0
p3 3 1
p4 5 1
L1 p1 p2 p3 p4
p1 0 4 4 6
p2 4 0 2 4
p3 4 2 0 2
p4 6 4 2 0
L2 p1 p2 p3 p4
p1 0 2.828 3.162 5.099
p2 2.828 0 1.414 3.162
p3 3.162 1.414 0 2
p4 5.099 3.162 2 0
L
p1 p2 p3 p4
p1 0 2 3 5
p2 2 0 1 3
p3 3 1 0 2
p4 5 3 2 0
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mahal anobi s Di st ance
T
q p q p q p s mahalanobi ) ( ) ( ) , (
1
=
For red points, the Euclidean distance is 14.7, Mahalanobis distance is 6.
is the covariance matrix of
the input data X
=
n
i
k
ik
j
ij k j
X X X X
n
1
,
) )( (
1
1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mahal anobi s Di st ance
Covariance Matrix:
=
3 . 0 2 . 0
2 . 0 3 . 0
B
A
C
A: (0.5, 0.5)
B: (0, 1)
C: (1.5, 1.5)
Mahal(A,B) = 5
Mahal(A,C) = 4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Common Pr oper t i es of a Di st ance
Distances, such as the Euclidean distance,
have some well known properties.
1. d(p, q) 0 for all p and q and d(p, q) = 0 only if
p = q. (Positive definiteness)
2. d(p, q) = d(q, p) for all p and q. (Symmetry)
3. d(p, r) d(p, q) + d(q, r) for all points p, q, and r.
(Triangle Inequality)
where d(p, q) is the distance (dissimilarity) between
points (data objects), p and q.
A distance that satisfies these properties is a
metric
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Common Pr oper t i es of a Si mi l ar i t y
Similarities, also have some well known
properties.
1. s(p, q) = 1 (or maximum similarity) only if p = q.
2. s(p, q) = s(q, p) for all p and q. (Symmetry)
where s(p, q) is the similarity between points (data
objects), p and q.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Si mi l ar i t y Bet ween Bi nar y Vect or s
Common situation is that objects, p and q, have only
binary attributes
Compute similarities using the following quantities
M
01
= the number of attributes where p was 0 and q was 1
M
10
= the number of attributes where p was 1 and q was 0
M
00
= the number of attributes where p was 0 and q was 0
M
11
= the number of attributes where p was 1 and q was 1
Simple Matching and Jaccard Coefficients
SMC = number of matches / number of attributes
= (M
11
+ M
00
) / (M
01
+ M
10
+ M
11
+ M
00
)
J = number of 11 matches / number of not-both-zero attributes values
= (M
11
) / (M
01
+ M
10
+ M
11
)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
SMC ver sus Jaccar d: Exampl e
p = 1 0 0 0 0 0 0 0 0 0
q = 0 0 0 0 0 0 1 0 0 1
M
01
= 2 (the number of attributes where p was 0 and q was 1)
M
10
= 1 (the number of attributes where p was 1 and q was 0)
M
00
= 7 (the number of attributes where p was 0 and q was 0)
M
11
= 0 (the number of attributes where p was 1 and q was 1)
SMC = (M
11
+ M
00
)/(M
01
+ M
10
+ M
11
+ M
00
) = (0+7) / (2+1+0+7) = 0.7
J = (M
11
) / (M
01
+ M
10
+ M
11
) = 0 / (2 + 1 + 0) = 0
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cosi ne Si mi l ar i t y
If d
1
and d
2
are two document vectors, then
cos( d
1
, d
2
) = (d
1
d
2
) / ||d
1
|| ||d
2
|| ,
where indicates vector dot product and || d || is the length of vector d.
Example:
d
1
= 3 2 0 5 0 0 0 2 0 0
d
2
= 1 0 0 0 0 0 0 1 0 2
d
1
d
2
= 3*1 + 2*0 + 0*0 + 5*0 + 0*0 + 0*0 + 0*0 + 2*1 + 0*0 + 0*2 = 5
||d
1
|| = (3*3+2*2+0*0+5*5+0*0+0*0+0*0+2*2+0*0+0*0)
0.5
= (42)
0.5
= 6.481
||d
2
|| = (1*1+0*0+0*0+0*0+0*0+0*0+0*0+1*1+0*0+2*2)
0.5
= (6)
0.5
= 2.245
cos( d
1
, d
2
) = .3150
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ext ended Jaccar d Coef f i ci ent ( Tani mot o)
Variation of Jaccard for continuous or count
attributes
Reduces to Jaccard for binary attributes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cor r el at i on
Correlation measures the linear relationship
between objects
To compute correlation, we standardize data
objects, p and q, and then take their dot product
) ( / )) ( ( p std p mean p p
k k
=
) ( / )) ( ( q std q mean q q
k k
=
q p q p n correlatio
= ) , (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Vi sual l y Eval uat i ng Correl at i on
Scatter plots
showing the
similarity from
1 to 1.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gener al Approach f or Combi ni ng Si mi l ar i t i es
Sometimes attributes are of many different
types, but an overall similarity is needed.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Usi ng Wei ght s t o Combi ne Si mi l ar i t i es
May not want to treat all attributes the same.
Use weights w
k
which are between 0 and 1 and sum
to 1.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Densi t y
Density-based clustering require a notion of
density
Examples:
Euclidean density
Euclidean density = number of points per unit volume
Probability density
Graph-based density
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Eucl i dean Densi t y Cel l -based
Simplest approach is to divide region into a
number of rectangular cells of equal volume and
define density as # of points the cell contains
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Eucl i dean Densi t y Cent er -based
Euclidean density is the number of points within a
specified radius of the point
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Dat a Mi ni ng: Expl or i ng Dat a
Lecture Notes for Chapter 3
Introduction to Data Mining
by
Tan, Steinbach, Kumar
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
What i s dat a expl or at i on?
Key motivations of data exploration include
Helping to select the right tool for preprocessing or analysis
Making use of humans abilities to recognize patterns
People can recognize patterns not captured by data analysis
tools
Related to the area of Exploratory Data Analysis (EDA)
Created by statistician John Tukey
Seminal book is Exploratory Data Analysis by Tukey
A nice online introduction can be found in Chapter 1 of the NIST
Engineering Statistics Handbook
http://www.itl.nist.gov/div898/handbook/index.htm
A preliminary exploration of the data to
better understand its characteristics.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Techni ques Used I n Dat a Expl or at i on
In EDA, as originally defined by Tukey
The focus was on visualization
Clustering and anomaly detection were viewed as
exploratory techniques
In data mining, clustering and anomaly detection are
major areas of interest, and not thought of as just
exploratory
In our discussion of data exploration, we focus on
Summary statistics
Visualization
Online Analytical Processing (OLAP)
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
I r i s Sampl e Dat a Set
Many of the exploratory data techniques are illustrated
with the Iris Plant data set.
Can be obtained from the UCI Machine Learning Repository
http://www.ics.uci.edu/~mlearn/MLRepository.html
From the statistician Douglas Fisher
Three flower types (classes):
Setosa
Virginica
Versicolour
Four (non-class) attributes
Sepal width and length
Petal width and length
Virginica. Robert H. Mohlenbrock. USDA
NRCS. 1995. Northeast wetland flora: Field
office guide to plant species. Northeast National
Technical Center, Chester, PA. Courtesy of
USDA NRCS Wetland Science Institute.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Summar y St at i st i cs
Summary statistics are numbers that summarize
properties of the data
Summarized properties include frequency, location and
spread
Examples: location - mean
spread - standard deviation
Most summary statistics can be calculated in a single
pass through the data
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Fr equency and Mode
The frequency of an attribute value is the
percentage of time the value occurs in the
data set
For example, given the attribute gender and a
representative population of people, the gender
female occurs about 50% of the time.
The mode of a an attribute is the most frequent
attribute value
The notions of frequency and mode are typically
used with categorical data
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Per cent i l es
For continuous data, the notion of a percentile is
more useful.
Given an ordinal or continuous attribute x and a
number p between 0 and 100, the pth percentile is
a value of x such that p% of the observed
values of x are less than .
For instance, the 50th percentile is the value
such that 50% of all values of x are less than .
x
p
x
p
x
p
x
50%
x
50%
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Measur es of Locat i on: Mean and Medi an
The mean is the most common measure of the
location of a set of points.
However, the mean is very sensitive to outliers.
Thus, the median or a trimmed mean is also
commonly used.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Measur es of Spr ead: Range and Var i ance
Range is the difference between the max and min
The variance or standard deviation is the most
common measure of the spread of a set of points.
However, this is also sensitive to outliers, so that
other measures are often used.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on
Visualization is the conversion of data into a visual
or tabular format so that the characteristics of the
data and the relationships among data items or
attributes can be analyzed or reported.
Visualization of data is one of the most powerful
and appealing techniques for data exploration.
Humans have a well developed ability to analyze large
amounts of information that is presented visually
Can detect general patterns and trends
Can detect outliers and unusual patterns
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Exampl e: Sea Sur f ace Temper at ur e
The following shows the Sea Surface
Temperature (SST) for July 1982
Tens of thousands of data points are summarized in a
single figure
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Repr esent at i on
Is the mapping of information to a visual format
Data objects, their attributes, and the relationships
among data objects are translated into graphical
elements such as points, lines, shapes, and
colors.
Example:
Objects are often represented as points
Their attribute values can be represented as the
position of the points or the characteristics of the
points, e.g., color, size, and shape
If position is used, then the relationships of points, i.e.,
whether they form groups or a point is an outlier, is
easily perceived.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Ar r angement
Is the placement of visual elements within a
display
Can make a large difference in how easy it is to
understand the data
Example:
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Sel ect i on
Is the elimination or the de-emphasis of certain
objects and attributes
Selection may involve the chossing a subset of
attributes
Dimensionality reduction is often used to reduce the
number of dimensions to two or three
Alternatively, pairs of attributes can be considered
Selection may also involve choosing a subset of
objects
A region of the screen can only show so many points
Can sample, but want to preserve points in sparse
areas
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on Techni ques: Hi st ogr ams
Histogram
Usually shows the distribution of values of a single variable
Divide the values into bins and show a bar plot of the number of
objects in each bin.
The height of each bar indicates the number of objects
Shape of histogram depends on the number of bins
Example: Petal Width (10 and 20 bins, respectively)
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Two-Di mensi onal Hi st ogr ams
Show the joint distribution of the values of two
attributes
Example: petal width and petal length
What does this tell us?
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on Techni ques: Box Pl ot s
Box Plots
Invented by J. Tukey
Another way of displaying the distribution of data
Following figure shows the basic part of a box plot
outlier
10
th
percentile
25
th
percentile
75
th
percentile
50
th
percentile
10
th
percentile
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Exampl e of Box Pl ot s
Box plots can be used to compare attributes
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on Techni ques: Scat t er Pl ot s
Scatter plots
Attributes values determine the position
Two-dimensional scatter plots most common, but can
have three-dimensional scatter plots
Often additional attributes can be displayed by using
the size, shape, and color of the markers that
represent the objects
It is useful to have arrays of scatter plots can
compactly summarize the relationships of several pairs
of attributes
See example on the next slide
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Scat t er Pl ot Ar r ay of I r i s At t r i but es
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on Techni ques: Cont our Pl ot s
Contour plots
Useful when a continuous attribute is measured on a
spatial grid
They partition the plane into regions of similar values
The contour lines that form the boundaries of these
regions connect points with equal values
The most common example is contour maps of
elevation
Can also display temperature, rainfall, air pressure,
etc.
An example for Sea Surface Temperature (SST) is provided
on the next slide
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Cont our Pl ot Exampl e: SST Dec, 1998
Celsius
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on Techni ques: Mat r i x Pl ot s
Matrix plots
Can plot the data matrix
This can be useful when objects are sorted according
to class
Typically, the attributes are normalized to prevent one
attribute from dominating the plot
Plots of similarity or distance matrices can also be
useful for visualizing the relationships between objects
Examples of matrix plots are presented on the next two
slides
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on of t he I r i s Dat a Mat r i x
standard
deviation
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on of t he I r i s Cor r el at i on Mat r i x
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Vi sual i zat i on Techni ques: Paral l el Coor di nat es
Parallel Coordinates
Used to plot the attribute values of high-dimensional
data
Instead of using perpendicular axes, use a set of
parallel axes
The attribute values of each object are plotted as a
point on each corresponding coordinate axis and the
points are connected by a line
Thus, each object is represented as a line
Often, the lines representing a distinct class of objects
group together, at least for some attributes
Ordering of attributes is important in seeing such
groupings
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Par al l el Coor di nat es Pl ot s f or I r i s Dat a
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Ot her Vi sual i zat i on Techni ques
Star Plots
Similar approach to parallel coordinates, but axes
radiate from a central point
The line connecting the values of an object is a
polygon
Chernoff Faces
Approach created by Herman Chernoff
This approach associates each attribute with a
characteristic of a face
The values of each attribute determine the appearance
of the corresponding facial characteristic
Each object becomes a separate face
Relies on humans ability to distinguish faces
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
St ar Pl ot s f or I r i s Dat a
Setosa
Versicolour
Virginica
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Cher nof f Faces f or I r i s Dat a
Setosa
Versicolour
Virginica
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
OLAP
On-Line Analytical Processing (OLAP) was
proposed by E. F. Codd, the father of the
relational database.
Relational databases put data into tables, while
OLAP uses a multidimensional array
representation.
Such representations of data previously existed in
statistics and other fields
There are a number of data analysis and data
exploration operations that are easier with such a
data representation.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Cr eat i ng a Mul t i di mensi onal Ar r ay
Two key steps in converting tabular data into a
multidimensional array.
First, identify which attributes are to be the dimensions
and which attribute is to be the target attribute whose
values appear as entries in the multidimensional array.
The attributes used as dimensions must have discrete values
The target value is typically a count or continuous value, e.g.,
the cost of an item
Can have no target variable at all except the count of objects
that have the same set of attribute values
Second, find the value of each entry in the
multidimensional array by summing the values (of the
target attribute) or count of all objects that have the
attribute values corresponding to that entry.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Exampl e: I r i s dat a
We show how the attributes, petal length, petal
width, and species type can be converted to a
multidimensional array
First, we discretized the petal width and length to have
categorical values: low, medium, and high
We get the following table - note the count attribute
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Exampl e: I r i s dat a ( cont i nued)
Each unique tuple of petal width, petal length, and
species type identifies one element of the array.
This element is assigned the corresponding count
value.
The figure illustrates
the result.
All non-specified
tuples are 0.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Exampl e: I r i s dat a ( cont i nued)
Slices of the multidimensional array are shown by
the following cross-tabulations
What do these tables tell us?
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
OLAP Oper at i ons: Dat a Cube
The key operation of a OLAP is the formation of a
data cube
A data cube is a multidimensional representation
of data, together with all possible aggregates.
By all possible aggregates, we mean the
aggregates that result by selecting a proper
subset of the dimensions and summing over all
remaining dimensions.
For example, if we choose the species type
dimension of the Iris data and sum over all other
dimensions, the result will be a one-dimensional
entry with three entries, each of which gives the
number of flowers of each type.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
Consider a data set that records the sales of
products at a number of company stores at
various dates.
This data can be represented
as a 3 dimensional array
There are 3 two-dimensional
aggregates (3 choose 2 ),
3 one-dimensional aggregates,
and 1 zero-dimensional
aggregate (the overall total)
Dat a Cube Exampl e
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
The following figure table shows one of the two
dimensional aggregates, along with two of the
one-dimensional aggregates, and the overall total
Dat a Cube Exampl e ( cont i nued)
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
OLAP Oper at i ons: Sl i ci ng and Di ci ng
Slicing is selecting a group of cells from the entire
multidimensional array by specifying a specific
value for one or more dimensions.
Dicing involves selecting a subset of cells by
specifying a range of attribute values.
This is equivalent to defining a subarray from the
complete array.
In practice, both operations can also be
accompanied by aggregation over some
dimensions.
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
OLAP Oper at i ons: Rol l -up and Dr i l l -down
Attribute values often have a hierarchical
structure.
Each date is associated with a year, month, and week.
A location is associated with a continent, country, state
(province, etc.), and city.
Products can be divided into various categories, such
as clothing, electronics, and furniture.
Note that these categories often nest and form a
tree or lattice
A year contains months which contains day
A country contains a state which contains a city
Tan,Steinbach, Kumar Introduction to Data Mining 8/05/2005 #
OLAP Oper at i ons: Rol l -up and Dr i l l -down
This hierarchical structure gives rise to the roll-up
and drill-down operations.
For sales data, we can aggregate (roll up) the sales
across all the dates in a month.
Conversely, given a view of the data where the time
dimension is broken into months, we could split the
monthly sales totals (drill down) into daily sales totals.
Likewise, we can drill down or roll up on the location or
product ID attributes.
Dat a Mi ni ng
Cl assi f i cat i on: Basi c Concept s, Deci si on
Tr ees, and Model Eval uat i on
Lecture Notes for Chapter 4
Introduction to Data Mining
by
Tan, Steinbach, Kumar
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl assi f i cat i on: Def i ni t i on
Given a collection of records (training set )
Each record contains a set of attributes, one of the
attributes is the class.
Find a model for class attribute as a function
of the values of other attributes.
Goal: previously unseen records should be
assigned a class as accurately as possible.
A test set is used to determine the accuracy of the
model. Usually, the given data set is divided into
training and test sets, with training set used to build
the model and test set used to validate it.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I l l ust r at i ng Cl assi f i cat i on Task
Apply
Model
Induction
Deduction
Learn
Model
Model
Tid Attrib1 Attrib2 Attrib3 Class
1 Yes Large 125K No
2 No Medium 100K No
3 No Small 70K No
4 Yes Medium 120K No
5 No Large 95K Yes
6 No Medium 60K No
7 Yes Large 220K No
8 No Small 85K Yes
9 No Medium 75K No
Tid Attrib1 Attrib2 Attrib3 Class
11 No Small 55K ?
12 Yes Medium 80K ?
13 Yes Large 110K ?
14 No Small 95K ?
15 No Large 67K ?
Test Set
Learning
algorithm
Training Set
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es of Cl assi f i cat i on Task
Predicting tumor cells as benign or malignant
Classifying credit card transactions
as legitimate or fraudulent
Classifying secondary structures of protein
as alpha-helix, beta-sheet, or random
coil
Categorizing news stories as finance,
weather, entertainment, sports, etc
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl assi f i cat i on Techni ques
Decision Tree based Methods
Rule-based Methods
Memory based reasoning
Neural Networks
Nave Bayes and Bayesian Belief Networks
Support Vector Machines
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e of a Deci si on Tr ee
Tid Refund Marital
Status
Taxable
Income
Cheat
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes No
Married
Single, Divorced
< 80K > 80K
Splitting Attributes
Training Data
Model: Decision Tree
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Anot her Exampl e of Deci si on Tr ee
Tid Refund Marital
Status
Taxable
Income
Cheat
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
MarSt
Refund
TaxInc
YES NO
NO
NO
Yes
No
Married
Single,
Divorced
< 80K > 80K
There could be more than one tree that
fits the same data!
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Deci si on Tr ee Cl assi f i cat i on Task
Apply
Model
Induction
Deduction
Learn
Model
Model
Tid Attrib1 Attrib2 Attrib3 Class
1 Yes Large 125K No
2 No Medium 100K No
3 No Small 70K No
4 Yes Medium 120K No
5 No Large 95K Yes
6 No Medium 60K No
7 Yes Large 220K No
8 No Small 85K Yes
9 No Medium 75K No
Tid Attrib1 Attrib2 Attrib3 Class
11 No Small 55K ?
12 Yes Medium 80K ?
13 Yes Large 110K ?
14 No Small 95K ?
15 No Large 67K ?
Test Set
Tree
Induction
algorithm
Training Set
Decision
Tree
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl y Model t o Test Dat a
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes No
Married
Single, Divorced
< 80K > 80K
Refund Marital
Status
Taxable
Income
Cheat
No Married 80K ?
10
Test Data
Start from the root of tree.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl y Model t o Test Dat a
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes No
Married
Single, Divorced
< 80K > 80K
Refund Marital
Status
Taxable
Income
Cheat
No Married 80K ?
10
Test Data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl y Model t o Test Dat a
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes No
Married
Single, Divorced
< 80K > 80K
Refund Marital
Status
Taxable
Income
Cheat
No Married 80K ?
10
Test Data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl y Model t o Test Dat a
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes No
Married
Single, Divorced
< 80K > 80K
Refund Marital
Status
Taxable
Income
Cheat
No Married 80K ?
10
Test Data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl y Model t o Test Dat a
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes No
Married
Single, Divorced
< 80K > 80K
Refund Marital
Status
Taxable
Income
Cheat
No Married 80K ?
10
Test Data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl y Model t o Test Dat a
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes No
Married
Single, Divorced
< 80K > 80K
Refund Marital
Status
Taxable
Income
Cheat
No Married 80K ?
10
Test Data
Assign Cheat to No
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Deci si on Tr ee Cl assi f i cat i on Task
Apply
Model
Induction
Deduction
Learn
Model
Model
Tid Attrib1 Attrib2 Attrib3 Class
1 Yes Large 125K No
2 No Medium 100K No
3 No Small 70K No
4 Yes Medium 120K No
5 No Large 95K Yes
6 No Medium 60K No
7 Yes Large 220K No
8 No Small 85K Yes
9 No Medium 75K No
Tid Attrib1 Attrib2 Attrib3 Class
11 No Small 55K ?
12 Yes Medium 80K ?
13 Yes Large 110K ?
14 No Small 95K ?
15 No Large 67K ?
Test Set
Tree
Induction
algorithm
Training Set
Decision
Tree
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Deci si on Tr ee I nduct i on
Many Algorithms:
Hunts Algorithm (one of the earliest)
CART
ID3, C4.5
SLIQ,SPRINT
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gener al St r uct ur e of Hunt s Al gor i t hm
Let D
t
be the set of training records
that reach a node t
General Procedure:
If D
t
contains records that
belong the same class y
t
, then t
is a leaf node labeled as y
t
If D
t
is an empty set, then t is a
leaf node labeled by the default
class, y
d
If D
t
contains records that
belong to more than one class,
use an attribute test to split the
data into smaller subsets.
Recursively apply the
procedure to each subset.
Tid Refund Marital
Status
Taxable
Income
Cheat
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
D
t
?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hunt s Al gor i t hm
Dont
Cheat
Refund
Dont
Cheat
Dont
Cheat
Yes No
Refund
Dont
Cheat
Yes No
Marital
Status
Dont
Cheat
Cheat
Single,
Divorced
Married
Taxable
Income
Dont
Cheat
< 80K >= 80K
Refund
Dont
Cheat
Yes No
Marital
Status
Dont
Cheat
Cheat
Single,
Divorced
Married
Tid Refund Marital
Status
Taxable
Income
Cheat
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Tr ee I nduct i on
Greedy strategy.
Split the records based on an attribute test
that optimizes certain criterion.
Issues
Determine how to split the records
How to specify the attribute test condition?
How to determine the best split?
Determine when to stop splitting
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Tr ee I nduct i on
Greedy strategy.
Split the records based on an attribute test
that optimizes certain criterion.
Issues
Determine how to split the records
How to specify the attribute test condition?
How to determine the best split?
Determine when to stop splitting
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Speci f y Test Condi t i on?
Depends on attribute types
Nominal
Ordinal
Continuous
Depends on number of ways to split
2-way split
Multi-way split
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Spl i t t i ng Based on Nomi nal At t r i but es
Multi-way split: Use as many partitions as distinct
values.
Binary split: Divides values into two subsets.
Need to find optimal partitioning.
CarType
Family
Sports
Luxury
CarType
{Family,
Luxury}
{Sports}
CarType
{Sports,
Luxury}
{Family}
OR
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Multi-way split: Use as many partitions as distinct
values.
Binary split: Divides values into two subsets.
Need to find optimal partitioning.
What about this split?
Spl i t t i ng Based on Or di nal At t r i but es
Size
Small
Medium
Large
Size
{Medium,
Large}
{Small}
Size
{Small,
Medium}
{Large}
OR
Size
{Small,
Large}
{Medium}
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Spl i t t i ng Based on Cont i nuous At t r i but es
Different ways of handling
Discretization to form an ordinal categorical
attribute
Static discretize once at the beginning
Dynamic ranges can be found by equal interval
bucketing, equal frequency bucketing
(percentiles), or clustering.
Binary Decision: (A < v) or (A v)
consider all possible splits and finds the best cut
can be more compute intensive
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Spl i t t i ng Based on Cont i nuous At t r i but es
Taxable
Income
> 80K?
Yes No
Taxable
Income?
(i) Binary split (ii) Multi-way split
< 10K
[10K,25K) [25K,50K) [50K,80K)
> 80K
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Tr ee I nduct i on
Greedy strategy.
Split the records based on an attribute test
that optimizes certain criterion.
Issues
Determine how to split the records
How to specify the attribute test condition?
How to determine the best split?
Determine when to stop splitting
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o det er mi ne t he Best Spl i t
Own
Car?
C0: 6
C1: 4
C0: 4
C1: 6
C0: 1
C1: 3
C0: 8
C1: 0
C0: 1
C1: 7
Car
Type?
C0: 1
C1: 0
C0: 1
C1: 0
C0: 0
C1: 1
Student
ID?
...
Yes No
Family
Sports
Luxury c
1
c
10
c
20
C0: 0
C1: 1
...
c
11
Before Splitting: 10 records of class 0,
10 records of class 1
Which test condition is the best?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o det er mi ne t he Best Spl i t
Greedy approach:
Nodes with homogeneous class distribution
are preferred
Need a measure of node impurity:
C0: 5
C1: 5
C0: 9
C1: 1
Non-homogeneous,
High degree of impurity
Homogeneous,
Low degree of impurity
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Measur es of Node I mpur i t y
Gini Index
Entropy
Misclassification error
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Fi nd t he Best Spl i t
B?
Yes No
Node N3 Node N4
A?
Yes No
Node N1 Node N2
Before Splitting:
C0 N10
C1 N11
C0 N20
C1 N21
C0 N30
C1 N31
C0 N40
C1 N41
C0 N00
C1 N01
M0
M1
M2 M3 M4
M12
M34
Gain = M0 M12 vs M0 M34
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Measur e of I mpur i t y: GI NI
Gini Index for a given node t :
(NOTE: p( j | t) is the relative frequency of class j at node t).
Maximum (1 - 1/n
c
) when records are equally
distributed among all classes, implying least
interesting information
Minimum (0.0) when all records belong to one class,
implying most interesting information
=
j
t j p t GINI
2
)] | ( [ 1 ) (
C1 0
C2 6
Gi ni = 0.000
C1 2
C2 4
Gi ni = 0.444
C1 3
C2 3
Gi ni = 0.500
C1 1
C2 5
Gi ni = 0.278
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es f or comput i ng GI NI
C1 0
C2 6
C1 2
C2 4
C1 1
C2 5
P(C1) = 0/6 = 0 P(C2) = 6/6 = 1
Gini = 1 P(C1)
2
P(C2)
2
= 1 0 1 = 0
=
j
t j p t GINI
2
)] | ( [ 1 ) (
P(C1) = 1/6 P(C2) = 5/6
Gini = 1 (1/6)
2
(5/6)
2
= 0.278
P(C1) = 2/6 P(C2) = 4/6
Gini = 1 (2/6)
2
(4/6)
2
= 0.444
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Spl i t t i ng Based on GI NI
Used in CART, SLIQ, SPRINT.
When a node p is split into k partitions (children), the
quality of split is computed as,
where, n
i
= number of records at child i,
n = number of records at node p.
=
=
k
i
i
split
i GINI
n
n
GINI
1
) (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Bi nar y At t r i but es: Comput i ng GI NI
I ndex
Splits into two partitions
Effect of Weighing partitions:
Larger and Purer Partitions are sought for.
B?
Yes No
Node N1 Node N2
Par ent
C1 6
C2 6
Gi ni = 0.500
N1 N2
C1 5 1
C2 2 4
Gi ni = 0.333
Gini(N1)
= 1 (5/6)
2
(2/6)
2
= 0.194
Gini(N2)
= 1 (1/6)
2
(4/6)
2
= 0.528
Gini(Children)
= 7/12 * 0.194 +
5/12 * 0.528
= 0.333
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cat egori cal At t ri but es: Comput i ng Gi ni I ndex
For each distinct value, gather counts for each class in
the dataset
Use the count matrix to make decisions
CarType
{Sports,
Luxury}
{Family}
C1 3 1
C2 2 4
Gi ni 0.400
CarType
{Sports}
{Family,
Luxury}
C1 2 2
C2 1 5
Gi ni 0.419
CarType
Family Sports Luxury
C1 1 2 1
C2 4 1 1
Gi ni 0.393
Multi-way split Two-way split
(find best partition of values)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cont i nuous At t ri but es: Comput i ng Gi ni I ndex
Use Binary Decisions based on one
value
Several Choices for the splitting value
Number of possible splitting values
= Number of distinct values
Each splitting value has a count matrix
associated with it
Class counts in each of the
partitions, A < v and A v
Simple method to choose best v
For each v, scan the database to
gather count matrix and compute
its Gini index
Computationally Inefficient!
Repetition of work.
Tid Refund Marital
Status
Taxable
Income
Cheat
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
Taxable
Income
> 80K?
Yes No
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cont i nuous At t ri but es: Comput i ng Gi ni I ndex...
For efficient computation: for each attribute,
Sort the attribute on values
Linearly scan these values, each time updating the count matrix
and computing gini index
Choose the split position that has the least gini index
Cheat No No No Yes Yes Yes No No No No
Taxable Income
60 70 75 85 90 95 100 120 125 220
55 65 72 80 87 92 97 110 122 172 230
<= > <= > <= > <= > <= > <= > <= > <= > <= > <= > <= >
Yes 0 3 0 3 0 3 0 3 1 2 2 1 3 0 3 0 3 0 3 0 3 0
No 0 7 1 6 2 5 3 4 3 4 3 4 3 4 4 3 5 2 6 1 7 0
Gini 0.420 0.400 0.375 0.343 0.417 0.400 0.300 0.343 0.375 0.400 0.420
Split Positions
Sorted Values
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Al t er nat i ve Spl i t t i ng Cr i t eri a based on I NFO
Entropy at a given node t:
(NOTE: p( j | t) is the relative frequency of class j at node t).
Measures homogeneity of a node.
Maximum (log n
c
) when records are equally distributed
among all classes implying least information
Minimum (0.0) when all records belong to one class,
implying most information
Entropy based computations are similar to the
GINI index computations
=
j
t j p t j p t Entropy ) | ( log ) | ( ) (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es f or comput i ng Ent r opy
C1 0
C2 6
C1 2
C2 4
C1 1
C2 5
P(C1) = 0/6 = 0 P(C2) = 6/6 = 1
Entropy = 0 log 0 1 log 1 = 0 0 = 0
P(C1) = 1/6 P(C2) = 5/6
Entropy = (1/6) log
2
(1/6) (5/6) log
2
(1/6) = 0.65
P(C1) = 2/6 P(C2) = 4/6
Entropy = (2/6) log
2
(2/6) (4/6) log
2
(4/6) = 0.92
=
j
t j p t j p t Entropy ) | ( log ) | ( ) (
2
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Spl i t t i ng Based on I NFO...
Information Gain:
Parent Node, p is split into k partitions;
n
i
is number of records in partition i
Measures Reduction in Entropy achieved because of
the split. Choose the split that achieves most reduction
(maximizes GAIN)
Used in ID3 and C4.5
Disadvantage: Tends to prefer splits that result in large
number of partitions, each being small but pure.
=
=
k
i
i
split
i Entropy
n
n
p Entropy GAIN
1
) ( ) (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Spl i t t i ng Based on I NFO...
Gain Ratio:
Parent Node, p is split into k partitions
n
i
is the number of records in partition i
Adjusts Information Gain by the entropy of the
partitioning (SplitINFO). Higher entropy partitioning
(large number of small partitions) is penalized!
Used in C4.5
Designed to overcome the disadvantage of Information
Gain
SplitINFO
GAIN
GainRATIO
Split
split
=
=
=
k
i
i i
n
n
n
n
SplitINFO
1
log
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Spl i t t i ng Cr i t eri a based on Cl assi f i cat i on Err or
Classification error at a node t :
Measures misclassification error made by a node.
Maximum (1 - 1/n
c
) when records are equally distributed
among all classes, implying least interesting information
Minimum (0.0) when all records belong to one class, implying
most interesting information
) | ( max 1 ) ( t i P t Error
i
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es f or Comput i ng Er r or
C1 0
C2 6
C1 2
C2 4
C1 1
C2 5
P(C1) = 0/6 = 0 P(C2) = 6/6 = 1
Error = 1 max (0, 1) = 1 1 = 0
P(C1) = 1/6 P(C2) = 5/6
Error = 1 max (1/6, 5/6) = 1 5/6 = 1/6
P(C1) = 2/6 P(C2) = 4/6
Error = 1 max (2/6, 4/6) = 1 4/6 = 1/3
) | ( max 1 ) ( t i P t Error
i
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Compar i son among Spl i t t i ng Cr i t er i a
For a 2-class problem:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi scl assi f i cat i on Er r or vs Gi ni
A?
Yes No
Node N1 Node N2
Par ent
C1 7
C2 3
Gi ni = 0.42
N1 N2
C1 3 4
C2 0 3
Gi ni = 0.361
Gini(N1)
= 1 (3/3)
2
(0/3)
2
= 0
Gini(N2)
= 1 (4/7)
2
(3/7)
2
= 0.489
Gini(Children)
= 3/10 * 0
+ 7/10 * 0.489
= 0.342
Gini improves !!
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Tr ee I nduct i on
Greedy strategy.
Split the records based on an attribute test
that optimizes certain criterion.
Issues
Determine how to split the records
How to specify the attribute test condition?
How to determine the best split?
Determine when to stop splitting
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St oppi ng Cr i t er i a f or Tr ee I nduct i on
Stop expanding a node when all the records
belong to the same class
Stop expanding a node when all the records have
similar attribute values
Early termination (to be discussed later)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Deci si on Tr ee Based Cl assi f i cat i on
Advantages:
Inexpensive to construct
Extremely fast at classifying unknown records
Easy to interpret for small-sized trees
Accuracy is comparable to other classification
techniques for many simple data sets
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e: C4.5
Simple depth-first construction.
Uses Information Gain
Sorts Continuous Attributes at each node.
Needs entire data to fit in memory.
Unsuitable for Large Datasets.
Needs out-of-core sorting.
You can download the software from:
http://www.cse.unsw.edu.au/~quinlan/c4.5r8.tar.gz
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Pr act i cal I ssues of Cl assi f i cat i on
Underfitting and Overfitting
Missing Values
Costs of Classification
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Under f i t t i ng and Over f i t t i ng ( Exampl e)
500 circular and 500
triangular data points.
Circular points:
0.5 sqrt(x
1
2
+x
2
2
) 1
Triangular points:
sqrt(x
1
2
+x
2
2
) > 0.5 or
sqrt(x
1
2
+x
2
2
) < 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Under f i t t i ng and Over f i t t i ng
Overfitting
Underfitting: when model is too simple, both training and test errors are large
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Over f i t t i ng due t o Noi se
Decision boundary is distorted by noise point
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Over f i t t i ng due t o I nsuf f i ci ent Exampl es
Lack of data points in the lower half of the diagram makes it difficult
to predict correctly the class labels of that region
- Insufficient number of training records in the region causes the
decision tree to predict the test examples using other training
records that are irrelevant to the classification task
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Not es on Over f i t t i ng
Overfitting results in decision trees that are more
complex than necessary
Training error no longer provides a good estimate
of how well the tree will perform on previously
unseen records
Need new ways for estimating errors
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Est i mat i ng Gener al i zat i on Er r or s
Re-substitution errors: error on training ( e(t) )
Generalization errors: error on testing ( e(t))
Methods for estimating generalization errors:
Optimistic approach: e(t) = e(t)
Pessimistic approach:
For each leaf node: e(t) = (e(t)+0.5)
Total errors: e(T) = e(T) + N 0.5 (N: number of leaf nodes)
For a tree with 30 leaf nodes and 10 errors on training
(out of 1000 instances):
Training error = 10/1000 = 1%
Generalization error = (10 + 300.5)/1000 = 2.5%
Reduced error pruning (REP):
uses validation data set to estimate generalization
error
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Occams Razor
Given two models of similar generalization errors,
one should prefer the simpler model over the
more complex model
For complex models, there is a greater chance
that it was fitted accidentally by errors in data
Therefore, one should include model complexity
when evaluating a model
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi ni mum Descr i pt i on Lengt h ( MDL)
Cost(Model,Data) = Cost(Data|Model) + Cost(Model)
Cost is the number of bits needed for encoding.
Search for the least costly model.
Cost(Data|Model) encodes the misclassification errors.
Cost(Model) uses node encoding (number of children)
plus splitting condition encoding.
A B
A?
B?
C?
1 0
0
1
Yes No
B
1
B
2
C
1
C
2
X y
X
1
1
X
2
0
X
3
0
X
4
1
X
n
1
X y
X
1
?
X
2
?
X
3
?
X
4
?
X
n
?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Addr ess Over f i t t i ng
Pre-Pruning (Early Stopping Rule)
Stop the algorithm before it becomes a fully-grown tree
Typical stopping conditions for a node:
Stop if all instances belong to the same class
Stop if all the attribute values are the same
More restrictive conditions:
Stop if number of instances is less than some user-specified
threshold
Stop if class distribution of instances are independent of the
available features (e.g., using
2
test)
Stop if expanding the current node does not improve impurity
measures (e.g., Gini or information gain).
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Addr ess Over f i t t i ng
Post-pruning
Grow decision tree to its entirety
Trim the nodes of the decision tree in a
bottom-up fashion
If generalization error improves after trimming,
replace sub-tree by a leaf node.
Class label of leaf node is determined from
majority class of instances in the sub-tree
Can use MDL for post-pruning
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e of Post -Pr uni ng
A?
A1
A2 A3
A4
Class = Yes 20
Class = No 10
Error = 10/30
Training Error (Before splitting) = 10/30
Pessimistic error = (10 + 0.5)/30 = 10.5/30
Training Error (After splitting) = 9/30
Pessimistic error (After splitting)
= (9 + 4 0.5)/30 = 11/30
PRUNE!
Class = Yes 8
Class = No 4
Class = Yes 3
Class = No 4
Class = Yes 4
Class = No 1
Class = Yes 5
Class = No 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es of Post -pr uni ng
Optimistic error?
Pessimistic error?
Reduced error pruning?
C0: 11
C1: 3
C0: 2
C1: 4
C0: 14
C1: 3
C0: 2
C1: 2
Dont prune for both cases
Dont prune case 1, prune case 2
Case 1:
Case 2:
Depends on validation set
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Handl i ng Mi ssi ng At t r i but e Val ues
Missing values affect decision tree construction in
three different ways:
Affects how impurity measures are computed
Affects how to distribute instance with missing
value to child nodes
Affects how a test instance with missing value
is classified
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Comput i ng I mpur i t y Measur e
Tid Refund Marital
Status
Taxable
Income
Class
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 ? Single 90K Yes
10
Cl ass
= Yes
Cl ass
= No
Refund= Yes 0 3
Refund= No 2 4
Refund= ? 1 0
Split on Refund:
Entropy(Refund=Yes) = 0
Entropy(Refund=No)
= -(2/6)log(2/6) (4/6)log(4/6) = 0.9183
Entropy(Children)
= 0.3 (0) + 0.6 (0.9183) = 0.551
Gain = 0.9 (0.8813 0.551) = 0.3303
Missing
value
Before Splitting:
Entropy(Parent)
= -0.3 log(0.3)-(0.7)log(0.7) = 0.8813
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Di st r i but e I nst ances
Tid Refund Marital
Status
Taxable
Income
Class
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10
Refund
Yes No
Cl ass= Yes 0
Cl ass= No 3
Cheat = Yes 2
Cheat = No 4
Refund
Yes
Tid Refund Marital
Status
Taxable
Income
Class
10 ? Single 90K Yes
10
No
Cl ass= Yes 2 + 6/ 9
Cl ass= No 4
Probability that Refund=Yes is 3/9
Probability that Refund=No is 6/9
Assign record to the left child with
weight = 3/9 and to the right child
with weight = 6/9
Cl ass= Yes 0 + 3/ 9
Cl ass= No 3
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl assi f y I nst ances
Refund
MarSt
TaxInc
YES NO
NO
NO
Yes
No
Married
Single,
Divorced
< 80K > 80K
Married Single Divorced Total
Class=No 3 1 0 4
Class=Yes 6/9 1 1 2.67
Total 3.67 2 1 6.67
Tid Refund Marital
Status
Taxable
Income
Class
11 No ? 85K ?
10
New record:
Probability that Marital Status
= Married is 3.67/6.67
Probability that Marital Status
={Single,Divorced} is 3/6.67
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ot her I ssues
Data Fragmentation
Search Strategy
Expressiveness
Tree Replication
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Dat a Fr agment at i on
Number of instances gets smaller as you traverse
down the tree
Number of instances at the leaf nodes could be
too small to make any statistically significant
decision
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Sear ch St r at egy
Finding an optimal decision tree is NP-hard
The algorithm presented so far uses a greedy,
top-down, recursive partitioning strategy to
induce a reasonable solution
Other strategies?
Bottom-up
Bi-directional
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Expr essi veness
Decision tree provides expressive representation for
learning discrete-valued function
But they do not generalize well to certain types of
Boolean functions
Example: parity function:
Class = 1 if there is an even number of Boolean attributes with truth
value = True
Class = 0 if there is an odd number of Boolean attributes with truth
value = True
For accurate modeling, must have a complete tree
Not expressive enough for modeling continuous variables
Particularly when test condition involves only a single
attribute at-a-time
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Deci si on Boundar y
y < 0.33?
: 0
: 3
: 4
: 0
y < 0.47?
: 4
: 0
: 0
: 4
x < 0.43?
Yes
Yes
No
No Yes No
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Border line between two neighboring regions of different classes is
known as decision boundary
Decision boundary is parallel to axes because test condition involves
a single attribute at-a-time
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Obl i que Deci si on Tr ees
x + y < 1
Class = +
Class =
Test condition may involve multiple attributes
More expressive representation
Finding optimal test condition is computationally expensive
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Tr ee Repl i cat i on
P
Q R
S 0 1
0 1
Q
S 0
0 1
Same subtree appears in multiple branches
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Model Eval uat i on
Metrics for Performance Evaluation
How to evaluate the performance of a model?
Methods for Performance Evaluation
How to obtain reliable estimates?
Methods for Model Comparison
How to compare the relative performance
among competing models?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Model Eval uat i on
Metrics for Performance Evaluation
How to evaluate the performance of a model?
Methods for Performance Evaluation
How to obtain reliable estimates?
Methods for Model Comparison
How to compare the relative performance
among competing models?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Met r i cs f or Per f or mance Eval uat i on
Focus on the predictive capability of a model
Rather than how fast it takes to classify or
build models, scalability, etc.
Confusion Matrix:
PREDICTED CLASS
ACTUAL
CLASS
Class=Yes Class=No
Class=Yes a b
Class=No c d
a: TP (true positive)
b: FN (false negative)
c: FP (false positive)
d: TN (true negative)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Met r i cs f or Per f or mance Eval uat i on
Most widely-used metric:
PREDICTED CLASS
ACTUAL
CLASS
Class=Yes Class=No
Class=Yes a
(TP)
b
(FN)
Class=No c
(FP)
d
(TN)
FN FP TN TP
TN TP
d c b a
d a
+ + +
+
=
+ + +
+
= Accuracy
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i on of Accur acy
Consider a 2-class problem
Number of Class 0 examples = 9990
Number of Class 1 examples = 10
If model predicts everything to be class 0,
accuracy is 9990/10000 = 99.9 %
Accuracy is misleading because model does
not detect any class 1 example
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cost Mat r i x
PREDICTED CLASS
ACTUAL
CLASS
C(i|j)
Class=Yes Class=No
Class=Yes C(Yes|Yes) C(No|Yes)
Class=No C(Yes|No) C(No|No)
C(i|j): Cost of misclassifying class j example as class i
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Comput i ng Cost of Cl assi f i cat i on
Cost
Matrix
PREDICTED CLASS
ACTUAL
CLASS
C(i|j)
+ -
+ -1 100
- 1 0
Model
M
1
PREDICTED CLASS
ACTUAL
CLASS
+ -
+ 150 40
- 60 250
Model
M
2
PREDICTED CLASS
ACTUAL
CLASS
+ -
+ 250 45
- 5 200
Accuracy = 80%
Cost = 3910
Accuracy = 90%
Cost = 4255
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cost vs Accur acy
Count
PREDICTED CLASS
ACTUAL
CLASS
Class=Yes Class=No
Class=Yes
a b
Class=No
c d
Cost
PREDICTED CLASS
ACTUAL
CLASS
Class=Yes Class=No
Class=Yes
p q
Class=No
q p
N = a + b + c + d
Accuracy = (a + d)/N
Cost = p (a + d) + q (b + c)
= p (a + d) + q (N a d)
= q N (q p)(a + d)
= N [q (q-p) Accuracy]
Accuracy is proportional to cost if
1. C(Yes|No)=C(No|Yes) = q
2. C(Yes|Yes)=C(No|No) = p
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cost -Sensi t i ve Measur es
c b a
a
p r
rp
b a
a
c a
a
+ +
=
+
=
+
=
+
=
2
2 2
(F) measure - F
(r) Recall
(p) Precision
Precision is biased towards C(Yes|Yes) & C(Yes|No)
Recall is biased towards C(Yes|Yes) & C(No|Yes)
F-measure is biased towards all except C(No|No)
d w c w b w a w
d w a w
4 3 2 1
4 1
Accuracy Weighted
+ + +
+
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Model Eval uat i on
Metrics for Performance Evaluation
How to evaluate the performance of a model?
Methods for Performance Evaluation
How to obtain reliable estimates?
Methods for Model Comparison
How to compare the relative performance
among competing models?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Met hods f or Per f or mance Eval uat i on
How to obtain a reliable estimate of
performance?
Performance of a model may depend on other
factors besides the learning algorithm:
Class distribution
Cost of misclassification
Size of training and test sets
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Lear ni ng Cur ve
Learning curve shows
how accuracy changes
with varying sample size
Requires a sampling
schedule for creating
learning curve:
Arithmetic sampling
(Langley, et al)
Geometric sampling
(Provost et al)
Effect of small sample size:
- Bias in the estimate
- Variance of estimate
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Met hods of Est i mat i on
Holdout
Reserve 2/3 for training and 1/3 for testing
Random subsampling
Repeated holdout
Cross validation
Partition data into k disjoint subsets
k-fold: train on k-1 partitions, test on the remaining one
Leave-one-out: k=n
Stratified sampling
oversampling vs undersampling
Bootstrap
Sampling with replacement
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Model Eval uat i on
Metrics for Performance Evaluation
How to evaluate the performance of a model?
Methods for Performance Evaluation
How to obtain reliable estimates?
Methods for Model Comparison
How to compare the relative performance
among competing models?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
ROC ( Recei ver Oper at i ng Char act er i st i c)
Developed in 1950s for signal detection theory to
analyze noisy signals
Characterize the trade-off between positive
hits and false alarms
ROC curve plots TP (on the y-axis) against FP
(on the x-axis)
Performance of each classifier represented as a
point on the ROC curve
changing the threshold of algorithm, sample
distribution or cost matrix changes the location
of the point
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
ROC Cur ve
At threshold t:
TP=0.5, FN=0.5, FP=0.12, FN=0.88
- 1-dimensional data set containing 2 classes (positive and negative)
- any points located at x > t is classified as positive
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
ROC Cur ve
(TP,FP):
(0,0): declare everything
to be negative class
(1,1): declare everything
to be positive class
(1,0): ideal
Diagonal line:
Random guessing
Below diagonal line:
prediction is opposite of
the true class
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Usi ng ROC f or Model Compar i son
No model consistently
outperform the other
M
1
is better for
small FPR
M
2
is better for
large FPR
Area Under the ROC
curve
Ideal:
Area = 1
Random guess:
Area = 0.5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Const r uct an ROC cur ve
Instance P(+|A) True Class
1 0.95 +
2 0.93 +
3 0.87 -
4 0.85 -
5 0.85 -
6 0.85 +
7 0.76 -
8 0.53 +
9 0.43 -
10 0.25 +
Use classifier that produces
posterior probability for each
test instance P(+|A)
Sort the instances according
to P(+|A) in decreasing order
Apply threshold at each
unique value of P(+|A)
Count the number of TP, FP,
TN, FN at each threshold
TP rate, TPR = TP/(TP+FN)
FP rate, FPR = FP/(FP + TN)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o const r uct an ROC cur ve
Class + - + - - - + - + +
0.25 0.43 0.53 0.76 0.85 0.85 0.85 0.87 0.93 0.95 1.00
TP 5 4 4 3 3 3 3 2 2 1 0
FP 5 5 4 4 3 2 1 1 0 0 0
TN 0 0 1 1 2 3 4 4 5 5 5
FN 0 1 1 2 2 2 2 3 3 4 5
TPR 1 0.8 0.8 0.6 0.6 0.6 0.6 0.4 0.4 0.2 0
FPR 1 1 0.8 0.8 0.6 0.4 0.2 0.2 0 0 0
Threshold >=
ROC Curve:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Test of Si gni f i cance
Given two models:
Model M1: accuracy = 85%, tested on 30 instances
Model M2: accuracy = 75%, tested on 5000 instances
Can we say M1 is better than M2?
How much confidence can we place on accuracy of
M1 and M2?
Can the difference in performance measure be
explained as a result of random fluctuations in the test
set?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Conf i dence I nt er val f or Accur acy
Prediction can be regarded as a Bernoulli trial
A Bernoulli trial has 2 possible outcomes
Possible outcomes for prediction: correct or wrong
Collection of Bernoulli trials has a Binomial distribution:
x Bin(N, p) x: number of correct predictions
e.g: Toss a fair coin 50 times, how many heads would turn up?
Expected number of heads = Np = 50 0.5 = 25
Given x (# of correct predictions) or equivalently,
acc=x/N, and N (# of test instances),
Can we predict p (true accuracy of model)?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Conf i dence I nt er val f or Accur acy
For large test sets (N > 30),
acc has a normal distribution
with mean p and variance
p(1-p)/N
Confidence Interval for p:
=
<
<
1
)
/ ) 1 (
(
2 / 1 2 /
Z
N p p
p acc
Z P
Area = 1 -
Z
/2
Z
1- /2
) ( 2
4 4 2
2
2 /
2 2
2 /
2
2 /
Z N
acc N acc N Z Z acc N
p
+
+ +
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Conf i dence I nt er val f or Accur acy
Consider a model that produces an accuracy of
80% when evaluated on 100 test instances:
N=100, acc = 0.8
Let 1- = 0.95 (95% confidence)
From probability table, Z
/2
=1.96
1- Z
0.99 2.58
0.98 2.33
0.95 1.96
0.90 1.65
N 50 100 500 1000 5000
p(lower) 0.670 0.711 0.763 0.774 0.789
p(upper) 0.888 0.866 0.833 0.824 0.811
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Compar i ng Per f or mance of 2 Model s
Given two models, say M1 and M2, which is
better?
M1 is tested on D1 (size=n1), found error rate = e
1
M2 is tested on D2 (size=n2), found error rate = e
2
Assume D1 and D2 are independent
If n1 and n2 are sufficiently large, then
Approximate:
( )
( )
2 2 2
1 1 1
, ~
, ~
N e
N e
i
i i
i
n
e e ) 1 (
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Compar i ng Per f or mance of 2 Model s
To test if performance difference is statistically
significant: d = e1 e2
d ~ N(d
t
,
t
) where d
t
is the true difference
Since D1 and D2 are independent, their variance
adds up:
At (1-) confidence level,
2
) 2 1 ( 2
1
) 1 1 ( 1
2
2
2
1
2
2
2
1
2
n
e e
n
e e
t
=
+ + =
t t
Z d d
2 /
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
An I l l ust r at i ve Exampl e
Given: M1: n1 = 30, e1 = 0.15
M2: n2 = 5000, e2 = 0.25
d = |e2 e1| = 0.1 (2-sided test)
At 95% confidence level, Z
/2
=1.96
=> Interval contains 0 => difference may not be
statistically significant
0043 . 0
5000
) 25 . 0 1 ( 25 . 0
30
) 15 . 0 1 ( 15 . 0
=
=
d
) 1 (
) (
1 , 1
1
2
2
=
=
=
Dat a Mi ni ng
Cl assi f i cat i on: Al t er nat i ve Techni ques
Lecture Notes for Chapter 5
Introduction to Data Mining
by
Tan, Steinbach, Kumar
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e-Based Cl assi f i er
Classify records by using a collection of
ifthen rules
Rule: (Condition) y
where
Condition is a conjunctions of attributes
y is the class label
LHS: rule antecedent or condition
RHS: rule consequent
Examples of classification rules:
(Blood Type=Warm) (Lay Eggs=Yes) Birds
(Taxable Income < 50K) (Refund=Yes) Evade=No
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e-based Cl assi f i er ( Exampl e)
R1: (Give Birth = no) (Can Fly = yes) Birds
R2: (Give Birth = no) (Live in Water = yes) Fishes
R3: (Give Birth = yes) (Blood Type = warm) Mammals
R4: (Give Birth = no) (Can Fly = no) Reptiles
R5: (Live in Water = sometimes) Amphibians
Name Blood Type Give Birth Can Fly Live in Water Class
human warm yes no no mammals
python cold no no no reptiles
salmon cold no no yes fishes
whale warm yes no yes mammals
frog cold no no sometimes amphibians
komodo cold no no no reptiles
bat warm yes yes no mammals
pigeon warm no yes no birds
cat warm yes no no mammals
leopard shark cold yes no yes fishes
turtle cold no no sometimes reptiles
penguin warm no no sometimes birds
porcupine warm yes no no mammals
eel cold no no yes fishes
salamander cold no no sometimes amphibians
gila monster cold no no no reptiles
platypus warm no no no mammals
owl warm no yes no birds
dolphin warm yes no yes mammals
eagle warm no yes no birds
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl i cat i on of Rul e-Based Cl assi f i er
A rule r covers an instance x if the attributes of
the instance satisfy the condition of the rule
R1: (Give Birth = no) (Can Fly = yes) Birds
R2: (Give Birth = no) (Live in Water = yes) Fishes
R3: (Give Birth = yes) (Blood Type = warm) Mammals
R4: (Give Birth = no) (Can Fly = no) Reptiles
R5: (Live in Water = sometimes) Amphibians
The rule R1 covers a hawk => Bird
The rule R3 covers the grizzly bear => Mammal
Name Blood Type Give Birth Can Fly Live in Water Class
hawk warm no yes no ?
grizzly bear warm yes no no ?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Cover age and Accur acy
Coverage of a rule:
Fraction of records
that satisfy the
antecedent of a rule
Accuracy of a rule:
Fraction of records
that satisfy both the
antecedent and
consequent of a
rule
Tid Refund Marital
Status
Taxable
Income
Class
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
(Status=Single) No
Coverage = 40%, Accuracy = 50%
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How does Rul e-based Cl assi f i er Wor k?
R1: (Give Birth = no) (Can Fly = yes) Birds
R2: (Give Birth = no) (Live in Water = yes) Fishes
R3: (Give Birth = yes) (Blood Type = warm) Mammals
R4: (Give Birth = no) (Can Fly = no) Reptiles
R5: (Live in Water = sometimes) Amphibians
A lemur triggers rule R3, so it is classified as a mammal
A turtle triggers both R4 and R5
A dogfish shark triggers none of the rules
Name Blood Type Give Birth Can Fly Live in Water Class
lemur warm yes no no ?
turtle cold no no sometimes ?
dogfish shark cold yes no yes ?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Char act er i st i cs of Rul e-Based Cl assi f i er
Mutually exclusive rules
Classifier contains mutually exclusive rules if
the rules are independent of each other
Every record is covered by at most one rule
Exhaustive rules
Classifier has exhaustive coverage if it
accounts for every possible combination of
attribute values
Each record is covered by at least one rule
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Fr om Deci si on Tr ees To Rul es
YES YES NO NO
NO NO
NO NO
Yes No
{Married}
{Single,
Divorced}
< 80K > 80K
Taxable
Income
Marital
Status
Refund
Classification Rules
(Refund=Yes) ==> No
(Refund=No, Marital Status={Single,Divorced},
Taxable Income<80K) ==> No
(Refund=No, Marital Status={Single,Divorced},
Taxable Income>80K) ==> Yes
(Refund=No, Marital Status={Married}) ==> No
Rules are mutually exclusive and exhaustive
Rule set contains as much information as the
tree
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul es Can Be Si mpl i f i ed
YES YES NO NO
NO NO
NO NO
Yes No
{Married}
{Single,
Divorced}
< 80K > 80K
Taxable
Income
Marital
Status
Refund
Tid Refund Marital
Status
Taxable
Income
Cheat
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
Initial Rule: (Refund=No) (Status=Married) No
Simplified Rule: (Status=Married) No
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ef f ect of Rul e Si mpl i f i cat i on
Rules are no longer mutually exclusive
A record may trigger more than one rule
Solution?
Ordered rule set
Unordered rule set use voting schemes
Rules are no longer exhaustive
A record may not trigger any rules
Solution?
Use a default class
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Or der ed Rul e Set
Rules are rank ordered according to their priority
An ordered rule set is known as a decision list
When a test record is presented to the classifier
It is assigned to the class label of the highest ranked rule it has
triggered
If none of the rules fired, it is assigned to the default class
R1: (Give Birth = no) (Can Fly = yes) Birds
R2: (Give Birth = no) (Live in Water = yes) Fishes
R3: (Give Birth = yes) (Blood Type = warm) Mammals
R4: (Give Birth = no) (Can Fly = no) Reptiles
R5: (Live in Water = sometimes) Amphibians
Name Blood Type Give Birth Can Fly Live in Water Class
turtle cold no no sometimes ?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Or der i ng Schemes
Rule-based ordering
Individual rules are ranked based on their quality
Class-based ordering
Rules that belong to the same class appear together
Rule-based Ordering
(Refund=Yes) ==> No
(Refund=No, Marital Status={Single,Divorced},
Taxable Income<80K) ==> No
(Refund=No, Marital Status={Single,Divorced},
Taxable Income>80K) ==> Yes
(Refund=No, Marital Status={Married}) ==> No
Class-based Ordering
(Refund=Yes) ==> No
(Refund=No, Marital Status={Single,Divorced},
Taxable Income<80K) ==> No
(Refund=No, Marital Status={Married}) ==> No
(Refund=No, Marital Status={Single,Divorced},
Taxable Income>80K) ==> Yes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Bui l di ng Cl assi f i cat i on Rul es
Direct Method:
Extract rules directly from data
e.g.: RIPPER, CN2, Holtes 1R
Indirect Method:
Extract rules from other classification models (e.g.
decision trees, neural networks, etc).
e.g: C4.5rules
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Di r ect Met hod: Sequent i al Cover i ng
1. Start from an empty rule
2. Grow a rule using the Learn-One-Rule function
3. Remove training records covered by the rule
4. Repeat Step (2) and (3) until stopping criterion
is met
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e of Sequent i al Cover i ng
(i) Original Data (ii) Step 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e of Sequent i al Cover i ng
(iii) Step 2
R1
(iv) Step 3
R1
R2
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Aspect s of Sequent i al Cover i ng
Rule Growing
Instance Elimination
Rule Evaluation
Stopping Criterion
Rule Pruning
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Gr owi ng
Two common strategies
Status =
Single
Status =
Divorced
Status =
Married
Income
> 80K
...
Yes: 3
No: 4
{ }
Yes: 0
No: 3
Refund=
No
Yes: 3
No: 4
Yes: 2
No: 1
Yes: 1
No: 0
Yes: 3
No: 1
(a) General-to-specific
Refund=No,
Status=Single,
Income=85K
(Class=Yes)
Refund=No,
Status=Single,
Income=90K
(Class=Yes)
Refund=No,
Status = Single
(Class = Yes)
(b) Specific-to-general
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Gr owi ng ( Exampl es)
CN2 Algorithm:
Start from an empty conjunct: {}
Add conjuncts that minimizes the entropy measure: {A}, {A,B},
Determine the rule consequent by taking majority class of instances
covered by the rule
RIPPER Algorithm:
Start from an empty rule: {} => class
Add conjuncts that maximizes FOILs information gain measure:
R0: {} => class (initial rule)
R1: {A} => class (rule after adding conjunct)
Gain(R0, R1) = t [ log (p1/(p1+n1)) log (p0/(p0 + n0)) ]
where t: number of positive instances covered by both R0 and R1
p0: number of positive instances covered by R0
n0: number of negative instances covered by R0
p1: number of positive instances covered by R1
n1: number of negative instances covered by R1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I nst ance El i mi nat i on
Why do we need to
eliminate instances?
Otherwise, the next rule is
identical to previous rule
Why do we remove
positive instances?
Ensure that the next rule is
different
Why do we remove
negative instances?
Prevent underestimating
accuracy of rule
Compare rules R2 and R3
in the diagram
class = +
class = -
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
- -
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
R1
R3 R2
+
+
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Eval uat i on
Metrics:
Accuracy
Laplace
M-estimate
k n
n
c
+
+
=
1
k n
kp n
c
+
+
=
n : Number of instances
covered by rule
n
c
: Number of instances
covered by rule
k : Number of classes
p : Prior probability
n
n
c
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St oppi ng Cr i t er i on and Rul e Pr uni ng
Stopping criterion
Compute the gain
If gain is not significant, discard the new rule
Rule Pruning
Similar to post-pruning of decision trees
Reduced Error Pruning:
Remove one of the conjuncts in the rule
Compare error rate on validation set before and
after pruning
If error improves, prune the conjunct
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Summar y of Di r ect Met hod
Grow a single rule
Remove Instances from rule
Prune the rule (if necessary)
Add rule to Current Rule Set
Repeat
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Di r ect Met hod: RI PPER
For 2-class problem, choose one of the classes as
positive class, and the other as negative class
Learn rules for positive class
Negative class will be default class
For multi-class problem
Order the classes according to increasing class
prevalence (fraction of instances that belong to a
particular class)
Learn the rule set for smallest class first, treat the rest
as negative class
Repeat with next smallest class as positive class
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Di r ect Met hod: RI PPER
Growing a rule:
Start from empty rule
Add conjuncts as long as they improve FOILs
information gain
Stop when rule no longer covers negative examples
Prune the rule immediately using incremental reduced
error pruning
Measure for pruning: v = (p-n)/(p+n)
p: number of positive examples covered by the rule in
the validation set
n: number of negative examples covered by the rule in
the validation set
Pruning method: delete any final sequence of
conditions that maximizes v
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Di r ect Met hod: RI PPER
Building a Rule Set:
Use sequential covering algorithm
Finds the best rule that covers the current set of
positive examples
Eliminate both positive and negative examples
covered by the rule
Each time a rule is added to the rule set,
compute the new description length
stop adding new rules when the new description
length is d bits longer than the smallest description
length obtained so far
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Di r ect Met hod: RI PPER
Optimize the rule set:
For each rule r in the rule set R
Consider 2 alternative rules:
Replacement rule (r*): grow new rule from scratch
Revised rule(r): add conjuncts to extend the rule r
Compare the rule set for r against the rule set for r*
and r
Choose rule set that minimizes MDL principle
Repeat rule generation and rule optimization
for the remaining positive examples
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I ndi r ect Met hods
Rule Set
r1: (P=No,Q=No) ==> -
r2: (P=No,Q=Yes) ==> +
r3: (P=Yes,R=No) ==> +
r4: (P=Yes,R=Yes,Q=No) ==> -
r5: (P=Yes,R=Yes,Q=Yes) ==> +
P
Q R
Q
- + +
- +
No No
No
Yes Yes
Yes
No Yes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I ndi r ect Met hod: C4.5r ul es
Extract rules from an unpruned decision tree
For each rule, r: A y,
consider an alternative rule r: A y where A
is obtained by removing one of the conjuncts
in A
Compare the pessimistic error rate for r
against all rs
Prune if one of the rs has lower pessimistic
error rate
Repeat until we can no longer improve
generalization error
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I ndi r ect Met hod: C4.5r ul es
Instead of ordering the rules, order subsets of
rules (class ordering)
Each subset is a collection of rules with the
same rule consequent (class)
Compute description length of each subset
Description length = L(error) + g L(model)
g is a parameter that takes into account the
presence of redundant attributes in a rule set
(default value = 0.5)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e
Name Give Birth Lay Eggs Can Fly Live in Water Have Legs Class
human yes no no no yes mammals
python no yes no no no reptiles
salmon no yes no yes no fishes
whale yes no no yes no mammals
frog no yes no sometimes yes amphibians
komodo no yes no no yes reptiles
bat yes no yes no yes mammals
pigeon no yes yes no yes birds
cat yes no no no yes mammals
leopard shark yes no no yes no fishes
turtle no yes no sometimes yes reptiles
penguin no yes no sometimes yes birds
porcupine yes no no no yes mammals
eel no yes no yes no fishes
salamander no yes no sometimes yes amphibians
gila monster no yes no no yes reptiles
platypus no yes no no yes mammals
owl no yes yes no yes birds
dolphin yes no no yes no mammals
eagle no yes yes no yes birds
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
C4.5 ver sus C4.5r ul es ver sus RI PPER
C4.5rules:
(Give Birth=No, Can Fly=Yes) Birds
(Give Birth=No, Live in Water=Yes) Fishes
(Give Birth=Yes) Mammals
(Give Birth=No, Can Fly=No, Live in Water=No) Reptiles
( ) Amphibians
Give
Birth?
Live In
Water?
Can
Fly?
Mammals
Fishes Amphibians
Birds Reptiles
Yes No
Yes
Sometimes
No
Yes
No
RIPPER:
(Live in Water=Yes) Fishes
(Have Legs=No) Reptiles
(Give Birth=No, Can Fly=No, Live In Water=No)
Reptiles
(Can Fly=Yes,Give Birth=No) Birds
() Mammals
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
C4.5 ver sus C4.5r ul es ver sus RI PPER
PREDICTED CLASS
Amphibians Fishes Reptiles Birds Mammals
ACTUAL Amphibians 0 0 0 0 2
CLASS Fishes 0 3 0 0 0
Reptiles 0 0 3 0 1
Birds 0 0 1 2 1
Mammals 0 2 1 0 4
PREDICTED CLASS
Amphibians Fishes Reptiles Birds Mammals
ACTUAL Amphibians 2 0 0 0 0
CLASS Fishes 0 2 0 0 1
Reptiles 1 0 3 0 0
Birds 1 0 0 3 0
Mammals 0 0 1 0 6
C4.5 and C4.5rules:
RIPPER:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Advant ages of Rul e-Based Cl assi f i er s
As highly expressive as decision trees
Easy to interpret
Easy to generate
Can classify new instances rapidly
Performance comparable to decision trees
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I nst ance-Based Cl assi f i er s
Atr1
...
AtrN Class
A
B
B
C
A
C
B
Set of Stored Cases
Atr1
...
AtrN
Unseen Case
Store the training records
Use training records to
predict the class label of
unseen cases
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I nst ance Based Cl assi f i er s
Examples:
Rote-learner
Memorizes entire training data and performs
classification only if attributes of record match one of
the training examples exactly
Nearest neighbor
Uses k closest points (nearest neighbors) for
performing classification
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est Nei ghbor Cl assi f i er s
Basic idea:
If it walks like a duck, quacks like a duck, then
its probably a duck
Training
Records
Test
Record
Compute
Distance
Choose k of the
nearest records
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est -Nei ghbor Cl assi f i er s
Requires three things
The set of stored records
Distance Metric to compute
distance between records
The value of k, the number of
nearest neighbors to retrieve
To classify an unknown record:
Compute distance to other
training records
Identify k nearest neighbors
Use class labels of nearest
neighbors to determine the
class label of unknown record
(e.g., by taking majority vote)
Unknown record
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Def i ni t i on of Near est Nei ghbor
X X X
(a) 1-nearest neighbor (b) 2-nearest neighbor (c) 3-nearest neighbor
K-nearest neighbors of a record x are data points
that have the k smallest distance to x
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
1 near est -nei ghbor
Voronoi Diagram
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est Nei ghbor Cl assi f i cat i on
Compute distance between two points:
Euclidean distance
Determine the class from nearest neighbor list
take the majority vote of class labels among
the k-nearest neighbors
Weigh the vote according to distance
weight factor, w = 1/d
2
=
i
i i
q p q p d
2
) ( ) , (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est Nei ghbor Cl assi f i cat i on
Choosing the value of k:
If k is too small, sensitive to noise points
If k is too large, neighborhood may include points from
other classes
X
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est Nei ghbor Cl assi f i cat i on
Scaling issues
Attributes may have to be scaled to prevent
distance measures from being dominated by
one of the attributes
Example:
height of a person may vary from 1.5m to 1.8m
weight of a person may vary from 90lb to 300lb
income of a person may vary from $10K to $1M
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est Nei ghbor Cl assi f i cat i on
Problem with Euclidean measure:
High dimensional data
curse of dimensionality
Can produce counter-intuitive results
1 1 1 1 1 1 1 1 1 1 1 0
0 1 1 1 1 1 1 1 1 1 1 1
1 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 1
vs
d = 1.4142 d = 1.4142
Solution: Normalize the vectors to unit length
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est nei ghbor Cl assi f i cat i on
k-NN classifiers are lazy learners
It does not build models explicitly
Unlike eager learners such as decision tree
induction and rule-based systems
Classifying unknown records are relatively
expensive
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e: PEBLS
PEBLS: Parallel Examplar-Based Learning
System (Cost & Salzberg)
Works with both continuous and nominal
features
For nominal features, distance between two
nominal values is computed using modified value
difference metric (MVDM)
Each record is assigned a weight factor
Number of nearest neighbor, k = 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e: PEBLS
Class
Marital Status
Single Married Divorced
Yes 2 0 1
No 2 4 1
=
i
i i
n
n
n
n
V V d
2
2
1
1
2 1
) , (
Distance between nominal attribute values:
d(Single,Married)
= | 2/4 0/4 | + | 2/4 4/4 | = 1
d(Single,Divorced)
= | 2/4 1/2 | + | 2/4 1/2 | = 0
d(Married,Divorced)
= | 0/4 1/2 | + | 4/4 1/2 | = 1
d(Refund=Yes,Refund=No)
= | 0/3 3/7 | + | 3/3 4/7 | = 6/7
Tid Refund Marital
Status
Taxable
Income
Cheat
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
Class
Refund
Yes No
Yes 0 3
No 3 4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e: PEBLS
=
=
d
i
i i Y X
Y X d w w Y X
1
2
) , ( ) , (
Tid Refund Marital
Status
Taxable
Income
Cheat
X Yes Single 125K No
Y No Married 100K No
10
Distance between record X and record Y:
where:
correctly predicts X times of Number
prediction for used is X times of Number
=
X
w
w
X
1 if X makes accurate prediction most of the time
w
X
> 1 if X is not reliable for making predictions
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Bayes Cl assi f i er
A probabilistic framework for solving classification
problems
Conditional Probability:
Bayes theorem:
) (
) ( ) | (
) | (
A P
C P C A P
A C P =
) (
) , (
) | (
) (
) , (
) | (
C P
C A P
C A P
A P
C A P
A C P
=
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e of Bayes Theor em
Given:
A doctor knows that meningitis causes stiff neck 50% of the
time
Prior probability of any patient having meningitis is 1/50,000
Prior probability of any patient having stiff neck is 1/20
If a patient has stiff neck, whats the probability
he/she has meningitis?
0002 . 0
20 / 1
50000 / 1 5 . 0
) (
) ( ) | (
) | ( =
= =
S P
M P M S P
S M P
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Bayesi an Cl assi f i er s
Consider each attribute and class label as random
variables
Given a record with attributes (A
1
, A
2
,,A
n
)
Goal is to predict class C
Specifically, we want to find the value of C that
maximizes P(C| A
1
, A
2
,,A
n
)
Can we estimate P(C| A
1
, A
2
,,A
n
) directly from
data?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Bayesi an Cl assi f i er s
Approach:
compute the posterior probability P(C | A
1
, A
2
, , A
n
) for
all values of C using the Bayes theorem
Choose value of C that maximizes
P(C | A
1
, A
2
, , A
n
)
Equivalent to choosing value of C that maximizes
P(A
1
, A
2
, , A
n
|C) P(C)
How to estimate P(A
1
, A
2
, , A
n
| C )?
) (
) ( ) | (
) | (
2 1
2 1
2 1
n
n
n
A A A P
C P C A A A P
A A A C P
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Nave Bayes Cl assi f i er
Assume independence among attributes A
i
when class is
given:
P(A
1
, A
2
, , A
n
|C) = P(A
1
| C
j
) P(A
2
| C
j
) P(A
n
| C
j
)
Can estimate P(A
i
| C
j
) for all A
i
and C
j
.
New point is classified to C
j
if P(C
j
) P(A
i
| C
j
) is
maximal.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Est i mat e Pr obabi l i t i es f r om Dat a?
Class: P(C) = N
c
/N
e.g., P(No) = 7/10,
P(Yes) = 3/10
For discrete attributes:
P(A
i
| C
k
) = |A
ik
|/ N
c
where |A
ik
| is number of
instances having attribute
A
i
and belongs to class C
k
Examples:
P(Status=Married|No) = 4/7
P(Refund=Yes|Yes)=0
k
Tid Refund Marital
Status
Taxable
Income
Evade
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
c c c
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Est i mat e Pr obabi l i t i es f r om Dat a?
For continuous attributes:
Discretize the range into bins
one ordinal attribute per bin
violates independence assumption
Two-way split: (A < v) or (A > v)
choose only one of the two splits as new attribute
Probability density estimation:
Assume attribute follows a normal distribution
Use data to estimate parameters of distribution
(e.g., mean and standard deviation)
Once probability distribution is known, can use it to
estimate the conditional probability P(A
i
|c)
k
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Est i mat e Pr obabi l i t i es f r om Dat a?
Normal distribution:
One for each (A
i
,c
i
) pair
For (Income, Class=No):
If Class=No
sample mean = 110
sample variance = 2975
Tid Refund Marital
Status
Taxable
Income
Evade
1 Yes Single 125K No
2 No Married 100K No
3 No Single 70K No
4 Yes Married 120K No
5 No Divorced 95K Yes
6 No Married 60K No
7 Yes Divorced 220K No
8 No Single 85K Yes
9 No Married 75K No
10 No Single 90K Yes
10
2
2
2
) (
2
2
1
) | (
ij
ij i
A
ij
j i
e c A P
=
0072 . 0
) 54 . 54 ( 2
1
) | 120 (
) 2975 ( 2
) 110 120 (
2
= = =
e No Income P
X
1
X
2
X
3
Y
Black box
0.3
0.3
0.3
t=0.4
Output
node
Input
nodes
=
> + + =
otherwise 0
true is if 1
) ( where
) 0 4 . 0 3 . 0 3 . 0 3 . 0 (
3 2 1
z
z I
X X X I Y
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ar t i f i ci al Neur al Net wor ks ( ANN)
Model is an assembly of
inter-connected nodes
and weighted links
Output node sums up
each of its input value
according to the weights
of its links
Compare output node
against some threshold t
X
1
X
2
X
3
Y
Black box
w
1
t
Output
node
Input
nodes
w
2
w
3
) ( t X w I Y
i
i i
=
Perceptron Model
) ( t X w sign Y
i
i i
=
or
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gener al St r uct ur e of ANN
Activation
function
g(S
i
)
S
i
O
i
I
1
I
2
I
3
w
i1
w
i2
w
i3
O
i
Neuron i Input Output
threshold, t
Input
Layer
Hidden
Layer
Output
Layer
x
1
x
2
x
3
x
4
x
5
y
Training ANN means learning
the weights of the neurons
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Al gor i t hm f or l ear ni ng ANN
Initialize the weights (w
0
, w
1
, , w
k
)
Adjust the weights in such a way that the output
of ANN is consistent with class labels of training
examples
Objective function:
Find the weights w
i
s that minimize the above
objective function
e.g., backpropagation algorithm (see lecture notes)
| |
2
) , (
=
i
i i i
X w f Y E
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
Find a linear hyperplane (decision boundary) that will separate the data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
One Possible Solution
B
1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
Another possible solution
B
2
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
Other possible solutions
B
2
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
Which one is better? B1 or B2?
How do you define better?
B
1
B
2
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
Find hyperplane maximizes the margin => B1 is better than B2
B
1
B
2
b
11
b
12
b
21
b
22
margin
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
B
1
b
11
b
12
0 = + b x w
1 = + b x w
1 + = + b x w
+
+
=
1 b x w if 1
1 b x w if 1
) (
x f
2
|| ||
2
Margin
w
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
We want to maximize:
Which is equivalent to minimizing:
But subjected to the following constraints:
This is a constrained optimization problem
Numerical approaches to solve it (e.g., quadratic programming)
2
|| ||
2
Margin
w
+
+
=
1 b x w if 1
1 b x w if 1
) (
i
i
i
x f
2
|| ||
) (
2
w
w L
=
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
What if the problem is not linearly separable?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Suppor t Vect or Machi nes
What if the problem is not linearly separable?
Introduce slack variables
Need to minimize:
Subject to:
+ +
+
=
i i
i i
1 b x w if 1
- 1 b x w if 1
) (
i
x f
|
.
|
\
|
+ =
=
N
i
k
i
C
w
w L
1
2
2
|| ||
) (
=
|
|
.
|
\
|
25
13
25
06 . 0 ) 1 (
25
i
i i
i
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es of Ensembl e Met hods
How to generate an ensemble of classifiers?
Bagging
Boosting
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Baggi ng
Sampling with replacement
Build classifier on each bootstrap sample
Each sample has probability (1 1/n)
n
of being
selected
Original Data 1 2 3 4 5 6 7 8 9 10
Bagging (Round 1) 7 8 10 8 2 5 10 10 5 9
Bagging (Round 2) 1 4 9 1 2 3 2 7 3 2
Bagging (Round 3) 1 8 5 10 5 5 9 6 3 7
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Boost i ng
An iterative procedure to adaptively change
distribution of training data by focusing more on
previously misclassified records
Initially, all N records are assigned equal
weights
Unlike bagging, weights may change at the
end of boosting round
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Boost i ng
Records that are wrongly classified will have their
weights increased
Records that are classified correctly will have
their weights decreased
Original Data 1 2 3 4 5 6 7 8 9 10
Boosting (Round 1) 7 3 2 8 7 9 4 10 6 3
Boosting (Round 2) 5 4 9 4 2 5 1 7 4 2
Boosting (Round 3) 4 4 8 10 4 5 4 6 3 4
Example 4 is hard to classify
Its weight is increased, therefore it is more
likely to be chosen again in subsequent rounds
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e: AdaBoost
Base classifiers: C
1
, C
2
, , C
T
Error rate:
Importance of a classifier:
( )
=
=
N
j
j j i j i
y x C w
N
1
) (
1
|
|
.
|
\
|
=
i
i
i
1
ln
2
1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e: AdaBoost
Weight update:
If any intermediate rounds produce error rate
higher than 50%, the weights are reverted back
to 1/n and the resampling procedure is repeated
Classification:
factor ion normalizat the is where
) ( if exp
) ( if exp
) (
) 1 (
j
i i j
i i j
j
j
i
j
i
Z
y x C
y x C
Z
w
w
j
j
=
=
+
( )
=
= =
T
j
j j
y
y x C x C
1
) ( max arg ) ( *
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Boosting
Round 1
+ + + - - - - - - -
0.0094 0.0094 0.4623
B1
= 1.9459
I l l ust r at i ng AdaBoost
Data points
for training
Initial weights for each data point
Original
Data
+ + + - - - - - + +
0.1 0.1 0.1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I l l ust r at i ng AdaBoost
Boosting
Round 1
+ + + - - - - - - -
Boosting
Round 2
- - - - - - - - + +
Boosting
Round 3
+ + + + + + + + + +
Overall
+ + + - - - - - + +
0.0094 0.0094 0.4623
0.3037 0.0009 0.0422
0.0276 0.1819
0.0038
B1
B2
B3
= 1.9459
= 2.9323
= 3.8744
Dat a Mi ni ng
Associ at i on Anal ysi s: Basi c Concept s
and Al gor i t hms
Lecture Notes for Chapter 6
Introduction to Data Mining
by
Tan, Steinbach, Kumar
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Associ at i on Rul e Mi ni ng
Given a set of transactions, find rules that will predict the
occurrence of an item based on the occurrences of other
items in the transaction
Market-Basket transactions
TID Items
1 Bread, Milk
2 Bread, Diaper, Beer, Eggs
3 Milk, Diaper, Beer, Coke
4 Bread, Milk, Diaper, Beer
5 Bread, Milk, Diaper, Coke
Example of Association Rules
{Diaper} {Beer},
{Milk, Bread} {Eggs,Coke},
{Beer, Bread} {Milk},
Implication means co-occurrence,
not causality!
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Def i ni t i on: Fr equent I t emset
Itemset
A collection of one or more items
Example: {Milk, Bread, Diaper}
k-itemset
An itemset that contains k items
Support count ()
Frequency of occurrence of an itemset
E.g. ({Milk, Bread,Diaper}) = 2
Support
Fraction of transactions that contain an
itemset
E.g. s({Milk, Bread, Diaper}) = 2/5
Frequent Itemset
An itemset whose support is greater
than or equal to a minsup threshold
TID Items
1 Bread, Milk
2 Bread, Diaper, Beer, Eggs
3 Milk, Diaper, Beer, Coke
4 Bread, Milk, Diaper, Beer
5 Bread, Milk, Diaper, Coke
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Def i ni t i on: Associ at i on Rul e
Example:
Beer } Diaper , Milk {
4 . 0
5
2
| T |
) Beer Diaper, , Milk (
= = =
s
67 . 0
3
2
) Diaper , Milk (
) Beer Diaper, Milk, (
= = =
c
Association Rule
An implication expression of the form
X Y, where X and Y are itemsets
Example:
{Milk, Diaper} {Beer}
Rule Evaluation Metrics
Support (s)
Fraction of transactions that contain
both X and Y
Confidence (c)
Measures how often items in Y
appear in transactions that
contain X
TID Items
1 Bread, Milk
2 Bread, Diaper, Beer, Eggs
3 Milk, Diaper, Beer, Coke
4 Bread, Milk, Diaper, Beer
5 Bread, Milk, Diaper, Coke
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Associ at i on Rul e Mi ni ng Task
Given a set of transactions T, the goal of
association rule mining is to find all rules having
support minsup threshold
confidence minconf threshold
Brute-force approach:
List all possible association rules
Compute the support and confidence for each rule
Prune rules that fail the minsup and minconf
thresholds
Computationally prohibitive!
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi ni ng Associ at i on Rul es
Example of Rules:
{Milk,Diaper} {Beer} (s=0.4, c=0.67)
{Milk,Beer} {Diaper} (s=0.4, c=1.0)
{Diaper,Beer} {Milk} (s=0.4, c=0.67)
{Beer} {Milk,Diaper} (s=0.4, c=0.67)
{Diaper} {Milk,Beer} (s=0.4, c=0.5)
{Milk} {Diaper,Beer} (s=0.4, c=0.5)
TID Items
1 Bread, Milk
2 Bread, Diaper, Beer, Eggs
3 Milk, Diaper, Beer, Coke
4 Bread, Milk, Diaper, Beer
5 Bread, Milk, Diaper, Coke
Observations:
All the above rules are binary partitions of the same itemset:
{Milk, Diaper, Beer}
Rules originating from the same itemset have identical support but
can have different confidence
Thus, we may decouple the support and confidence requirements
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi ni ng Associ at i on Rul es
Two-step approach:
1. Frequent Itemset Generation
Generate all itemsets whose support minsup
2. Rule Generation
Generate high confidence rules from each frequent itemset,
where each rule is a binary partitioning of a frequent itemset
Frequent itemset generation is still
computationally expensive
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Fr equent I t emset Gener at i on
null
AB AC AD AE BC BD BE CD CE DE
A B C D E
ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE
ABCD ABCE ABDE ACDE BCDE
ABCDE
Given d items, there
are 2
d
possible
candidate itemsets
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Fr equent I t emset Gener at i on
Brute-force approach:
Each itemset in the lattice is a candidate frequent itemset
Count the support of each candidate by scanning the
database
Match each transaction against every candidate
Complexity ~ O(NMw) => Expensive since M = 2
d
!!!
TID Items
1 Bread, Milk
2 B d Di B E
N
T ti
List of
Candidates
M
w
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Comput at i onal Compl exi t y
Given d unique items:
Total number of itemsets = 2
d
Total number of possible association rules:
1 2 3
1
1
1 1
+ =
(
|
.
|
\
|
|
.
|
\
|
=
+
=
d d
d
k
k d
j
j
k d
k
d
R
If d=6, R = 602 rules
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Fr equent I t emset Gener at i on St r at egi es
Reduce the number of candidates (M)
Complete search: M=2
d
Use pruning techniques to reduce M
Reduce the number of transactions (N)
Reduce size of N as the size of itemset increases
Used by DHP and vertical-based mining algorithms
Reduce the number of comparisons (NM)
Use efficient data structures to store the candidates or
transactions
No need to match every candidate against every
transaction
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Reduci ng Number of Candi dat es
Apriori principle:
If an itemset is frequent, then all of its subsets must also
be frequent
Apriori principle holds due to the following property
of the support measure:
Support of an itemset never exceeds the support of its
subsets
This is known as the anti-monotone property of support
) ( ) ( ) ( : , Y s X s Y X Y X
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Found to be
Infrequent
null
AB AC AD AE BC BD BE CD CE DE
A B C D E
ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE
ABCD ABCE ABDE ACDE BCDE
ABCDE
I l l ust rat i ng Apr i or i Pr i nci pl e
null
AB AC AD AE BC BD BE CD CE DE
A B C D E
ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE
ABCD ABCE ABDE ACDE BCDE
ABCDE
Pruned
supersets
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I l l ust r at i ng Apr i or i Pr i nci pl e
Item Count
Bread 4
Coke 2
Milk 4
Beer 3
Diaper 4
Eggs 1
Itemset Count
{Bread,Milk} 3
{Bread,Beer} 2
{Bread,Diaper} 3
{Milk,Beer} 2
{Milk,Diaper} 3
{Beer,Diaper} 3
Itemset Count
{Bread,Milk,Diaper} 3
I t ems (1-it emset s)
Pairs (2-it emset s)
(No need t o generat e
candidat es involving Coke
or Eggs)
Triplet s (3-it emset s)
Minimum Support = 3
I f every subset is considered,
6
C
1
+
6
C
2
+
6
C
3
= 41
Wit h support-based pruning,
6 + 6 + 1 = 13
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Apr i or i Al gor i t hm
Method:
Let k=1
Generate frequent itemsets of length 1
Repeat until no new frequent itemsets are identified
Generate length (k+1) candidate itemsets from length k
frequent itemsets
Prune candidate itemsets containing subsets of length k that
are infrequent
Count the support of each candidate by scanning the DB
Eliminate candidates that are infrequent, leaving only those
that are frequent
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Reduci ng Number of Compar i sons
Candidate counting:
Scan the database of transactions to determine the
support of each candidate itemset
To reduce the number of comparisons, store the
candidates in a hash structure
Instead of matching each transaction against every candidate,
match it against candidates contained in the hashed buckets
TID Items
1 Bread, Milk
2 Bread, Diaper, Beer, Eggs
N
Transactions
Hash Structure
k
Buckets
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gener at e Hash Tr ee
2 3 4
5 6 7
1 4 5
1 3 6
1 2 4
4 5 7
1 2 5
4 5 8
1 5 9
3 4 5 3 5 6
3 5 7
6 8 9
3 6 7
3 6 8
1,4,7
2,5,8
3,6,9
Hash function
Suppose you have 15 candidate itemsets of length 3:
{1 4 5}, {1 2 4}, {4 5 7}, {1 2 5}, {4 5 8}, {1 5 9}, {1 3 6}, {2 3 4}, {5 6 7}, {3 4 5},
{3 5 6}, {3 5 7}, {6 8 9}, {3 6 7}, {3 6 8}
You need:
Hash function
Max leaf size: max number of itemsets stored in a leaf node (if number of
candidate itemsets exceeds max leaf size, split the node)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Associ at i on Rul e Di scover y: Hash t r ee
1 5 9
1 4 5 1 3 6
3 4 5 3 6 7
3 6 8
3 5 6
3 5 7
6 8 9
2 3 4
5 6 7
1 2 4
4 5 7
1 2 5
4 5 8
1,4,7
2,5,8
3,6,9
Hash Function
Candidate Hash Tree
Hash on
1, 4 or 7
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Associ at i on Rul e Di scover y: Hash t r ee
1 5 9
1 4 5 1 3 6
3 4 5 3 6 7
3 6 8
3 5 6
3 5 7
6 8 9
2 3 4
5 6 7
1 2 4
4 5 7
1 2 5
4 5 8
1,4,7
2,5,8
3,6,9
Hash Function
Candidate Hash Tree
Hash on
2, 5 or 8
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Associ at i on Rul e Di scover y: Hash t r ee
1 5 9
1 4 5 1 3 6
3 4 5 3 6 7
3 6 8
3 5 6
3 5 7
6 8 9
2 3 4
5 6 7
1 2 4
4 5 7
1 2 5
4 5 8
1,4,7
2,5,8
3,6,9
Hash Function
Candidate Hash Tree
Hash on
3, 6 or 9
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Subset Oper at i on
1 2 3 5 6
Transaction, t
2 3 5 6 1 3 5 6 2
5 6 1 3 3 5 6 1 2 6 1 5 5 6 2 3 6 2 5
5 6 3
1 2 3
1 2 5
1 2 6
1 3 5
1 3 6
1 5 6
2 3 5
2 3 6
2 5 6 3 5 6
Subsets of 3 items
Level 1
Level 2
Level 3
6 3 5
Given a transaction t, what
are the possible subsets of
size 3?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Subset Oper at i on Usi ng Hash Tr ee
1 5 9
1 4 5 1 3 6
3 4 5 3 6 7
3 6 8
3 5 6
3 5 7
6 8 9
2 3 4
5 6 7
1 2 4
4 5 7
1 2 5
4 5 8
1 2 3 5 6
1 + 2 3 5 6
3 5 6 2 +
5 6 3 +
1,4,7
2,5,8
3,6,9
Hash Function
transaction
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Subset Oper at i on Usi ng Hash Tr ee
1 5 9
1 4 5 1 3 6
3 4 5 3 6 7
3 6 8
3 5 6
3 5 7
6 8 9
2 3 4
5 6 7
1 2 4
4 5 7
1 2 5
4 5 8
1,4,7
2,5,8
3,6,9
Hash Function
1 2 3 5 6
3 5 6 1 2 +
5 6 1 3 +
6 1 5 +
3 5 6 2 +
5 6 3 +
1 + 2 3 5 6
transaction
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Subset Oper at i on Usi ng Hash Tr ee
1 5 9
1 4 5 1 3 6
3 4 5 3 6 7
3 6 8
3 5 6
3 5 7
6 8 9
2 3 4
5 6 7
1 2 4
4 5 7
1 2 5
4 5 8
1,4,7
2,5,8
3,6,9
Hash Function
1 2 3 5 6
3 5 6 1 2 +
5 6 1 3 +
6 1 5 +
3 5 6 2 +
5 6 3 +
1 + 2 3 5 6
transaction
Match transaction against 11 out of 15 candidates
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Fact or s Af f ect i ng Compl exi t y
Choice of minimum support threshold
lowering support threshold results in more frequent itemsets
this may increase number of candidates and max length of
frequent itemsets
Dimensionality (number of items) of the data set
more space is needed to store support count of each item
if number of frequent items also increases, both computation and
I/O costs may also increase
Size of database
since Apriori makes multiple passes, run time of algorithm may
increase with number of transactions
Average transaction width
transaction width increases with denser data sets
This may increase max length of frequent itemsets and traversals
of hash tree (number of subsets in a transaction increases with its
width)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Compact Represent at i on of Frequent I t emset s
Some itemsets are redundant because they have
identical support as their supersets
Number of frequent itemsets
Need a compact representation
TID A1 A2 A3 A4 A5 A6 A7 A8 A9 A10 B1 B2 B3 B4 B5 B6 B7 B8 B9 B10 C1 C2 C3 C4 C5 C6 C7 C8 C9 C10
1 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
2 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
3 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
4 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
5 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
6 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0
7 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0
8 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0
9 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0
10 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0
11 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1
12 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1
13 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1
14 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1
15 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1
=
|
.
|
\
|
=
10
1
10
3
k
k
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Maxi mal Fr equent I t emset
null
AB AC AD AE BC BD BE CD CE DE
A B C D E
ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE
ABCD ABCE ABDE ACDE BCDE
ABCD
E
Border
Infrequent
Itemsets
Maximal
Itemsets
An itemset is maximal frequent if none of its immediate supersets
is frequent
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl osed I t emset
An itemset is closed if none of its immediate supersets
has the same support as the itemset
TID Items
1 {A,B}
2 {B,C,D}
3 {A,B,C,D}
4 {A,B,D}
5 {A,B,C,D}
Itemset Support
{A} 4
{B} 5
{C} 3
{D} 4
{A,B} 4
{A,C} 2
{A,D} 3
{B,C} 3
{B,D} 4
{C,D} 3
Itemset Support
{A,B,C} 2
{A,B,D} 3
{A,C,D} 2
{B,C,D} 3
{A,B,C,D} 2
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Maxi mal vs Cl osed I t emset s
TID Items
1 ABC
2 ABCD
3 BCE
4 ACDE
5 DE
null
AB AC AD AE BC BD BE CD CE DE
A B C D E
ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE
ABCD ABCE ABDE ACDE BCDE
ABCDE
124 123
1234 245 345
12 124 24
4
123
2
3 24
34
45
12
2
24
4 4
2
3 4
2
4
Transaction Ids
Not supported by
any transactions
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Maxi mal vs Cl osed Fr equent I t emset s
null
AB AC AD AE BC BD BE CD CE DE
A B C D E
ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE
ABCD ABCE ABDE ACDE BCDE
ABCDE
124 123
1234 245 345
12 124 24
4
123
2
3 24
34
45
12
2
24
4 4
2
3 4
2
4
Minimum support = 2
# Closed = 9
# Maximal = 4
Closed and
maximal
Closed but
not maximal
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Maxi mal vs Cl osed I t emset s
Frequent
Itemsets
Closed
Frequent
Itemsets
Maximal
Frequent
Itemsets
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Al t ernat i ve Met hods f or Frequent I t emset Generat i on
Traversal of Itemset Lattice
General-to-specific vs Specific-to-general
Frequent
itemset
border
null
{a
1
,a
2
,...,a
n
}
(a) General-to-specific
null
{a
1
,a
2
,...,a
n
}
Frequent
itemset
border
(b) Specific-to-general
..
..
..
..
Frequent
itemset
border
null
{a
1
,a
2
,...,a
n
}
(c) Bidirectional
..
..
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Al t ernat i ve Met hods f or Frequent I t emset Generat i on
Traversal of Itemset Lattice
Equivalent Classes
null
AB AC AD BC BD
CD
A B
C
D
ABC ABD ACD
BCD
ABCD
null
AB AC
AD BC BD CD
A B
C
D
ABC
ABD ACD BCD
ABCD
(a) Prefix tree (b) Suffix tree
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Al t ernat i ve Met hods f or Frequent I t emset Generat i on
Traversal of Itemset Lattice
Breadth-first vs Depth-first
(a) Breadth first (b) Depth first
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Al t ernat i ve Met hods f or Frequent I t emset Generat i on
Representation of Database
horizontal vs vertical data layout
TID Items
1 A,B,E
2 B,C,D
3 C,E
4 A,C,D
5 A,B,C,D
Horizontal
Data Layout
A B C D
1 1 2 2
4 2 3 4
5 5 4 5
6 7 8 9
Vertical Data Layout
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
FP-gr owt h Al gor i t hm
Use a compressed representation of the
database using an FP-tree
Once an FP-tree has been constructed, it uses a
recursive divide-and-conquer approach to mine
the frequent itemsets
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
FP-t r ee const r uct i on
null
A:1
B:1
null
A:1
B:1
B:1
C:1
D:1
After reading TID=1:
After reading TID=2:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
FP-Tr ee Const r uct i on
null
A:7
B:5
B:3
C:3
D:1
C:1
D:1
C:3
D:1
D:1
E:1
E:1
Pointers are used to assist
frequent itemset generation
D:1
E:1
Transaction
Database
Item Pointer
A
B
C
D
E
Header table
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
FP-gr owt h
null
A:7
B:5
B:1
C:1
D:1
C:1
D:1
C:3
D:1
D:1
Conditional Pattern base
for D:
P = {(A:1,B:1,C:1),
(A:1,B:1),
(A:1,C:1),
(A:1),
(B:1,C:1)}
Recursively apply FP-
growth on P
Frequent Itemsets found
(with sup > 1):
AD, BD, CD, ACD, BCD
D:1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Tr ee Pr oj ect i on
Set enumeration tree:
null
AB AC AD AE BC BD BE CD CE DE
A B C D E
ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE
ABCD ABCE ABDE ACDE BCDE
ABCDE
Possible Extension:
E(A) = {B,C,D,E}
Possible Extension:
E(ABC) = {D,E}
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Tr ee Pr oj ect i on
Items are listed in lexicographic order
Each node P stores the following information:
Itemset for node P
List of possible lexicographic extensions of P: E(P)
Pointer to projected database of its ancestor node
Bitvector containing information about which
transactions in the projected database contain the
itemset
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Pr oj ect ed Dat abase
TID Items
1 {B}
2 {}
3 {C,D,E}
4 {D,E}
5 {B,C}
6 {B,C,D}
7 {}
8 {B,C}
9 {B,D}
10 {}
Original Database:
Projected Database
for node A:
For each transaction T, projected transaction at node A is T E(A)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
ECLAT
For each item, store a list of transaction ids (tids)
TID Items
1 A,B,E
2 B,C,D
3 C,E
4 A,C,D
5 A,B,C,D
6 A,E
7 A,B
8 A,B,C
9 A,C,D
10 B
Horizontal
Data Layout
A B C D E
1 1 2 2 1
4 2 3 4 3
5 5 4 5 6
6 7 8 9
7 8 9
8 10
9
Vertical Data Layout
TID-list
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
ECLAT
Determine support of any k-itemset by intersecting tid-lists
of two of its (k-1) subsets.
3 traversal approaches:
top-down, bottom-up and hybrid
Advantage: very fast support counting
Disadvantage: intermediate tid-lists may become too
large for memory
A
1
4
5
6
7
8
9
B
1
2
5
7
8
10
AB
1
5
7
8
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Gener at i on
Given a frequent itemset L, find all non-empty
subsets f L such that f L f satisfies the
minimum confidence requirement
If {A,B,C,D} is a frequent itemset, candidate rules:
ABC D, ABD C, ACD B, BCD A,
A BCD, B ACD, C ABD, D ABC
AB CD, AC BD, AD BC, BC AD,
BD AC, CD AB,
If |L| = k, then there are 2
k
2 candidate
association rules (ignoring L and L)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Gener at i on
How to efficiently generate rules from frequent
itemsets?
In general, confidence does not have an anti-
monotone property
c(ABC D) can be larger or smaller than c(AB D)
But confidence of rules generated from the same
itemset has an anti-monotone property
e.g., L = {A,B,C,D}:
c(ABC D) c(AB CD) c(A BCD)
Confidence is anti-monotone w.r.t. number of items on the
RHS of the rule
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Gener at i on f or Apr i or i Al gor i t hm
ABCD=>{ }
BCD=>A ACD=>B ABD=>C ABC=>D
BC=>AD BD=>AC CD=>AB AD=>BC AC=>BD AB=>CD
D=>ABC C=>ABD B=>ACD A=>BCD
Lattice of rules
ABCD=>{ }
BCD=>A ACD=>B ABD=>C ABC=>D
BC=>AD BD=>AC CD=>AB AD=>BC AC=>BD AB=>CD
D=>ABC C=>ABD B=>ACD A=>BCD
Pruned
Rules
Low
Confidence
Rule
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Rul e Gener at i on f or Apr i or i Al gor i t hm
Candidate rule is generated by merging two rules
that share the same prefix
in the rule consequent
join(CD=>AB,BD=>AC)
would produce the candidate
rule D => ABC
Prune rule D=>ABC if its
subset AD=>BC does not have
high confidence
BD=>AC CD=>AB
D=>ABC
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ef f ect of Suppor t Di st r i but i on
Many real data sets have skewed support
distribution
Support
distribution of
a retail data set
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ef f ect of Suppor t Di st r i but i on
How to set the appropriate minsup threshold?
If minsup is set too high, we could miss itemsets
involving interesting rare items (e.g., expensive
products)
If minsup is set too low, it is computationally
expensive and the number of itemsets is very large
Using a single minimum support threshold may
not be effective
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl e Mi ni mum Suppor t
How to apply multiple minimum supports?
MS(i): minimum support for item i
e.g.: MS(Milk)=5%, MS(Coke) = 3%,
MS(Broccoli)=0.1%, MS(Salmon)=0.5%
MS({Milk, Broccoli}) = min (MS(Milk), MS(Broccoli))
= 0.1%
Challenge: Support is no longer anti-monotone
Suppose: Support(Milk, Coke) = 1.5% and
Support(Milk, Coke, Broccoli) = 0.5%
{Milk,Coke} is infrequent but {Milk,Coke,Broccoli} is frequent
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl e Mi ni mum Suppor t
A
Item MS(I) Sup(I)
A 0.10% 0.25%
B 0.20% 0.26%
C 0.30% 0.29%
D 0.50% 0.05%
E 3% 4.20%
B
C
D
E
AB
AC
AD
AE
BC
BD
BE
CD
CE
DE
ABC
ABD
ABE
ACD
ACE
ADE
BCD
BCE
BDE
CDE
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl e Mi ni mum Suppor t
A
B
C
D
E
AB
AC
AD
AE
BC
BD
BE
CD
CE
DE
ABC
ABD
ABE
ACD
ACE
ADE
BCD
BCE
BDE
CDE
Item MS(I) Sup(I)
A 0.10% 0.25%
B 0.20% 0.26%
C 0.30% 0.29%
D 0.50% 0.05%
E 3% 4.20%
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl e Mi ni mum Suppor t ( Li u 1999)
Order the items according to their minimum
support (in ascending order)
e.g.: MS(Milk)=5%, MS(Coke) = 3%,
MS(Broccoli)=0.1%, MS(Salmon)=0.5%
Ordering: Broccoli, Salmon, Coke, Milk
Need to modify Apriori such that:
L
1
: set of frequent items
F
1
: set of items whose support is MS(1)
where MS(1) is min
i
( MS(i) )
C
2
: candidate itemsets of size 2 is generated from F
1
instead of L
1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl e Mi ni mum Suppor t ( Li u 1999)
Modifications to Apriori:
In traditional Apriori,
A candidate (k+1)-itemset is generated by merging two
frequent itemsets of size k
The candidate is pruned if it contains any infrequent subsets
of size k
Pruning step has to be modified:
Prune only if subset contains the first item
e.g.: Candidate={Broccoli, Coke, Milk} (ordered according to
minimum support)
{Broccoli, Coke} and {Broccoli, Milk} are frequent but
{Coke, Milk} is infrequent
Candidate is not pruned because {Coke,Milk} does not contain
the first item, i.e., Broccoli.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Pat t er n Eval uat i on
Association rule algorithms tend to produce too
many rules
many of them are uninteresting or redundant
Redundant if {A,B,C} {D} and {A,B} {D}
have same support & confidence
Interestingness measures can be used to
prune/rank the derived patterns
In the original formulation of association rules,
support & confidence are the only measures used
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl i cat i on of I nt er est i ngness Measur e
Interestingness
Measures
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Comput i ng I nt er est i ngness Measur e
Given a rule X Y, information needed to compute rule
interestingness can be obtained from a contingency table
Y Y
X f
11
f
10
f
1+
X f
01
f
00
f
o+
f
+1
f
+0
|T|
Contingency table for X Y
f
11
: support of X and Y
f
10
: support of X and Y
f
01
: support of X and Y
f
00
: support of X and Y
Used to define various measures
support, confidence, lift, Gini,
J-measure, etc.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Dr awback of Conf i dence
Coffee Coffee
Tea 15 5 20
Tea 75 5 80
90 10 100
Associat ion Rule: Tea Coffee
Confidence= P(Coffee| Tea) = 0.75
but P(Coffee) = 0.9
Alt hough confidence is high, rule is misleading
P(Coffee| Tea) = 0.9375
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St at i st i cal I ndependence
Population of 1000 students
600 students know how to swim (S)
700 students know how to bike (B)
420 students know how to swim and bike (S,B)
P(SB) = 420/1000 = 0.42
P(S) P(B) = 0.6 0.7 = 0.42
P(SB) = P(S) P(B) => Statistical independence
P(SB) > P(S) P(B) => Positively correlated
P(SB) < P(S) P(B) => Negatively correlated
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St at i st i cal -based Measur es
Measures that take into account statistical
dependence
)] ( 1 )[ ( )] ( 1 )[ (
) ( ) ( ) , (
) ( ) ( ) , (
) ( ) (
) , (
) (
) | (
Y P Y P X P X P
Y P X P Y X P
t coefficien
Y P X P Y X P PS
Y P X P
Y X P
Interest
Y P
X Y P
Lift
=
=
=
=
\
|
|
|
.
|
\
|
=
T i C j
j i D C ) , ( ) sup(
min
Example:
Sup(W1,W2,W3)
= 0 + 0 + 0 + 0 + 0.17
= 0.17
TID W1 W2 W3 W4 W5
D1 0.40 0.33 0.00 0.00 0.17
D2 0.00 0.00 0.33 1.00 0.33
D3 0.40 0.50 0.00 0.00 0.00
D4 0.00 0.00 0.33 0.00 0.17
D5 0.20 0.17 0.33 0.00 0.33
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ant i -monot one pr oper t y of Suppor t
Example:
Sup(W1) = 0.4 + 0 + 0.4 + 0 + 0.2 = 1
Sup(W1, W2) = 0.33 + 0 + 0.4 + 0 + 0.17 = 0.9
Sup(W1, W2, W3) = 0 + 0 + 0 + 0 + 0.17 = 0.17
TID W1 W2 W3 W4 W5
D1 0.40 0.33 0.00 0.00 0.17
D2 0.00 0.00 0.33 1.00 0.33
D3 0.40 0.50 0.00 0.00 0.00
D4 0.00 0.00 0.33 0.00 0.17
D5 0.20 0.17 0.33 0.00 0.33
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i -l evel Associ at i on Rul es
Food
Bread
Milk
Skim
2%
Electronics
Computers Home
Desktop Laptop
Wheat White
Foremost Kemps
DVD TV
Printer Scanner
Accessory
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i -l evel Associ at i on Rul es
Why should we incorporate concept hierarchy?
Rules at lower levels may not have enough support to
appear in any frequent itemsets
Rules at lower levels of the hierarchy are overly
specific
e.g., skim milk white bread, 2% milk wheat bread,
skim milk wheat bread, etc.
are indicative of association between milk and bread
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i -l evel Associ at i on Rul es
How do support and confidence vary as we
traverse the concept hierarchy?
If X is the parent item for both X1 and X2, then
(X) (X1) + (X2)
If (X1 Y1) minsup,
and X is parent of X1, Y is parent of Y1
then (X Y1) minsup, (X1 Y) minsup
(X Y) minsup
If conf(X1 Y1) minconf,
then conf(X1 Y) minconf
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i -l evel Associ at i on Rul es
Approach 1:
Extend current association rule formulation by augmenting each
transaction with higher level items
Original Transaction: {skim milk, wheat bread}
Augmented Transaction:
{skim milk, wheat bread, milk, bread, food}
Issues:
Items that reside at higher levels have much higher support
counts
if support threshold is low, too many frequent patterns involving items
from the higher levels
Increased dimensionality of the data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i -l evel Associ at i on Rul es
Approach 2:
Generate frequent patterns at highest level first
Then, generate frequent patterns at the next highest
level, and so on
Issues:
I/O requirements will increase dramatically because
we need to perform more passes over the data
May miss some potentially interesting cross-level
association patterns
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Sequence Dat a
10 15 20 25 30 35
2
3
5
6
1
1
Timeline
Object A:
Object B:
Object C:
4
5
6
2 7
8
1
2
1
6
1
7
8
Object Timestamp Events
A 10 2, 3, 5
A 20 6, 1
A 23 1
B 11 4, 5, 6
B 17 2
B 21 7, 8, 1, 2
B 28 1, 6
C 14 1, 8, 7
Sequence Database:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es of Sequence Dat a
Sequence
Database
Sequence Element
(Transaction)
Event
(Item)
Customer Purchase history of a given
customer
A set of items bought by
a customer at time t
Books, diary products,
CDs, etc
Web Data Browsing activity of a
particular Web visitor
A collection of files
viewed by a Web visitor
after a single mouse click
Home page, index
page, contact info, etc
Event data History of events generated
by a given sensor
Events triggered by a
sensor at time t
Types of alarms
generated by sensors
Genome
sequences
DNA sequence of a
particular species
An element of the DNA
sequence
Bases A,T,G,C
Sequence
E1
E2
E1
E3
E2
E3
E4
E2
Element
( Transact ion)
Event
(I t em)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
For mal Def i ni t i on of a Sequence
A sequence is an ordered list of elements
(transactions)
s = < e
1
e
2
e
3
>
Each element contains a collection of events (items)
e
i
= {i
1
, i
2
, , i
k
}
Each element is attributed to a specific time or location
Length of a sequence, |s|, is given by the number
of elements of the sequence
A k-sequence is a sequence that contains k
events (items)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl es of Sequence
Web sequence:
< {Homepage} {Electronics} {Digital Cameras} {Canon Digital Camera}
{Shopping Cart} {Order Confirmation} {Return to Shopping} >
Sequence of initiating events causing the nuclear
accident at 3-mile Island:
(http://stellar-one.com/nuclear/staff_reports/summary_SOE_the_initiating_event.htm)
< {clogged resin} {outlet valve closure} {loss of feedwater}
{condenser polisher outlet valve shut} {booster pumps trip}
{main waterpump trips} {main turbine trips} {reactor pressure increases}>
Sequence of books checked out at a library:
<{Fellowship of the Ring} {The Two Towers} {Return of the King}>
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
For mal Def i ni t i on of a Subsequence
A sequence <a
1
a
2
a
n
> is contained in another
sequence <b
1
b
2
b
m
> (m n) if there exist integers
i
1
< i
2
< < i
n
such that a
1
b
i1
, a
2
b
i1
, , a
n
b
in
The support of a subsequence w is defined as the fraction
of data sequences that contain w
A sequential pattern is a frequent subsequence (i.e., a
subsequence whose support is minsup)
Data sequence Subsequence Contain?
< {2,4} {3,5,6} {8} > < {2} {3,5} > Yes
< {1,2} {3,4} > < {1} {2} > No
< {2,4} {2,4} {2,5} > < {2} {4} > Yes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Sequent i al Pat t er n Mi ni ng: Def i ni t i on
Given:
a database of sequences
a user-specified minimum support threshold, minsup
Task:
Find all subsequences with support minsup
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Sequent i al Pat t er n Mi ni ng: Chal l enge
Given a sequence: <{a b} {c d e} {f} {g h i}>
Examples of subsequences:
<{a} {c d} {f} {g} >, < {c d e} >, < {b} {g} >, etc.
How many k-subsequences can be extracted
from a given n-sequence?
<{a b} {c d e} {f} {g h i}> n = 9
k=4: Y _ _ Y Y _ _ _ Y
<{a} {d e} {i}>
126
4
9
: Answer
=
|
|
.
|
\
|
=
|
|
.
|
\
|
k
n
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Sequent i al Pat t er n Mi ni ng: Exampl e
Minsup = 50%
Examples of Frequent Subsequences:
< {1,2} > s=60%
< {2,3} > s=60%
< {2,4}> s=80%
< {3} {5}> s=80%
< {1} {2} > s=80%
< {2} {2} > s=60%
< {1} {2,3} > s=60%
< {2} {2,3} > s=60%
< {1,2} {2,3} > s=60%
Object Timestamp Events
A 1 1,2,4
A 2 2,3
A 3 5
B 1 1,2
B 2 2,3,4
C 1 1, 2
C 2 2,3,4
C 3 2,4,5
D 1 2
D 2 3, 4
D 3 4, 5
E 1 1, 3
E 2 2, 4, 5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ext r act i ng Sequent i al Pat t er ns
Given n events: i
1
, i
2
, i
3
, , i
n
Candidate 1-subsequences:
<{i
1
}>, <{i
2
}>, <{i
3
}>, , <{i
n
}>
Candidate 2-subsequences:
<{i
1
, i
2
}>, <{i
1
, i
3
}>, , <{i
1
} {i
1
}>, <{i
1
} {i
2
}>, , <{i
n-1
} {i
n
}>
Candidate 3-subsequences:
<{i
1
, i
2
, i
3
}>, <{i
1
, i
2
, i
4
}>, , <{i
1
, i
2
} {i
1
}>, <{i
1
, i
2
} {i
2
}>, ,
<{i
1
} {i
1
, i
2
}>, <{i
1
} {i
1
, i
3
}>, , <{i
1
} {i
1
} {i
1
}>, <{i
1
} {i
1
} {i
2
}>,
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gener al i zed Sequent i al Pat t er n ( GSP)
Step 1:
Make the first pass over the sequence database D to yield all the 1-
element frequent sequences
Step 2:
Repeat until no new frequent sequences are found
Candidate Generation:
Merge pairs of frequent subsequences found in the (k-1)th pass to generate
candidate sequences that contain k items
Candidate Pruning:
Prune candidate k-sequences that contain infrequent (k-1)-subsequences
Support Counting:
Make a new pass over the sequence database D to find the support for these
candidate sequences
Candidate Elimination:
Eliminate candidate k-sequences whose actual support is less than minsup
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Candi dat e Gener at i on
Base case (k=2):
Merging two frequent 1-sequences <{i
1
}> and <{i
2
}> will produce
two candidate 2-sequences: <{i
1
} {i
2
}> and <{i
1
i
2
}>
General case (k>2):
A frequent (k-1)-sequence w
1
is merged with another frequent
(k-1)-sequence w
2
to produce a candidate k-sequence if the
subsequence obtained by removing the first event in w
1
is the same
as the subsequence obtained by removing the last event in w
2
The resulting candidate after merging is given by the sequence w
1
extended with the last event of w
2
.
If the last two events in w
2
belong to the same element, then the last event
in w
2
becomes part of the last element in w
1
Otherwise, the last event in w
2
becomes a separate element appended to
the end of w
1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Candi dat e Gener at i on Exampl es
Merging the sequences
w
1
=<{1} {2 3} {4}> and w
2
=<{2 3} {4 5}>
will produce the candidate sequence < {1} {2 3} {4 5}> because the
last two events in w
2
(4 and 5) belong to the same element
Merging the sequences
w
1
=<{1} {2 3} {4}> and w
2
=<{2 3} {4} {5}>
will produce the candidate sequence < {1} {2 3} {4} {5}> because the
last two events in w
2
(4 and 5) do not belong to the same element
We do not have to merge the sequences
w
1
=<{1} {2 6} {4}> and w
2
=<{1} {2} {4 5}>
to produce the candidate < {1} {2 6} {4 5}> because if the latter is a
viable candidate, then it can be obtained by merging w
1
with
< {1} {2 6} {5}>
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
GSP Exampl e
< {1} {2} {3} >
< {1} {2 5} >
< {1} {5} {3} >
< {2} {3} {4} >
< {2 5} {3} >
< {3} {4} {5} >
< {5} {3 4} >
< {1} {2} {3} {4} >
< {1} {2 5} {3} >
< {1} {5} {3 4} >
< {2} {3} {4} {5} >
< {2 5} {3 4} >
< {1} {2 5} {3} >
Frequent
3-sequences
Candidate
Generation
Candidate
Pruning
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ti mi ng Const r ai nt s ( I )
{A B} {C} {D E}
<= m
s
<= x
g
>n
g
x
g
: max-gap
n
g
: min-gap
m
s
: maximum span
Data sequence Subsequence Contain?
< {2,4} {3,5,6} {4,7} {4,5} {8} > < {6} {5} > Yes
< {1} {2} {3} {4} {5}> < {1} {4} > No
< {1} {2,3} {3,4} {4,5}> < {2} {3} {5} > Yes
< {1,2} {3} {2,3} {3,4} {2,4} {4,5}> < {1,2} {5} > No
x
g
= 2, n
g
= 0, m
s
= 4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mi ni ng Sequent i al Pat t erns wi t h Ti mi ng Const rai nt s
Approach 1:
Mine sequential patterns without timing constraints
Postprocess the discovered patterns
Approach 2:
Modify GSP to directly prune candidates that violate
timing constraints
Question:
Does Apriori principle still hold?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Apr i or i Pr i nci pl e f or Sequence Dat a
Object Timestamp Events
A 1 1,2,4
A 2 2,3
A 3 5
B 1 1,2
B 2 2,3,4
C 1 1, 2
C 2 2,3,4
C 3 2,4,5
D 1 2
D 2 3, 4
D 3 4, 5
E 1 1, 3
E 2 2, 4, 5
Suppose:
x
g
= 1 (max-gap)
n
g
= 0 (min-gap)
m
s
= 5 (maximum span)
minsup = 60%
<{2} {5}> support = 40%
but
<{2} {3} {5}> support = 60%
Problem exists because of max-gap constraint
No such problem if max-gap is infinite
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cont i guous Subsequences
s is a contiguous subsequence of
w = <e
1
>< e
2
>< e
k
>
if any of the following conditions hold:
1. s is obtained from w by deleting an item from either e
1
or e
k
2. s is obtained from w by deleting an item from any element e
i
that
contains more than 2 items
3. s is a contiguous subsequence of s and s is a contiguous
subsequence of w (recursive definition)
Examples: s = < {1} {2} >
is a contiguous subsequence of
< {1} {2 3}>, < {1 2} {2} {3}>, and < {3 4} {1 2} {2 3} {4} >
is not a contiguous subsequence of
< {1} {3} {2}> and < {2} {1} {3} {2}>
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Modi f i ed Candi dat e Pr uni ng St ep
Without maxgap constraint:
A candidate k-sequence is pruned if at least one of its
(k-1)-subsequences is infrequent
With maxgap constraint:
A candidate k-sequence is pruned if at least one of its
contiguous (k-1)-subsequences is infrequent
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ti mi ng Const r ai nt s ( I I )
{A B} {C} {D E}
<= m
s
<= x
g
>n
g
<= ws
x
g
: max-gap
n
g
: min-gap
ws: window size
m
s
: maximum span
Data sequence Subsequence Contain?
< {2,4} {3,5,6} {4,7} {4,6} {8} > < {3} {5} > No
< {1} {2} {3} {4} {5}> < {1,2} {3} > Yes
< {1,2} {2,3} {3,4} {4,5}> < {1,2} {3,4} > Yes
x
g
= 2, n
g
= 0, ws = 1, m
s
= 5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Modi f i ed Suppor t Count i ng St ep
Given a candidate pattern: <{a, c}>
Any data sequences that contain
< {a c} >,
< {a} {c}> ( where time({c}) time({a}) ws)
<{c} {a} > (where time({a}) time({c}) ws)
will contribute to the support count of candidate
pattern
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ot her For mul at i on
In some domains, we may have only one very long
time series
Example:
monitoring network traffic events for attacks
monitoring telecommunication alarm signals
Goal is to find frequent sequences of events in the
time series
This problem is also known as frequent episode mining
E1
E2
E1
E2
E1
E2
E3
E4 E3 E4
E1
E2
E2 E4
E3 E5
E2
E3 E5
E1
E2 E3 E1
Pattern: <E1> <E3>
Gener al Suppor t Count i ng Schemes
p
Object's Timeline
Sequence: (p) (q)
Method Support
Count
COBJ
1
1
CWIN 6
CMINWIN
4
p q
p
q q
p
q q
p
2 3 4 5 6 7
CDIST_O 8
CDIST 5
Assume:
x
g
= 2 (max-gap)
n
g
= 0 (min-gap)
ws = 0 (window size)
m
s
= 2 (maximum span)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Fr equent Subgr aph Mi ni ng
Extend association rule mining to finding frequent
subgraphs
Useful for Web Mining, computational chemistry,
bioinformatics, spatial data sets, etc
Databases
Homepage
Research
Artificial
Intelligence
Data Mining
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gr aph Def i ni t i ons
a
b a
c c
b
(a) Labeled Graph
p q
p
p
r
s
t
r
t
q p
a
a
c
b
(b) Subgraph
p
s
t
p
a
a
c
b
(c) Induced Subgraph
p
r
s
t
r
p
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Repr esent i ng Tr ansact i ons as Gr aphs
Each transaction is a clique of items
Transaction
Id
Items
1 {A,B,C,D}
2 {A,B,E}
3 {B,C}
4 {A,B,D,E}
5 {B,C,D}
A
B
C
D
E
TID = 1:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Repr esent i ng Gr aphs as Tr ansact i ons
a
b
e
c
p
q
r
p
a
b
d
p
r
G1 G2
q
e
c
a
p q
r
b
p
G3
d
r
d
r
(a,b,p) (a,b,q) (a,b,r) (b,c,p) (b,c,q) (b,c,r) (d,e,r)
G1 1 0 0 0 0 1 0
G2 1 0 0 0 0 0 0
G3 0 0 1 1 0 0 0
G3
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Chal l enges
Node may contain duplicate labels
Support and confidence
How to define them?
Additional constraints imposed by pattern
structure
Support and confidence are not the only constraints
Assumption: frequent subgraphs must be connected
Apriori-like approach:
Use frequent k-subgraphs to generate frequent (k+1)
subgraphs
What is k?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Chal l enges
Support:
number of graphs that contain a particular subgraph
Apriori principle still holds
Level-wise (Apriori-like) approach:
Vertex growing:
k is the number of vertices
Edge growing:
k is the number of edges
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ver t ex Gr owi ng
a
a
e
a
p
q
r
p
a
a
a
p
r
r
d
G1
G2
p
|
|
|
|
|
|
|
=
0 0
0 0
0
1
r p
r p
q p p
M
G
|
|
|
|
|
|
|
=
0
0 0
0 0
2
r r p
r p
p p
M
G
a
a
a
p
q
r
e
p
|
|
|
|
|
|
|
=
0 0 0 0
0 0
0 0 0
0 0
3
r
r r p
r p
q p p
M
G
G3 = join(G1,G2)
d
r
+
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Edge Gr owi ng
a
a
f
a
p
q
r
p
a
a
a
p
r
r
f
G1
G2
p
a
a
a
p
q
r
f
p
G3 = join(G1,G2)
r
+
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Apr i or i -l i ke Al gor i t hm
Find frequent 1-subgraphs
Repeat
Candidate generation
Use frequent (k-1)-subgraphs to generate candidate k-subgraph
Candidate pruning
Prune candidate subgraphs that contain infrequent
(k-1)-subgraphs
Support counting
Count the support of each remaining candidate
Eliminate candidate k-subgraphs that are infrequent
In practice, it is not as easy. There are many other issues
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e: Dat aset
a
b
e
c
p
q
r
p
a
b
d
p
r
G1 G2
q
e
c
a
p q
r
b
p
G3
d
r
d
r
(a,b,p) (a,b,q) (a,b,r) (b,c,p) (b,c,q) (b,c,r) (d,e,r)
G1 1 0 0 0 0 1 0
G2 1 0 0 0 0 0 0
G3 0 0 1 1 0 0 0
a e
q
c
d
p
p
p
G4
r
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e
p
a b c d e
k=1
Frequent
Subgraphs
a b
p
c d
p
c e
q
a e
r
b d
p
a b
d
r
p
d c
e
p
(Pruned candidate)
Minimum support count = 2
k=2
Frequent
Subgraphs
k=3
Candidate
Subgraphs
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Candi dat e Gener at i on
In Apriori:
Merging two frequent k-itemsets will produce a
candidate (k+1)-itemset
In frequent subgraph mining (vertex/edge
growing)
Merging two frequent k-subgraphs may produce more
than one candidate (k+1)-subgraph
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl i ci t y of Candi dat es ( Ver t ex Gr owi ng)
a
a
e
a
p
q
r
p
a
a
a
p
r
r
d
G1
G2
p
|
|
|
|
|
|
|
=
0 0
0 0
0
1
r p
r p
q p p
M
G
|
|
|
|
|
|
|
=
0
0 0
0 0
2
r r p
r p
p p
M
G
a
a
a
p
q
r
e
p
|
|
|
|
|
|
|
=
? 0 0 0
0 0
0 0 0
0 0
3
r
r r p
r p
q p p
M
G
G3 = join(G1,G2)
d
r
?
+
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl i ci t y of Candi dat es ( Edge gr owi ng)
Case 1: identical vertex labels
a
b
e
c
a
b
e
c
+
a
b
e
c
e
a
b
e
c
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl i ci t y of Candi dat es ( Edge gr owi ng)
Case 2: Core contains identical labels
+
a
a
a
a
c
b
a
a
a
a
c
a
a
a
a
c
b
b
a
a
a
a
b
a
a
a
a
c
Core: The (k-1) subgraph that is common
between the joint graphs
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Mul t i pl i ci t y of Candi dat es ( Edge gr owi ng)
Case 3: Core multiplicity
a
a b
+
a
a
a a b
a a b
a
a
a b
a a
a b
a b
a a b
a a
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Adj acency Mat r i x Repr esent at i on
A(1) A(2)
B (6)
A(4)
B (5)
A(3)
B (7) B (8)
A(1) A(2) A(3) A(4) B(5) B(6) B(7) B(8)
A(1) 1 1 1 0 1 0 0 0
A(2) 1 1 0 1 0 1 0 0
A(3) 1 0 1 1 0 0 1 0
A(4) 0 1 1 1 0 0 0 1
B(5) 1 0 0 0 1 1 1 0
B(6) 0 1 0 0 1 1 0 1
B(7) 0 0 1 0 1 0 1 1
B(8) 0 0 0 1 0 1 1 1
A(2) A(1)
B (6)
A(4)
B (7)
A(3)
B (5) B (8)
A(1) A(2) A(3) A(4) B(5) B(6) B(7) B(8)
A(1) 1 1 0 1 0 1 0 0
A(2) 1 1 1 0 0 0 1 0
A(3) 0 1 1 1 1 0 0 0
A(4) 1 0 1 1 0 0 0 1
B(5) 0 0 1 0 1 0 1 1
B(6) 1 0 0 0 0 1 1 1
B(7) 0 1 0 0 1 1 1 0
B(8) 0 0 0 1 1 1 0 1
The same graph can be represented in many ways
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gr aph I somor phi sm
A graph is isomorphic if it is topologically
equivalent to another graph
A
A
A A
B A
B
A
B
B
A
A
B B
B
B
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gr aph I somor phi sm
Test for graph isomorphism is needed:
During candidate generation step, to determine
whether a candidate has been generated
During candidate pruning step, to check whether its
(k-1)-subgraphs are frequent
During candidate counting, to check whether a
candidate is contained within another graph
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gr aph I somor phi sm
Use canonical labeling to handle isomorphism
Map each graph into an ordered string representation
(known as its code) such that two isomorphic graphs
will be mapped to the same canonical encoding
Example:
Lexicographically largest adjacency matrix
(
(
(
(
0 1 1 0
1 0 1 1
1 1 0 0
0 1 0 0
String: 0010001111010110
(
(
(
(
0 0 0 1
0 0 1 1
0 1 0 1
1 1 1 0
Canonical: 0111101011001000
Dat a Mi ni ng
Cl ust er Anal ysi s: Basi c Concept s
and Al gor i t hms
Lecture Notes for Chapter 8
Introduction to Data Mining
by
Tan, Steinbach, Kumar
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
What i s Cl ust er Anal ysi s?
Finding groups of objects such that the objects in a group
will be similar (or related) to one another and different
from (or unrelated to) the objects in other groups
I nt er-clust er
dist ances are
maximized
I nt ra-clust er
dist ances are
minimized
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Appl i cat i ons of Cl ust er Anal ysi s
Understanding
Group related documents
for browsing, group genes
and proteins that have
similar functionality, or
group stocks with similar
price fluctuations
Summarization
Reduce the size of large
data sets
Discovered Clusters Industry Group
1
Applied-Matl-DOWN,Bay-Network-Down,3-COM-DOWN,
Cabletron-Sys-DOWN,CISCO-DOWN,HP-DOWN,
DSC-Comm-DOWN,INTEL-DOWN,LSI-Logic-DOWN,
Micron-Tech-DOWN,Texas-Inst-Down,Tellabs-Inc-Down,
Natl-Semiconduct-DOWN,Oracl-DOWN,SGI-DOWN,
Sun-DOWN
Technology1-DOWN
2
Apple-Comp-DOWN,Autodesk-DOWN,DEC-DOWN,
ADV-Micro-Device-DOWN,Andrew-Corp-DOWN,
Computer-Assoc-DOWN,Circuit-City-DOWN,
Compaq-DOWN, EMC-Corp-DOWN, Gen-Inst-DOWN,
Motorola-DOWN,Microsoft-DOWN,Scientific-Atl-DOWN
Technology2-DOWN
3
Fannie-Mae-DOWN,Fed-Home-Loan-DOWN,
MBNA-Corp-DOWN,Morgan-Stanley-DOWN
Financial-DOWN
4
Baker-Hughes-UP,Dresser-Inds-UP,Halliburton-HLD-UP,
Louisiana-Land-UP,Phillips-Petro-UP,Unocal-UP,
Schlumberger-UP
Oil-UP
Clustering precipitation
in Australia
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
What i s not Cl ust er Anal ysi s?
Supervised classification
Have class label information
Simple segmentation
Dividing students into different registration groups
alphabetically, by last name
Results of a query
Groupings are a result of an external specification
Graph partitioning
Some mutual relevance and synergy, but areas are not
identical
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Not i on of a Cl ust er can be Ambi guous
How many clusters?
Four Clusters Two Clusters
Six Clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust er i ngs
A clustering is a set of clusters
Important distinction between hierarchical and
partitional sets of clusters
Partitional Clustering
A division data objects into non-overlapping subsets (clusters)
such that each data object is in exactly one subset
Hierarchical clustering
A set of nested clusters organized as a hierarchical tree
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Par t i t i onal Cl ust er i ng
Original Points A Partitional Clustering
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng
p4
p1
p3
p2
p4
p1
p3
p2
p4 p1 p2 p3
p4 p1 p2 p3
Traditional Hierarchical Clustering
Non-traditional Hierarchical Clustering Non-traditional Dendrogram
Traditional Dendrogram
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ot her Di st i nct i ons Bet ween Set s of Cl ust ers
Exclusive versus non-exclusive
In non-exclusive clusterings, points may belong to multiple
clusters.
Can represent multiple classes or border points
Fuzzy versus non-fuzzy
In fuzzy clustering, a point belongs to every cluster with some
weight between 0 and 1
Weights must sum to 1
Probabilistic clustering has similar characteristics
Partial versus complete
In some cases, we only want to cluster some of the data
Heterogeneous versus homogeneous
Cluster of widely different sizes, shapes, and densities
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust er s
Well-separated clusters
Center-based clusters
Contiguous clusters
Density-based clusters
Property or Conceptual
Described by an Objective Function
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust ers: Wel l -Separ at ed
Well-Separated Clusters:
A cluster is a set of points such that any point in a cluster is
closer (or more similar) to every other point in the cluster than
to any point not in the cluster.
3 well-separated clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust ers: Cent er -Based
Center-based
A cluster is a set of objects such that an object in a cluster is
closer (more similar) to the center of a cluster, than to the
center of any other cluster
The center of a cluster is often a centroid, the average of all
the points in the cluster, or a medoid, the most representative
point of a cluster
4 center-based clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust ers: Cont i gui t y- Based
Contiguous Cluster (Nearest neighbor or
Transitive)
A cluster is a set of points such that a point in a cluster is
closer (or more similar) to one or more other points in the
cluster than to any point not in the cluster.
8 contiguous clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust ers: Densi t y- Based
Density-based
A cluster is a dense region of points, which is separated by
low-density regions, from other regions of high density.
Used when the clusters are irregular or intertwined, and when
noise and outliers are present.
6 density-based clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust er s: Concept ual Cl ust ers
Shared Property or Conceptual Clusters
Finds clusters that share some common property or represent
a particular concept.
.
2 Overlapping Circles
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust ers: Obj ect i ve Funct i on
Clusters Defined by an Objective Function
Finds clusters that minimize or maximize an objective function.
Enumerate all possible ways of dividing the points into clusters and
evaluate the `goodness' of each potential set of clusters by using
the given objective function. (NP Hard)
Can have global or local objectives.
Hierarchical clustering algorithms typically have local objectives
Partitional algorithms typically have global objectives
A variation of the global objective function approach is to fit the
data to a parameterized model.
Parameters for the model are determined from the data.
Mixture models assume that the data is a mixture' of a number of
statistical distributions.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Types of Cl ust ers: Obj ect i ve Funct i on
Map the clustering problem to a different domain
and solve a related problem in that domain
Proximity matrix defines a weighted graph, where the
nodes are the points being clustered, and the
weighted edges represent the proximities between
points
Clustering is equivalent to breaking the graph into
connected components, one for each cluster.
Want to minimize the edge weight between clusters
and maximize the edge weight within clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Char act er i st i cs of t he I nput Dat a Ar e I mpor t ant
Type of proximity or density measure
This is a derived measure, but central to clustering
Sparseness
Dictates type of similarity
Adds to efficiency
Attribute type
Dictates type of similarity
Type of Data
Dictates type of similarity
Other characteristics, e.g., autocorrelation
Dimensionality
Noise and Outliers
Type of Distribution
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust er i ng Al gor i t hms
K-means and its variants
Hierarchical clustering
Density-based clustering
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
K-means Cl ust eri ng
Partitional clustering approach
Each cluster is associated with a centroid (center point)
Each point is assigned to the cluster with the closest
centroid
Number of clusters, K, must be specified
The basic algorithm is very simple
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
K-means Cl ust eri ng Det ai l s
Initial centroids are often chosen randomly.
Clusters produced vary from one run to another.
The centroid is (typically) the mean of the points in the
cluster.
Closeness is measured by Euclidean distance, cosine
similarity, correlation, etc.
K-means will converge for common similarity measures
mentioned above.
Most of the convergence happens in the first few
iterations.
Often the stopping condition is changed to Until relatively few
points change clusters
Complexity is O( n * K * I * d )
n = number of points, K = number of clusters,
I = number of iterations, d = number of attributes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Two di f f erent K-means Cl ust er i ngs
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Sub-optimal Clustering
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Optimal Clustering
Original Points
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I mport ance of Choosi ng I ni t i al Cent roi ds
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 1
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 2
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 3
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 4
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 5
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 6
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I mport ance of Choosi ng I ni t i al Cent roi ds
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 1
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 2
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 3
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 4
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 5
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 6
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Eval uat i ng K-means Cl ust er s
Most common measure is Sum of Squared Error (SSE)
For each point, the error is the distance to the nearest cluster
To get SSE, we square these errors and sum them.
x is a data point in cluster C
i
and m
i
is the representative point for
cluster C
i
can show that m
i
corresponds to the center (mean) of the cluster
Given two clusters, we can choose the one with the smallest
error
One easy way to reduce SSE is to increase K, the number of
clusters
A good clustering with smaller K can have a lower SSE than a poor
clustering with higher K
=
=
K
i C x
i
i
x m dist SSE
1
2
) , (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I mport ance of Choosi ng I ni t i al Cent roi ds
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 1
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 2
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 3
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 4
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I mport ance of Choosi ng I ni t i al Cent roi ds
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 1
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 2
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 3
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 4
-2 -1.5 -1 -0.5 0 0.5 1 1.5 2
0
0.5
1
1.5
2
2.5
3
x
y
Iteration 5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Probl ems wi t h Sel ect i ng I ni t i al Poi nt s
If there are K real clusters then the chance of selecting
one centroid from each cluster is small.
Chance is relatively small when K is large
If clusters are the same size, n, then
For example, if K = 10, then probability = 10!/10
10
= 0.00036
Sometimes the initial centroids will readjust themselves in
right way, and sometimes they dont
Consider an example of five pairs of clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
10 Cl ust ers Exampl e
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 1
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 2
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 3
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 4
Starting with two initial centroids in one cluster of each pair of clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
10 Cl ust ers Exampl e
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 1
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 2
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 3
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 4
Starting with two initial centroids in one cluster of each pair of clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
10 Cl ust ers Exampl e
Starting with some pairs of clusters having three initial centroids, while other have only one.
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 1
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 2
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 3
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
10 Cl ust ers Exampl e
Starting with some pairs of clusters having three initial centroids, while other have only one.
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 1
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 2
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 3
0 5 10 15 20
-6
-4
-2
0
2
4
6
8
x
y
Iteration 4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Sol ut i ons t o I ni t i al Cent r oi ds Pr obl em
Multiple runs
Helps, but probability is not on your side
Sample and use hierarchical clustering to
determine initial centroids
Select more than k initial centroids and then
select among these initial centroids
Select most widely separated
Postprocessing
Bisecting K-means
Not as susceptible to initialization issues
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Handl i ng Empt y Cl ust er s
Basic K-means algorithm can yield empty
clusters
Several strategies
Choose the point that contributes most to SSE
Choose a point from the cluster with the highest SSE
If there are several empty clusters, the above can be
repeated several times.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Updat i ng Cent er s I ncr ement al l y
In the basic K-means algorithm, centroids are
updated after all points are assigned to a centroid
An alternative is to update the centroids after
each assignment (incremental approach)
Each assignment updates zero or two centroids
More expensive
Introduces an order dependency
Never get an empty cluster
Can use weights to change the impact
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Pr e-pr ocessi ng and Post -pr ocessi ng
Pre-processing
Normalize the data
Eliminate outliers
Post-processing
Eliminate small clusters that may represent outliers
Split loose clusters, i.e., clusters with relatively high
SSE
Merge clusters that are close and that have relatively
low SSE
Can use these steps during the clustering process
ISODATA
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Bi sect i ng K-means
Bisecting K-means algorithm
Variant of K-means that can produce a partitional or a
hierarchical clustering
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Bi sect i ng K-means Exampl e
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of K-means
K-means has problems when clusters are of
differing
Sizes
Densities
Non-globular shapes
K-means has problems when the data contains
outliers.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of K-means: Di f f er i ng Si zes
Original Points
K-means (3 Clusters)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of K-means: Di f f er i ng Densi t y
Original Points
K-means (3 Clusters)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of K-means: Non-gl obul ar Shapes
Original Points
K-means (2 Clusters)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Overcomi ng K-means Li mi t at i ons
Original Points K-means Clusters
One solution is to use many clusters.
Find parts of clusters, but need to put together.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Overcomi ng K-means Li mi t at i ons
Original Points K-means Clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Overcomi ng K-means Li mi t at i ons
Original Points K-means Clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng
Produces a set of nested clusters organized as a
hierarchical tree
Can be visualized as a dendrogram
A tree like diagram that records the sequences of
merges or splits
1 3 2 5 4 6
0
0.05
0.1
0.15
0.2
1
2
3
4
5
6
1
2
3 4
5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St r engt hs of Hi er ar chi cal Cl ust er i ng
Do not have to assume any particular number of
clusters
Any desired number of clusters can be obtained by
cutting the dendogram at the proper level
They may correspond to meaningful taxonomies
Example in biological sciences (e.g., animal kingdom,
phylogeny reconstruction, )
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng
Two main types of hierarchical clustering
Agglomerative:
Start with the points as individual clusters
At each step, merge the closest pair of clusters until only one cluster
(or k clusters) left
Divisive:
Start with one, all-inclusive cluster
At each step, split a cluster until each cluster contains a point (or
there are k clusters)
Traditional hierarchical algorithms use a similarity or
distance matrix
Merge or split one cluster at a time
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Aggl omer at i ve Cl ust er i ng Al gor i t hm
More popular hierarchical clustering technique
Basic algorithm is straightforward
1. Compute the proximity matrix
2. Let each data point be a cluster
3. Repeat
4. Merge the two closest clusters
5. Update the proximity matrix
6. Until only a single cluster remains
Key operation is the computation of the proximity of
two clusters
Different approaches to defining the distance between
clusters distinguish the different algorithms
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St ar t i ng Si t uat i on
Start with clusters of individual points and a
proximity matrix
p1
p3
p5
p4
p2
p1 p2 p3 p4 p5
. . .
.
.
.
Proximity Matrix
...
p1 p2 p3 p4 p9 p10 p11 p12
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I nt er medi at e Si t uat i on
After some merging steps, we have some clusters
C1
C4
C2
C5
C3
C2 C1
C1
C3
C5
C4
C2
C3 C4 C5
Proximity Matrix
...
p1 p2 p3 p4 p9 p10 p11 p12
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I nt er medi at e Si t uat i on
We want to merge the two closest clusters (C2 and C5) and
update the proximity matrix.
C1
C4
C2
C5
C3
C2 C1
C1
C3
C5
C4
C2
C3 C4 C5
Proximity Matrix
...
p1 p2 p3 p4 p9 p10 p11 p12
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Af t er Mer gi ng
The question is How do we update the proximity matrix?
C1
C4
C2 U C5
C3
? ? ? ?
?
?
?
C2
U
C5 C1
C1
C3
C4
C2 U C5
C3 C4
Proximity Matrix
...
p1 p2 p3 p4 p9 p10 p11 p12
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Def i ne I nt er -Cl ust er Si mi l ar i t y
p1
p3
p5
p4
p2
p1 p2 p3 p4 p5
. . .
.
.
.
Similarity?
MIN
MAX
Group Average
Distance Between Centroids
Other methods driven by an objective
function
Wards Method uses squared error
Proximity Matrix
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Def i ne I nt er -Cl ust er Si mi l ar i t y
p1
p3
p5
p4
p2
p1 p2 p3 p4 p5
. . .
.
.
.
Proximity Matrix
MIN
MAX
Group Average
Distance Between Centroids
Other methods driven by an objective
function
Wards Method uses squared error
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Def i ne I nt er -Cl ust er Si mi l ar i t y
p1
p3
p5
p4
p2
p1 p2 p3 p4 p5
. . .
.
.
.
Proximity Matrix
MIN
MAX
Group Average
Distance Between Centroids
Other methods driven by an objective
function
Wards Method uses squared error
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Def i ne I nt er -Cl ust er Si mi l ar i t y
p1
p3
p5
p4
p2
p1 p2 p3 p4 p5
. . .
.
.
.
Proximity Matrix
MIN
MAX
Group Average
Distance Between Centroids
Other methods driven by an objective
function
Wards Method uses squared error
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
How t o Def i ne I nt er -Cl ust er Si mi l ar i t y
p1
p3
p5
p4
p2
p1 p2 p3 p4 p5
. . .
.
.
.
Proximity Matrix
MIN
MAX
Group Average
Distance Between Centroids
Other methods driven by an objective
function
Wards Method uses squared error
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust er Si mi l ar i t y: MI N or Si ngl e Li nk
Similarity of two clusters is based on the two
most similar (closest) points in the different
clusters
Determined by one pair of points, i.e., by one link in
the proximity graph.
I1 I2 I3 I4 I5
I1 1.00 0.90 0.10 0.65 0.20
I2 0.90 1.00 0.70 0.60 0.50
I3 0.10 0.70 1.00 0.40 0.30
I4 0.65 0.60 0.40 1.00 0.80
I5 0.20 0.50 0.30 0.80 1.00
1 2 3 4 5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng: MI N
Nested Clusters Dendrogram
1
2
3
4
5
6
1
2
3
4
5
3 6 2 5 4 1
0
0.05
0.1
0.15
0.2
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St r engt h of MI N
Original Points Two Clusters
Can handle non-elliptical shapes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of MI N
Original Points Two Clusters
Sensitive to noise and outliers
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust er Si mi l ar i t y: MAX or Compl et e Li nkage
Similarity of two clusters is based on the two least
similar (most distant) points in the different
clusters
Determined by all pairs of points in the two clusters
I1 I2 I3 I4 I5
I1 1.00 0.90 0.10 0.65 0.20
I2 0.90 1.00 0.70 0.60 0.50
I3 0.10 0.70 1.00 0.40 0.30
I4 0.65 0.60 0.40 1.00 0.80
I5 0.20 0.50 0.30 0.80 1.00
1 2 3 4 5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng: MAX
Nested Clusters Dendrogram
3 6 4 1 2 5
0
0.05
0.1
0.15
0.2
0.25
0.3
0.35
0.4
1
2
3
4
5
6
1
2 5
3
4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St r engt h of MAX
Original Points Two Clusters
Less susceptible to noise and outliers
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of MAX
Original Points Two Clusters
Tends to break large clusters
Biased towards globular clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust er Si mi l ar i t y: Gr oup Aver age
Proximity of two clusters is the average of pairwise proximity
between points in the two clusters.
Need to use average connectivity for scalability since total
proximity favors large clusters
| | Cl ust er | | Cl ust er
) p , p pr oxi mi t y(
) Cl ust er , Cl ust er pr oxi mi t y(
j i
Cl ust er p
Cl ust er p
j i
j i
j j
i i
I1 I2 I3 I4 I5
I1 1.00 0.90 0.10 0.65 0.20
I2 0.90 1.00 0.70 0.60 0.50
I3 0.10 0.70 1.00 0.40 0.30
I4 0.65 0.60 0.40 1.00 0.80
I5 0.20 0.50 0.30 0.80 1.00
1 2 3 4 5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng: Gr oup Aver age
Nested Clusters Dendrogram
3 6 4 1 2 5
0
0.05
0.1
0.15
0.2
0.25
1
2
3
4
5
6
1
2
5
3
4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng: Gr oup Aver age
Compromise between Single and Complete
Link
Strengths
Less susceptible to noise and outliers
Limitations
Biased towards globular clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust er Si mi l ar i t y: War ds Met hod
Similarity of two clusters is based on the increase
in squared error when two clusters are merged
Similar to group average if distance between points is
distance squared
Less susceptible to noise and outliers
Biased towards globular clusters
Hierarchical analogue of K-means
Can be used to initialize K-means
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi erarchi cal Cl ust eri ng: Compari son
Group Average
Wards Method
1
2
3
4
5
6
1
2
5
3
4
MIN MAX
1
2
3
4
5
6
1
2
5
3
4
1
2
3
4
5
6
1
2 5
3
4
1
2
3
4
5
6
1
2
3
4
5
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng: Ti me and Space r equi r ement s
O(N
2
) space since it uses the proximity matrix.
N is the number of points.
O(N
3
) time in many cases
There are N steps and at each step the size, N
2
,
proximity matrix must be updated and searched
Complexity can be reduced to O(N
2
log(N) ) time for
some approaches
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi erarchi cal Cl ust eri ng: Probl ems and Li mi t at i ons
Once a decision is made to combine two clusters,
it cannot be undone
No objective function is directly minimized
Different schemes have problems with one or
more of the following:
Sensitivity to noise and outliers
Difficulty handling different sized clusters and convex
shapes
Breaking large clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
MST: Di vi si ve Hi er ar chi cal Cl ust er i ng
Build MST (Minimum Spanning Tree)
Start with a tree that consists of any point
In successive steps, look for the closest pair of points (p, q) such
that one point (p) is in the current tree but the other (q) is not
Add q to the tree and put an edge between p and q
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
MST: Di vi si ve Hi er ar chi cal Cl ust er i ng
Use MST for constructing hierarchy of clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
DBSCAN
DBSCAN is a density-based algorithm.
Density = number of points within a specified radius (Eps)
A point is a core point if it has more than a specified number
of points (MinPts) within Eps
These are points that are at the interior of a cluster
A border point has fewer than MinPts within Eps, but is in
the neighborhood of a core point
A noise point is any point that is not a core point or a border
point.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
DBSCAN: Cor e, Bor der, and Noi se Poi nt s
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
DBSCAN Al gor i t hm
Eliminate noise points
Perform clustering on the remaining points
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
DBSCAN: Cor e, Bor der and Noi se Poi nt s
Original Points
Point types: core,
border and noise
Eps = 10, MinPts = 4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
When DBSCAN Works Wel l
Original Points
Clusters
Resistant to Noise
Can handle clusters of different shapes and sizes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
When DBSCAN Does NOT Work Wel l
Original Points
(MinPts=4, Eps=9.75).
(MinPts=4, Eps=9.92)
Varying densities
High-dimensional data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
DBSCAN: Det ermi ni ng EPS and Mi nPt s
Idea is that for points in a cluster, their k
th
nearest
neighbors are at roughly the same distance
Noise points have the k
th
nearest neighbor at farther
distance
So, plot sorted distance of every point to its k
th
nearest neighbor
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust er Val i di t y
For supervised classification we have a variety of
measures to evaluate how good our model is
Accuracy, precision, recall
For cluster analysis, the analogous question is how to
evaluate the goodness of the resulting clusters?
But clusters are in the eye of the beholder!
Then why do we want to evaluate them?
To avoid finding patterns in noise
To compare clustering algorithms
To compare two sets of clusters
To compare two clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust ers f ound i n Random Dat a
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Random
Points
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
K-means
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
DBSCAN
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Complete
Link
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
1. Determining the clustering tendency of a set of data, i.e.,
distinguishing whether non-random structure actually exists in the
data.
2. Comparing the results of a cluster analysis to externally known
results, e.g., to externally given class labels.
3. Evaluating how well the results of a cluster analysis fit the data
without reference to external information.
- Use only the data
4. Comparing the results of two different sets of cluster analyses to
determine which is better.
5. Determining the correct number of clusters.
For 2, 3, and 4, we can further distinguish whether we want to
evaluate the entire clustering or just individual clusters.
Di f f er ent Aspect s of Cl ust er Val i dat i on
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Numerical measures that are applied to judge various aspects
of cluster validity, are classified into the following three types.
External Index: Used to measure the extent to which cluster labels
match externally supplied class labels.
Entropy
Internal Index: Used to measure the goodness of a clustering
structure without respect to external information.
Sum of Squared Error (SSE)
Relative Index: Used to compare two different clusterings or
clusters.
Often an external or internal index is used for this function, e.g., SSE or
entropy
Sometimes these are referred to as criteria instead of indices
However, sometimes criterion is the general strategy and index is the
numerical measure that implements the criterion.
Measur es of Cl ust er Val i di t y
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Two matrices
Proximity Matrix
Incidence Matrix
One row and one column for each data point
An entry is 1 if the associated pair of points belong to the same cluster
An entry is 0 if the associated pair of points belongs to different clusters
Compute the correlation between the two matrices
Since the matrices are symmetric, only the correlation between
n(n-1) / 2 entries needs to be calculated.
High correlation indicates that points that belong to the
same cluster are close to each other.
Not a good measure for some density or contiguity based
clusters.
Measur i ng Cl ust er Val i di t y Vi a Cor rel at i on
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Measur i ng Cl ust er Val i di t y Vi a Cor rel at i on
Correlation of incidence and proximity matrices
for the K-means clusterings of the following two
data sets.
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Corr = -0.9235 Corr = -0.5810
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Order the similarity matrix with respect to cluster
labels and inspect visually.
Usi ng Si mi l ar i t y Mat r i x f or Cl ust er Val i dat i on
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Points
P
o
i
n
t
s
20 40 60 80 100
10
20
30
40
50
60
70
80
90
100
Similarity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Usi ng Si mi l ar i t y Mat r i x f or Cl ust er Val i dat i on
Clusters in random data are not so crisp
Points
P
o
i
n
t
s
20 40 60 80 100
10
20
30
40
50
60
70
80
90
100
Similarity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
DBSCAN
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Points
P
o
i
n
t
s
20 40 60 80 100
10
20
30
40
50
60
70
80
90
100
Similarity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
Usi ng Si mi l ar i t y Mat r i x f or Cl ust er Val i dat i on
Clusters in random data are not so crisp
K-means
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Usi ng Si mi l ar i t y Mat r i x f or Cl ust er Val i dat i on
Clusters in random data are not so crisp
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Points
P
o
i
n
t
s
20 40 60 80 100
10
20
30
40
50
60
70
80
90
100
Similarity
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
Complete Link
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Usi ng Si mi l ar i t y Mat r i x f or Cl ust er Val i dat i on
1
2
3
5
6
4
7
DBSCAN
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
500 1000 1500 2000 2500 3000
500
1000
1500
2000
2500
3000
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Clusters in more complicated figures arent well separated
Internal Index: Used to measure the goodness of a clustering
structure without respect to external information
SSE
SSE is good for comparing two clusterings or two clusters
(average SSE).
Can also be used to estimate the number of clusters
I nt er nal Measur es: SSE
2 5 10 15 20 25 30
0
1
2
3
4
5
6
7
8
9
10
K
S
S
E
5 10 15
-6
-4
-2
0
2
4
6
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I nt er nal Measur es: SSE
SSE curve for a more complicated data set
1
2
3
5
6
4
7
SSE of clusters found using K-means
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Need a framework to interpret any measure.
For example, if our measure of evaluation has the value, 10, is that
good, fair, or poor?
Statistics provide a framework for cluster validity
The more atypical a clustering result is, the more likely it represents
valid structure in the data
Can compare the values of an index that result from random data or
clusterings to those of a clustering result.
If the value of the index is unlikely, then the cluster results are valid
These approaches are more complicated and harder to understand.
For comparing the results of two different sets of cluster
analyses, a framework is less necessary.
However, there is the question of whether the difference between two
index values is significant
Fr amework f or Cl ust er Val i di t y
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Example
Compare SSE of 0.005 against three clusters in random data
Histogram shows SSE of three clusters in 500 sets of random data
points of size 100 distributed over the range 0.2 0.8 for x and y
values
St at i st i cal Framewor k f or SSE
0.016 0.018 0.02 0.022 0.024 0.026 0.028 0.03 0.032 0.034
0
5
10
15
20
25
30
35
40
45
50
SSE
C
o
u
n
t
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Correlation of incidence and proximity matrices for the
K-means clusterings of the following two data sets.
St at i st i cal Framewor k f or Corr el at i on
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
x
y
Corr = -0.9235 Corr = -0.5810
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cluster Cohesion: Measures how closely related
are objects in a cluster
Example: SSE
Cluster Separation: Measure how distinct or well-
separated a cluster is from other clusters
Example: Squared Error
Cohesion is measured by the within cluster sum of squares (SSE)
Separation is measured by the between cluster sum of squares
Where |C
i
| is the size of cluster i
I nt ernal Measures: Cohesi on and Separat i on
=
i C x
i
i
m x WSS
2
) (
=
i
i i
m m C BSS
2
) (
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I nt ernal Measures: Cohesi on and Separat i on
Example: SSE
BSS + WSS = constant
1 2 3 4 5
m
1
m
2
m
10 9 1
9 ) 3 5 . 4 ( 2 ) 5 . 1 3 ( 2
1 ) 5 . 4 5 ( ) 5 . 4 4 ( ) 5 . 1 2 ( ) 5 . 1 1 (
2 2
2 2 2 2
= + =
= + =
= + + + =
Total
BSS
WSS
K=2 clusters:
10 0 10
0 ) 3 3 ( 4
10 ) 3 5 ( ) 3 4 ( ) 3 2 ( ) 3 1 (
2
2 2 2 2
= + =
= =
= + + + =
Total
BSS
WSS
K=1 cluster:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
A proximity graph based approach can also be used for
cohesion and separation.
Cluster cohesion is the sum of the weight of all links within a cluster.
Cluster separation is the sum of the weights between nodes in the cluster
and nodes outside the cluster.
I nt ernal Measures: Cohesi on and Separat i on
cohesion separation
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Silhouette Coefficient combine ideas of both cohesion and separation,
but for individual points, as well as clusters and clusterings
For an individual point, i
Calculate a = average distance of i to the points in its cluster
Calculate b = min (average distance of i to points in another cluster)
The silhouette coefficient for a point is then given by
s = 1 a/b if a < b, (or s = b/a - 1 if a b, not the usual case)
Typically between 0 and 1.
The closer to 1 the better.
Can calculate the Average Silhouette width for a cluster or a
clustering
I nt ernal Measures: Si l houet t e Coef f i ci ent
a
b
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Ext ernal Measures of Cl ust er Val i di t y: Ent ropy and Puri t y
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
The validation of clustering structures is the most
difficult and frustrating part of cluster analysis.
Without a strong effort in this direction, cluster
analysis will remain a black art accessible only to
those true believers who have experience and
great courage.
Algorithms for Clustering Data, Jain and Dubes
Fi nal Comment on Cl ust er Val i di t y
Dat a Mi ni ng
Cl ust er Anal ysi s: Advanced Concept s
and Al gor i t hms
Lecture Notes for Chapter 9
Introduction to Data Mining
by
Tan, Steinbach, Kumar
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Hi er ar chi cal Cl ust er i ng: Revi si t ed
Creates nested clusters
Agglomerative clustering algorithms vary in terms
of how the proximity of two clusters are computed
MIN (single link): susceptible to noise/outliers
MAX/GROUP AVERAGE:
may not work well with non-globular clusters
CURE algorithm tries to handle both problems
Often starts with a proximity matrix
A type of graph-based algorithm
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Uses a number of points to represent a cluster
Representative points are found by selecting a constant
number of points from a cluster and then shrinking them
toward the center of the cluster
Cluster similarity is the similarity of the closest pair of
representative points from different clusters
CURE: Anot her Hi er ar chi cal Appr oach
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
CURE
Shrinking representative points toward the center
helps avoid problems with noise and outliers
CURE is better able to handle clusters of arbitrary
shapes and sizes
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CURE
Picture from CURE, Guha, Rastogi, Shim.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CURE
Picture from CURE, Guha, Rastogi, Shim.
(centroid)
(single link)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
CURE Cannot Handl e Di f f er i ng Densi t i es
Original Points
CURE
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gr aph-Based Cl ust er i ng
Graph-Based clustering uses the proximity graph
Start with the proximity matrix
Consider each point as a node in a graph
Each edge between two nodes has a weight which is
the proximity between the two points
Initially the proximity graph is fully connected
MIN (single-link) and MAX (complete-link) can be
viewed as starting with this graph
In the simplest case, clusters are connected
components in the graph.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Graph-Based Cl ust eri ng: Sparsi f i cat i on
The amount of data that needs to be
processed is drastically reduced
Sparsification can eliminate more than 99% of the
entries in a proximity matrix
The amount of time required to cluster the data is
drastically reduced
The size of the problems that can be handled is
increased
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Graph-Based Cl ust eri ng: Sparsi f i cat i on
Clustering may work better
Sparsification techniques keep the connections to the most
similar (nearest) neighbors of a point while breaking the
connections to less similar points.
The nearest neighbors of a point tend to belong to the same
class as the point itself.
This reduces the impact of noise and outliers and sharpens
the distinction between clusters.
Sparsification facilitates the use of graph
partitioning algorithms (or algorithms based
on graph partitioning algorithms.
Chameleon and Hypergraph-based Clustering
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Sparsi f i cat i on i n t he Cl ust er i ng Pr ocess
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of Cur rent Mer gi ng Schemes
Existing merging schemes in hierarchical
clustering algorithms are static in nature
MIN or CURE:
merge two clusters based on their closeness (or minimum
distance)
GROUP-AVERAGE:
merge two clusters based on their average connectivity
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of Cur rent Mer gi ng Schemes
Closeness schemes
will merge (a) and (b)
(a)
(b)
(c)
(d)
Average connectivity schemes
will merge (c) and (d)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Chamel eon: Cl ust er i ng Usi ng Dynami c Model i ng
Adapt to the characteristics of the data set to find the
natural clusters
Use a dynamic model to measure the similarity between
clusters
Main property is the relative closeness and relative inter-
connectivity of the cluster
Two clusters are combined if the resulting cluster shares certain
properties with the constituent clusters
The merging scheme preserves self-similarity
One of the areas of application is spatial data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Char act er i st i cs of Spat i al Dat a Set s
Clusters are defined as densely
populated regions of the space
Clusters have arbitrary shapes,
orientation, and non-uniform sizes
Difference in densities across clusters
and variation in density within clusters
Existence of special artifacts (streaks)
and noise
The clustering algorithm must address
the above characteristics and also
require minimal supervision.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Chamel eon: St eps
Preprocessing Step:
Represent the Data by a Graph
Given a set of points, construct the k-nearest-
neighbor (k-NN) graph to capture the relationship
between a point and its k nearest neighbors
Concept of neighborhood is captured dynamically
(even if region is sparse)
Phase 1: Use a multilevel graph partitioning
algorithm on the graph to find a large number of
clusters of well-connected vertices
Each cluster should contain mostly points from one
true cluster, i.e., is a sub-cluster of a real cluster
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Chamel eon: St eps
Phase 2: Use Hierarchical Agglomerative
Clustering to merge sub-clusters
Two clusters are combined if the resulting cluster
shares certain properties with the constituent clusters
Two key properties used to model cluster similarity:
Relative Interconnectivity: Absolute interconnectivity of two
clusters normalized by the internal connectivity of the clusters
Relative Closeness: Absolute closeness of two clusters
normalized by the internal closeness of the clusters
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CHAMELEON
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CHAMELEON
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CURE (10
clusters)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CURE (15 clusters)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CHAMELEON
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CURE (9
clusters)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exper i ment al Resul t s: CURE (15
clusters)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
i j
i j
4
SNN graph: the weight of an edge is the number of shared
neighbors between vertices given that the vertices are connected
Shar ed Near Nei ghbor Appr oach
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cr eat i ng t he SNN Gr aph
Sparse Graph
Link weights are similarities
between neighboring points
Shared Near Neighbor Graph
Link weights are number of
Shared Nearest Neighbors
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
ROCK ( RObust Cl ust er i ng usi ng l i nKs)
Clustering algorithm for data with categorical and
Boolean attributes
A pair of points is defined to be neighbors if their similarity is greater
than some threshold
Use a hierarchical clustering scheme to cluster the data.
1. Obtain a sample of points from the data set
2. Compute the link value for each set of points, i.e., transform the
original similarities (computed by Jaccard coefficient) into similarities
that reflect the number of shared neighbors between points
3. Perform an agglomerative hierarchical clustering on the data using
the number of shared neighbors as similarity measure and
maximizing the shared neighbors objective function
4. Assign the remaining points to the clusters that have been found
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Jar vi s-Pat r i ck Cl ust er i ng
First, the k-nearest neighbors of all points are found
In graph terms this can be regarded as breaking all but the k
strongest links from a point to other points in the proximity graph
A pair of points is put in the same cluster if
any two points share more than T neighbors and
the two points are in each others k nearest neighbor list
For instance, we might choose a nearest neighbor list of
size 20 and put points in the same cluster if they share
more than 10 near neighbors
Jarvis-Patrick clustering is too brittle
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
When Jarvi s-Pat ri ck Wor ks Reasonabl y Wel l
Original Points
Jarvis Patrick Clustering
6 shared neighbors out of 20
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Smallest threshold, T,
that does not merge
clusters.
Threshold of T - 1
When Jarvi s-Pat ri ck Does NOT Wor k Wel l
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
SNN Cl ust er i ng Al gor i t hm
1. Compute the similarity matrix
This corresponds to a similarity graph with data points for nodes and
edges whose weights are the similarities between data points
2. Sparsify the similarity matrix by keeping only the k most similar
neighbors
This corresponds to only keeping the k strongest links of the similarity
graph
3. Construct the shared nearest neighbor graph from the sparsified
similarity matrix.
At this point, we could apply a similarity threshold and find the
connected components to obtain the clusters (Jarvis-Patrick
algorithm)
4. Find the SNN density of each Point.
Using a user specified parameters, Eps, find the number points that
have an SNN similarity of Eps or greater to each point. This is the
SNN density of the point
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
SNN Cl ust eri ng Al gori t hm
5. Find the core points
Using a user specified parameter, MinPts, find the core
points, i.e., all points that have an SNN density greater
than MinPts
6. Form clusters from the core points
If two core points are within a radius, Eps, of each other
they are place in the same cluster
7. Discard all noise points
All non-core points that are not within a radius of Eps of
a core point are discarded
8. Assign all non-noise, non-core points to clusters
This can be done by assigning such points to the
nearest core point
(Note that steps 4-8 are DBSCAN)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
SNN Densi t y
a) All Points b) High SNN Density
c) Medium SNN Density d) Low SNN Density
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
SNN Cl ust eri ng Can Handl e Di f f eri ng Densi t i es
Original Points
SNN Clustering
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
SNN Cl ust eri ng Can Handl e Ot her Di f f i cul t Si t uat i ons
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Fi ndi ng Cl ust er s of Ti me Ser i es I n Spat i o-Tempor al Dat a
26 SLP Clusters via Shared Nearest Neighbor Clustering (100 NN, 1982-1994)
longitude
l
a
t
i
t
u
d
e
-180 -150 -120 -90 -60 -30 0 30 60 90 120 150 180
90
60
30
0
-30
-60
-90
13
26
24
25
22
14
16 20
17 18
19
15
23
1
9
6
4
7
10
12
11
3
5
2
8
21
SNN Clusters of SLP.
SNN Density of SLP Time Series Data
longitude
l
a
t
i
t
u
d
e
-180 -150 -120 -90 -60 -30 0 30 60 90 120 150 180
90
60
30
0
-30
-60
-90
SNN Density of Points on the Globe.
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Feat ures and Li mi t at i ons of SNN Cl ust eri ng
Does not cluster all the points
Complexity of SNN Clustering is high
O( n * time to find numbers of neighbor within Eps)
In worst case, this is O(n
2
)
For lower dimensions, there are more efficient ways to find
the nearest neighbors
R* Tree
k-d Trees
Dat a Mi ni ng
Anomal y Det ect i on
Lecture Notes for Chapter 10
Introduction to Data Mining
by
Tan, Steinbach, Kumar
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Anomal y/ Out l i er Det ect i on
What are anomalies/outliers?
The set of data points that are considerably different than the
remainder of the data
Variants of Anomaly/Outlier Detection Problems
Given a database D, find all the data points x D with anomaly
scores greater than some threshold t
Given a database D, find all the data points x D having the top-
n largest anomaly scores f(x)
Given a database D, containing mostly normal (but unlabeled)
data points, and a test point x, compute the anomaly score of x
with respect to D
Applications:
Credit card fraud detection, telecommunication fraud detection,
network intrusion detection, fault detection
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
I mpor t ance of Anomal y Det ect i on
Ozone Depletion History
In 1985 three researchers (Farman,
Gardinar and Shanklin) were
puzzled by data gathered by the
British Antarctic Survey showing that
ozone levels for Antarctica had
dropped 10% below normal levels
Why did the Nimbus 7 satellite,
which had instruments aboard for
recording ozone levels, not record
similarly low ozone concentrations?
The ozone concentrations recorded
by the satellite were so low they
were being treated as outliers by a
computer program and discarded!
Sources:
ht t p: / / exploringdat a.cqu.edu.au/ ozone.ht ml
ht t p: / / www.epa.gov/ ozone/ science/ hole/ size.ht ml
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Anomal y Det ect i on
Challenges
How many outliers are there in the data?
Method is unsupervised
Validation can be quite challenging (just like for clustering)
Finding needle in a haystack
Working assumption:
There are considerably more normal observations
than abnormal observations (outliers/anomalies) in
the data
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Anomal y Det ect i on Schemes
General Steps
Build a profile of the normal behavior
Profile can be patterns or summary statistics for the overall population
Use the normal profile to detect anomalies
Anomalies are observations whose characteristics
differ significantly from the normal profile
Types of anomaly detection
schemes
Graphical & Statistical-based
Distance-based
Model-based
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gr aphi cal Appr oaches
Boxplot (1-D), Scatter plot (2-D), Spin plot (3-D)
Limitations
Time consuming
Subjective
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Convex Hul l Met hod
Extreme points are assumed to be outliers
Use convex hull method to detect extreme values
What if the outlier occurs in the middle of the
data?
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
St at i st i cal Appr oaches
Assume a parametric model describing the
distribution of the data (e.g., normal distribution)
Apply a statistical test that depends on
Data distribution
Parameter of distribution (e.g., mean, variance)
Number of expected outliers (confidence limit)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Gr ubbs Test
Detect outliers in univariate data
Assume data comes from normal distribution
Detects one outlier at a time, remove the outlier,
and repeat
H
0
: There is no outlier in data
H
A
: There is at least one outlier
Grubbs test statistic:
Reject H
0
if:
s
X X
G
=
max
2
2
) 2 , / (
) 2 , / (
2
) 1 (
>
N N
N N
t N
t
N
N
G
= =
t i
t
t i
t
t i
t
t
t i
t
t
A x
i A t
M x
i M t t
A x
i A
A
M x
i M
M
N
i
i D t
x P A x P M D LL
x P x P x P D L
) ( log log ) ( log ) 1 log( ) (
) ( ) ( ) 1 ( ) ( ) (
| | | |
1
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Li mi t at i ons of St at i st i cal Appr oaches
Most of the tests are for a single attribute
In many cases, data distribution may not be
known
For high dimensional data, it may be difficult to
estimate the true distribution
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Di st ance-based Appr oaches
Data is represented as a vector of features
Three major approaches
Nearest-neighbor based
Density based
Clustering based
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Near est -Nei ghbor Based Appr oach
Approach:
Compute the distance between every pair of data
points
There are various ways to define outliers:
Data points for which there are fewer than p neighboring
points within a distance D
The top n data points whose distance to the kth nearest
neighbor is greatest
The top n data points whose average distance to the k
nearest neighbors is greatest
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Out l i er s i n Lower Di mensi onal Pr oj ect i on
Divide each attribute into equal-depth intervals
Each interval contains a fraction f = 1/ of the records
Consider a k-dimensional cube created by
picking grid ranges from k different dimensions
If attributes are independent, we expect region to
contain a fraction f
k
of the records
If there are N points, we can measure sparsity of a
cube D as:
Negative sparsity indicates cube contains smaller
number of points than expected
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Exampl e
N=100, = 5, f = 1/5 = 0.2, N f
2
= 4
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Densi t y-based: LOF appr oach
For each point, compute the density of its local
neighborhood
Compute local outlier factor (LOF) of a sample p as the
average of the ratios of the density of sample p and the
density of its nearest neighbors
Outliers are points with largest LOF value
p
2
p
1
I n t he NN approach, p
2
is
not considered as out lier,
while LOF approach find
bot h p
1
and p
2
as out liers
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Cl ust er i ng-Based
Basic idea:
Cluster the data into
groups of different density
Choose points in small
cluster as candidate
outliers
Compute the distance
between candidate points
and non-candidate
clusters.
If candidate points are far
from all other non-candidate
points, they are outliers
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Base Rat e Fal l acy
Bayes theorem:
More generally:
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Base Rat e Fal l acy ( Axel sson, 1999)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Base Rat e Fal l acy
Even though the test is 99% certain, your chance
of having the disease is 1/100, because the
population of healthy people is much larger than
sick people
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Base Rat e Fal l acy i n I nt r usi on Det ect i on
I: intrusive behavior,
I: non-intrusive behavior
A: alarm
A: no alarm
Detection rate (true positive rate): P(A|I)
False alarm rate: P(A|I)
Goal is to maximize both
Bayesian detection rate, P(I|A)
P(I|A)
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Det ect i on Rat e vs Fal se Al ar m Rat e
Suppose:
Then:
False alarm rate becomes more dominant if P(I)
is very low
Tan,Steinbach, Kumar Introduction to Data Mining 4/18/2004 #
Det ect i on Rat e vs Fal se Al ar m Rat e
Axelsson: We need a very low false alarm rate to achieve
a reasonable Bayesian detection rate