27
TẠP CHÍ KHOA HỌC, Đại học Huế, Số 50, 2009
ÁP DỤNG KỸ THUẬT PHÂN NHÓM VÀO PHÂN MẢNH NGANG LỚP
TRONG C
Ơ SỞ DỮ LIỆU HƯỚNG ĐỐI TƯỢNG
Nguyễn Thị Hương Giang
Trường Đại học Sư phạm, Đại học Huế
TÓM TẮT
Bài báo trình bày việc áp dụng kỹ thuật phân nhóm vào phân mảnh ngang lớp trong cơ
sở dữ liệu hướng đối tượng khiến các phân mảnh hiện thời thích nghi với tập các ứng dụng
người sử dụng mới; đồng thời đề xuất phương pháp phân nhóm gia tăng dựa trên phân cấp
nhân có thể phân lớp lại tập các đối tượng khi thuộc tính các đối tượng tăng lên.
I. Giới thiệu
Phân m
ảnh dữ liệu là một trong những hướng nghiên cứu mới trong cơ sở dữ
li
ệu (CSDL), là kỹ thuật thiết kế cơ sở dữ liệu ở mức logic nhằm giảm bớt những truy
xu
ất không cần thiết đến dữ liệu, cho phép thực hiện song song các câu truy vấn bằng
cách chia nó ra thành m
ột tập các câu truy vấn con tác động lên các mảnh nhằm nâng
cao vi
ệc thực hiện các ứng dụng. Trong mô hình quan hệ, có các kiểu phân mảnh: phân
m
ảnh ngang, phân mảnh dọc và phân mảnh hỗn hợp. Phân mảnh ngang là phân hoạch
m
ột quan hệ thành một tập các quan hệ con, mỗi quan hệ con này chứa một tập con các
b
ộ (các hàng) của quan hệ ban đầu. Phân mảnh dọc là phân hoạch một quan hệ thành
m
ột tập các quan hệ con, trong đó mỗi quan hệ con được định nghĩa trên một tập con
các thu
ộc tính của quan hệ ban đầu. Phân mảnh hỗn hợp phân hoạch một quan hệ thành
các t
ập con các bộ con, trong đó các bộ con được xác định bởi phân mảnh dọc, còn các
t
ập con được xác định bởi phân mảnh ngang.
Trong nh
ững năm gần đây, do các ứng dụng ngày càng phức tạp, các mô hình
CSDL tr
ước đó cũng như mô hình quan hệ đã bộc lộ nhiều nhược điểm trong việc mô
hình hóa và x
ử lý dữ liệu. Có nhiều mô hình CSDL ra đời và được phát triển nhằm khắc
ph
ục những hạn chế đó, một trong số chúng là mô hình CSDL hướng đối tượng. Có
nhi
ều điểm tương đồng giữa phân mảnh ngang trong CSDL quan hệ và CSDL hướng
đối tượng. Tuy nhiên, do mô hình CSDL hướng đối tượng có các đặc trưng riêng như:
tính k
ế thừa, tính bao gói, phân cấp lớp,… nên chúng ta không thể áp dụng việc phân
m
ảnh ngang từ mô hình quan hệ sang mô hình đối tượng. Do đó, phân mảnh dữ liệu
trong CSDL h
ướng đối tượng vẫn đang được nhiều nhà nghiên cứu quan tâm. Vấn đề
chúng tôi
đưa ra trong bài báo này là áp dụng kỹ thuật phân nhóm vào phân mảnh ngang
l
ớp trong CSDL hướng đối tượng.
28
Một hệ CSDL hướng đối tượng phân tán muốn tối ưu hóa việc thực hiện các ứng
d
ụng cần phải có phân mảnh lớp và lược đồ phân phối các mảnh này tại các nơi phân
tán
để cực tiểu việc truyền dữ liệu. Một tiếp cận phân mảnh ngang sử dụng các phương
th
ức gộp nhóm khai thác dữ liệu cho việc phân chia các thể hiện đối tượng thành các
m
ảnh đã được trình bày trong [1], [2], [3], [4]. Nhưng các ứng dụng CSDL thực liên
quan t
ới yếu tố thời gian, do đó, nó đòi hỏi sự phân mảnh để giải quyết tình trạng tại
m
ột thời điểm, có một số ứng dụng truy cập vào hệ thống và một số khác lại ra khỏi hệ
th
ống. Trong trường hợp này, để có được phân mảnh phù hợp với tập các ứng dụng
ng
ười sử dụng mới, chúng ta có thể áp dụng lược đồ phân mảnh ban đầu (ứng với
CSDL ban
đầu), nhưng cách làm này không hiệu quả. Vì vậy, cần có phương pháp phân
m
ảnh mở rộng giải quyết trường hợp khi các ứng dụng người sử dụng mới đến hệ thống
thì các phân m
ảnh hiện thời phải thích nghi theo. Mặt khác, nói chung, các phương pháp
phân nhóm hi
ện thời bắt đầu với tập các đối tượng biết trước, cùng với tập các thuộc
tính bi
ết trước. Nhưng có nhiều ứng dụng có tập thuộc tính mô tả các đối tượng được
m
ở rộng ra, được suy ra. Do đó, chúng tôi đề xuất phương pháp phân nhóm gia tăng dựa
trên phân c
ấp nhân (Hieararchical Core Based Incremental Clustering - HCBIC), có thể
phân l
ớp lại tập các đối tượng khi thuộc tính các đối tượng tăng lên.
II. Mô hình vector toán học của CSDL hướng đối tượng
Phân m
ảnh CSDL đối tượng có nghĩa là phân mảnh từng lớp của nó, giả sử gọi
l
ớp đó là C. Một lớp C là một bộ được sắp xếp C=(K, A, M, I), với A là tập các thuộc
tính
đối tượng, M là tập các phương thức, K là định danh lớp và I là tập các thể hiện của
l
ớp C. Trong phạm vi bài báo, chúng tôi chỉ giải quyết sự phân mảnh nguyên thủy [4].
Các l
ớp được tổ chức trong một phân cấp kế thừa, trong đó, lớp con là sự
chuyên bi
ệt hóa của lớp cha của nó. Bài toán chỉ giải quyết trường hợp thừa kế đơn,
nh
ưng khi chuyển sang thừa kế bội cũng sẽ không ảnh hưởng tới thuật toán phân mảnh,
mi
ễn là các xung đột thừa kế được giải quyết bên trong mô hình dữ liệu. Liên kết giữa
m
ột đối tượng và một lớp được cụ thể hóa bởi một phép toán cụ thể. Một đối tượng O là
m
ột thể hiện của một lớp C nếu C là lớp được chuyên biệt hóa có liên kết (kết hợp) với
O trong phân c
ấp kế thừa. Một đối tượng O là một thành viên của một lớp C nếu O là
th
ể hiện của C hoặc là thể hiện của một trong các lớp con của C. Một CSDL hướng đối
t
ượng là một tập các lớp từ một phân cấp kế thừa, với tất cả các thể hiện của nó. Root là
l
ớp đặc biệt, là tổ tiên (lớp cha) của tất cả các lớp trong CSDL. Do đó, trong mô hình
c
ủa chúng ta, đồ thị kế thừa là một cây. Các quan hệ khác giữa các lớp trong một CSDL
là các m
ối quan hệ kết hợp và kết tập. Một điểm vào CSDL là một thể hiện siêu lớp
(meta-class) trên bi
ến cho trước trong hệ thống. Một điểm vào cho phép sự tìm kiếm từ
nó t
ới tất cả các lớp và các thể hiện lớp của cây con của nó (bao gồm cả nó). Thường có
nhi
ều điểm vào trong một CSDL hướng đối tượng.
Cho tr
ước một cây thừa kế phức H, một biểu thức đường dẫn P là C
1
.A
1
…A
n
,
n
≥
1 với C là một điểm vào trong H, A
1
là một thuộc tính của lớp C
1
, A
i
là một thuộc tính
29
của lớp C
i
trong H, C
i
là miền thuộc tính A
i-1
của lớp C
i-1
(1
≤
i
≤
n). Mục đích của phân
m
ảnh và điều phối phân mảnh của hệ CSDL hướng đối tượng là tối ưu sự thực thi các
truy v
ấn của người sử dụng. Một truy vấn hướng đối tượng là một bộ với cấu trúc như
sau:
q = (l
ớp mục tiêu, mệnh đề tính chất), trong đó “lớp mục tiêu” xác định lớp mà
truy v
ấn trả về các thể hiện đối tượng của nó trên nó, “mệnh đề tính chất” là biểu thức
logic trên các thu
ộc tính lớp trong hình thức nối chuNn. Biểu thức logic được xây dựng
s
ử dụng các vị từ đơn giản: attribute
Θ
value với Θ ∈{ <, >, ≥, ≤, ≠}.
G
ọi Q = {q
1
, …, q
t
} là tập các truy vấn mà phân mảnh thực hiện. Pred
Q
(C) =
{p
1
, , p
n
} là tập các vị từ đơn giản. Pred
Q
(C) = { p ∈ Pred
Q
/ p là điều kiện của một
thu
ộc tính của lớp C}. Cho trước 2 lớp C và C”, với C” là lớp con của C, Pred
Q
(C”) ⊇
Pred
Q
(C). Do đó, tập các vị từ cho lớp C” gồm tất cả các vị từ được xác định trực tiếp
trên các thu
ộc tính của C” và các vị từ được định nghĩa trên các thuộc tính của lớp cha
C c
ủa nó và các thuộc tính được thừa kế từ C. Với mỗi một đối tượng O
i
trong tập
Inst(C ) - t
ập tất cả các thể hiện của lớp C, i = 1 m, m=|Inst(C)|, ta kết hợp một vector
điều kiện a
i
= (a
i1
,…,a
is
), với Pred
Q
(C) = {p
1
,…,p
s
}:
ij
0, ( )
1, ( )
j i
j i
p O false
a
p O true
=
=
=
Các
đối tượng sẽ được gộp nhóm với nhau trong các phân mảnh sao cho các đối
t
ượng trong cùng một phân mảnh có độ tương tự cao, trong khi độ tương tự so với các
đối tượng trong các nhóm khác thấp. Độ tương tự giữa các đối tượng được đo bằng các
hàm kho
ảng cách, áp dụng cho các vector điều kiện mô tả các đối tượng. Chúng ta sử
d
ụng khoảng cách Euclide để đo độ tương tự giữa các đối tượng:
( )
2
1
( , )
s
E i j il jl
l
d a a a a
=
= −
∑
v
ớ
i a
i
, a
j
là các vector
đ
i
ề
u ki
ệ
n c
ủ
a O
i
, O
j
∈Inst(C).
2.1. Phân mảnh gia tăng sử dụng thuật toán CBIC (Core-Based Incremental
Clustering)
Tr
ướ
c tiên, khi
đ
i t
ừ
CSDL trung tâm t
ớ
i CSDL phân tán, ta áp d
ụ
ng ph
ươ
ng
pháp phân m
ả
nh kh
ở
i t
ạ
o. Trong [1], [2], [3], [4], cho tr
ướ
c m
ộ
t t
ậ
p các truy v
ấ
n
Q
init
= {q
1
,…,q
n
}, m
ệ
nh
đề
phân m
ả
nh ban
đầ
u c
ủ
a t
ậ
p
đố
i t
ượ
ng Inst(C) c
ủ
a l
ớ
p C
đ
òi
h
ỏ
i tr
ướ
c tiên các
đố
i t
ượ
ng trong Inst(C) ph
ả
i
đượ
c mô hình hóa nh
ư
đ
ã mô t
ả
ở
trên.
Sau
đ
ó, áp d
ụ
ng ph
ươ
ng pháp phân nhóm k-means trên không gian vector mô t
ả
Inst(C),
và k
ế
t qu
ả
s
ẽ
là các nhóm bi
ể
u di
ễ
n các phân m
ả
nh cho l
ớ
p C.
Phân m
ả
nh hi
ệ
n th
ờ
i c
ủ
a CSDL h
ướ
ng
đố
i t
ượ
ng phân tán
đượ
c phát tri
ể
n
để
t
ố
i
ư
u hóa s
ự
th
ự
c thi c
ủ
a t
ậ
p truy v
ấ
n ban
đầ
u, Q
init
. Khi các truy v
ấ
n m
ớ
i vào h
ệ
th
ố
ng
Q
new
= Q
init
∪ {q
p+1
, …, q
t
}, phân m
ả
nh
đ
ang t
ồ
n t
ạ
i ph
ả
i thích nghi theo. Chúng ta áp
30
d
ụ
ng ph
ươ
ng pháp g
ộ
p nhóm d
ự
a trên k-means và Core Based Incremental Clustering
(CBIC) – ph
ươ
ng pháp g
ộ
p nhóm gia t
ă
ng d
ự
a trên nhân ([5], [6]).
M
ở
r
ộ
ng c
ủ
a t
ậ
p truy v
ấ
n Q
init
thành Q
new
có ngh
ĩ
a là v
ớ
i m
ộ
t s
ố
các l
ớ
p trong
CSDL, t
ậ
p các v
ị
t
ừ
có k
ế
t h
ợ
p v
ớ
i các l
ớ
p s
ẽ
t
ă
ng lên. Do
đ
ó, các l
ớ
p này ph
ả
i
đượ
c
phân m
ả
nh l
ạ
i
để
phù h
ợ
p v
ớ
i t
ậ
p h
ợ
p truy v
ấ
n m
ớ
i. Cho C là m
ộ
t l
ớ
p nh
ư
v
ậ
y. V
ớ
i m
ỗ
i
Pred
Q-init
(C) = {p
1
,…,p
n
} xác
đị
nh Pred
Q-new
(C) ∪ {p
n+1
,…,p
s
}. Do
đ
ó, vector
đ
i
ề
u ki
ệ
n
c
ủ
a m
ỗ
i m
ộ
t
đố
i t
ượ
ng O
i
∈ Inst(C)
đượ
c m
ở
r
ộ
ng nh
ư
sau:
Ph
ươ
ng pháp CBIC b
ắ
t
đầ
u b
ằ
ng vi
ệ
c phân chia Inst(C) thành các nhóm b
ằ
ng
cách áp d
ụ
ng ph
ươ
ng pháp k-means trong b
ướ
c phân m
ả
nh ban
đầ
u. Cho {K
1
,
K
2
,…,K
p
} là các phân m
ả
nh ban
đầ
u c
ủ
a Inst(C), K
i
∩ K
j
= ∅, i ≠j,
1
Ins ( )
p
l
l
K t C
=
=
U
.
Ph
ươ
ng pháp CBIC phân chia các
đố
i t
ượ
ng trong Inst(C): {K
1
’, K
2
’,….K
p
’} sau khi m
ở
r
ộ
ng t
ậ
p truy v
ấ
n. Nó b
ắ
t
đầ
u t
ừ
ý t
ưở
ng khi b
ổ
sung m
ộ
t s
ố
thành ph
ầ
n (các
đặ
c tính,
thu
ộ
c tính) vào các vector
đ
i
ề
u ki
ệ
n và các thành ph
ầ
n này không mang l
ạ
i nhi
ề
u thông
tin trong h
ệ
th
ố
ng, thì vi
ệ
c s
ắ
p x
ế
p thành các nhóm c
ũ
t
ươ
ng t
ự
v
ớ
i ph
ươ
ng pháp m
ớ
i.
Thu
ậ
t toán xác
đị
nh sau
đ
ó các
đố
i t
ượ
ng bên trong m
ỗ
i m
ộ
t phân m
ả
nh K
i
có kh
ả
n
ă
ng
k
ế
t h
ợ
p l
ạ
i v
ớ
i nhau trong cùng m
ộ
t nhóm. Chúng là nh
ữ
ng
đố
i t
ượ
ng, sau khi m
ở
r
ộ
ng
thu
ộ
c tính, v
ẫ
n còn g
ầ
n h
ơ
n v
ớ
i tr
ọ
ng tâm (trung bình nhóm) c
ủ
a nhóm K
i
. Các
đố
i
t
ượ
ng này t
ạ
o ra cái
đượ
c g
ọ
i là nhân (core) c
ủ
a l
ớ
p K
i
, g
ọ
i là Core
i
. Tr
ọ
ng tâm c
ủ
a K
i
đượ
c tính là giá tr
ị
trung bình c
ủ
a t
ấ
t c
ả
các vector
đ
i
ề
u ki
ệ
n
đượ
c m
ở
r
ộ
ng c
ủ
a các
đố
i
t
ượ
ng trong K
i
.
Các nhân c
ủ
a t
ấ
t c
ả
các phân m
ả
nh K
i
, i = 1 p, s
ẽ
là nhóm kh
ở
i t
ạ
o m
ớ
i cho
các b
ướ
c l
ặ
p phân chia ti
ế
p theo b
ắ
t
đầ
u. Ti
ế
p
đ
ó, thu
ậ
t toán CBIC ti
ế
p t
ụ
c theo cùng
cách nh
ư
thu
ậ
t toán k-means th
ự
c hi
ệ
n. Thu
ậ
t toán CBIC, cho k
ế
t qu
ả
hi
ệ
u qu
ả
h
ơ
n là
th
ự
c hi
ệ
n k-means t
ừ
t
ậ
p
đố
i t
ượ
ng có thu
ộ
c tính m
ở
r
ộ
ng.
Ví d
ụ
minh h
ọ
a CSDL h
ướ
ng
đố
i t
ượ
ng và t
ậ
p truy v
ấ
n
Xét c
ấ
u trúc phân l
ớ
p trong m
ộ
t CSDL c
ủ
a m
ộ
t tr
ườ
ng
đạ
i h
ọ
c:
Các truy v
ấ
n sau th
ự
c hi
ệ
n trên các l
ớ
p c
ủ
a CSDL cho
ở
trên:
q
1:
cho bi
ế
t t
ấ
t c
ả
các sinh viên t
ố
t nghi
ệ
p
đ
ã ghi tên vào khoa Component
a
i
điều kiện ban đầu của đối tượng O
i
'
1 1 is
, , , , ,
i i in in
a a a a a
+
=
142 43
31
Oriented Programming và khoa Intelligent Systems, q
1
= (Grad, Grad.Dept in
(“Component Oriented Programming”, “Intelligent Systems”) ).
q
2
: cho bi
ế
t t
ấ
t c
ả
các sinh viên ch
ư
a t
ố
t nghi
ệ
p
đ
ã ghi tên vào khoa Computer
Science và có
đ
i
ể
m trung bình t
ừ
7
đế
n 10, q
2
= (UnderGrad, UnderGrad.Dept like
“CS%” and UnderGrad.Grade between 7 and 10).
q
3
: cho bi
ế
t t
ấ
t c
ả
các sinh viên ch
ư
a t
ố
t nghi
ệ
p ghi tên vào khoa Computer
Science và khoa Mathematics có tu
ổ
i l
ớ
n h
ơ
n 24, q
3
= (UnderGrad, (UnderGrad.Dept
like “Math%” or UnderGrad.Dept like “CS%”) and UnderGrad.Age >=24).
q
4
: cho bi
ế
t t
ấ
t c
ả
nh
ữ
ng nghiên c
ứ
u sinh
đ
ã vi
ế
t ít nh
ấ
t 2 bài báo, q
4
=
(Researcher, Researcher, count(Researcher. Doc) >=2.
q
5
: cho bi
ế
t t
ấ
t c
ả
các gi
ả
ng viên làm vi
ệ
c trong khoa Component Oriented
Programming ho
ặ
c khoa Intelligent Systems và có l
ươ
ng cao h
ơ
n 40.000, q
5
: (Prof, Prof.
Dept in (“Component Oriented Programming“, “Intelligent Systems“) và Prof. Salary
>=40.000
q
6
: cho bi
ế
t t
ấ
t c
ả
các gi
ả
ng viên có bài
đă
ng trên
ấ
n ph
N
m IEEE ho
ặ
c ACM, q
6
= (Prof, Prof.Doc.Pulisher in (“IEEE”, “ACM”)
q
7
: cho bi
ế
t t
ấ
t c
ả
các sinh viên thi tr
ượ
t, q
7
= (Student, Student.Grade <=5)
q
8
: cho bi
ế
t t
ấ
t c
ả
nh
ữ
ng nhân viên có l
ươ
ng cao h
ơ
n 35.000, q
8
= (Employee,
Employee.Salary > 35.000)
q
9
: cho bi
ế
t t
ấ
t c
ả
các sinh viên
đ
ã t
ố
t nghi
ệ
p có
đă
ng ít nh
ấ
t 1 bài báo, q
9
=
(Grad, Grad.count(Grad.Doc)>=1)
q
10
: cho bi
ế
t t
ấ
t c
ả
các
độ
i ng
ũ
nhân viên có l
ươ
ng cao h
ơ
n 12.000, q
10
= (Staff,
Staff.Salary > 12.000)
q
11
: cho bi
ế
t t
ấ
t c
ả
các nghiên c
ứ
u sinh vi
ế
t s
ố
bài báo ít h
ơ
n s
ố
bài báo trung
bình c
ủ
a các nghiên c
ứ
u sinh, q
11
= (Researcher, Researcher.Count(Paper) <
Avg( Researcher.Count(Paper) )
q
12
: cho bi
ế
t t
ấ
t c
ả
các sinh viên
đ
ã t
ố
t nghi
ệ
p l
ậ
p gia
đ
ình, q
12
= (Grad,
Grad.MaritalStatuss=”married”)
q
13
: cho bi
ế
t t
ấ
t c
ả
các sinh viên ch
ư
a t
ố
t nghi
ệ
p ghi tên vào khoa Mathematics
và khoa Computer Science, q
13
= (Undergraduate, Undergraduate.Dept like “Math-
CS%”)
q
14
: cho bi
ế
t t
ấ
t c
ả
nh
ữ
ng ng
ườ
i có tu
ổ
i l
ớ
n h
ơ
n 30, q
14
= (Person, Person,
Person.Age > 30)
q
15
: cho bi
ế
t t
ấ
t c
ả
các tr
ợ
gi
ả
ng có tu
ổ
i l
ớ
n h
ơ
n 28, q
15
= (Prof, Prof.Position =
“assistant professor” and Prof.age > 28)
32
q
16
: cho bi
ế
t t
ấ
t c
ả
các sinh viên có qu
ố
c t
ị
ch Hungary ho
ặ
c
Đứ
c, q
16
= (Student,
Student.Nationality in (“ hungarian”, “ german”)
Các truy v
ấ
n t
ừ
q
1
đế
n q
12
là nh
ữ
ng truy v
ấ
n ban
đầ
u – có
đượ
c t
ừ
phân m
ả
nh
ngang và l
ượ
c
đồ
phân ph
ố
i kh
ở
i t
ạ
o: Q
init
= {q
1
, …., q
12
}. Các truy v
ấ
n t
ừ
q
13
đế
n q
16
là
các truy v
ấ
n m
ớ
i vào h
ệ
th
ố
ng, và phân m
ả
nh
đ
ang t
ồ
n t
ạ
i ph
ả
i thích
ứ
ng
để
phù h
ợ
p và
để
t
ố
i
ư
u hóa t
ậ
p
ứ
ng d
ụ
ng m
ớ
i: Q
new
= Q
init
∪ {q
13
, …, q
16
}.
III. Phương pháp phân nhóm gia tăng dựa trên phân cấp nhân (Hieararchical Core
Based Incremental Clustering - HCBIC).
Phân l
ớ
p là ph
ươ
ng pháp phân bi
ệ
t các nhóm bên trong m
ộ
t t
ậ
p các
đố
i t
ượ
ng
th
ự
c hi
ệ
n trên t
ậ
p các
đặ
c tính ho
ặ
c thu
ộ
c tính có liên quan c
ủ
a
đố
i t
ượ
ng. Vi
ệ
c phân
nhóm
đượ
c th
ự
c hi
ệ
n trên t
ậ
p các
đặ
c tính ho
ặ
c thu
ộ
c tính có liên quan c
ủ
a
đố
i t
ượ
ng.
Các
đố
i t
ượ
ng bên trong m
ộ
t nhóm
đượ
c xem là g
ầ
n nhau h
ơ
n các
đố
i t
ượ
ng trong
nhóm khác nh
ờ
vào khái ni
ệ
m
độ
t
ươ
ng t
ự
.
Độ
t
ươ
ng t
ự
gi
ữ
a các
đố
i t
ượ
ng
đượ
c
đ
o
b
ằ
ng hàm kho
ả
ng cách ho
ặ
c bán kho
ả
ng cách trên các giá tr
ị
thu
ộ
c tính mô t
ả
đố
i t
ượ
ng.
Ph
ươ
ng pháp phân nhóm phân c
ấ
p bi
ể
u di
ễ
n l
ớ
p chính c
ủ
a k
ỹ
thu
ậ
t phân nhóm.
Có 2 ki
ể
u phân nhóm phân c
ấ
p. Cho tr
ướ
c m
ộ
t t
ậ
p g
ồ
m n
đố
i t
ượ
ng và m
ộ
t s
ố
k, k≤n,
ph
ươ
ng pháp d
ướ
i lên (bottom-up) b
ắ
t
đầ
u v
ớ
i n singleton (t
ậ
p h
ợ
p ch
ỉ
có 1 thành ph
ầ
n),
tr
ộ
n chúng l
ạ
i v
ớ
i nhau cho
đế
n khi
đạ
t
đượ
c s
ố
l
ượ
ng các nhóm k mong mu
ố
n. T
ạ
i m
ỗ
i
b
ướ
c, 2 nhóm t
ươ
ng t
ự
nhau nh
ấ
t
đượ
c ch
ọ
n
để
tr
ộ
n. Còn ph
ươ
ng pháp trên xu
ố
ng (top-
down) b
ắ
t
đầ
u t
ừ
m
ộ
t nhóm ch
ứ
a t
ấ
t c
ả
n
đố
i t
ượ
ng và chia nó cho
đế
n khi
đạ
t
đượ
c s
ố
l
ượ
ng các nhóm k mong mu
ố
n.
Nói chung, các ph
ươ
ng pháp này b
ắ
t
đầ
u v
ớ
i t
ậ
p các
đố
i t
ượ
ng bi
ế
t tr
ướ
c,
đ
o
trên m
ộ
t t
ậ
p các thu
ộ
c tính bi
ế
t tr
ướ
c. Nh
ư
ng có nhi
ề
u
ứ
ng d
ụ
ng có t
ậ
p
đố
i t
ượ
ng là
độ
ng, ho
ặ
c t
ậ
p thu
ộ
c tính mô t
ả
các
đố
i t
ượ
ng liên quan
đượ
c m
ở
r
ộ
ng ra. Do
đ
ó,
để
có
đượ
c phân l
ớ
p
đố
i t
ượ
ng trong các
đ
i
ề
u ki
ệ
n này, thu
ậ
t toán phân nhóm có th
ể
ph
ả
i th
ự
c
hi
ệ
n nhi
ề
u l
ầ
n, b
ắ
t
đầ
u t
ừ
t
ậ
p các
đố
i t
ượ
ng ban
đầ
u, và m
ỗ
i l
ầ
n khi các
đố
i t
ượ
ng ho
ặ
c
thu
ộ
c tính thay
đổ
i l
ạ
i th
ự
c hi
ệ
n l
ạ
i thu
ậ
t toán. Rõ ràng
đ
i
ề
u này là kém hi
ệ
u qu
ả
. Vì v
ậ
y,
chúng tôi trình bày trong bài báo này ph
ươ
ng pháp phân nhóm gia t
ă
ng d
ự
a trên ph
ươ
ng
pháp phân c
ấ
p nhân có th
ể
phân l
ớ
p l
ạ
i t
ậ
p
đố
i t
ượ
ng khi t
ậ
p thu
ộ
c tính t
ă
ng lên.
Đầ
u
tiên, chúng ta dùng thu
ậ
t toán HCA (Hieararchical Clustering Algorithm) [7]
để
phân
chia thành các nhóm, sau
đ
ó, khi thu
ộ
c tính thay
đổ
i (
đượ
c m
ở
r
ộ
ng) thì chúng ta áp
d
ụ
ng thu
ậ
t toán HCBIC (Hieararchical Core Based Incremental Clustering).
Đ
i
ề
u này
s
ẽ
hi
ệ
u qu
ả
h
ơ
n khi th
ự
c hi
ệ
n l
ạ
i thu
ậ
t toán HCA trên t
ậ
p
đố
i t
ượ
ng có thu
ộ
c tính
đượ
c
m
ở
r
ộ
ng.
3.1 Định nghĩa
Cho {O
1
, O
2
, …, O
n
} là t
ậ
p các
đố
i t
ượ
ng
đượ
c phân l
ớ
p. M
ỗ
i
đố
i t
ượ
ng
đượ
c
đ
o
v
ớ
i t
ậ
p m các thu
ộ
c tính kh
ở
i t
ạ
o và mô t
ả
b
ở
i m vector
đ
a chi
ề
u O
i
= (O
i1
, …, O
im
),
O
ik
∈ ℜ, 1≤ i ≤ n, 1 ≤ k ≤ m. Thông th
ườ
ng, thu
ộ
c tính liên quan t
ớ
i các
đố
i t
ượ
ng
đề
u
33
đượ
c chu
N
n hóa
để
đả
m b
ả
o
độ
đ
o c
ủ
a chúng là b
ằ
ng nhau [3].
Cho {K
1
, K
2
, …, K
p
} là t
ậ
p các nhóm có
đượ
c khi áp d
ụ
ng thu
ậ
t toán HCA. M
ỗ
i
m
ộ
t nhóm là m
ộ
t t
ậ
p các
đố
i t
ượ
ng.
1 2
{O ,O , ,O }
j
j j j
j n
K = , 1
≤
j
≤
p. Tâm nhóm K
j
bi
ể
u
di
ễ
n giá tr
ị
trung bình c
ủ
a nhóm và
đượ
c xác
đị
nh b
ở
i:
1
1 1
, ,
j j
n n
k km
k k
j
j j
O O
f
n n
= =
=
∑ ∑
Ta s
ử
d
ụ
ng hàm kho
ả
ng cách d cho các
đố
i t
ượ
ng phân bi
ệ
t, c
ụ
th
ể
là dùng hàm
kho
ả
ng cách Euclide:
d( O
i
, O
j
) = d
E
(O
i
, O
j
) =
2
1
( )
m
il jl
l
O O
=
−
∑
Vi
ệ
c
đ
o các thu
ộ
c tính
đượ
c th
ự
c hi
ệ
n sau khi m
ở
r
ộ
ng s (s ≥ 1) thu
ộ
c tính m
ớ
i,
đượ
c ký hi
ệ
u là (m+1), (m+2),…, (m+s). Sau khi m
ở
r
ộ
ng, vector c
ủ
a
đố
i t
ượ
ng tr
ở
thành O
i
’ = (O
i1
, …, O
im
, O
im+1
, …O
im+s
), 1
≤
i
≤
n.
L
ấ
y
đ
i
ể
m b
ắ
t
đầ
u trong b
ướ
c phân l
ớ
p tr
ướ
c bên trong nhóm và xét trong các
đ
i
ề
u ki
ệ
n
đ
ó
đố
i t
ượ
ng m
ở
r
ộ
ng
'
j
i
O
còn
đ
úng khi
đặ
t nó trong nhóm K
j
’ c
ủ
a nó hay
không.
Để
làm
đượ
c
đ
i
ề
u
đ
ó, chúng ta bi
ể
u di
ễ
n các kho
ả
ng cách f
j
c
ủ
a
'
j
i
O
t
ớ
i các tâm
c
ũ
c
ủ
a nó và f
j
’ t
ớ
i tâm các nhóm m
ớ
i r
ồ
i so sánh v
ớ
i các kho
ả
ng cách t
ớ
i các tâm f
r
và
f
r
’ c
ủ
a m
ộ
t nhóm b
ấ
t k
ỳ
khác
1
≤
r
≤
p, r
≠
j.
N
ế
u các
đố
i t
ượ
ng trong nhóm j th
ỏ
a mãn
các
đ
i
ề
u ki
ệ
n và
độ
t
ươ
ng t
ự
đủ
l
ớ
n
để
đượ
c gi
ữ
cùng v
ớ
i nhau, chúng ta gi
ữ
chúng
trong m
ộ
t nhóm. Các
đố
i t
ượ
ng còn l
ạ
i trong nhóm j (nh
ữ
ng
đố
i t
ượ
ng này không th
ỏ
a
mãn các
đ
i
ề
u ki
ệ
n trên) s
ẽ
đượ
c trích ra và
đượ
c phân ph
ố
i t
ừ
ng
đố
i t
ượ
ng m
ộ
t vào t
ậ
p
h
ợ
p m
ộ
t ph
ầ
n t
ử
c
ủ
a nó. Ti
ế
n trình
đ
i
ề
u ch
ỉ
nh nhóm này s
ẽ
tr
ả
v
ề
k
ế
t qu
ả
là m
ộ
t s
ố
các
nhóm k’,
k
≤
k’
≤
n
.
Để
có l
ạ
i
đượ
c k nhóm
đ
ích, chúng ta ti
ế
p t
ụ
c tr
ộ
n các nhóm theo
cùng cách nh
ư
thu
ậ
t toán HCA. Nh
ư
ng khi chúng ta không b
ắ
t
đầ
u l
ạ
i t
ừ
t
ậ
p h
ợ
p m
ộ
t
ph
ầ
n t
ử
, s
ố
các b
ướ
c s
ẽ
gi
ả
m
đ
i
đ
áng k
ể
.
Định lý:
N
ế
u ( , ) ( , ), , ,1 , ,
j j
E i j E i r
d O f d O f j r j r p r j
≤ ∀ ≤ ≤ ≠
(1)
và
1
, {m+1, m+2, , m+s}
j
n
kl
k
il
j
O
O l
n
=
≥ ∀ ∈
∑
(2)
đ
úng v
ớ
i
đố
i t
ượ
ng
'
O
j
i
và nhóm
'
j
K
c
ủa nó thì đối tượng
'
O
j
i
gần với tâm
'
j
f
của nó hơn các tâm
'
r
f
của nhóm khác, 1 , ,
j r p r j
≤ ≤ ≠
.
34
Ch
ứng minh:
2
2
2 ' ' 2 ' ' 2 2
1 1
1 1
(O , ) (O , ) (O , ) (O , )
j
r
n
n
kl kl
m s m s
j j j j
k k
i j i r i j il i r il
l m l m
j r
O O
d f d f d f O d f O
n n
+ +
= =
= + = +
− = + − − − −
∑ ∑
∑ ∑
Sử dụng bất đẳng thức (1), ta có :
2
2
2 ' ' 2 ' '
1 1
1 1
(O , ) (O , )
j
r
n
n
kl kl
m s m s
j j
k k
i j i r il il
l m l m
j r
O O
d f d f O O
n n
+ +
= =
= + = +
− ≤ − − −
∑ ∑
∑ ∑
⇔
2 ' ' 2 ' '
1 1 1 1
1
(O , ) (O , ) * 2*
j j
r r
n n
n n
kl kl kl kl
m s
j j
k k k k
i j i r il
l m
j r j r
O O O O
d f d f O
n n n n
+
= = = =
= +
− ≤ − + −
∑ ∑ ∑ ∑
∑
N
ếu bất đẳng thức (2) đúng với mọi thuộc tính của
'
O
j
i
thì bất đẳng thức trên trở
thành:
2
2 ' ' 2 ' '
1 1
1
(O , ) (O , )
j
r
n
n
kl kl
m s
j j
k k
i j i r
l m
j r
O O
d f d f
n n
+
= =
= +
− ≤ − −
∑ ∑
∑
⇔
2 ' ' 2 ' '
(O , ) (O , )
j j
i j i r
d f d f
− ≤
0
Vì tất cả các khoảng cách là các số không âm nên:
' ' ' '
(O , ) (O , ), ,1 ,
j j
i j i r
d f d f r r p r j
≤ ∀ ≤ ≤ ≠
Điều kiện (1) trong định lý đòi hỏi đối tượng
i j
O K
∈ , ở bước cuối cùng của tiến
trình phân nhóm
đầu tiên (khởi tạo), là gần hơn với tâm nhóm của nó hơn tâm của nhóm
b
ất kỳ nào khác. Tất cả các đối tượng
i j
O K
∈ thỏa mãn bất đẳng thức (1) và có các mở
r
ộng đối tượng thỏa mãn điều kiện (2), là có độ tương tự đủ lớn với các đối tượng khác
cùng nhóm và không t
ương tự với các đối tượng trong các nhóm khác sau khi mở rộng
t
ập thuộc tính .
3.2. Thuật toán HCBIC
Chúng ta dùng các tính chất và định nghĩa ở phần trên để xác định trong mỗi
nhóm, nh
ững đối tượng nào vẫn được giữ lại với nhau mà không di chuyển sang các
nhóm khác. Các
đối tượng này là kết quả của sự mở rộng tập thuộc tính, và chúng hình
35
thành nên cái gọi là nhân của nhóm.
Định
nghĩa:
a, Đặt
' ' '
or { | ,
j j j
j i i j i
StrongC e O O K O
= ∈
thỏa bất đẳng thức (1) và
'
j
i
O
thỏa các
b
ất đẳng thức (2)}
là t
ập các đối tượng trong
'
j
K
(trước khi mở rộng) gần với tâm nhóm của chúng
h
ơn với tâm của bất kỳ nhóm nào khác và sau khi mở rộng, mỗi một thuộc tính mới l
th
ỏa mãn bất đẳng thức (2),
1
m l m s
+ ≤ ≤ +
.
b,
'
( )
j
i
sat O
là t
ậ
p t
ấ
t c
ả
các thu
ộ
c tính m
ớ
i l, 1
m l m s
+ ≤ ≤ +
c
ủ
a
đố
i t
ượ
ng
'
j
i
O
th
ỏ
a mãn b
ấ
t
đẳ
ng th
ứ
c (2).
' ' '
w or { | ,
j j j
j i i j i
eakC e O O K O
= ∈
th
ỏ
a b
ấ
t
đẳ
ng th
ứ
c (1) và
'
'
1
| ( ) |
| ( ) | }
j
n
j
k
j
k
i
j
sat O
sat O
n
=
≥
∑
T
ậ
p thu
ộ
c tính c
ủ
a các
đố
i t
ượ
ng trong
'
j
K
th
ỏ
a mãn b
ấ
t
đẳ
ng th
ứ
c (1) tr
ướ
c khi
m
ở
r
ộ
ng; và sau khi m
ở
r
ộ
ng thì ít nh
ấ
t là trung bình c
ộ
ng thu
ộ
c tính m
ớ
i c
ủ
a các
đố
i
t
ượ
ng trong
'
j
K
th
ỏ
a mãn b
ấ
t
đẳ
ng th
ứ
c (2).
c)
Cor or
j j
e StrongC e
= n
ế
u or
j
StrongC e
≠ ∅
, n
ế
u không thì Cor w
j j
e eakCore
= .
'
or \ Cor
j j j
OC e K e
=
là t
ậ
p các
đố
i t
ượ
ng ngoài nhân trong nhóm
'
j
K
.
V
ớ
i m
ỗ
i thu
ộ
c tính m
ớ
i l, 1
m l m s
+ ≤ ≤ +
và m
ỗ
i nhóm
'
j
K
có ít nh
ấ
t m
ộ
t
đố
i
t
ượ
ng th
ỏ
a b
ấ
t
đẳ
ng th
ứ
c (2) t
ươ
ng
ứ
ng v
ớ
i thu
ộ
c tính l.
Đ
ó là
đố
i t
ượ
ng có giá tr
ị
thu
ộ
c
tính l l
ớ
n nh
ấ
t trong s
ố
các
đố
i t
ượ
ng trong
'
j
K
ch
ắ
c ch
ắ
n th
ỏ
a quan h
ệ
(giá tr
ị
l
ớ
n nh
ấ
t
trong m
ộ
t t
ậ
p h
ợ
p l
ớ
n h
ơ
n ho
ặ
c b
ằ
ng giá tr
ị
trung bình c
ủ
a t
ậ
p h
ợ
p
đ
ó). Nh
ư
ng không
đả
m b
ả
o trong nhóm
'
j
K
có
đố
i t
ượ
ng th
ỏ
a quan h
ệ
(2) cho t
ấ
t c
ả
các thu
ộ
c tính m
ớ
i
m+1,…, m+s. N
ế
u có các
đố
i t
ượ
ng nh
ư
v
ậ
y th
ỏ
a b
ấ
t
đẳ
ng th
ứ
c (1) ( or
j
StrongC e
≠ ∅
)
thì theo
đị
nh lý trên, chúng g
ầ
n v
ớ
i tâm nhóm
'
j
f
h
ơ
n v
ớ
i b
ấ
t k
ỳ
m
ộ
t tâm nhóm
'
r
f
nào
khác, 1 ,
r p r j
≤ ≤ ≠
. Sau
đ
ó,
Cor
j
e
s
ẽ
đượ
c l
ấ
y b
ằ
ng v
ớ
i
or
j
StrongC e
, và s
ẽ
là tâm
c
ủ
a nhóm j trong thu
ậ
t toán gia t
ă
ng. Nh
ư
ng n
ế
u or
j
StrongC e
= ∅
thì ta s
ẽ
ch
ọ
n là tâm
nhóm j cho
đố
i t
ượ
ng
ổ
n
đị
nh (không thay
đổ
i) nh
ấ
t trong s
ố
các
đố
i t
ượ
ng trong
'
j
K
.
Các
đố
i t
ượ
ng này ( w
j
eakCore
) có th
ể
ít thay
đổ
i nh
ấ
t trong s
ố
các
đố
i t
ượ
ng trong
or
j
StrongC e
. Tuy nhiên,
đ
i
ề
u này là không ch
ắ
c ch
ắ
n vì: các
đố
i t
ượ
ng trong t
ậ
p “y
ế
u
h
ơ
n” w
j
eakCore
có th
ể
l
ạ
i thích h
ợ
p nh
ư
các
đố
i t
ượ
ng trong
or
j
StrongC e
,
đ
ó là do ta
th
ấ
y
đ
i
ề
u ki
ệ
n (2) trong
đị
nh lý bi
ể
u di
ễ
n
đ
i
ề
u ki
ệ
n
đủ
cho các
đố
i t
ượ
ng trong
'
j
K
là
36
g
ầ
n v
ớ
i
'
j
f
h
ơ
n v
ớ
i tâm nhóm
'
r
f
nào khác, nh
ư
ng không ph
ả
i là
đ
i
ề
u ki
ệ
n
đủ
.
Các nhân c
ủ
a nhóm s
ẽ
là các nhóm m
ớ
i trong ti
ế
n trình phân nhóm gia t
ă
ng.
Thu
ậ
t toán phân nhóm gia t
ă
ng d
ự
a trên phân c
ấ
p nhân và s
ẽ
d
ừ
ng khi
đạ
t
đượ
c
s
ố
các nhóm mong mu
ố
n.
Input:
-
1
{ , , }
n
X O O
= : t
ậ
p m các
đố
i t
ượ
ng
đượ
c phân nhóm tr
ướ
c
đ
ó
- T
ậ
p
' '
1
X'={O , , }
n
O
: t
ậ
p m+s các
đố
i t
ượ
ng m
ở
r
ộ
ng
đượ
c phân nhóm,
'
i
O
có
cùng m thành ph
ầ
n
đầ
u tiên nh
ư
i
O
,
- Kho
ả
ng cách d
E
gi
ữ
a các
đố
i t
ượ
ng trong không gian
đ
a chi
ề
u,
- p: s
ố
l
ượ
ng các nhóm mong mu
ố
n,
-
1
K={ , , }
p
K K
: t
ậ
p các
đố
i t
ượ
ng
đượ
c phân l
ớ
p tr
ướ
c
đ
ó trong X.
Output:
Phân l
ớ
p l
ạ
i
' '
1
K'={ , , }
p
K K
cho các
đố
i t
ượ
ng trong X’.
Thu
ậ
t toán
đượ
c mô t
ả
nh
ư
sau (theo ngôn ng
ữ
“t
ự
a” Pascal):
Begin
For t
ấ
t c
ả
các nhóm K
j
∈K do
Tính Core
j
= (StrongCore
j
≠
∅
) ?
StrongCore
j
:=WeakCore
j
Tính Ocore
j
= K
j
\ Core
j
EndFor
C = ∅ //t
ậ
p h
ợ
p nhóm hi
ệ
n th
ờ
i
For i=1 to p do
If Core
i
≠
∅
C = C ∪ {Core
j
}
EndIf
For t
ấ
t c
ả
O ∈ Ocore
j
do
C = C ∪ {O} //thêm m
ộ
t t
ậ
p h
ợ
p m
ộ
t ph
ầ
n t
ử
vào C
EndFor
EndFor
While |C| > p do
(
* *
, ): arg in( , ) ( , )
u v E u v
u v
C C m C C d C C
=
* *
wne
u v
C C C
= ∪
w
\{ , ) { }
ne
u v
C C C C C
+ +
= ∪
EndWhile
'
K =C
End.
37
Kho
ả
ng cách gi
ữ
a hai nhóm d
E
(C
u
,C
v
)
đượ
c tính nh
ư
sau:
( , )
d ( , )
| | | |
i u j v E i j
E u v
u v
a C b C d a b
C C
C C
∈ ∈
=
×
∑ ∑
Thu
ật toán bắt đầu bằng việc tính nhân các nhóm cũ. Các nhân sẽ là các nhóm
kh
ởi tạo mới trong các bước lặp tiếp theo. Sau đó, thuật toán được thực hiện như thuật
toán HCA.
3.3 So sánh tính hiệu quả của thuật toán HCBIC và thuật toán HCA
Chúng ta so sánh thuật toán HCBIC và HCA theo tiêu chí số lần lặp và độ “chặt”
c
ủa các nhóm đạt được. Định nghĩa độ phân tán DISP (dispersion) trong tiến trình phân
nhóm nh
ư sau:
, ,
2
1
| |
( , )
( )
i j k
k
i j
p
O O K i j
k
K
d O O
C
DISP K
p
∈ >
=
=
∑
∑
V
ới K={K
1
, …, K
p
} là tập hợp nhóm có được sau khi áp dụng thuật toán phân
nhóm. DISP bi
ểu diễn khoảng cách trung bình giữa các đối tượng trong một nhóm.
Kho
ảng cách này là nhỏ hơn và “chặt” hơn so với khoảng cách trong HCA [8].
IV. Kết luận
Áp dụng kỹ thuật phân nhóm vào phân mảnh ngang lớp trong CSDL hướng đối
t
ượng là phương pháp xử lý có hiệu quả trong các bài toán phân mảnh. Đây là một
h
ướng nghiên cứu mới và có giá trị thực tiễn. Trong tương lai, chúng tôi sẽ ứng dụng và
phân tích thu
ật toán trên các CSDL thực nghiệm cụ thể đồng thời nghiên cứu lý thuyết
phân nhóm phân c
ấp sẽ được áp dụng cho các kỹ thuật phân nhóm khác như thế nào.
TÀI LIỆU THAM KHẢO
10. Darabant, A.S., Campan, A., Semi-supervised learning techniques: kmeans clustering in
OODB Fragmentation, IEEE International Conference on Computational Cybernetics
ICCC 2004, Vienna University of Technology, Austria, August 30 - September 1 (2004),
333–338.
11. Darabant, A.S., Campan, A., Hierarchical AI Clustering for Horizontal Object
Fragmentation, In Proc. of Int. Conf. of Computers and Communications, Oradea, May
(2004), 117–122.
12. Darabant, A.S., Campan, A., AI Clustering Techniques: a New Approach to Object
Oriented Database Fragmentation, in Proceedings of the 8th IEEE International
Conference on Intelligent Engineering Systems, Cluj Napoca, (2004), 73–78.
38
13. Darabant, A.S., Campan, A., Cret, O., Hierarchical Clustering in Object Oriented Data
Models with Complex Class Relationships, in Proceedings of the 8th IEEE International
Conference on Intelligent Engineering Systems, Cluj Napoca, (2004), 307–312.
14. S¸erban, G., Campan, A., Core Based Incremental Clustering, Studia Universitatis
“Babe¸s-Bolyai”, Informatica, XLXI(2), (2005), 89–96.
15. S¸erban, G., Campan, A., Incremental Clustering Using a Core-Based Approach, in Proc.
of the 20th International Symposium on Computer and Information Sciences (ISCIS’05),
Istanbul, Turkey, 2005.
16. S. Aeberhard, D. Coomans, and O. de Vel. The classification performance of rda. Tech.
Rep. Dept. of Computer Science and Dept. of Mathematics and Statistics, James Cook
University of North Queensland, (1992), 92-01.
17. Gabriela S¸erban and Alina Cˆampan. A New Core-Based Method For Hierarchical
Incremental Clustering. Proceedings of the Seventh International Symposium on
Symbolic and Numeric Algorithms for Scientific Computing, 2005 (SYNASC’05).
18. C. Manning and H. Schutze. Foundation of statistical natural language processing.
MIT, 1999.
19. G. Serban and A. Campan. Core based incremental clustering. Studia Universitatis
“Babes¸-Bolyai”, Informatica, L(1), (2005), 89–96.
20. Alina Campan, Adrian Sergiu Darabant, Gabriela Serban. Clustering techniques for
adaptive horizontal fragmentation in object oriented databases. Proceedings of the
International Conference on Theory and Application of Mathematics and Informatics
ICTAMI 2005 - Alba Iulia, Romania.
APPLYING CLUSTERING TECHNIQUES FOR
HORIZONTAL FRAGMENTATION IN OBJECT ORIENTED DATABASES
Nguyen Thi Huong Giang
College of Pedagogy, Hue University
SUMMARY
In this paper, we introduce an incremental method to apply clustering techniques for
horizontal fragmentation in object oriented databases which makes current fragments adapt
with new applications; and propose a clustering method based on an hierarchical
agglomerative approach, called Hierarchical Core Based Incremental Clustering (HCBIC), that
is capable of the re-partition of the objects set, when the attribute sets increase.