Khai phá dữ liệu là một lĩnh vực vẫn còn khá mới mẻ, lý thú. Luận văn đã trình
bày, một số vấn đề cơ bản nhất, các phương pháp cơ bản để khai phá dữ liệu, đặc biệt
trình bày chi tiết, làm rõ vấn đề khai phá luật kết hợp. Phương pháp khai phá dữ liệu
có thể là: phân lớp, hồi quy, cây quyết định, suy diễn, quy nạp, K-láng giềng gần,
các phương pháp trên có thể áp dụng trong dữ liệu thông thường và trên tập mờ.
78 trang |
Chia sẻ: lylyngoc | Lượt xem: 3383 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu Luận văn Khai phá dữ liệu ứng dụng trong đào tạo, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
bỏ mục có
support < minsup
C2
2 - itemset
{A, B}
{A, C}
{A, E}
{B, C}
{B, E}
{C, E}
C2
2 - itemset
{A, B}
{A, C}
{A, E}
{B, C}
{B, E}
{C, E}
Tỉa
L1
1 - itemset Count-support
{A} 2 - 50%
{B} 3 – 75%
{C} 3 – 75%
{E} 3 - 75%
Kết nối L1 & L1
L2
2 - itemset Count-support
{A, C} 2 – 50%
{B, C} 2 – 50%
{B, E} 3 – 75%
{C, E} 2 – 50%
Kết nối L2 & L2
Tỉa
C3
3 - itemset Count- support
{B, C, E} 2 - 50%
Quét toàn bộ D
C2
2 - itemset
{A, B}
{A, C}
{A, E}
{B, C}
{B, E}
{C, E}
Quét toàn bộ D
C2
2 - itemset Count-support
{A, B} 1 – 25%
{A, C} 2 – 50%
{A, E} 1 – 25%
{B, C} 2 – 50%
{B, E} 3 – 75%
{C, E} 2 – 50%
Xóa bỏ mục có
support < minsup
Xóa bỏ mục có
support < minsup L3
3 - itemset Count- support
{B, C, E} 2 - 50%
3 - itemset
{B, C, E}
3 - itemset
{B, C, E}
43
Một số biến thể của giải thuật Apriori
Giải thuật Apriori_TID là phần mở rộng theo hướng tiếp cận cơ bản của giải
thuật Apriori. Thay vì dựa vào cơ sở dữ liệu thô, giải thuật AprioriTID biểu diễn bên
trong mỗi giao dịch bởi các ứng viên hiện hành.
1. L1= {Large 1-itemset};
2. C’1 = Database D;
3. for (k=2; Lk-1 ; k++) do
4. Begin
5. Ck = apriori_gen(Lk-1);
6. C’k = ;
7. for tất cả t C’k-1 do
8. begin
// xác định tập ứng viên trong Ck chứa trong giao dịch với định //danh t.
Tid (Transaction Code)
9. Ct = c Ck | (c-c[k]) t.Set_of_ItemSets ^ (c-c[k-1]
t.Set_of_ItemSets
10. for những ứng viên c Ct do c.count ++;
11. if (Ct) then C’k+=
12. end
13. Lk = c Ck | c.count minsup;
14. End
15. return = kLk;
Thuật toán này cũng sử dụng hàm apriori_gen để sinh ra các tập ứng cử viên cho
mỗi giai đoạn. Nhưng thuật toán này không dùng CSDL D để đếm các support với các
giai đoạn k > 1 mà sử dụng tập C’k. Mỗi phần tử của C’k có dạng , trong
đó mỗi Xk là một tập phổ biến k_itemset tiềm năng trong giao dịch Tid. Khi k = 1, C’k
tương ứng với D, trong đó mỗi item i được coi là một itemset {i}. Với k>1, C’k được
sinh ra bởi C’k+= . Phần tử của C’k tương ứng với giao dịch t là <t.Tid,
{c | c chứa trong t}>. Nếu một giao dịch không chứa bất kỳ tập ứngviên k_itemset
nào thì C’k sẽ không có một điểm vào nào cho giao dịch này. Do đó, số lượng điểm
vào trong C’k có thể nhỏ hơn số giao dịch trong CSDL, đặc biệt với k lớn. Hơn nữa,
với các giá trị k khá lớn, mỗi điểm vào có thể nhỏ hơn giao dịch tương ứng vì một số
ứng viên đã được chứa trong giao dịch. Tuy nhiên, với các giá trị k nhỏ, mỗi điểm vào
có thể lớn hơn giao dịch tương ứng vì một một điểm vào trong C’k bao gồm tất cả các
ứng viên k_itemset được chứa trong giao dịch.
Giải thuật AprioriHybrid kết hợp cả hai hướng tiếp cận trên. Ngoài ra còn có
một số các giải thuật tựa Apriori(TID), chúng được định hướng để cài trực tiếp trong
SQL.
44
Giải thuật DIC là một biến thể khác nữa của giải thuật Apriori. Giải thuật DIC
làm giảm đi khoảng phân biệt nghiêm ngặt giữa việc đếm và việc phát sinh các ứng
viên. Bất kỳ ứng viên nào tới được ngưỡng minsupp, thì giải thuật DIC bắt đầu phát
sinh thêm các ứng viên dựa vào nó. Để thực hiện điều này giải thuật DIC dùng một
prefix-tree (cây tiền tố). Ngược với hashtree, mỗi nút (nút lá hoặc nút trong) của
prefix-tree được gán một ứng viên xác định trong tập phổ biến. Cách sử dụng cũng
ngược với hashtree, bất cứ khi nào tới được một nút ta có thể khẳng định rằng tập item
đã kết hợp với nút này trong giao tác đó. Hơn nữa, việc xác định độ hỗ trợ và phát sinh
ứng viên khớp nhau sẽ làm giảm đi số lần duyệt cơ sở dữ liệu.
2.3.2.Kỹ thuật DFS
Giả sử việc đếm các thể hiện được thực hiện trên tập các ứng viên có kích thước
hợp lý, với mỗi tập các ứng viên đó thì cần một thao tác duyệt cơ sở dữ liệu. Chẳng
hạn như, giải thuật Apriori dựa vào BFS thực hiện duyệt cơ sở dữ liệu mỗi k-kích
thước ứng viên một lần. Khi thực hiện tìm kiếm ưu tiên theo chiều sâu (DFS) tập ứng
viên chỉ gồm chỉ gồm một nút của cây từ phần 2.2.2. Một điều hiển nhiên là nếu phải
thực hiện duyệt cơ sở dữ liệu cho mỗi nút thì tổng chi phí kết quả thật khổng lồ. Vì thế
việc kết hợp DFS với việc đếm các thể hiện là không thật sự thích hợp.
2.5. Thuật toán AIS
2.5.1. Bài toán đặt ra
Đầu tiên, duyệt toàn bộ CSDL để tìm tất cả các tập mục phổ biến L1.
Tiếp theo, chừng nào Lk-1 ! = ( k >= 2)
1. Tìm tập các ứng cử viên bằng cách quét toàn bộ CSDL, với mỗi giao dịch,
ta tìm tổ hợp chập k của các mục có trong giao dịch và xác định các mục
trong tổ hợp này có là phổ biến hay không? Nếu không phải thì bỏ qua. Trái
lại, ta bổ sung tổ hợp đó vào tập hợp ứng cử viên bằng cách: kiểm tra xem tổ
hợp này đã nằm trong tổ hợp ứng cử viên hay chưa? Nếu chưa thì bổ sung
thêm và tăng độ hỗ trợ lên 1. Trái lại, tăng độ hỗ trợ của tổ hợp tương ứng
trong tập ứng cử viên thêm 1.
2. Duyệt toàn bộ các ứng cử viên, loại bỏ tất các tổ hợp có độ hỗ trợ nhỏ hơn
độ hỗ trợ yêu cầu của người sử dụng.
Cuối cùng ta được tất cả các tập mục phổ biến thoả mãn, có độ hỗ trợ tối thiểu
lớn hơn hoặc bằng độ hỗ trợ tối thiểu mà người sử dụng yêu cầu.
45
Thuật toán hoàn toàn sử dụng chiến lược “vét cạn”, xem xét toàn bộ các tập mục
phổ biến bằng cách sinh tổ hợp tập các mục và kiểm tra độ hỗ trợ.
2.5.2. Thuật toán AIS
Input: CSDL minsup
Output: Các tập mục phổ biến
1. L1={ Các tập mục phổ biến }.
2. For ( k=2;Lk-1 ; k++ )
3.{ Ck = ;
4. for ( tất cả các giao dịch t D )
5. Lt = subSet (Lk-1; t);
6. // Các tập mục phổ biến thuộc Lk-1 chứa trong giao dịch t
7. for (tất cả các tập mục phổ biến lt Lt)
8. Ct = tăng lt thêm một mục có trong giao dịch t;
9. for (Các ứng cử viên c Ct )
10. if ( c Ck) tăng biến đếm của c thêm l cho mục tương ứng thuộc
Ck
11. else add c vào Ck và tăng biến đếm tương ứng thêm 1)
12.
13.
14. Lk = c Ck c.count minsup
15.
16.return L = kLk
Ví dụ minh hoạ thuật toán AIS
Cho CSDL trong bảng sau. Giả sử với độ hỗ trợ tối thiểu là 2 giao dịch
CSDL L1
TID Các mục Tập mục Độ hỗ trợ
100 1, 3, 4 1 2
200 2, 3, 5 2 3
300 1, 2, 3, 5 3 3
400 2, 5 5 3
C2 L2
Tập mục Độ hỗ trợ Tập mục Độ hỗ trợ
1, 3 2 1, 3 2
1, 4 1 2, 3 2
46
3, 4 1 2, 5 3
2, 3 2 3, 5 2
2, 5 3
3, 5 2
1, 2 1
1, 5 1
C3 L3
Tập mục Độ hỗ trợ Tập mục Độ hỗ trợ
1,3,4 1 2,3,5 2
2,3,5 2
1,2,3 1
1,2,5 1
1,3,5 1
C4
Tập mục Độ hỗ trợ
1,2,3,5 1
Bảng 2.7. Ví dụ thuật toán AIS
Theo bước 1 của thuật toán, ta thu được L1 là tập gồm các mục có số lần xuất
hiện (độ hỗ trợ) lớn hơn hoặc bằng 2. Trong các bước từ 2 đến 14 ta thu được tập ứng
cử viên C2 là tập tất cả các tập có hai mục (2-itemset) và độ hỗ trợ tương ứng. Bước
13, ta thu được tập phổ biến L2 từ C2, L2 là tập các 2 itemset có độ hỗ trợ lớn hơn hoặc
bằng 2. Lặp lại các bước từ 2 đến 14 ta thu được tập các ứng cử viên C3 gồm tập tất cả
các tập có ba mục có độ hỗ trợ lớn hơn hoặc bằng 2. Tương tự, ta thu được C4 là tập có
bốn mục L4 bằng rỗng. Như vậy, tập các tập mục phổ biến mà ví dụ trên ta thu được
là: 1, 2, 3, 5, 1,3, 2,3, 2,5, 3,5, 2,3,5}. Thuật toán kết thúc.
47
2.6. Thuật toán SETM
2.6.1. Bài toán đặt ra
Thuật toán SETM được đề xuất do mong muốn dùng SQL để tìm các tập mục
phổ biến.
1. Đầu tiên, duyệt toàn bộ CSDL để tìm tất cả các tập mục phổ biến L1 và các mục
phổ biến cùng với TID của nó L1' được xếp theo TID.
2. Tiếp theo chừng nào Lk-1!= (k >= 2)
3. Tìm tập các ứng cử viên bằng cách quét toàn bộ CSDL, với mỗi giao dịch ta tìm tổ
hợp chập k của các mục có trong giao dịch và xác định các mục cùng với TID
trong tổ hợp này có thuộc L'k-1 ? Nếu không phải thì bỏ qua. Trái lại, ta bổ sung tổ
hợp đó vào tập ứng cử viên đồng thời lưu một bản sao của tập mục ứng cử viên
cùng với TID của nó.
4. Sắp xếp lại các ứng cử viên theo tập mục.
5. Xoá tất cả các ứng cử viên có độ hỗ trợ nhỏ hơn độ hỗ trợ do người sử dụng đề ra.
Kết quả lưu vào Lk'.
6. Xếp lại Lk' theo TID.
7. Cuối cùng ta được tất cả các tập mục phổ biến thoả mãn, có độ hỗ trợ tối thiểu lớn
hơn hoặc bằng độ hỗ trợ tối thiểu mà người sử dụng yêu cầu.
2.6.2. Thuật toán SETM
Input: CSDL D, minsup
Ouput: Tập các tập mục phổ biến.
1.L1 = Các mục phổ biến
2.L1' = Các mục phổ biến cùng các TID của nó được xếp theo TID
3.for (k=2; Lk-1 ; k ++)
4.C'k = ;
5. for (tất cả các giao dịch t D)
6. Lt = l L'k-1 \I.TID = t.TID
// Các tập có ( k-1) - itemset phổ biến có trong giao dịch t
7.for (tất cả các tập mục phổ bíên lt Lt)
8. Ct = tăng lt thêm một mục có trong t;
// Các ứng cử viên có trong t
9. C'k + = \ c C1 ;
10.
11.
48
12. sort C'k theo các tập mục
13. delete các mục c C'k có c.count < minsup đưa vào L'k;
14. Lk = \ l L'k; kết hợp với bước 13
15. sort L'k theo TID
16.
17.return L = kLk';
Giống như AIS thuật toán SETM cũng sinh ra các ứng cử viên dựa trên các giao
dịch đọc được từ CSDL. Vì thế, nó sinh ra và đếm mỗi tập mục ứng cử viên mà thuật
toán AIS sinh ra. Tuy nhiên, để dùng phép nối (JOIN) chuẩn của SQL. SETM chia sự
phát sinh ứng cử viên từ việc đếm. Nó lưu một bản sao của tập mục ứng cử viên cùng
với TID của việc phát sinh giao dịch trong cấu trúc tuần tự (bước 9). Cuối mỗi bước,
đếm độ hỗ trợ của các tập mục ứng cử viên được xác định bởi việc xếp (bước 12) và
việc kết hợp lại cấu trúc tuần tự này (bước 13). SETM ghi nhớ các TID của việc phát
sinh các giao dịch với các tập mục ứng cử viên. Để tránh việc thao tác trên tập con, nó
dùng thông tin này để xác định các tập mục lớn chứa trong giao dịch được đọc (bước
6). L'k C'k và thu được bởi việc xóa các ứng cử viên này mà không có độ hỗ trợ tối
thiểu (bước 13). Giả sử rằng CSDL được xếp thứ tự TID, SETM có thể dễ dàng tìm
các tập mục phổ biến được chứa trong một giao dịch trong bước tiếp theo bằng việc
xếp L'k theo TID (bước 15). Thực tế, nó cần thăm hỏi mỗi thành viên của L'k chỉ một
lần theo thứ tự TID và việc sinh ứng cử viên ở các bước 5 đến 11 có thể thực hiện nhờ
phép toán Merge-join.
Nhược điểm chính của thuật toán này là dựa vào số các tập ứng cử viên C'k. Khi
với mỗi tập các mục ứng cử viên có một TID kết hợp với nó, nó yêu cầu nhiều không
gian để lưu trữ số lượng lớn các TID. Hơn nữa, khi độ hỗ trợ của tập mục ứng cử viên
được tính vào cuối mỗi bước, C'k không theo thứ tự. Vì thế, việc xếp lại các mục là cần
thiết (bước 12). Sau đó, các tập mục ứng cử viên được cắt tỉa bằng việc loại bỏ các tập
mục ứng cử viên không thoả mãn ràng buộc độ hỗ trợ. Một sắp xếp khác trên TID là
cần thiết đối với tập kết qủa L'k (bước 15) trước khi nó có thể được sử dụng để phát
sinh các ứng cử viên trong bước tiếp theo.
Ví dụ minh hoạ thuật toán SETM
Xét CSDL cho trong bảng sau. Giả sử với độ hỗ trợ tối thiểu là 2 giao dịch
CSDL L1 L’1
TID Các mục Tập mục Độ hỗ trợ TID Tập mục
100 1, 3, 4 {1} 2 100 {1}
200 2, 3, 5 {2} 3 100 {3}
49
300 1, 2, 3, 5 {3} 3 200 {2}
400 2, 5 {5} 3 200 {3}
200 {5}
300 {1}
300 {2}
300 {3}
300 {5}
400 {2}
400 {5}
C’2 L2 L’2
TID Tập mục Tập mục Độ hỗ trợ TID Tập mục
100 {1, 3} {1, 3} 2 100 {1, 3}
100 {1, 4} {2, 3} 2 200 {2, 3}
100 {3, 4} {2, 5} 3 200 {2, 5}
200 {2, 3} {3, 5} 2 200 {3, 5}
200 {2, 5} 300 {1, 3}
200 {3, 5} 300 {2,3}
300 {1, 2} 300 {2, 5}
300 {1, 3} 300 {3, 5}
300 {1, 5} 400 {2, 5}
300 {2, 3}
300 {2, 5}
300 {3, 5}
400 {2,5}
L'3 L3
TID Tập mục Tập mục Độ hỗ trợ
50
200 {2, 3, 5} {2, 3, 5} 2
300 {2, 3, 5}
C'4 L4 = L'4 =
TID Tập mục
300 {1, 2, 3, 5}
Bảng 2.8: Ví dụ thuật toán SETM
Như vậy, tập các tập mục phổ biến mà ví dụ trên thu được là:
L = 1, 2,3,5,1, 3,2, 3,2, 5,3, 5,2, 3, 5.
Thuật toán kết thúc.
2.7. Thuật toán CHARM[9]
2.7.1. Tư tưởng thuật toán CHARM
2.7.1.1. Cơ sở lý thuyết
Cho quan hệ nhị phân R I x X. Cho R I & R T, xét các ánh xạ: t: I T,
t(X) = {yT/xX, x R y}; i:TI, i(Y) = {xl/yY, x R y}. Một ánh xạ t(X) là tập
tất cả các giao dịch chứa tập mục X, tương tự i(Y) là tập mục tất cả các giao dịch chứa
tập mục Y.
Định nghĩa một kết nối Galois giữa P(I) và P(T) tương ứng là các tập khả năng
của l và T. Chúng ta biểu diễn cặp (X, t(X) là X x t(X) và cặp (i(X),Y) là i(Y) x Y kết
nối Galois thoả mãn các thuộc tính sau (trong đó X, X1, X2 P(I) và Y,Y1, Y2 P(T):
X X2 t(X1) t(X2).
Y1 Y2 i(Y1) i(Y2).
X i(t(X)) và Y i(t(Y)).
Cho s là một tập. Hàm c: P(S)P(S) là một toán tử đóng trên S nếu với X,Y
S, c thoả mãn các thuộc tính sau:
Extention: X c(X)
Monotonicity: Nếu X Y, thì c(X) c(Y)
Idempotency: c(c(X)) = c(X)
51
Một tập con X của S được gọi là đóng nếu c(X) =X
Cho X Y và Y T. Cho Cit (X) biểu diễn ánh xạ hợp i0t(X) = i(t(X)) và Cit (Y)=
i0i(Y) = t(i(Y)). Thì Cit :P(I) P(I) và Cti :P(T) P(T) là hai toán tử đóng trên các tập
mục và các tập giao dịch tương ứng. Một số định nghĩa :
Định nghĩa tập mục đóng: X được gọi là tập mục đóng nếu X = Cit(X)
Định nghĩa tập mục đóng phổ biến: X được gọi là tập mục đóng phổ biến
nếu X là tập mục đóng và support(X) minsup.
Định nghĩa tập giao dịch đóng: Y là tập giao đóng nếu Y=Cit(Y)
Các ánh xạ Cit và Cti là các toán tử đóng, thoả mãn 3 thuộc tính Extension,
monotonicity và Idempotency.
Cho f: P(I) N là ánh xạ 1-1 từ các tập mục sang số nguyên. Với bất kỳ hai tập
mục X1 và X2 nào, chúng ta nói X1 X2 f(X1) f(X2). Hàm f xác định thứ tự toàn
thể trên tập tất cả các tập mục.
Ví dụ: nếu f biểu diễn theo thứ tự các từ điển, thì tập mục AC < AD. Khi với mẫu
khác, nếu f sắp xếp các tập mục theo thứ tự tăng dần độ hỗ trợ của chúng, thì AD <
AC nếu độ hỗ trợ của AD nhỏ hơn độ hỗ trợ của AC.
Giả sử rằng chúng ta đang xử lý nhánh X1 t(X1) và chúng ta muốn kết nối với
anh em của nó X2 t(X2). Điều này là X1 X2 (dưới dạng một thứ tự phù hợp f).
Việc tính toán trong CHARM dựa trên các thuộc tính dưới đây:
1. Nếu t(X1) = t(X2), thì t(X1 X2) = t(X1) t(X2) = t(X1) = t(X2). Vì thế chúng ta có
sự xuất hiện của X1 bằng X1 X2 và xoá X2 được xem xét từ xa, vì bao đóng của
X2 được đồng nhất với bao đóng của X1 X2. Mặt khác, chúng ta coi như X1 X2
là một tập mục hợp.
2. Nếu t(X1) t(X2) thì t(X1 X2) = t(X1) t(X2) = t(X1) t(X2). Ở đây ta có thể
thay mọi sự xuất hiện của X1 bằng X1 X2, vì nếu X1 xuất hiện trong bất kỳ giao
dịch nào, thì X2 cũng xuất hiện. Nhưng khi t(X1) t(X2), chúng ta không thể xóa
X2. Nó phát sinh ra bao đóng khác.
3. Nếu t(X1) t(X2) thì t(X1 X2) = t(X1) t(X2) = t(X1) t(X2). Trong trường hợp
này, chúng ta thay thế mọi sự xuất hiện của X2 bằng X1 X2, vì bất chỗ nào X2
xuất hiện thì X1 cũng xuất hiện. Tuy nhiên, X1 là kết quả của bao đóng khác và nó
phải được giữ lại.
52
4. Nếu t(X1) t(X2) thì t(X1 X2) = t(X1) t(X2) t(X1) t(X2). Trong trường hợp
này, không được loại bỏ cả X1 và X2 dẫn đến các bao đóng khác nhau.
2.7.2.2. Bài toán đặt ra
CHARM thực hiện trên cả không gian các tập phổ biến (itemset) và không gian
các tập định danh (TIDset). CHARM không tìm tất cả các tập con có thể của tập mục
mà thuật toán kết hợp tìm tập đóng hiệu quả hơn (bottom-up). Nếu CSDL cảu tập mục
là lớn và tập mục phổ biến là dày thì CHARM duyệt cả không gian tập mục và tập
định danh. Đồng thời sẽ bỏ qua nhiều mức để đi tìm tập phổ biến đóng thay cho việc
tính toán nhiều tập con không đóng. Hơn nữa, CHARM sử dụng hai kỹ thuật cắt tỉa:
1. Tỉa các ứng cử viên nếu tập con của nó không phổ biến đồng thời tỉa các
nhánh dựa trên tính chất không đóng (non-closure-property).
2. Bất kỳ tập không đóng nào cũng đều bị tỉa.
CHARM không sử dụng cấu trúc dữ liệu cây băm (hash tree), phép toán cơ sở
được sử dụng là hợp 2 tập mục và giao 2 tập định danh. Thuật toán bắt đầu bằng việc
khởi tạo các nút để kiểm tra các mục đơn phổ biến và các tập giao dịch của chúng
trong dòng 1. Tính toán chính được thực hiện trong CHARM-EXTEND, nó trả về các
tập mục đóng phổ biến C.
CHARM-EXTEND có trách nhiệm kiểm tra mỗi nhánh có khả năng. Nó rút ra
mỗi cặp tập mục – tập giao dịch (itemset-tidset) trong tập nút hiện tại Node (Xi t(Xi),
dòng 3), và kết nối nó với các cặp khác mà đứng sau nó (Xi t(Xi),dòng 5) theo thứ tự
tuyệt đối f. Việc kết nối các cặp itemset-tidsset được tính toán trong. Thủ tục
CHARM-PROPERTY kiểm tra tập kết quả với độ hỗ trợ yêu cầu và cũng áp dụng 4
thuộc tính được thảo luận ở trên. Lưu ý rằng thủ tục này có thể thay đổi tập nút hiện tại
bằng việc xoá các cặp itemset-tidset mà đã được chứa trong các cặp đó. Nó cũng chèn
các cặp phổ biến con mới được sinh ra trong tập các nút mới New. Nếu tập này khác
rỗng chúng ta thực hiện lại quá trình theo chiều sâu (dòng 8). Sau đó, chúng ta chèn
tập mục mở rộng có thể có X của Xi trong tập các tập mục đóng, vì nó không thể được
thực hiện; ở giai đoạn này bất kỳ tập mục đóng đang chứa Xi, đã từng được sinh ra, sau
đó chúng ta quay lại dòng 3 để xử lý nhánh tiếp theo (không được tỉa). Thủ tục
CHARM-PROPERTY kiểm tra đơn giản nếu cặp mới là phổ biến. Sau khi nó kiểm tra
mỗi cặp itemset-tidset với 4 thuộc tính cơ bản, việc mở rộng các tập mục hiện có, xoá
một nhánh được gộp từ các nút hiện có, hoặc việc chèn các cặp mới trong tập nút cho
bước tiếp theo (theo chiều sâu).
53
2.7.2. Thuật toán CHARM
CHARM (R I T, minsup)
1.Nodes = {Ij t(Ij): Ij I t(Ij) minsup }
2.CHARM-EXTEND (Nodes, C)
3.For (mỗi Xi t(Xj) Nodes)
4. NewN = & X = Xi
5. for (mỗi Xj t(Xj) Nodes với f(j) > f(i))
6. X= X Xj và Y= t(Xi) t(Xj)
7. CHARM-PROPERTY( Nodes, NewN)
8. if (NewN ) CHARM-EXTEND (NewN)
9. C=C X;//nếu X chưa được gộp
CHARM-PROPERTY( Nodes, NewN)
10. if ( || Y || minsup)
11. if(t(Xi) = t(Xj)) // Thuộc tính 1
12. Loại Xj ra khỏi Nodes
13. Thay thế tất cả các Xi bởi X
14. else if (t(Xi) t(Xj)) // Thuộc tính 2
15. Thay thế tất cả các Xi bởi X
16. else (if t(Xi) t(Xj)) // Thuộc tính 3
17. Xoá tất cả các Xj khỏi Nodes
18. Bổ sung X Y vào NewN
19. else if (t(Xi) t(Xj)) // Thuộc tính 4
20. Bổ sung X Y vào NewN
Ví dụ minh hoạ thuật toán CHARM
Cho I ={A, C, D, T, W } và T = {1, 2, 3, 4, 5, 6}
Giao dịch Các mục
1 {A, C, T, W}
2 {C, D, W }
3 {A, C,T, W }
4 {A, C, D, W }
5 {A, C, D, T, W }
6 {C, D, T }
Bảng 2.9: Tập các giao dịch trong ví dụ thuật toán CHARM
Từ bảng giao dịch trên, ta thu được tập mục phổ biến với độ hỗ trợ tối thiểu là 3
giao dịch:
54
Tập mục Hỗ trợ
{C} 6
{{W}, {C, W }} 5
{{A}, {D}, {T}, {A,C},{A,W}, 4
{{A,T},{D,W},{T,W},{A,C,T},{A,T,W},{C,T,W},{C,D,W},{
A,C,T,W}
3
Bảng 2.10: Tập mục phổ biến trong ví dụ minh hoạ thuật toán CHARM
a) Sắp xếp các tập mục theo thứ tự từ điển
Chú ý: Để tiện cho mô tả chúng ta qui ước viết: ví dụ: 1345 tương ứng là
{1,3,4,5}, ACD tương ứng với {A,C,D}
Hình 2.11: Thuật toán CHARM sắp xếp theo thứ tự từ điển
Ban đầu ta có 5 nhánh tương ứng với 5 mục và các tập giao dịch từ CSDL
trên(minsup=3). Để phát sinh con của mục A(hoặc cặp A x{1,3,4,5}) chúng ta cần nối
nó với tất cả các anh em đi sau nó. Khi ta nối 2 cặp X1 x t(X1) và X2 x t(X2). Cặp kết
quả đưa ra là (X1 X2) x (t(X1) t(X2)). Mặt khác, chúng ta cần thực hiện giao của
các tập giao dịch tương ứng mỗi khi chúng ta nối hai hoặc nhiều hơn hai mục.
Khi chúng ta thử mở rộng A với C, chúng ta thấy rằng thuộc tính hai là đúng.
Nghĩa là, t(A) = {1,3,4,5} {1,2,3,4,5,6} =t(C). Vì thế, chúng ta có thể xoá A và thay
bằng AC. Kết nối A với D kết quả là tập không phổ biến {A,C,D} bị cắt tỉa. Kết nối
với T kết quả cặp{A,T,C} x {1,3,5} theo thuộc tính 4 không bị tỉa. Khi thử kết nối A
D x 2456
CD x 2456 CT x 1356 CW x 12345
CTW x 135
A x 1345
AC x 1345
ACW x 1345
C x 123456 Tx 1356 W x 12345
ACD x 45 ACTx 135
ACTW x 135
CDT x 56 CDW x 245
{}
55
với W ta thấy rằng t(A) t(W) theo thuộc tính 2 ta thay A bằng {A,W}. Do đó {A,C}
thành {A,C,W} và {A,C,T} thành {A,C,T,W}.
Tiếp theo ta bắt đầu xử lý nhánh C, ta kết nối C với D, ta thấy thuộc tính có 3
hiệu lực, nghĩa là: t(X) t(D), tức là mỗi khi D xuất hiện thì C cũng xuất hiện. Vì thế,
D có thể được loại bỏ và toàn bộ nhánh D bị tỉa; còn {C,D} thay bằng D. Cũng như
vậy, ngữ cảnh tương tự xảy ra với T và W. Cả 2 nhánh bị tỉa và được tỉa thay thế bởi
{C,T} và {C,W} là con của C.Tiếp tục duyệt theo chiều sâu,chúng ta xử lý tiếp với
nút{C,D}.Nối{C,D} với{C,T} kết quả là tập mục không phổ biến {C,D,T} bị cắt tỉa.
Nối {C,D} với {C,W} kết quả là {C,D,W} theo thuộc tính 4 không bị loại bỏ. Tương
tự, nối {C,T} và {C,W} thành {C,T,W}.Lúc này các nhánh đã được xử lý.
Cuối cùng, chúng ta xoá {C,T,W} x {1,3,5} vì nó được chứa trong{A,C,T,W} x
{1,3,5}. Qua 10 bước xác định được tất cả 7 tập mục phổ biến đóng.
b) Sắp xếp các tập mục theo độ hỗ trợ tăng dần
Hình 2.12: Sắp xếp theo độ hỗ trợ tăng dần
Nhận xét:
Tính đúng đắn: Thuật toán CHARM tìm ra tất cả các tập mục phổ biến đóng.
Thời gian tính toán: Thời gian tính toán của thuật toán CHARM là O(l*|C|) trong
đó C là các tập mục phổ biến đóng; l là độ dài trung bình của tập định danh.
Độ phức tạp: Số lần duyệt CSDL của CHARM là O(|C|/(*|I|)) trong đó: C là
các tập mục phổ biến đóng; {I} là tập các mục và là độ lớn phân vùng CSDL trong
bộ nhớ.
{ }
A x 1345
AW x 1345
ACW x 1345
T x 1356
CT x 1356
W x 12345
CW x 12345
C x 123456
AT x 135
ATW x 135
ACTW x 134
AD x 45 DT x 56
D x 2456
CD x 2456
DW x 245
CDW x 245
TW x 135
CTW x 135
56
2.8. Kết luận
Chương này đã trình bày về lý thuyết luật và luật kết hợp, trình bày một số vấn
đề cơ bản của việc khai phá dữ liệu dùng luật kết hợp. Trình bày một số thuật toán tiêu
biểu khai phá luật kết hợp. Thuật toán kinh điển Apriori tìm tập mục phổ biến theo
cách sinh các ứng cử, biến thể của thuật toán Apriori là thuật toán Apriori_Tid, và
thuật toán AIS, SETS, CHARM. Độ phức tạp thuật toán tìm các tập mục phổ biến là
khó, thời gian tìm các tập mục phổ biến là tuyến tính với kích thước của CSDL vì các
CSDL thường là rất thừa và các thuật toán đã dùng một số kỹ thuật tỉa hiệu quả.
57
Chương 3
ỨNG DỤNG KHAI PHÁ LUẬT KẾT HỢP TRONG ĐÀO TẠO
3.1. Bài toán
Hiện nay trường Đại học Dân lập Hải Phòng đã bắt đầu thực hiện chương trình
đào tạo theo chế tín chỉ, nên đầu mỗi học kỳ sinh viên phải tiến hành đăng ký môn
học. Để tạo điều kiện cho việc chọn đăng ký môn học cho mỗi học kỳ phòng Đào tạo
sẽ phải lên danh sách các lớp học kèm theo thời khóa biểu. Bên cạnh đó để hỗ trợ thêm
cho sinh viên có thể đăng ký môn học được tốt hơn thì các cán bộ phòng đào tạo và
cán bộ tư vấn học tập phải tổ chức dữ liệu một cách khoa học rồi tiến hành trích rút
thông tin dựa theo kết quả học tập của các môn học kỳ trước đó. Để có thể hỗ trợ sinh
viên lựa chọn ngành nghề, lựa chọn môn học, hỗ trợ sau tốt nghiệp, đánh giá kết quả
học tập của sinh viên phải dựa trên cơ sở hệ thống điểm mà sinh viên đã đạt được. Đây
là cơ sở mang tính khoa học.
Để có được những đánh giá mang tính thuyết phục, thì cần phải có phương pháp
khai phá dữ liệu có hiệu quả, từ đó để đưa ra những kết luận có cơ sở khoa học, mang
nhiều ý nghĩa thực tiễn. Muốn vậy chúng ta phải có dữ liệu tương đối đầy đủ. Trên cơ
sở rút ra những luật kết hợp, tìm ra được các luật mạnh để có thể phân tích dựa trên dữ
liệu điểm sinh viên.
Hình 3.1: Trường Đại học Dân lập Hải phòng
Trong phạm vi luận văn này, tác giả sử dụng các kỹ thuật khai phá dữ liệu đối
với CSDL điểm của sinh viên trường Đại học Dân lập Hải phòng nhằm giúp cho sinh
viên có thể lựa chọn tốt môn học, ngành nghề, giúp cho cán bộ đào tạo đánh giá được
kết quả học tập của sinh viên, và hiệu quả đào tạo thông qua thuật toán Apriori đã trình
bày ở phần trước.
58
3.2. Đặc tả dữ liệu
Một đặc điểm mang tính thực tế là các item không đơn thuần chỉ được xét là “có”
hay “không” trong khi đếm support mà mỗi item được kèm theo một trọng số mô tả
mức quan trọng của item đó. Các item ta vẫn xem xét thường ở dạng Boolean. Chúng
mang giá trị là “1” nếu item có mặt trong giao dịch và “0” nếu ngược lại. Các bài toán
khai phá như trên người ta vẫn gọi là khai phá luật kết hợp kiểu Boolean (Mining
Boolean Association Rules).
Nhưng trong thực tế, các bảng số liệu thường xuất hiện các thuộc tính không đơn
giản như vậy. Các thuộc tính có thể ở dạng số (quantitative) như điểm môn lập trình
Java, điểm môn cơ sở dữ liệu, hoặc dạng phân loại (categorical) như các lớp, các
ngành...
Các bài toán khai phá luật kết hợp trên các thuộc tính như vậy gọi là khai phá
luật kết hợp định lượng (Mining Quantitative Association Rules). Cũng như các bài
toán khai phá luật kết hợp trước đây, mục tiêu của bài toán khai phá luật kết hợp định
lượng cũng là kết xuất các luật kết hợp trên các ngưỡng support tối thiểu và các
ngưỡng confidence tối thiểu.
Với các thuộc tính định lượng thì cần phải có sự phân đoạn cho các thuộc tính
này vì suy cho cùng thì khi tính support cũng cần phải kiểm tra lại nó tồn tại hay
không tồn tại trong giao dịch. Nói cách khác là cần phải thực hiện ánh xạ các thuộc
tính định lượng sang thuộc tính Boolean. Nếu các thuộc tính phân loại hoặc số lượng
chỉ có vài giá trị riêng biệt thì có thể thực hiện ánh xạ này đơn giản như sau: Mỗi thuộc
tính trong bảng dữ liệu có p giá trị riêng biệt sẽ được lập thành p thuộc tính logic mới.
Mỗi thuộc tính logic này tương ứng với một cặp (attribute, value). Nó có giá trị “1”
nếu value có mặt trong dữ liệu gốc và có giá trị “0” nếu ngược lại. Nếu số giá trị riêng
biệt của một số thuộc tính khá lớn thì người ta thực hiện phân đoạn thuộc tính thành
các khoảng và ánh xạ mỗi cặp (attribute, value) thành một thuộc tính. Sau khi ánh xạ,
có thể thực hiện khai phá luật kết hợp trên cơ sở dữ liệu mới bằng thuật toán khai phá
luật kết hợp kiểu logic.
Tổng quát, ta có thể đưa ra một số phương pháp rời rạc hoá như sau:
Trường hợp 1 : Nếu A là thuộc tính số rời rạc hoặc là thuộc tính hạng mục có
miền giá trị hữu hạng dạng {V1, V2,..., Vk} và k đủ nhỏ (<100) thì ta biến đổi thuộc
tính này thành k thuộc tính nhị phân A_V1, A_V2,..., A_Vk. Giá trị của bản ghi tại
trường A_Vi = True (hoặc 1) Nếu giá trị của bản ghi đó tại thuộc tính A ban đầu bằng
vi, Ngược lại Giá trị của A_Vi = False (hoặc 0).
59
Trường hợp 2 : Nếu A là thuộc tính số liên tục hoặc A là thuộc tính số rời rạc hay
thuộc tính hạng mục có miền giá trị hữu hạng dạng {V1, V2,..., Vp} (p lớn) thì ta sẽ
ánh xạ thành q thuộc tính nhị phân , ,..., <A :
startq.. endq>. Giá trị của bản ghi tại trường bằng True (hoặc 1) nếu
giá trị của bản ghi đó tại thuộc tính A ban đầu nằm trong khoảng [starti.. endi], ngược
lại giá trị của = False (hoặc 0).
Mã Sv Họ tên Lớp CSDL
CTDL&
GT
Java …. C++
08850 Lã Vũ Bình CT801 8 8 8 …. 7
08963 Trần Quang Lâm CT802 8 7 9 …. 7
08760 Bùi Thị Hạnh CT801 7 8 9 …. 7
08865 Trần Văn Sơn CT801 5 6 6 …. 4
07866 Nguyễn Thị Thuỳ CT701 5 7 7 … 8
07889 Trần Thị Lan CT702 9 8 9 … 8
08975 Trần Hồng Quang CT801 4 6 6 … 7
LT1011 Nguyễn Tuấn Anh LT101 6 5 7 … 7
….. …. … … … … … …
Bảng 3.2: Ví dụ CSDL điểm của sinh viên
Ví dụ: Với bảng số liệu trên đây ta có thể phân chia như sau:
Theo quy chế 25 của bộ giáo dục đào tạo mỗi sinh viên chỉ được phép thi tối đa
hai lần cho một lần học của mỗi môn học, nếu sinh viên nào qua hai lần thi vẫn chưa
đỗ thì phải học lại môn đó. Vậy ở đây nếu sinh viên nào phải thi lại thì sẽ có hai điểm
của môn học đó. Vậy đối với các sinh viên này tác giả sẽ lấy điểm cao nhất trong hai
lần thi. Thuộc tính điểm các môn là thuộc tính có nhiều giá trị, ta có thể phân thành
các khoảng, 0..5, 5..7, 7..9, 9..10. Vậy theo như bảng trên thì mỗi điểm sẽ có 4 khoảng
điểm: ở đó đặt 1 ứng với khoảng điểm (0..5), 2 ứng với khoảng [5..7), 3 ứng với
khoảng [7..9), 4 ứng với khoảng [9..10]. Như vậy, với cách ánh xạ trên, từ CSDL gốc
ban đầu, ta có CSDL dạng logic đối với môn CSDL sau đây, các môn khác tương tự
cũng chia làm 4 khoảng:
60
CSDL
Mã Sv Họ tên Lớp
1:(0..5) 2:[5..7) 3:[7..9) 4:[9..10]
08850 Lã Vũ Bình CT801 0 0 1 0
08963 Trần Quang Lâm CT802 0 0 1 0
08760 Bùi Thị Hạnh CT801 0 0 1 0
08865 Trần Văn Sơn CT801 0 1 0 0
07866 Nguyễn Thị Thuỳ CT701 0 1 0 0
07889 Trần Thị Lan CT702 0 0 0 1
08975 Trần Hồng Quang CT801 1 0 0 0
LT1011 Nguyễn Tuấn Anh LT101 0 1 0 0
….. …. … … … … …
Bảng 3.3: Dữ liệu đã chuyển đổi từ dạng số sang dạng logic
Việc ánh xạ như trên có thể xảy ra vấn đề sau:
“minsup”: Nếu số lượng khoảng cho thuộc tính số lượng (hoặc số các giá
trị riêng cho thuộc tính phân loại) là lớn thì support cho các khoảng có thể
là nhỏ. Do đó, việc chia một thuộc tính ra quá nhiều khoảng có thể làm
cho luật chứa nó không đạt được support tối thiểu.
“minconf”: Một số thông tin có thể bị mất do việc chia khoảng. Một số
luật có thể có minconf chỉ khi một item trong chúng có giá trị đơn hoặc
một khoảng rất nhỏ, do đó thông tin có thể bị mất. Sự mất mát thông tin
càng tăng khi kích thước khoảng chia càng lớn.
Như vậy, nếu kích thước khoảng là quá lớn (số khoảng nhỏ) thì có nguy cơ một
số luật sẽ không có confidence tối thiểu, còn nếu kích thước các khoảng quá nhỏ (số
khoảng lớn) thì một số luật lại có nguy cơ không có support tối thiểu.
Để giải quyết hai vấn đề trên, người ta chú ý đến tất cả các vùng liên tục trên
thuộc tính số lượng hoặc trên các khoảng đã phân đoạn. Vấn đề “minsup”sẽ được khắc
phục bằng cách liên hợp các khoảng gần kề hoặc các giá trị gần kề. Vấn đề “minconf”
sẽ được khắc phục bằng cách tăng số lượng khoảng mà không ảnh hưởng đến vấn đề
“minsup”.
61
Người ta có thể thực hiện một phương pháp đơn giản để thực hiện việc chuyển
các thuộc tính số lượng và phân loại về cùng một dạng với nhau. Với thuộc tính phân
loại, các giá trị của nó sẽ được ánh xạ vào tập các số nguyên liên tiếp. Với các thuộc
tính số lượng không cần khoảng chia (tức là có ít giá trị) thì các giá trị sẽ được ánh xạ
vào tập các số nguyên liên tiếp theo thứ tự của các giá trị đó. Còn đối với các thuộc
tính số lượng được phân khoảng, thì các khoảng sẽ được ánh xạ vào tập số nguyên liên
tiếp, trong đó thứ tự các khoảng sẽ được bảo tồn. Các ánh xạ này sẽ làm cho mỗi bản
ghi trong CSDL trở thành một tập các cặp (Attribute, Value). Bài toán khai phá luật
kết hợp lúc này có thể thực hiện qua các bước sau:
1. Xác định số lượng mỗi phần chia cho mỗi thuộc tính số lượng.
2. Với các thuộc tính phân loại, ánh xạ các thuộc tính vào tập số nguyên liên
tiếp. Với các thuộc tính số lượng không cần sự phân khoảng, ánh xạ các
giá trị của chúng vào tập các số nguyên liên tiếp theo thứ tự giá trị thuộc
tính. Với các thuộc tính số lượng đã được phân khoảng, ánh xạ các khoảng
được chia vào tập các số nguyên liên tiếp và bảo tồn thứ tự các khoảng.
Bằng cách này, thuật toán chỉ xem các giá trị hoặc các vùng giá trị như là
các thuộc tính định lượng.
3. Tìm support cho mỗi giá trị của các thuộc tính phân loại lẫn thuộc tính số
lượng, tiếp theo tìm tất cả các itemset mà support của nó lớn hơn support
tối thiểu.
4. Sử dụng các tập tìm được để sinh ra các luật kết hợp.
5. Xác định luật đáng quan tâm và kết xuất chúng.
Như vậy, khi xét trên CSDL điểm của sinh viên (giả sử với các môn học chuyên
ngành CNTT), ta có thể thực hiện phân chia thuộc tính điểm trong bảng thành các
khoảng và ký hiệu như sau:
Mã mh Tên môn học 1:(0..5) 2:[5..7) 3:[7..9) 4:[9..10]
ct1 An toàn bảo mật thông tin A1 A2 A3 A4
ct2 Anh văn chuyên ngành B1 B2 B3 B4
ct3 Bảo vệ đồ án tốt nghiệp_ Mon TN C1 C2 C3 C4
ct4 Cấu trúc dữ liệu và giải thuật D1 D2 D3 D4
ct5 Cấu trúc máy tính E1 E2 E3 E4
ct6 Chương trình dịch F1 F2 F3 F4
ct7 Cơ sở dữ liệu 1 G1 G2 G3 G4
62
ct8 Cơ sở dữ liệu 2 H1 H2 H3 H4
ct9 Công nghệ phần mềm I1 I2 I3 I4
ct10 Đồ hoạ máy tính J1 J2 J3 J4
ct11 Hệ điều hành K1 K2 K3 K4
ct12 Hệ quản trị CSDL Oracle N1 N2 N3 N4
ct13 Kỹ thuật Ghép nối máy tính M1 M2 M3 M4
ct14 Lập trình Visual Basic O1 O2 O3 O4
ct15 Lập trình ASP/PHP P1 P2 P3 P4
ct16 Lập trình C Q1 Q2 Q3 Q4
ct17 Lập trình C++ R1 R2 R3 R4
ct18 Lập trình hướng đối tượng S1 S2 S3 S4
ct19 Lập trình JAVA T1 T2 T3 T4
ct20 Lôgíc toán U1 U2 U3 U4
ct21 Lý thuyết đồ thị V1 V2 V3 V4
ct22 Mạng máy tính W1 W2 W3 W4
ct23 Mạng máy tính và truyền số liệu X1 X2 X3 X4
ct24 Mạng và hệ phân tán Y1 Y2 Y3 Y4
ct25 MATLAP và mô phỏng Z1 Z2 Z3 Z4
ct26 Otomat và ngôn ngữ hình thức Aa1 Aa2 Aa3 Aa4
ct27 Phân tích và thiết kế hệ thống Bb1 Bb2 Bb3 Bb4
ct28 Phương pháp tính Cc1 Cc2 Cc3 Cc4
ct29 Quản lý dự án CNTT Dd1 Dd2 Dd3 Dd4
ct30 Quản trị mạng Ee1 Ee2 Ee3 Ee4
ct31 Thương mại điện tử Ff1 Ff2 Ff3 Ff4
ct32 Tin học đại cương Gg1 Gg2 Gg3 Gg4
ct33 Trí tuệ nhân tạo Hh1 Hh2 Hh3 Hh4
ct34 Vi xử lý và lập trình Assembly Ii1 Ii2 Ii3 Ii4
ct35 Xử lý ảnh Jj1 Jj2 Jj3 Jj4
63
Bảng 3.4: Bảng ký hiệu tên các môn học
Sơ đồ quan hệ để lưu trữ dữ liệu điểm của sinh viên như sau:
Hình 3.5: Sơ đồ quan hệ CSDL điểm sinh viên
3.3. Chương trình thử nghiệm minh họa
Đẻ thử nghiệm một số khía cạnh lí thuyết liên quan đến khai phá dữ liệu, luận
văn thực hienẹ chương trình minh họa. Chương trình cài đặt trên ngôn ngữ C#, CSDL
thiết kế trên SQL Server 2005, hệ điều hành WindowsXP, chip máy tính Pentium IV
1.7 GHz, RAM 512 MB, ổ cứng 80 GB còn trống gần 7 GB. Chương trình có một số
giao diện chính sau:
Hình 3.6: Giao diện chương trình chính
64
Hình 3.7: Phần kết nối CSDL
Hinh 3.8: Form cập nhật điểm sinh viên
Hình 3.9: Form cập nhật thêm sinh viên
65
Hình 3.10: Phần dữ liệu đã được mã hoá
Hình 3.11: Phần tạo luật kết hợp dùng thuật toán Apriori
66
Hình 3.12: Phần mô phỏng thuật toán với dữ liệu nhập vào từ bàn phím
3.4. Kết luận
Chương trình thực hiện tìm các tập phổ biến và luật kết hợp thông qua thuật toán
Apriori. Từ các luật kết hợp thu được từ chương trình ta có thể tìm ra các luật mạnh
phục vụ cho công tác đào tạo, hỗ trợ cho sinh viên lựa chọn môn học, ngành nghề.
Để xác định độ Support của các tập ứng viên, thuật toán Apriori luôn luôn phải
quét lại toàn bộ các giao dịch trong CSDL. Do vậy sẽ tiêu tốn rất nhiều thời gian khi
số k-items tăng (số lần xét duyệt các giao dịch tăng).
Hướng phát triển
Tiếp tục hoàn thiện và mở rộng chương trình trong luận văn này để có thể áp
dụng vào thực tế toàn diện hơn. Mở rộng khai phá luật kết hợp với dữ liệu đầu vào
rộng hơn, không chỉ dừng lại ở điểm của sinh viên mà còn có thể là các yếu tố khác
như: chuyên ngành về mạng máy tính thì sau khi ra trường có thể dễ xin việc hơn nên
có nhiều sinh viên đăng ký học ngành này hơn. Xây dựng thêm phần tiền xử lý dữ liệu.
Các tệp CSDL khác nhau như: Microsoft Access, Foxpro, Oracle… đều có thể chuyển
về một dạng thống nhất để chương trình xử lý được.
Nghiên cứu sâu các thuật toán khai phá dữ liệu, và áp dụng vào một số bài toán
khai phá dữ liệu phù hợp với giai đoạn hiện nay: dự báo dân số, bệnh dịch, thời tiết,
định hướng trong kinh doanh …
67
KẾT LUẬN
Khai phá dữ liệu là một lĩnh vực vẫn còn khá mới mẻ, lý thú. Luận văn đã trình
bày, một số vấn đề cơ bản nhất, các phương pháp cơ bản để khai phá dữ liệu, đặc biệt
trình bày chi tiết, làm rõ vấn đề khai phá luật kết hợp. Phương pháp khai phá dữ liệu
có thể là: phân lớp, hồi quy, cây quyết định, suy diễn, quy nạp, K- láng giềng gần, …
các phương pháp trên có thể áp dụng trong dữ liệu thông thường và trên tập mờ.
Bài toán khai phá luật kết hợp là bài toán khó. Luận văn đã trình bày thuật toán
khai phá kinh điển Apriori và các thuật toán mới hiệu quả nhất (Apriori_Tid, Setm,
Ais, Charm). Một cách tiếp cận khai phá luật kết hợp đảm bảo không dư thừa các luật
và cho hiệu quả khai phá cao là dựa trên tập đóng. Thuật toán khai phá hiệu quả điển
hình là thuật toán CHARM.
Kết quả xây dựng chương trình thử nghiệm dựa trên thuật toán Apriori nhằm mô
phỏng rõ hơn về khai phá dữ liệu bằng luật kết hợp. Chương trình ứng dụng vào bài
toán dự báo kết quả học tập của sinh viên, hỗ trợ sinh viên lựa chọn môn học, lựa chọn
ngành học, hỗ trợ cho cán bộ đào tạo đưa ra định hướng đào tạo trong các năm tiếp
theo.
68
PHỤ LỤC
Lớp Apriori
public class Apriori
{
//Mang danh sach cac tap phan tu luu trong cac tap muc pho bien
protected ItemsetArrayList itemsetsFrequentCollection;
//Mang danh sach cac phan tu luu trong tap muc cac ung cu
protected ItemsetArrayList itemsetsCandidateCollection;
//Xay dung lop Apriori
public Apriori()
{
this.itemsetsCandidateCollection = new ItemsetArrayList();
this.itemsetsFrequentCollection = new ItemsetArrayList();
}
public void OnProgressMonitorEvent(ProgressMonitorEventArgs e)
{
if (ProgressMonitorEvent != null)
{
ProgressMonitorEvent(this, e);
}
}
public event ProgressMonitorEventHandler ProgressMonitorEvent;
protected DataRow[] FindItems(string find, DataTable data)
{
return data.Select(find);
}
protected int FindItems(string find, string data)
{
string[] splitstring = data.Split(new Char[] { ',' });
int length = splitstring.Length;
int countFound = 0;
string[] found = new string[length];
for (int counter = 0; counter < length; counter++)
{
found[counter] = splitstring[counter].Trim();
}
foreach (string member in found)
{
if (member == find)
{
countFound++;
}
}
return countFound;
}
//Mang danh sach cac tap muc
protected int FindItems(ItemsetArrayList find, string data)
69
{
string[] splitstring = data.Split(new Char[] { ',' });
int length = find.Count;
string[] found = new string[splitstring.Length];
int minimumValue = 0;
int[] search = new int[length];
for (int counter = 0; counter < splitstring.Length; counter++)
{
found[counter] = splitstring[counter].Trim();
}
for (int count = 0; count < length; count++)
{
foreach (string member in found)
{
if (member == (string)find[count])
{
search[count]++;
}
}
}
switch (length)
{
case 0:
{
minimumValue = 0;
break;
}
case 1:
{
minimumValue = search[0];
break;
}
default:
{
for (int counter = 0; counter < search.Length; counter++)
{
if (counter == 0)
{
minimumValue = search[counter];
}
else
{
if (search[counter] < minimumValue)
{
minimumValue = search[counter];
}
}
70
}
break;
}
}
return minimumValue;
}
//Tinh Support cua 1 tap muc trong CSDL
public int SupportCount(string find, Database Transactions_Data)
{
int count = 0;
DataTable datatable = Transactions_Data.Transactions.Tables[0];
foreach (DataRow datarow in datatable.Rows)
{
count = count + FindItems(find, (datarow["Transactions"]).ToString());
}
return count;
}
//Lay gia tri Support cua 1 tap muc
public int SupportCount(ItemsetArrayList find, Database transactionsData)
{
int count = 0;
int total = 0;
DataTable dataTable
=transactionsData.Transactions.Tables["TransactionTable"];
foreach (DataRow datarow in dataTable.Rows)
{
count = this.FindItems(find, (datarow["Transactions"]).ToString());
total = count + total;
}
return total;
}
//Tao tap cac tap muc tu CSDL cua cac giao
[ReservedAttribute(false, "December 25, 2002")]
public ItemsetCandidate CreateOneItemsets(Database dataBase)
{
DataTable dataTable = dataBase.Transactions.Tables["TransactionTable"];
ItemsetCandidate candidateItemset = new ItemsetCandidate();
ItemsetArrayList uniqueItems = new ItemsetArrayList(1); ;
ItemsetArrayList candidateItems;
ItemsetArrayList items;
StringBuilder item = new StringBuilder(10);
int itemSupportCount = 0;
int counter = 1;
string msg = "Creating One Itemsets";
ProgressMonitorEventArgs e = new ProgressMonitorEventArgs(1, 100, 80,
"Apriori.CreateOneItemsets(Database)", msg);
this.OnProgressMonitorEvent(e);
foreach (DataRow dataRow in dataTable.Rows)
71
{
item.Append(dataRow["Transactions"].ToString());
if (counter < (dataTable.Rows.Count))
{
item.Append(", ");
counter++;
}
}
candidateItems =
ItemsetArrayList.ConvertToItemsetArrayList(item.ToString(), new Char[] { ',' });
for (int count = 0; count < candidateItems.Count; count++)
{
item = new StringBuilder(10);
item.Append(((string)candidateItems[count]).Trim());
if (!(item.ToString() == ""))
{
if (!uniqueItems.Contains(item.ToString()))
{
itemSupportCount = this.SupportCount(item.ToString(), dataBase);
dataBase.AddItemset(item.ToString(), 1, itemSupportCount);
items = new ItemsetArrayList(1);
uniqueItems.Add(item.ToString());
items.Add(item.ToString());
items.Level = 1;
items.SupportCount = itemSupportCount;
items.TrimToSize();
candidateItemset.Items.Add(items);
}
}
}
candidateItemset.Items.TrimToSize();
candidateItemset.Level = 1;
return candidateItemset;
}
//Lop Apriori_Gen
public void AprioriGenerator(ItemsetCandidate Candidate_Itemset, Database
TransactionsData, int minimum_support)
{
string start = "Generating Level " + Candidate_Itemset.Level + " Candidates : "
+ Candidate_Itemset.Items.Count + " Items";
ProgressMonitorEventArgs e = new ProgressMonitorEventArgs(1, 100, 25,
"Apriori.AprioriGenerator()", start);
this.OnProgressMonitorEvent(e);
//Them 1 tap muc ung cu vien vao tap cac tap muc ung cu vien
ItemsetCandidate candidateItemset =
this.JoinCandidateItemsets(Candidate_Itemset, TransactionsData, minimum_support);
if (candidateItemset.Items.Count > 0)
{
72
this.AprioriGenerator(candidateItemset, TransactionsData,
minimum_support);
}
string done = "Finished Generating Candidate Itemsets ";
e = new ProgressMonitorEventArgs(1, 100, 70, "Apriori.AprioriGenerator()",
done);
this.OnProgressMonitorEvent(e);
}
//tap muc ung cu vien
protected ItemsetCandidate GenerateFrequentItemsets(ItemsetCandidate
candidateItemset, int minimum_support)
{
ItemsetCandidate itemsetFrequent = new ItemsetCandidate();
foreach (ItemsetArrayList itemsFrequent in candidateItemset.Items)
{
if (itemsFrequent.SupportCount >= minimum_support)
{
itemsetFrequent.Items.Add(itemsFrequent);
}
}
itemsetFrequent.Items.Capacity = itemsetFrequent.Items.Count;
return itemsetFrequent;
}
//Kiem tra neu 1 phan tap muc co 1 tap muc con pho bien
protected bool HasInfrequentSubSet()
{
throw new Exception("This is a reserved attribute! Do not use it");
}
public ItemsetArrayList ItemsetsFrequentCollection
{
get
{
return itemsetsFrequentCollection;
}
set
{
itemsetsFrequentCollection.Add(value);
}
}
//Lua chon tap cac ung cu vien
public ItemsetArrayList ItemsetsCandidateCollection
{
get
{
return itemsetsCandidateCollection;
}
set
{
73
itemsetsCandidateCollection.Add(value);
}
}
//Tao 1 tap muc bang 1 tap muc ung cu vien
public ItemsetCandidate JoinCandidateItemsets(ItemsetCandidate
candidate_itemset, Database transactionsData, int minimumSupport)
{
//neu so tap muc bang 0
if (candidate_itemset.Items.Count == 0)
{
throw new Exception("cannot join items : no items are present!");
}
else
{
ItemsetArrayList copy_candidate_itemset = candidate_itemset.Items;
ItemsetCandidate new_candidate_itemset = new ItemsetCandidate();
new_candidate_itemset.Level = candidate_itemset.Level + 1;
//thanh phan cua 1 tap muc cua k phan tu duoc ket noi
//neu (k-2) phan tu dau tien tham gia vao ket noi
int count_common_items = (new_candidate_itemset.Level - 2);
foreach (ItemsetArrayList itemset in candidate_itemset.Items)
{
int count_members = 0;
foreach (ItemsetArrayList copy_itemset in copy_candidate_itemset)
{
bool join_items = true;
for (count_members = 0; count_members < count_common_items;
count_members++)
{
if (itemset[count_members] != copy_itemset[count_members])
{
join_items = false;
break;
}
}
If
(itemset[count_common_items].ToString().CompareTo(copy_itemset[count_common
_items].ToString()) != -1)
{
join_items = false;
}
if (join_items == true)
{
ItemsetArrayList new_itemset = new ItemsetArrayList(1);
for (count_members = 0; count_members <= count_common_items;
count_members++)
{
if (itemset[count_members] == copy_itemset[count_members])
74
{
new_itemset.Add(itemset[count_members]);
}
else
{
new_itemset.Add(itemset[count_members]);
new_itemset.Add(copy_itemset[count_members]);
}
}
new_itemset.Capacity = new_itemset.Count;
//lay ra support cho moi tap muc
new_itemset.SupportCount = this.SupportCount(new_itemset,
transactionsData);
new_itemset.Level = new_candidate_itemset.Level;
itemset.Capacity = itemset.Count;
//Them tap muc vao bang cac tap muc
transactionsData.AddItemset(new_itemset, ",");
//Khong them cac tap muc neu co support < minsupp
if (new_itemset.SupportCount >= minimumSupport)
{
new_candidate_itemset.Items.Add(new_itemset);
}
}
}
}
new_candidate_itemset.Items.Capacity =
new_candidate_itemset.Items.Count;
return new_candidate_itemset;
}
}
//Tao tap cac luat tu cac tap muc
public void CreateItemsetRuleset(ItemsetArrayList parentRuleset,
ItemsetArrayList leftRuleset, ItemsetArrayList rightRuleset, Database
transactionsData)
{
//Tao va them 1 luat ket hop vao CSDL
transactionsData.AddRuleset(parentRuleset, leftRuleset, rightRuleset);
}
public void CreateItemsetSubsets(int Level, ItemsetArrayList itemSubset,
ItemsetArrayList parentItemset, Database transactionsData)
{
int length = 0;
ItemsetArrayList childSubset = new ItemsetArrayList(1);
ItemsetArrayList rulesItemset;
if (itemSubset.Count > Level)
{
foreach (ItemsetArrayList item in itemSubset)
{
75
ItemsetArrayList[] subsets = this.CreateItemsetSubsets(item);
if (parentItemset == null)
{
parentItemset = item;
}
if (subsets != null)
{
length = subsets.Length;
}
else
{
break;
}
for (int count = 0; count < length; count++)
{
//them tap muc va tap con vao bangAdd the itemset and the subset to
the subsets table
transactionsData.AddSubset(item, subsets[count]);
childSubset.Add(subsets[count]);
//Tao 1 tap muc co support, conf va luat ket hop
rulesItemset = (parentItemset - subsets[count]);
this.CreateItemsetRuleset(parentItemset, subsets[count], rulesItemset,
transactionsData);
}
}
childSubset.TrimToSize();
this.CreateItemsetSubsets(0, childSubset, parentItemset, transactionsData);
}
}
public ItemsetArrayList[] CreateItemsetSubsets(ItemsetArrayList itemSubset)
{
int length = itemSubset.Count;
ItemsetArrayList[] subset = new ItemsetArrayList[length];
switch (length)
{
case 0:
{
subset = null;
break;
}
case 1:
{
subset = null;
break;
}
default:
{
subset[0] = new ItemsetArrayList(1);
76
for (int count = 0; count < (length - 1); count++)
{
subset[0].Add(itemSubset[count]);
}
subset[0].TrimToSize();
subset[1] = new ItemsetArrayList(1);
for (int count = 1; count < (length); count++)
{
subset[1].Add(itemSubset[count]);
}
subset[1].TrimToSize();
for (int count = 1; count < (length - 1); count++)
{
int position = 0;
subset[(count + 1)] = new ItemsetArrayList(1);
subset[(count + 1)].Add(itemSubset[position]);
for (position = 1; position < length; position++)
{
if (position != count)
{
subset[(count + 1)].Add(itemSubset[position]);
}
}
subset[(count + 1)].TrimToSize();
}
break;
}
}
return subset;
}
}
}
77
TÀI LIỆU THAM KHẢO
Tiếng Việt
[1]. Thái Nguyên (29 – 31 tháng 8 năm 2003), Một số vấn đề chọn lọc của công
nghệ thông tin, Nhà xuất bản Khoa học Kỹ thuật.
[2]. Nguyễn Công Cường, Nguyễn Doãn Phước (2001), Hệ mờ, mạng nơron và
ứng dụng - NXB Khoa học Kỹ thuật.
[3] Nguyễn Văn Vỵ (2006), Phân tích thiết kế hệ thống, NXB. Đại học Quốc gia
Hà Nội.
[4]. Đỗ Trung Tuấn (1999), Cơ sở dữ liệu, Nhà xuất bản Giáo dục.
[5]. Nguyễn Đình Thúc (1998), Mạng nơron, Nhà xuất bản Giáo dục.
Tiếng Anh
[6]. John Wiley & Sons (2003) - Data Mining-Concepts Models Methods And
Algorithms, Copyright © 2003 The Institute of Electrical and Electronics Engineers,
Inc.
[7]. Bao Ho Tu (1998), Introduction to Knowledge Discovery and Data mining,
Institute of Information Technology National Center for Natural Science and
Technology.
[8]. Jean – Marc Adamo (2001), Data Mining for Association Rules and
Sequential Patterns, Sequential and Parallel Algorithms, Springer – Verlag New
York, Inc.
[9]. Mohammet J. Zaki and Chin Jui Hasiao CHAM, An efficient Algorithm for
Close Itemset Mining.
[10]. Jean-Marc Adamo (2001), Data Mining for Association Rule and
Sequential Pattens, With 54 Illustrations. ISBN0-95048-6.
[11]. John Wiley & Son, Visual Data Mining: Techniques and Tools for Data
Visualization and Mining, by Tom Soukup and Ian Davidson, ISBN: 0471149993.
[12]. John Wiley & Sons (2003), Data Mining: Concepts, Models, Methods, and
Algorithms, by Mehmed Kantardzic, ISBN:0471228524.
[13]. W. H. Inmon, R. D. Hackthon, Using the Data Warehouse, A Wiley-QEA
Publication.
[14]. J.R. Quinlan (1986), Introduction of Decision Trees. Machine learning 1,
Kluwer Academic Press,81-106.
78
Địa chỉ trang Web
[15]
[16]
[17]
[18]
[19]
es-4spp.pdf
Các file đính kèm theo tài liệu này:
- LUẬN VĂN-PHÁ DỮ LIỆU ỨNG DỤNG TRONG ĐÀO TẠO.pdf