Tóm tắt
Rời rạc hóa dữ liệu
- Thu giảm số trị của một thuộc tính liên tục (continuous attribute) bằng cách chia
miền trị thành các khoảng (interval) có dán nhãn. Các nhãn này được dùng thay
cho các giá trị thực.
- Tiến hành theo hai cách: trên xuống (top down) và dưới lên (bottom up), có giám
sát (supervised) và không có giám sát (unsupervised).
- Tạo phân hoạch phân cấp/đa phân giải (multiresolution) trên các trị thuộc tính
phân cấp ý niệm cho thuộc tính số (numerical attribute)
Tạo cây phân cấp ý niệm
- Hỗ trợ khai phá dữ liệu ở nhiều mức trừu trượng
- Cho thuộc tính số (numerical attributes): binning, histogram analysis, entropybased discretization, 2-merging, cluster analysis, discretization by intuitive
partitioning
- Cho thuộc tính phân loại/rời rạc (categorical/discrete attributes): chỉ định tường
minh bởi người sử dụng hay chuyên gia, nhóm dữ liệu tường minh, dựa trên số
lượng trị phân biệt (khác nhau) của mỗi thuộc tính
88 trang |
Chia sẻ: vutrong32 | Lượt xem: 4044 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu Bài giảng Khai phá dữ liệu (Data mining) - Chương 2: Các vấn đề tiền xử lý dữ liệu, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Chương 2: Các vấn đề tiền xử lý dữ liệu
1
Nội dung
Tổng quan về giai đoạn tiền xử lý dữ liệu
Tóm tắt mô tả về dữ liệu
Làm sạch dữ liệu
Tích hợp dữ liệu
Biến đổi dữ liệu
Thu giảm dữ liệu
Rời rạc hóa dữ liệu
Tạo cây phân cấp ý niệm
Tóm tắt
2
Tổng quan về giai đoạn tiền xử lý dữ liệu
Giai đoạn tiền xử lý dữ liệu:
- Các kỹ thuật datamining đều thực hiện trên các cơ
sở dữ liệu, nguồn dữ liệu lớn. Đó là kết quả của quá
trình ghi chép liên tục thông tin phản ánh hoạt động
của con người, các quá trình tự nhiên
- Các dữ liệu lưu trữ hoàn toàn là dưới dạng thô,
chưa sẵn sàng cho việc phát hiện, khám phá thông
tin ẩn chứa trong đó. Do vậy chúng cần phải qua
giai đoạn tiền xử lý dữ liệu trước khi tiến hành bất
kỳ một phân tích nào.
3
Tổng quan về giai đoạn tiền xử lý dữ liệu
Chất lượng dữ liệu (data quality)
- Tính chính xác (accuracy): giá trị được ghi nhận
đúng với giá trị thực.
- Tính hiện hành (currency/timeliness): giá trị được
ghi nhận không bị lỗi thời.
- Tính toàn vẹn (completeness): tất cả các giá trị
dành cho một biến/thuộc tính đều được ghi nhận.
- Tính nhất quán (consistency): tất cả giá trị dữ liệu
đều được biểu diễn như nhau trong tất cả các
trường hợp.
4
Tổng quan về giai đoạn tiền xử lý dữ liệu
5
Data
Cleaning
Data Integration
Data Sources
Data Warehouse
Task-relevant Data
Selection/Transformation
Data Mining
Pattern Evaluation/
Presentation
Patterns
Tổng quan về giai đoạn tiền xử lý dữ liệu
6
Tổng quan về giai đoạn tiền xử lý dữ liệu
Các kỹ thuật tiền xử lý dữ liệu
- Làm sạch dữ liệu (data cleaning/cleansing)
- Tích hợp dữ liệu (data integration)
- Biến đổi dữ liệu (data transformation)
- Thu giảm dữ liệu (data reduction)
7
Tóm tắt mô tả về dữ liệu
8
Các kiểu dữ liệu
Tóm tắt mô tả về dữ liệu
Xác định các thuộc tính (properties) tiêu biểu của dữ
liệu về xu hướng chính (central tendency) và sự phân
tán (dispersion) của dữ liệu
- Các độ đo về xu hướng chính: mean, median,
mode, midrange
- Các độ đo về sự phân tán: quartiles, interquartile
range (IQR), variance
Làm nổi bật các giá trị dữ liệu nên được xem như
nhiễu (noise) hoặc phần tử biên (outliers), cung cấp
cái nhìn tổng quan về dữ liệu
9
Tóm tắt mô tả về dữ liệu
Các độ đo về xu hướng chính của dữ liệu
- Mean
- Weighted arithmetic mean
- Median
- Mode: giá trị xuất hiện thường xuyên nhất trong tập dữ liệu
- Midrange: giá trị trung bình của các giá trị lớn nhất và nhỏ nhất
trong tập dữ liệu
10
evenNifxx
oddNifx
Median
NN
N
2/)( 12/2/
2/
Tóm tắt mô tả về dữ liệu
Ví dụ: Mean: Giả sử chúng ta có các giá trị sau về
lương (tính theo đơn vị nghìn đôla) theo thứ tự tăng
dần như sau: 30, 36, 47, 50, 52, 52, 56, 60, 63, 70,
70, 110
Tính giá trị trung bình của các lương trên?
11
Tóm tắt mô tả về dữ liệu
Ví dụ: Median: Giả sử chúng ta có các giá trị sau về
lương (tính theo đơn vị nghìn đôla) theo thứ tự tăng
dần như sau: 30, 36, 47, 50, 52, 52, 56, 60, 63, 70,
70, 110
Tính median của các lương trên?
- Dữ liệu trên được sắp xếp tăng dần, giá trị
middlemost là 52 và 56. Do vậy median=
(52+56)/2= 108/2= 54.
12
Tóm tắt mô tả về dữ liệu
Ví dụ: Mode, Midrange: Giả sử chúng ta có các giá trị
sau về lương (tính theo đơn vị nghìn đôla) theo thứ tự
tăng dần như sau: 30, 36, 47, 50, 52, 52, 56, 60, 63,
70, 70, 110
Mode, Midrange của các lương trên?
Mode là $52,000 và $70,000
Midrange=
13
Tóm tắt mô tả về dữ liệu
Các độ đo về sự phân tán của dữ liệu
- Quartiles
The first quartile (Q1): the 25th percentile
The second quartile (Q2): the 50th percentile (median)
The third quartile (Q3): the 75th percentile
- Interquartile Range (IQR) = Q3 – Q1
Outliers (the most extreme observations): giá trị nằm
cách trên Q3 hay dưới Q1 một khoảng 1.5xIQR
- Variance
14
Tóm tắt mô tả về dữ liệu
Ví dụ: Q1, Q2, Q3, IRQ: Giả sử chúng ta có các giá trị
sau về lương (tính theo đơn vị nghìn đôla) theo thứ tự
tăng dần như sau: 30, 36, 47, 50, 52, 52, 56, 60, 63,
70, 70, 110
Q1= 47$, Q3=63$, IRQ= 63-47=16$
15
Tóm tắt mô tả về dữ liệu
Ví dụ: Variance and standard deviation: Giả sử chúng
ta có các giá trị sau về lương (tính theo đơn vị nghìn
đôla) theo thứ tự tăng dần như sau: 30, 36, 47, 50, 52,
52, 56, 60, 63, 70, 70, 110
16
Tóm tắt mô tả về dữ liệu
17
Q1 Q2 Q3
Tóm tắt mô tả về sự phân bố dữ liệu gồm năm trị số quan trọng:
median, Q1, Q3, trị lớn nhất, và trị nhỏ nhất (theo thứ tự:
Minimum, Q1, Median, Q3, Maximum).
Tóm tắt mô tả về dữ liệu
Boxplots và Outliers
- Boxplot là cách để biểu
diễn sự phân tán dữ liệu
- Boxplot được biểu diễn
bởi 5 giá trị Minimum, Q1,
Median, Q3, Maximum
như sau:
Chiều dài của box là
interquartile range.
Median được đánh dấu bởi đường
gạch trong box.
Hai gạch ngoài box là
whiskers là the smallest
(Minimum) và largest
(Maximum)
18
Outliers
(the most
extreme
observatio
ns): giá
trị nằm
cách trên
Q3 hay
dưới Q1
một
khoảng
1.5xIQR
Làm sạch dữ liệu (data cleaning/cleansing):
Thiếu giá trị
- Hãy xem xét một kho dữ liệu bán hàng và quản lý
khách hàng. Trong đó có thể có một hoặc nhiều giá
trị mà khó có thể thu thập được ví dụ như thu nhập
của khách hàng. Vậy làm cách nào để chúng ta có
được các thông tin đó?
19
Làm sạch dữ liệu (data cleaning/cleansing):
Thiếu giá trị
- Hãy xem xét các phương pháp sau:
Bỏ qua các bộ
Điền vào các giá trị thiếu bằng tay
Sử dụng các giá trị quy ước để điền vào cho giá trị thiếu
Sử dụng các thuộc tính có nghĩa là để điền vào cho giá trị
thiếu
Sử dụng các giá trị của các bộ cùng thể loại để thay thế
cho giá trị thiếu
Sử dụng giá trị có tỉ lệ xuất hiện cao để điền vào cho các
giá trị thiếu
20
Làm sạch dữ liệu (data cleaning/cleansing):
Thiếu giá trị
- Bỏ qua các bộ: điều này thường được thực hiện khi thông tin
nhãn dữ liệu bị mất. Phương pháp này không phải lúc nào
cũng hiệu quả trừ khi các bộ có chứa một số thuộc tính
không thực sự quan trọng.
- Điền vào các giá trị thiếu bằng tay: phương pháp này thường
tốn thời gian và có thể không khả thi cho một tập dữ liệu
nguồn lớn với nhiều giá trị bị thiếu.
- Sử dụng các giá trị quy ước để điền vào cho giá trị thiếu:
Thay thế các giá trị thuộc tính thiếu bởi cùng một hằng số
quy ước, chẳng hạn như một nhãn ghi giá trị “Không biết”
hoặc “∞”. Tuy vậy điều này cũng có thể khiến cho chương
trình khai phá dữ liệu hiểu nhầm trong một số trường hợp và
đưa ra các kết luận không hợp lý.
21
Làm sạch dữ liệu (data cleaning/cleansing):
Thiếu giá trị
- Sử dụng các thuộc tính có nghĩa là để điền vào cho giá trị thiếu:
Ví dụ, ta biết thu nhập bình quân đầu người của một khu vực là
800.000đ, giá trị này có thể được dùng thể thay thế cho giá trị
thu nhập bị thiếu của khách hàng trong khu vực đó.
- Sử dụng các giá trị của các bộ cùng thể loại để thay thế cho giá
trị thiếu: Ví dụ, nếu khách hàng A thuộc cùng nhóm phân loại
theo rủi ro tín dụng với một khách hàng B khác trong khi đó
khách hàng này có thông tin thu nhập bình quân. Ta có thể sử
dụng giá trị đó để điền vào cho giá trị thu nhập bình quân của
khách hàng A .
- Sử dụng giá trị có tỉ lệ xuất hiện cao để điền vào cho các giá trị
thiếu: Điều này có thể xác định bằng phương pháp hồi quy, các
công cụ suy luận dựa trên lý thuyết Bayesian hay cây quyết
định
22
Làm sạch dữ liệu (data cleaning/cleansing):
Dữ liệu nhiễu
- Nhiễu dữ liệu là một lỗi ngẫu nhiên hay do biến
động của các biến trong quá trình thực hiện, hoặc
sự ghi chép nhầm lẫn không được kiểm soát
- Ví dụ cho thuộc tính như giá cả, làm cách nào để có
thể làm mịn thuộc tính này để loại bỏ dữ liệu nhiễu.
Hãy xem xét các kỹ thuật làm mịn sau:
Binning
Hồi quy
Nhóm cụm
23
Làm sạch dữ liệu (data cleaning/cleansing):
24
Làm sạch dữ liệu (data cleaning/cleansing):
Dữ liệu nhiễu
- Binning: Làm mịn một giá trị dữ liệu được xác định thông qua các giá
trị xung quanh nó.
- Ví dụ, các giá trị giá cả được sắp xếp trước sau đó phân thành các
dải khác nhau có cùng kích thước 3 (tức mỗi “Bin” chứa 3 giá trị).
- Khi làm mịn trung vị trong mỗi bin, các giá trị sẽ được thay thế bằng
giá trị trung bình các giá trị có trong bin
- Làm mịn biên: các giá trị nhỏ nhất và lớn nhất được xác định và dùng
làm danh giới của bin. Các giá trị còn lại của bin sẽ được thay thế
bằng một trong hai giá trị trên tùy thuộc vào độ lệch giữa giá trị ban
đầu với các giá trị biên đó.
- Ví dụ, bin 1 có các giá trị 4, 8, 15 với giá trị trung bình là 9. Do vậy
nếu làm mịn trung vị các giá trị ban đầu sẽ được thay thế bằng 9. Còn
nếu làm mịn biên giá trị 8 ở gần giá trị 4 hơn nên nó được thay thế
bằng 4.
25
Làm sạch dữ liệu (data cleaning/cleansing):
Dữ liệu nhiễu
- Hồi quy: Phương pháp thường dùng là hồi quy tuyến tính, để tìm
ra được một mối quan hệ tốt nhất giữa hai thuộc tính (hoặc các
biến), từ đó một thuộc tính có thể dùng để dự đoán thuộc tính
khác.
- Hồi quy tuyến tính đa điểm là một sự mở rộng của phương pháp
trên, trong đó có nhiều hơn hai thuộc tính được xem xét, và các
dữ liệu tính ra thuộc về một miền đa chiều.
26
x
y
y = x + 1
X1
Y1
Y1’
Dữ liệu nhiễu
- Phân tích cụm (cluster analysis): Các giá trị tương tự
nhau được tổ chức thành các nhóm hay “cụm" trực
quan. Các giá trị rơi ra bên ngoài các nhóm này sẽ
được xem xét để làm mịn.
27
Làm sạch dữ liệu (data cleaning/cleansing):
Xử lý dữ liệu không nhất quán
- Định nghĩa của dữ liệu không nhất quán
Dữ liệu được ghi nhận khác nhau cho cùng một đối tượng/thực
thể discrepancies from inconsistent data representations
2004/12/25 và 25/12/2004
Dữ liệu được ghi nhận không phản ánh đúng ngữ nghĩa cho
các đối tượng/thực thể
Ràng buộc khóa ngoại
- Nguyên nhân
Sự không nhất quán trong các qui ước đặt tên hay mã dữ liệu
Định dạng không nhất quán của các vùng nhập liệu
Thiết bị ghi nhận dữ liệu,
28
Làm sạch dữ liệu (data cleaning/cleansing):
Xử lý dữ liệu không nhất quán (inconsistent data)
- Giải pháp
Tận dụng siêu dữ liệu, ràng buộc dữ liệu, sự kiểm
tra của nhà phân tích dữ liệu cho việc nhận diện
Điều chỉnh dữ liệu không nhất quán bằng tay
Các giải pháp biến đổi/chuẩn hóa dữ liệu tự động
29
Làm sạch dữ liệu (data cleaning/cleansing):
Trong nhiều bài toán phân tích, chúng ta phải đồng ý rằng
nguồn dữ liệu dùng để phân tích không thống nhất. Để có
thể phân tích được, các dữ liệu này cần phải được tích
hợp, kết hợp thành một kho dữ liệu thống nhất.
Về dạng thức, các nguồn dữ liệu có thể được lưu trữ rất
đa dạng từ: các cơ sở dữ liệu phổ dụng, các tập tin flat-
file, các dữ liệu khối .
Vấn đề đặt ra là làm thế nào có thể tích hợp chúng mà
vẫn đảm bảo tính tương đương của thông tin giữa các
nguồn
30
Tích hợp dữ liệu (data integration)
Ví dụ: làm thế nào mà người phân tích dữ liệu hoặc máy
tính chắc chắn rằng thuộc tính id của khách hàng trong
một cơ sở dữ liệu A và số hiệu cust trong một flat-file là
các thuộc tính giống nhau về tính chất?
Việc tích hợp luôn cần các thông tin diễn tả tính chất của
mỗi thuộc tính (siêu dữ liệu) như: tên, ý nghĩa, kiểu dữ
liệu, miền xác định, các quy tắc xử lý giá trị rỗng, bằng
không . Các siêu dữ liệu sẽ được sử dụng để giúp
chuyển đổi các dữ liệu. Do vậy bước này cũng liên quan
đến quá trình làm sạch dữ liệu.
31
Tích hợp dữ liệu (data integration)
Dư thừa dữ liệu:
- Đây cũng là một vấn đề quan trọng, ví dụ như thuộc tính
doanh thu hàng năm có thể là dư thừa nếu như nó có
thể được suy diễn từ các thuộc tính hoặc tập thuộc tính
khác.
32
Tích hợp dữ liệu (data integration)
Dư thừa dữ liệu:
- Phát hiện dư thừa: phân tích tương quan (correlation
analysis)
Dựa trên dữ liệu hiện có, kiểm tra khả năng dẫn ra
một thuộc tính B từ thuộc tính A.
Đối với các thuộc tính rời rạc (categorical/discrete
attributes), đánh giá tương quan giữa hai thuộc tính
với phép kiểm thử chi-square (2).
Đối với các thuộc tính số (numerical attributes), đánh
giá tương quan giữa hai thuộc tính với các hệ số
tương quan bằng cách sử dụng correlation coefficient
và covariance
33
Tích hợp dữ liệu (data integration)
Phân tích tương quan giữa hai thuộc tính rời rạc A và B
- A có c giá trị phân biệt, a1, a2, , ac.
- B có r giá trị phân biệt, b1, b2, , br.
- oij: số lượng đối tượng (tuples) quan sát được có trị thuộc
tính A là ai và trị thuộc tính B là bj.
- eij: số lượng đối tượng (tuples) mong đợi có trị thuộc tính A
là ai và trị thuộc tính B là bj.
- count(A=ai): số lượng đối tượng có trị thuộc tính A là ai.
- count(B=bj): số lượng đối tượng có trị thuộc tính B là bj.
34
Tích hợp dữ liệu (data integration)
Phân tích tương quan giữa hai thuộc tính rời rạc A và B
- Phép kiểm thống kê chi-square kiểm tra giả thuyết liệu
A và B có độc lập với nhau dựa trên một mức quan
trọng (significance level) với bậc tự do (degree of
freedom).
Nếu giả thuyết bị loại bỏ thì A và B có sự liên hệ với
nhau dựa trên thống kê.
- Bậc tự do (degree of freedom): (r-1)*(c-1)
Tra bảng phân bố chi-square để xác định giá trị 2.
Nếu giá trị tính toán được lớn hơn hay bằng trị tra
bảng được thì hai thuộc tính A và B độc lập nhau
(giả thuyết đúng).
35
Tích hợp dữ liệu (data integration)
Phân tích tương quan giữa hai thuộc tính rời rạc A và B
- Ví dụ: phân tích tương quan của các thuộc tính sử dụng
phương pháp 2
- Giả sử có một nhóm 1500 người được khảo sát. Giới tính
của họ được ghi nhận sau đó họ sẽ được hỏi về thể loại
sách yêu thích thuộc hai dạng hư cấu và viễn tưởng. Như
vậy ở đây có hai thuộc tính “giới tính” và “sở thích đọc”. Số
lần xuất hiện (observed frequencies) của các trường hợp
được cho trong bảng sau: (các số trong ngoặc là expected
frequencies)
36
Tích hợp dữ liệu (data integration)
Phân tích tương quan giữa hai thuộc tính rời rạc A và B
Vậy chúng ta tính được
37
Tích hợp dữ liệu (data integration)
Phân tích tương quan giữa hai thuộc tính rời rạc A và B
Từ bảng dữ liệu cho thấy bậc tự do (r-1)(c-1) = (2-1)(2-
1) = 1. Với 1 bậc tự do, giá trị cần để bác bỏ giả thiết
này ở mức 0.001 là 10.828. Và với giá trị tính được như
trên 507.93 > 10.828 nên chúng ta có thể bát bỏ giả
thuyết sở thích đọc là độc lập với giới tính. Và kết luận
rằng: hai thuộc tính này có một quan hệ tương quan khá
mạnh trong nhóm người được khảo sát.
38
Tích hợp dữ liệu (data integration)
Phân tích tương quan giữa hai thuộc tính số A và B (Correlation coefficient)
Trong đó:
- N là số bộ
- ai và bi là các giá trị của thuộc tính A và B tại bộ thứ i
- và là giá trị trung bình tương ứng của A và B
- σA và σB biểu diễn độ lệch chuẩn của A và B
- là tổng của tích AB (với mỗi bộ, giá trị của thuộc
tính A được nhân với giá trị của thuộc tính b trong bộ đó)
- Lưu ý rằng: -1<=r A,B <= +1 39
Tích hợp dữ liệu (data integration)
A B
Dư thừa dữ liệu:
Nếu r A,B lớn hơn 0, thì A và B có khả năng có mối liên hệ
tương quan với nhau, nghĩa là nếu giá trị A tăng thì giá trị
của B cũng tăng lên. Giá trị này càng cao thì mối quan hệ
càng chặt chẽ. Và hệ quả là nếu giá trị đủ cao thì một
trong hai thuộc tính A (hoặc B) có thể được loại bỏ.
Nếu r A,B bằng 0 thì A và B là độc lập với nhau và giữa
chúng không có mối quan hệ nào.
Nếu r A,B nhỏ hơn 0 thì A và B có mối quan hệ tương
quan nghịch, khi đó nếu một thuộc tính tăng thì giá trị của
thuộc tính kia giảm đi.
40
Tích hợp dữ liệu (data integration)
Dư thừa dữ liệu:
Chú ý rằng, nếu giữa A và B có mối quan hệ tương quan
thì không có nghĩa chúng có mối quan hệ nhân quả, nghĩa
là A hoặc B biến đổi là do sự tác động từ thuộc tính kia.
Ví dụ có thể xem xét mối quan hệ tương quan giữa số
bệnh viện và số vụ tai nạn ô tô ở một địa phương. Hai
thuộc tính này thực sự không có quan hệ nhân quả trực
tiếp mà chúng quan hệ nhân quả với một thuộc tính thứ 3
là dân số
41
Tích hợp dữ liệu (data integration)
42
Phân tích tương quan giữa hai thuộc tính số A và B (Covariance)
Covariance tương tự với correlation
Covariance giữa A và B được định nghĩa như sau:
Tích hợp dữ liệu (data integration)
Correlation coefficient:
It can be simplified in computation as
Suppose two stocks A and B have the following values in one week: (2, 5), (3,
8), (5, 10), (4, 11), (6, 14).
Question: If the stocks are affected by the same industry trends, will their
prices rise or fall together?
- E(A) = (2 + 3 + 5 + 4 + 6)/ 5 = 20/5 = 4
- E(B) = (5 + 8 + 10 + 11 + 14) /5 = 48/5 = 9.6
- Cov(A,B) = (2×5+3×8+5×10+4×11+6×14)/5 − 4 × 9.6 = 4
Thus, A and B rise together since Cov(A, B) > 0.
Tích hợp dữ liệu (data integration)
Ví dụ: Covariance
44
Phân tích tương quan giữa hai thuộc tính số A và B
Tích hợp dữ liệu (data integration)
A
B
A
B
A
B
A
B
A
B
Vấn đề mâu thuẫn giá trị dữ liệu
- Cho cùng một thực thể thật, các giá trị thuộc tính
đến từ các nguồn dữ liệu khác nhau có thể khác
nhau về cách biểu diễn (representation), đo lường
(scaling), và mã hóa (encoding).
Representation: “2004/12/25” với “25/12/2004”.
Scaling: thuộc tính weight trong các hệ thống đo
khác nhau với các đơn vị đo khác nhau, thuộc
tính price trong các hệ thống tiền tệ khác nhau với
các đơn vị tiền tệ khác nhau.
Encoding: “yes” và “no” với “1” và “0”.
45
Tích hợp dữ liệu (data integration)
Biến đổi dữ liệu (data transformation)
Trong phần này các dữ liệu sẽ được biến đổi sang
các dạng phù hợp cho việc khai phá dữ liệu. Các
phương pháp thường thấy như:
- Làm mịn: Phương pháp này loại bỏ các trường hợp
nhiễu khỏi dữ liệu ví dụ như các phương pháp
binning, hồi quy, nhóm cụm.
- Tổng hợp: trong đó tổng hợp hoặc tập hợp các
hành động được áp dụng trên dữ liệu. Ví dụ thấy
rằng doanh số bán hàng hàng ngày có thể được
tổng hợp để tính toán hàng tháng và hàng năm.
Bước này thường được sử dụng để xây dựng một
khối dữ liệu cho việc phân tích
46
Biến đổi dữ liệu (data transformation)
Trong phần này các dữ liệu sẽ được biến đổi sang
các dạng phù hợp cho việc khai phá dữ liệu. Các
phương pháp thường thấy như:
- Khái quát hóa dữ liệu: trong đó các dữ liệu mức
thấp hoặc thô được thay thế bằng các khái niệm ở
mức cao hơn thông qua kiến trúc khái niệm.
- Ví dụ, các thuộc tính phân loại ví dụ như “Đường
phố” có thể khái quát hóa lên mức cao hơn thành
“Thành phố” hay “Quốc gia”. Tương tự như vậy các
giá trị số, như tuổi có thể được ánh xạ lên khái niệm
cao hơn như “Trẻ”, “Trung niên”, “Có tuổi”
47
Biến đổi dữ liệu (data transformation)
Trong phần này các dữ liệu sẽ được biến đổi sang
các dạng phù hợp cho việc khai phá dữ liệu. Các
phương pháp thường thấy như:
- Chuẩn hóa: trong đó các dữ liệu của thuộc tính
được quy về các khoảng giá trị nhỏ hơn ví dụ như
từ -1.0 đến 1.0, hoặc từ 0.0 đến 1.0
- Xác định thêm thuộc tính, trong đó các thuộc tính
mới sẽ được thêm vào nguồn dữ liệu để giúp cho
quá trình khai phá.
48
Chuẩn hóa:
- Một thuộc tính được chuẩn hóa bằng cách ánh xạ
một cách có tỉ lệ dữ liệu về một khoảng xác định ví
dụ như 0.0 đến 1.0.
- Chuẩn hóa là một phần hữu ích của thuật toán phân
lớp trong mạng noron, hoặc thuật toán tính toán độ
lệch sử dụng trong việc phân lớp hay nhóm cụm
các phần tử liền kề. Chúng ta sẽ xem xét ba
phương pháp:
min-max
z-score
Normalization by decimal scaling
49
Biến đổi dữ liệu (data transformation)
Chuẩn hóa Min-Max:
- Thực hiện một biến đổi tuyến tính trên dữ liệu ban
đầu. Giả sử rằng minA và maxA là giá trị tối thiểu và
tối đa của thuộc tính A. Chuẩn hóa min-max sẽ ánh
xạ giá trị v của thuộc tính A thành v’ trong khoảng
[new_minA, new_maxA] bằng cách tính toán :
50
Biến đổi dữ liệu (data transformation)
Chuẩn hóa Min-Max:
- Ví dụ: Giả sử giá trị nhỏ nhất và lớn nhất cho thuộc
tính “thu nhập bình quân” là 500.000 và 4.500.000.
Chúng ta muốn ánh xạ giá trị 2.500.000 về khoảng
[0.0, 1.0] sử dụng chuẩn hóa min-max. Giá trị mới
thu được là
51
Biến đổi dữ liệu (data transformation)
Chuẩn hóa z-score:
- Với phương pháp này, các giá trị của một thuộc tính
A được chuẩn hóa dựa vào độ lệch tiêu chuẩn và
trung bình của A. Một giá trị v của thuộc tính A được
ánh xạ thành v’ như sau:
- Với ví dụ phía trên: Giả sử thu nhập bình quân có
độ lệch tiêu chuẩn và trung bình là: 500.000 và
1.000.000. Sử dụng phương pháp z-score thì giá trị
2.500.000 được ánh xạ thành
52
Biến đổi dữ liệu (data transformation)
Chuẩn hóa thay đổi số chữ số phần thập phân
(decimal scale):
- Phương pháp này sẽ di chuyển dấu phân cách
phần thập phân của các giá trị của thuộc tính A.
- Số chữ số sau dấu phân cách phần thập phân được
xác định phụ thuộc vào giá trị tuyệt đối lớn nhất có
thể có của thuộc tính A. Khi đó giá trị v sẽ được ánh
xạ thành v’ bằng cách tính:
53
Biến đổi dữ liệu (data transformation)
Chuẩn hóa thay đổi số chữ số phần thập phân
(decimal scale):
- Trong đó j là giá trị nguyên nhỏ nhất thỏa mãn
Max(|v’|) < 1
- Ví dụ: Giả sử rằng các giá trị của thuộc tính A được
ghi nhận nằm trong khoảng -968 đến 917. Giá trị
tuyệt đối lớn nhất của miền là 986. Để thực hiện
chuẩn hóa theo phương pháp ánh xạ này, trước đó
chúng ta mang các giá trị chia cho 1.000 (j = 3).
Như vậy giá trị -986 sẽ chuyển thành -0.986 và 917
được chuyển thành 0.917
54
Biến đổi dữ liệu (data transformation)
Việc khai phá dữ liệu luôn được tiến hành trên các
kho dữ liệu khổng lồ và phức tạp.
Các kỹ thuật khai phá khi áp dụng trên chúng luôn tốn
thời gian cũng như tài nguyên của máy tính.
Do vậy đòi hỏi chúng cần được thu giảm trước khi áp
dụng các kỹ thuật khai phá.
55
Thu giảm dữ liệu (data reduction):
Một số chiến lược thu giảm dữ liệu như sau:
- Tổng hợp khối dữ liệu (data cube aggregation)
- Thu giảm chiều (dimensionality reduction)
Chọn một số thuộc tính (attribute subset selection)
Chuyển dạng sóng (Wavelet Transformation)
Phân tích thành phần chính (Principal Component
Analysis )
- Thu giảm lượng (numerosity reduction)
- Nén dữ liệu
- Rời rạc hóa (discretization)
- Tạo phân cấp ý niệm (concept hierarchy generation)
56
Thu giảm dữ liệu (data reduction):
Tổng hợp khối dữ liệu (data
cube aggregation):
Hãy xem xét dữ liệu bán hàng
của một đơn vị, các dữ liệu đó
được tổ chức báo cáo theo
hàng quý cho các năm từ 2008
đến 2010. Tuy nhiên việc khai
phá dữ liệu lại quan tâm hơn
đến các báo cáo bán hàng theo
năm chứ không phải theo từng
quý. Do đó các dữ liệu nên
được tổng hợp thành báo cáo
tổng về tình hình bán hàng theo
năm hơn là theo quý
57
Sum()
cube: Sale
Thu giảm dữ liệu (data reduction):
Tổng hợp khối dữ liệu(data cube aggregation)
- Phân cấp khái niệm có thể tồn tại ở mỗi thuộc tính,
nó cho phép phân tích dữ liệu ở nhiều mức trừu
tượng.
- Ví dụ: phân cấp chi nhánh cho phép các chi nhánh
được nhóm lại theo từng vùng dựa trên địa chỉ. Khối
dữ liệu cho phép truy cập nhanh đến các dữ liệu đã
tính toán, tổng hợp do vậy nó khá phù hợp với các
quá trình khái phá.
58
Thu giảm dữ liệu (data reduction):
Tổng hợp khối dữ liệu(data cube aggregation)
- Các khối dữ liệu được tạo ở mức trừu tượng thấp
thường được gọi là cuboid. Các cuboid tương ứng
với một tập thực thể nào đó ví dụ như người bán
hàng, khách hàng. Các khối này cung cấp nhiều
thông tin hữu dụng cho quá trình phân tích. Khối dữ
liệu ở mức trừu tượng cao gọi là apex cuboid, trong
hình trên thể hiện dữ liệu bán hàng cho cả 3 năm,
tất cả các loại mặt hàng và các chi nhánh. Khối dữ
liệu được tạo từ nhiều mức trừu tượng thường
được gọi là cuboids, do vậy khối dữ liệu thường
được gọi bằng tên khác là lưới cuboids.
59
Thu giảm dữ liệu (data reduction):
Chọn một số thuộc tính:
- Nguồn dữ liệu dùng phân tích có thể chứa hàng
trăm thuộc tính, rất nhiều trong số đó có thể không
cần cho việc phân tích hoặc chúng là dư thừa.
- Ví dụ: nếu nhiệm vụ phân tích chỉ liên quan đến việc
phân loại khách hàng xem họ có hoặc không muốn
mua một đĩa nhạc mới hay không. Khi đó thuộc tính
điện thoại của khách hàng là không cần thiết khi so
với các thuộc tính như độ tuổi, sở thích âm nhạc
60
Thu giảm dữ liệu (data reduction):
Chọn một số thuộc tính:
- Mặc dù vậy việc lựa chọn thuộc tính nào cần quan
tâm là một việc khó khăn và mất thời gian đặt biệt
khi các đặc tính của dữ liệu là không rõ ràng. Giữ
các thuộc tính cần, bỏ các thuộc tính không hữu ích
cũng sẽ có thể gây nhầm lẫn, và sai lệch kết quả
của các thuật toán khai phá dữ liệu.
- Phương pháp này rút gọn kích thước dữ liệu bằng
cách loại bỏ các thuộc tính không hữu ích hoặc dư
thừa (hoặc loại bỏ các chiều). Mục đích chính là tìm
ra tập thuộc tính nhỏ nhất sao cho khi áp dụng các
phương pháp khai phá dữ liệu thì kết quả thu được
là gần sát nhất với kết quả khi sử dụng tất cả các
thuộc tính.
61
Thu giảm dữ liệu (data reduction):
Chọn một số thuộc tính
- Vậy làm cách nào để tìm ra một tập thuộc tính con
đủ tốt từ tập thuộc tính ban đầu.
- Với N thuộc tính chúng ta sẽ có 2n tập thuộc tính
con. Việc phát sinh và xem xét hết các tập này là
khá tốn công sức cũng như tài nguyên, đặc biệt khi
N và số các lớp dữ liệu tăng lên.
- Do vậy cần có các phương pháp khác, một trong số
đó là phương pháp tìm kiếm tham lam, nó sẽ duyệt
qua không gian thuộc tính và tìm kiếm các lựa chọn
tốt nhất vào thời điểm xét.
62
Thu giảm dữ liệu (data reduction):
Chọn một số thuộc tính
63
Thu giảm dữ liệu (data reduction):
Chọn một số thuộc tính
- Các kỹ thuật lựa chọn thường dùng như:
Lựa chọn tăng dần: Xuất phát từ một tập rỗng các thuộc tính,
các thuộc tính tốt nhất mỗi khi xác định được sẽ được thêm vào
tập này. Lặp lại bước trên cho đến khi không thêm được thuộc
tính nào nữa.
Loại bớt: Xuất phát từ tập có đầy đủ các thuộc tính. Ở mỗi
bước loại ra các thuộc tính tồi nhất.
Kết hợp giữa phương pháp loại bớt và lựa chọn tăng dần bằng
cách tại mỗi bước ngoài việc lựa chọn thêm các thuộc tính tốt
nhất đưa vào tập thì cũng đồng thời loại bỏ đi các thuộc tính tồi
nhất khỏi tập đang xét.
Cây quyết định: Khi sử dụng, cây được xây dựng từ nguồn dữ
liệu ban đầu. Tất cả các thuộc tính không xuất hiện trên cây
được coi là không hữu ích. Tập các thuộc tính có trên cây sẽ là
tập thuộc tính rút gọn
64
Thu giảm dữ liệu (data reduction):
Chọn một số thuộc tính:
- Việc lựa chọn ra thuộc tính tốt (xấu) được xác định
thông qua các phép kiểm thống kê, trong đó giả sử
rằng thuộc tính đang xét là độc lập với các thuộc
tính khác hoặc phương pháp đánh giá thuộc tính sử
dụng độ đo thông tin thường được dùng trong việc
xây dựng cây quyết định phân lớp
65
Thu giảm dữ liệu (data reduction):
Biến đổi wavelet (wavelet transforms)
- Discrete wavelet transform (DWT) là kỹ thuật xử lý
tín hiệu dạng linear mà khi áp dụng với vector dữ
liệu X, chuyển vector đó thành 1 vector khác dạng
số X’: wavelet coefficients. Hai vector này có cùng
độ dài.
- Khi áp dụng kỹ thuật này để thu giảm dữ liệu, chúng
ta giả sử rằng mỗi bộ như là 1 vector dữ liệu n-
chiều là X = (x1, x2, , x3)
66
Thu giảm dữ liệu (data reduction):
Biến đổi wavelet (wavelet transforms)
- Dữ liệu được chuyển đổi thành dạng sóng có thể bị cắt bỏ
bớt.
- Phép tính xấp xỉ nén của dữ liệu: chỉ lưu một mảnh nhỏ các
hệ số sóng lớn nhất của wavelet coefficients
- DWT thì tương tự như Discrete Fourier transform (DFT),
nhưng nén tổn thất tốt hơn, có nghĩa là cùng số lượng
coefficient được giữ lại trong DWT và DFT của 1 vector cho
sẵn, thì DWT sẽ cho ra kết quả xấp xỉ chính xác so với dữ
liệu ban đầu hơn.
67
Thu giảm dữ liệu (data reduction):
Biến đổi wavelet (wavelet transforms)
- Do vậy, đối với một phép xấp xỉ tương đương, DWT
yêu cầu nhiều bộ nhớ hơn so với DFT.
- Chuyển đổi Wavelet có thể được áp dụng trong
không gian đa chiều chẳng hạn như khối dữ liệu
(data cube).
- Chuyển đổi Wavelet cho kết quả tốt đối với dữ liệu
thưa thớt hay bị lệch và với dữ liệu với các
thuộc tính có thứ tự.
- Chuyển đổi Wavelet có nhiều ứng dụng trong thực
tế: nén ảnh, computer vision,, phân tích dữ liệu
chuỗi thời gian, làm sạch dữ liệu
68
Thu giảm dữ liệu (data reduction):
69
DWT cho nén ảnh
Image
Low Pass High Pass
Low Pass High Pass
Low Pass High Pass
Thu giảm dữ liệu (data reduction):
Biến đổi wavelet (wavelet transforms)
- Do vậy, đối với một phép xấp xỉ tương đương, DWT
yêu cầu nhiều bộ nhớ hơn so với DFT.
- Chuyển đổi Wavelet có thể được áp dụng trong
không gian đa chiều chẳng hạn như khối dữ liệu
(data cube).
- Chuyển đổi Wavelet cho kết quả tốt đối với dữ liệu
thưa thớt hay bị lệch và với dữ liệu với các
thuộc tính có thứ tự.
- Chuyển đổi Wavelet có nhiều ứng dụng trong thực
tế: nén ảnh, computer vision, phân tích dữ liệu chuỗi
thời gian, làm sạch dữ liệu
70
Thu giảm dữ liệu (data reduction):
Phân tích thành phần chính (Principal Component
Analysis )
- Cho N vector dữ liệu k-chiều, tìm c (<= k) vector
trực giao tốt nhất để trình diễn dữ liệu.
Tập dữ liệu gốc được rút gọn thành N vector dữ
liệu c chiều: c thành phần chính (chiều được rút
gọn).
- Mỗi vector dữ liệu là tổ hợp tuyến tính của các
vector thành phần chính.
- Chỉ áp dụng cho dữ liệu số
71
Thu giảm dữ liệu (data reduction):
Phân tích thành phần chính (Principal Component
Analysis )
- Dùng khi số chiều vector lớn.
- Có thể sử dụng với các dữ liệu thưa thớt hay bị
lệch.
- Có thể áp dụng cho các thuộc tính có thứ tự và
không thứ tự
- So với chuyển đổi wavelet, PCA có khuynh hướng
tốt hơn đối với dữ liệu thưa thớt, trong khi đó
chuyển đổi wavelet thích hợp hơn đối với dữ liệu đa
chiều.
72
Thu giảm dữ liệu (data reduction):
Phân tích thành phần chính (Principal Component
Analysis )
Y1, Y2 là thành phần chính ban đầu được ánh xạ
sang X1, X2
Thu giảm dữ liệu (data reduction):
X1
X2
Y1
Y2
Thu giảm lượng (numerosity reduction)
- Các kỹ thuật giảm lượng dữ liệu bằng các dạng biểu diễn
dữ liệu thay thế.
- Các phương pháp có thông số (parametric): mô hình ước
lượng dữ liệu các thông số được lưu trữ thay cho dữ
liệu thật
Hồi quy
- Các phương pháp phi thông số (nonparametric): lưu trữ
các biểu diễn thu giảm của dữ liệu
Histogram, Clustering, Sampling
74
Thu giảm dữ liệu (data reduction):
Histogram
- Chia dữ liệu thành các
buckets và lưu giá trị
trung bình(tổng) vào
mỗi bucket
- Partitioning rules:
Equal-width: equal
bucket range
Equal-frequency (or
equal-depth)
75
Thu giảm dữ liệu (data reduction):
0
5
10
15
20
25
30
35
40
10000 30000 50000 70000 90000
Clustering
- Phân chia dữ liệu vào các nhóm và lưu biểu diễn của
nhóm
Thu giảm dữ liệu (data reduction):
Sampling (With or
without Replacement)
- Dùng tập ngẫu nhiên
nhỏ hơn để thay tập
dữ liệu lớn
- Phương pháp lấy mẫu
ngẫu nhiên không
thay thế (SRSWOR)
- Phương pháp lấy mẫu
ngẫu nhiên có thay
thế (SRSWR)
- Phương pháp lấy mẫu
theo nhóm/cấp
(Cluster or Stratified
Sampling)
77
Thu giảm dữ liệu (data reduction):
Raw Data
Sampling (Cluster or Stratified Sampling)
78
Thu giảm dữ liệu (data reduction):
Raw Data Cluster/Stratified Sample
79
Nén dữ liệu (data compression)
- String compression
- Audio/video compression
- Time sequence is not audio
- Dimensionality and numerosity reduction may also
be considered as forms of data compression
Thu giảm dữ liệu (data reduction):
80
Nén dữ liệu (data compression)
Original Data Compressed
Data
lossless
Original Data
Approximated
Thu giảm dữ liệu (data reduction):
Rời rạc hóa dữ liệu
Giảm số lượng giá trị của một thuộc tính liên tục
(continuous attribute) bằng các chia miền trị thuộc tính
thành các khoảng (intervals)
Các nhãn (labels) được gán cho các khoảng
(intervals) này và được dùng thay giá trị thực của
thuộc tính
Các trị thuộc tính có thể được phân hoạch theo một
phân cấp (hierarchical) hay ở nhiều mức phân giải
khác nhau (multiresolution)
81
Rời rạc hóa dữ liệu
Rời rạc hóa dữ liệu cho các thuộc tính số (numeric
attributes)
- Các phân cấp ý niệm được dùng để thu giảm dữ
liệu bằng việc thu thập và thay thế các ý niệm cấp
thấp bởi các ý niệm cấp cao.
- Các phân cấp ý niệm được xây dựng tự động dựa
trên việc phân tích phân bố dữ liệu.
- Chi tiết của thuộc tính sẽ bị mất.
- Dữ liệu đạt được có ý nghĩa và dễ được diễn dịch
hơn, đòi hỏi ít không gian lưu trữ hơn.
82
Rời rạc hóa dữ liệu
Các phương pháp rời rạc hóa dữ liệu cho các thuộc
tính số
- Binning
- Histogram analysis
- Interval merging by 2 analysis
- Cluster analysis
- Entropy-based discretization
- Discretization by “natural/intuitive partitioning”
83
Tạo cây phân cấp ý niệm
Dữ liệu phân loại (categorical data)
- Dữ liệu rời rạc (discrete data)
- Miền trị thuộc tính phân loại (categorical attribute)
Số giá trị phân biệt hữu hạn
Không có thứ tự giữa các giá trị
Tạo phân cấp ý niệm cho dữ liệu rời rạc
84
Tạo cây phân cấp ý niệm
Các phương pháp tạo phân cấp ý niệm cho dữ liệu rời
rạc (categorical/discrete data)
- Đặc tả thứ tự riêng phần (partial ordering)/thứ tự
toàn phần (total ordering) của các thuộc tính tường
minh ở mức lược đồ bởi người sử dụng hoặc
chuyên gia:
street < city < state < country
- Đặc tả một phần phân cấp bằng cách nhóm dữ liệu
tường minh:
{Urbana, Champaign, Chicago} < Illinois
85
Tạo cây phân cấp ý niệm
Các phương pháp tạo phân cấp ý niệm cho dữ liệu rời
rạc (categorical/discrete data)
- Đặc tả chỉ một tập riêng phần các thuộc tính (partial
set of attributes)
E.g., only street < city, not others
- Tạo phân cấp tự động (hay các mức thuộc tính)
bằng cách phân tích số lượng các giá trị phân biệt
E.g., for a set of attributes: {street, city, state,
country}
86
Tóm tắt
Dữ liệu thực tế: không đầy đủ (incomplete/missing), nhiễu
(noisy), không nhất quán (inconsistent)
Quá trình tiền xử lý dữ liệu
- Làm sạch dữ liệu: xử lý dữ liệu bị thiếu, làm trơn dữ liệu
nhiễu, nhận dạng các phần tử biên, hiệu chỉnh dữ liệu không
nhất quán
- Tích hợp dữ liệu: vấn đề nhận dạng thực thể, vấn đề dư thừa,
vấn đề mâu thuẫn giá trị dữ liệu
- Biến đổi dữ liệu: làm trơn dữ liệu, kết hợp dữ liệu, tổng quát
hóa, chuẩn hóa, xây dựng thuộc tính/đặc tính
- Thu giảm dữ liệu: kết hợp khối dữ liệu, chọn một số thuộc
tính, thu giảm chiều, rời rạc hóa và tạo phân cấp ý niệm
87
Tóm tắt
Rời rạc hóa dữ liệu
- Thu giảm số trị của một thuộc tính liên tục (continuous attribute) bằng cách chia
miền trị thành các khoảng (interval) có dán nhãn. Các nhãn này được dùng thay
cho các giá trị thực.
- Tiến hành theo hai cách: trên xuống (top down) và dưới lên (bottom up), có giám
sát (supervised) và không có giám sát (unsupervised).
- Tạo phân hoạch phân cấp/đa phân giải (multiresolution) trên các trị thuộc tính
phân cấp ý niệm cho thuộc tính số (numerical attribute)
Tạo cây phân cấp ý niệm
- Hỗ trợ khai phá dữ liệu ở nhiều mức trừu trượng
- Cho thuộc tính số (numerical attributes): binning, histogram analysis, entropy-
based discretization, 2-merging, cluster analysis, discretization by intuitive
partitioning
- Cho thuộc tính phân loại/rời rạc (categorical/discrete attributes): chỉ định tường
minh bởi người sử dụng hay chuyên gia, nhóm dữ liệu tường minh, dựa trên số
lượng trị phân biệt (khác nhau) của mỗi thuộc tính
88
Các file đính kèm theo tài liệu này:
- 2_data_mining_tienxulydulieu_chapter_21_564.pdf