VAÄN DUÏNG TÖ TÖÔÛNG HOÀ CHÍ MINH VEÀ COÂNG TAÙC SÖÛ DUÏNG CAÙN BOÄ, COÂNG CHÖÙC TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Hà Đồng Hưng 86 SỬ DỤNG PHẦN MỀM MS EXCEL DỰ BÁO THÔNG TIN THEO PHÂN LỚP NAÏVE BAYES[.]
TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Hà Đồng Hưng SỬ DỤNG PHẦN MỀM MS EXCEL DỰ BÁO THÔNG TIN THEO PHÂN LỚP NAÏVE BAYES USING MS EXCEL TO FORECAST INFORMATION ACCORDING TO NAÏVE BAYES CLASSIFICATION HÀ ĐỒNG HƯNG TĨM TẮT: Dự báo thơng tin có vai trị quan trọng việc hoạch định tất lĩnh vực ngành nghề Việc dự báo thơng tin xác đem lại nhiều lợi ích cho cá nhân tổ chức Để dự báo, sử dụng phần mềm chuyên dụng với chi phí quyền đào tạo Vấn đề đặt tìm giải pháp áp dụng cơng cụ thông dụng để dự báo thông tin Bài viết đề xuất giải pháp áp dụng phần mềm MS Excel, phần mềm phổ biến dễ sử dụng, để khai thác liệu, dự báo thông tin theo phân lớp Naïve Bayes Kết thử nghiệm với liệu cho thấy: dự báo thông tin dựa vào phân lớp liệu; Dữ liệu huấn luyện bổ sung cách dễ dàng cách nhập thêm vào tập tin MS Excel; Các công thức viết tự động cập nhật kết có thay đổi tập huấn luyện làm tăng độ tin cậy thông tin dự báo Từ khóa: dự báo; phân lớp; khai thác liệu; Naïve Bayes ABSTRACT: Information forecasting plays an important role in industry planning Accurate forecasted information will bring many benefits to individuals and organizations Specialized software can be used with beneficial licensing and training costs The problem is to find a solution applying popular tools to forecast information This paper proposes applying MS Excel, a very popular and easy-to-use software in mining data and forecasting information according to the Naïve Bayes classification Experimental results with data show that: Forecast information is produced based on data classification; The training data can be easily added by appending into the MS Excel file; That written formulas automatically update the results in any change in the training set increases forecasted information reliability Key words: forecasting; classification; data mining; Nạve Bayes cơng tốn nhiều công sức, xử lý chậm, dễ sai không phù hợp với xử lý liệu lớn Các phương pháp tự động nhanh chóng, xác, hiệu với xử lý liệu lớn Một nghiên cứu Fatimetou Zahra Mohamed Mahmoud kết luận rằng: “Thật vậy, phân tích dự báo hệ thống ngành nghề khác cho mục đích khác nhau, số thu kết mong muốn số khác khơng Trong hầu hết ĐẶT VẤN ĐỀ Ngày nay, liệu hạt nhân hoạt động lĩnh vực ngành nghề, từ liệu có thơng tin hữu ích Tuy nhiên, để chuyển từ liệu thành thơng tin hữu ích phục vụ người vấn đề tiếp tục nghiên cứu Xử lý liệu có nhiều phương pháp gồm phương pháp thủ công phương pháp tự động Các phương pháp thủ ThS Trường Đại học Văn Lang, hung.hd@vlu.edu.vn, Mã số: TCKH25-03-2021 86 TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Số 26, Tháng 03 - 2021 nghiên cứu tập trung vào việc phát triển tạo mơ hình Nhưng điều có đủ khơng?”[3] Câu hỏi kết luận cho ý tưởng cần có thêm nghiên cứu mang tính chất thực nghiệm ứng dụng dự báo thông tin viết Trong nghiên cứu Vaibhav Kumar M L Garg kết luận: “dựa tham số đầu vào, đầu hay tương lai giá trị dự đốn”[4] Vì vậy, để dự báo thông tin, cần lượng liệu đầu vào làm sở cho dự báo Hiện nay, giới có phần mềm chuyên dụng hay tính thêm vào (Plug-in) vào MS Excel để dự báo thông tin Tuy nhiên, việc sử dụng chúng địi hỏi nhiều chi phí quyền chi phí đào tạo Chúng ta có tập dịng liệu, dịng liệu bao gồm thuộc tính điều kiện thuộc tính kết Tập liệu gọi tập liệu huấn luyện (tập học) Vậy, có thêm dịng liệu xác định giá trị thuộc tính điều kiện thuộc tính kết dự báo có kết nào? Phương pháp phân lớp Naïve Bayes sử dụng để giải vấn đề Tuy nhiên, thực thủ công, tập liệu lớn tốn nhiều thời gian, công sức dễ sai sót Mỗi có biến động liệu tập huấn luyện phải làm lại từ đầu Nếu dùng phần mềm Excel, cần viết hàm thực thi tập liệu huấn luyện cho kết dự báo tức thì, khơng sai sót; Hoặc, có biến động tập liệu huấn luyện, Excel cập nhật, cho kết dự báo tốt Đặc biệt, phần mềm Excel phổ biến, linh hoạt tùy biến dễ sử dụng Bài viết trình bày cách dùng phần mềm Excel để dự báo thông tin theo phân lớp Naïve Bayes NỘI DUNG Naïve Bayes kỹ thuật để xây dựng phân lớp: Gán nhãn lớp cho trường hợp vấn đề, nhãn lớp rút từ số tập hữu hạn giá trị thuộc tính kết Một lợi Native Bayes cần lượng nhỏ liệu huấn luyện để tính tham số cần thiết cho việc phân lớp Cho V1, V2,…, Vm phân hoạch không gian mẫu V, Vi lớp Không gian thể X gồm thể mô tả tập thuộc tính A1, A2,…, An Khơng gian thể X tập học Khi với giá trị , phân lớp xuất giá trị hàm phân lớp f(x) Vi Tiếp cận Bayes lấy giá trị có xác suất cao VMAP cho thể Chữ MAP viết tắt cụm từ Maximum A Posterior 𝑉𝑀𝐴𝑃 = max 𝑃(𝑣𝑗 )𝑃(𝑎1 , 𝑎2 , … , 𝑎𝑛 , |𝑣𝑗 ) Trong cơng thức có hai số hạng cần quan tâm P(vj) P(a1, a2, …, an) Ta tính P(vj) cách đếm số lần xuất giá trị đích vj tập học Để tính P(a1, a2,…, an) ta giả thiết ban đầu thuộc tính độc lập Nói cách khác, xác suất thể quan sát < a1, a2,…, an > lớp vj tích khả thuộc tính riêng biệt vj 𝑃(𝑎1 , 𝑎2 , … , 𝑎𝑛 |𝑣𝑗 ) = ∏ 𝑃(𝑎𝑖 |𝑣𝑗 ) 𝑖 Do vậy, công thức viết lại là: 𝑉𝑁𝐵 = max 𝑃(𝑣𝑗 ) ∏ 𝑃(𝑎𝑖 |𝑣𝑗 ) 𝑣𝑗 ∈𝑉 𝑖 Với NB viết tắt cụm từ Naïve Bayes”[1] 2.1 Dữ liệu huấn luyện Giả sử có tập liệu gọi tập liệu huấn luyện bao gồm thuộc tính điều kiện: Tuổi (Già, Trẻ, Trung niên), Thu nhập (Cao, Thấp, Trung bình), Sinh viên (Khơng, Phải), Hạng tín dụng (Bình thường, Tốt); thuộc tính kết quả: Mua máy tính (Có, Khơng) 2.2 Áp dụng phương pháp phân lớp Naïve Bayes Ước lượng P(vj) với v1 = “Có”, v2 = “Khơng”, P(ai | vj) Ta thu P(vj): P(v1) = P(Mua máy tính = Có) = 6/10 P(v2) = P(Mua máy tính = Khơng) = 4/10 Và 87 TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Hà Đồng Hưng Bảng Tập liệu huấn luyện Tuổi Trung niên Trẻ Trung niên Già Già Già Trung niên Trẻ Trẻ Già Thu nhập Cao Cao Cao Trung bình Thấp Thấp Thấp Trung bình Thấp Trung bình Sinh viên Khơng Khơng Khơng Khơng Phải Phải Phải Khơng Phải Phải Hạng tín dụng Bình thường Tốt Bình thường Bình thường Bình thường Tốt Tốt Bình thường Bình thường Bình thường Mua máy tính Khơng Khơng Có Có Có Khơng Có Khơng Có Có Nguồn: Dịch từ [2] Dự đoán cho liệu mới: Bảng Dữ liệu dự báo Tuổi Trung niên Thu nhập Trung bình Hạng tín dụng Bình thường Sinh viên Phải Mua máy tính ? Nguồn: Dịch từ [2] Bảng Xác suất theo thuộc tính phân lớp P(Tuổi = Già | Mua máy tính = Có) P(Tuổi = Trẻ | Mua máy tính = Có) P(Tuổi = Trung niên | Mua máy tính = Có) P(Thu nhập = Cao | Mua máy tính = Có) P(Thu nhập = Thấp | Mua máy tính = Có) P(Thu nhập = Trung bình | Mua máy tính = Có) P(Sinh viên = Khơng | Mua máy tính = Có) P(Sinh viên = Phải | Mua máy tính = Có) P(Hạng tín dụng = Bình thường | Mua máy tính = Có) P(Hạng tín dụng = Tốt | Mua máy tính = Có) Tuổi 3/6 P(Tuổi = Già | Mua máy tính = Khơng) 1/6 P(Tuổi = Trẻ | Mua máy tính = Khơng) 2/6 P(Tuổi = Trung niên | Mua máy tính = Không) Thu nhập 1/6 P(Thu nhập = Cao | Mua máy tính = Khơng) 3/6 P(Thu nhập = Thấp | Mua máy tính = Khơng) 2/6 P(Thu nhập = Trung bình | Mua máy tính = Khơng) Sinh viên 2/6 P(Sinh viên = Khơng | Mua máy tính = Khơng) 4/6 P(Sinh viên = Phải | Mua máy tính = Khơng) Hạng tín dụng 5/6 P(Hạng tín dụng = Bình thường | Mua máy tính = Khơng) 1/6 P(Hạng tín dụng = Tốt | Mua máy tính = Khơng) Phân lớp: X new = (Tuổi = Trung niên, Thu nhập = Trung bình, Sinh viên = Phải, Tín nhiệm = Bình thường) Ta cần tính: P(Mua máy tính = Có) P(Xnew | Mua máy tính = Có ) = 6/10 * 2/6 * 2/6 * 4/6 * 5/6 = 0.037 P(Mua máy tính = Khơng) P(Xnew | Mua máy tính = Khơng ) = 4/10 * 1/4 * 1/4 * 1/4 * 2/4 = 0.003 Vậy X new = (Tuổi = Trung niên, Thu nhập = Trung bình, Sinh viên = Phải, Tín nhiệm = Bình thường) thuộc phân lớp Mua máy tính = Có 1/4 2/4 1/4 2/4 1/4 1/4 3/4 1/4 2/4 2/4 Trong cách xác định xác suất trên, ta hồn tồn tính cách nhẩm đếm tập liệu huấn luyện có số lượng dịng liệu Trong suy luận Naïve Bayes, cần số lượng nhỏ liệu thơng tin dự đốn Tuy nhiên, để thơng tin dự đốn đạt độ tin cậy cao, ta cần lượng liệu đủ lớn Khi có liệu lớn, ta nên dùng công cụ để hỗ trợ cho hiệu (thời gian nhanh, tốn cơng, hạn chế tối đa sai sót,…) Một cơng cụ phổ biến dễ sử dụng phần mềm Microsoft Excel Với việc tổ chức liệu 88 TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Số 26, Tháng 03 - 2021 Excel với việc áp dụng hàm Excel theo phương pháp phân lớp Naïve Bayes cho kết dự báo thông tin hiệu 2.3 Sử dụng Microsoft Excel Tạo tập tin Microsoft Excel đặt tên NaiveBayes.xlsx (tên đặt theo tùy ý) bao gồm sheet Các sheet đặt tên theo thứ tự: “Dữ liệu”, “Phân lớp”, “Tuổi”, “Thu nhập”, “Sinh viên”, “Hạng tín dụng”, “Dự báo” 2.3.1 Sheet “Dữ liệu” Sheet chứa liệu cho việc suy luận Dữ liệu sheet dịng với giá trị thuộc tính điều kiện xác định giá trị dự báo kiểm nghiệm thực tế Dữ liệu nhiều, dự báo cho kết đáng tin cậy Đặt tên tên biến tham chiếu đến địa Sheet “Dữ liệu”: CotTuoi = ‘Dữ liệu’!$A:$A, CotThuNhap = ‘Dữ liệu’!$B:$B, CotSinhVien = ‘Dữ liệu’!$C:$C, CotHangTinDung = ‘Dữ liệu’!$D:$D, CotMuaMayTinh = ‘Dữ liệu’!$E:$E Hình Sheet “Phân lớp” 2.3.3 Sheet “Tuổi” Sheet chứa giá trị thuộc tính tuổi: già, trẻ, trung niên (được xếp tăng dần) với xác suất phân lớp tương ứng Cơng thức tính xác suất sau: B2 = COUNTIFS (CotTuoi, A2, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có") B3 = COUNTIFS (CotTuoi, A3, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có") B4 = COUNTIFS (CotTuoi, A4, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có") C2 = COUNTIFS (CotTuoi, A2, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không") C3 = COUNTIFS (CotTuoi, A3, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không") C4 = COUNTIFS (CotTuoi, A4, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không") Đặt tên tên biến tham chiếu đến địa chỉ: VungGTTuoi=Tuổi!$A$2:$A$4 VungXSTuoiLopCo=Tuổi!$B$2:$B$4 VungXSTuoiLopKhong=Tuổi!$C$2:$C$4 Hình Sheet “Dữ liệu” 2.3.2 Sheet “Phân lớp” Sheet chứa xác suất cho phân lớp dựa sheet liệu Trong tập huấn luyện gồm có phân lớp cho dự đốn “Có” “Khơng” dự đốn thơng tin có mua máy tính hay khơng mua máy tính Các giá trị xác suất tính dựa vào hàm thống kê Microsoft Excel: B2 = COUNTIF (CotMuaMayTinh, A2) / (COUNTA (CotMuaMayTinh) - 1); B3 = COUNTIF (CotMuaMayTinh, A3) / (COUNTA (CotMuaMayTinh) - 1) Đặt tên tên biến tham chiếu đến địa chỉ: XSLopCo=‘Phân lớp’!$B$2, XSLopKhong=‘Phân lớp’!$B$3 Hình Sheet “Tuổi” 2.3.4 Sheet “Thu nhập” Sheet chứa giá trị thuộc tính thu nhập: cao, thấp, trung bình (được xếp tăng dần) với xác suất phân lớp tương ứng Cơng thức tính xác suất sau: B2 = COUNTIFS (CotThuNhap, A2, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có"); B3 = COUNTIFS (CotThuNhap, A3, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có"); B4 = COUNTIFS (CotThuNhap, A4, CotMuaMayTinh, 89 TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Hà Đồng Hưng 2.3.6 Sheet “Hạng tín dụng” Sheet chứa giá trị thuộc tính hạng tín dụng: bình thường, tốt (được xếp tăng dần) với xác suất phân lớp tương ứng Cơng thức tính xác suất sau: B2 = COUNTIFS (CotHangTinDung, A2, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có"); B3 = COUNTIFS (CotHangTinDung, A3, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có"); C2 = COUNTIFS (CotHangTinDung, A2, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không"); C3 = COUNTIFS (CotHangTinDung, A3, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không") Đặt tên tên biến tham chiếu đến địa chỉ: VungGTHangTinDung = ‘Sinh viên’!$A$2:$A$3, VungXSHangTinDungLopCo=‘Sinhviên’!$B$2:$B$3, VungXSHangTinDungLopKhong=‘Sinhviên’!$C$2:$C$3 "Có") / COUNTIF (CotMuaMayTinh, "Có"); C2 = COUNTIFS (CotThuNhap, A2, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không"); C3 = COUNTIFS (CotThuNhap, A3, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không"); C4 = COUNTIFS (CotThuNhap, A4, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không") Đặt tên tên biến tham chiếu đến địa chỉ: VungGTThuNhap = ‘Thu nhập’!$A$2:$A$4, VungXSThuNhapLopCo = ‘Thu nhập’!$B$2:$B$4, VungXSThuNhapLopKhong=‘Thunhập’!$C$2:$C$4 Hình Sheet “Thu nhập” 2.3.5 Sheet “Sinh viên” Sheet chứa giá trị thuộc tính sinh viên: khơng, phải (được xếp tăng dần) với xác suất phân lớp tương ứng Cơng thức tính xác suất sau: B2 = COUNTIFS (CotSinhVien, A2, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có"); B3=COUNTIFS(CotSinhVien, A3, CotMuaMayTinh, "Có") / COUNTIF (CotMuaMayTinh, "Có"); C2 = COUNTIFS (CotSinhVien, A2, CotMuaMayTinh, "Khơng") / COUNTIF (CotMuaMayTinh, "Không"); C3 = COUNTIFS (CotSinhVien, A3, CotMuaMayTinh, "Không") / COUNTIF (CotMuaMayTinh, "Không") Đặt tên tên biến tham chiếu đến địa chỉ: VungGTSinhVien = ‘Sinh viên’!$A$2:$A$3, VungXSSinhVienLopCo = ‘Sinh viên’!$B$2:$B$3, VungXSSinhVienLopKhong = ‘Sinh viên’!$C$2:$C$3 Hình Sheet “Hạng tín dụng” 2.3.7 Sheet “Dự báo” Sheet chứa giá trị thuộc tính điều kiện (tuổi, thu nhập, sinh viên, hạng tín dụng) dịng liệu cần dự báo thông tin kết dự báo (mua máy tính) Ta nhập thơng tin cho dịng liệu cần dự báo: Tuổi = Trung niên, Thu nhập = Trung bình, Hạng tín dụng = Bình thường Sau ta viết hàm cho E2, F2 G2 sau: E2=XSLopCo*LOOKUP(A2,VungGTTuoi, VungXSTuoiLopCo)*LOOKUP(B2,VungGTThuNhap, VungXSThuNhapLopCo)*LOOKUP(C2,Vung GTSinhVien,VungXSSinhVienLopCo)*LOOK UP(D2,VungGTHangTinDung,VungXSHang TinDungLopCo); F2=XSLopKhong*LOOKUP(A2,VungGT Tuoi,VungXSTuoiLopKhong)*LOOKUP(B2, VungGTThuNhap,VungXSThuNhapLopKhong)* LOOKUP(C2,VungGTSinhVien,VungXSSinh Hình Sheet “Sinh viên” 90 TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Số 26, Tháng 03 - 2021 phần mềm Excel, ta hồn tồn dự báo thông tin dựa vào phân lớp liệu Dữ liệu huấn luyện bổ sung cách dễ dàng cách nhập thêm liệu vào tập tin Excel Các công thức viết cập nhật tự động kết có thay đổi tập huấn luyện làm cho độ tin cậy thông tin dự báo ngày cao Qua cách thức phân tích liệu dự báo trên, rõ ràng thấy rằng, ta áp dụng phương pháp cho liệu tương tự khác mà ta cần để dự báo kết cách thay đổi liệu huấn luyện cho phù hợp VienLopKhong)*LOOKUP(D2,VungGTHang TinDung, VungXSHangTinDungLopKhong); G2 = IF (OR (MIN (E2:F2) = 0, F2 = E2), "Chưa thể dự đốn", IF (E2>F2, "Có", "Không")) Vậy X new = (Tuổi = Trung niên, Thu nhập = Trung bình, Sinh viên = Phải, Tín nhiệm = Bình thường) thuộc phân lớp Mua máy tính = Có Hình Sheet “Dự báo” KẾT LUẬN Với tập liệu huấn luyện, áp dụng phương pháp Naïve Bayes sử dụng TÀI LIỆU THAM KHẢO [1] Đỗ Phúc (2009), Giáo trình khai thác liệu, Nxb Đại học Quốc gia Thành phố Hồ Chí Minh [2] Jing Gao (Fall 2013), Data Mining and Bioinformatics, https://cse.buffalo.edu/~jing/cse601/ fa13/materials/classification_methods.pdf, ngày truy cập: 26-08-2020 Ngày nhận bài: 22-8-2020 Ngày biên tập xong: 06-01-2021 Duyệt đăng: 25-3-2021 91 ... mềm Excel phổ biến, linh hoạt tùy biến dễ sử dụng Bài viết trình bày cách dùng phần mềm Excel để dự báo thông tin theo phân lớp Naïve Bayes NỘI DUNG Naïve Bayes kỹ thuật để xây dựng phân lớp: ... kết dự báo thông tin hiệu 2.3 Sử dụng Microsoft Excel Tạo tập tin Microsoft Excel đặt tên NaiveBayes.xlsx (tên đặt theo tùy ý) bao gồm sheet Các sheet đặt tên theo thứ tự: “Dữ liệu”, ? ?Phân lớp? ??,... biến dễ sử dụng phần mềm Microsoft Excel Với việc tổ chức liệu 88 TẠP CHÍ KHOA HỌC ĐẠI HỌC VĂN LANG Số 26, Tháng 03 - 2021 Excel với việc áp dụng hàm Excel theo phương pháp phân lớp Naïve Bayes