Kĩ thuật lập trình - Chương 3: Các kỹ thuật tìm kiếm Heuristics

 Khái niệm

 Tìm kiếm tốt nhất trước

 Phương pháp leo ñồi

 Cài ñặt hàm ñánh giá

 Thu giảm ràng buộc

 Giải thuật cắt tỉa α-

pdf35 trang | Chia sẻ: Mr Hưng | Lượt xem: 916 | Lượt tải: 0download
Bạn đang xem trước 20 trang nội dung tài liệu Kĩ thuật lập trình - Chương 3: Các kỹ thuật tìm kiếm Heuristics, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
1Chương 3: Các kỹ thuật tìm kiếm Heuristics 2Nội dung  Khái niệm  Tìm kiếm tốt nhất trước  Phương pháp leo ñồi  Cài ñặt hàm ñánh giá  Thu giảm ràng buộc  Giải thuật cắt tỉa α-β 3Giới hạn của duyệt hệ thống  8-puzzle  Lời giải cần trung bình 22 cấp (depth)  ðộ rộng của bước ~ 3  Tìm kiếm vét cạn cho 22 cấp cần  3.1 x 1010 states  Nếu chỉ giới hạn ở d=12, cần trung bình 3.6 triệu trạng thái [24 puzzle có 1024 trạng thái]  Cần chiến lược tìm kiếm heuristic 4Khái niệm: Heuristic  Heuristics: là các phỏng ñoán, ước chừng dựa trên kinh nghiệm, trực giác  Các hệ giải quyết AI sử dụng heuristic trong hai tình huống cơ bản:  Bài toán ñược ñịnh nghĩa chính xác nhưng chi phí tìm lời giải vét cạn là không thể chấp nhận VD: Sự bùng nổ KGTT trong trò chơi cờ vua  Vấn ñề với nhiều sự mơ hồ trong lời phát biểu bài toán hay dữ liệu cũng như tri thức sẵn có VD: Chẩn ñoán trong y học 5Khái niệm: Giải thuật Heuristics  Một giải thuật heuristic có thể ñược xem gồm 2 phần:  Phép ño heuristic: thể hiện qua hàm ñánh giá heuristic (evaluation function f(n) - EF), dùng ñể ñánh giá các ñặc ñiểm của một trạng thái trong KGTT  Giải thuật tìm kiếm heuristic:  TK tốt nhất (best-first search)  A* search  Giải thuật leo núi (hill-climbing) 6Ví dụ phép ño Heuristics 7Ví dụ phép ño Heuristics (tt) Heuristic “Số ñường thắng nhiều nhất” (theo các ñường chéo trên bàn cờ) áp dụng cho các con cờ ñầu tên ñặt vào bàn cờ trong bàn cờ tic-tac-toe 8Ví dụ phép ño Heuristics (tt) 9Giải thuật leo ñồi (Hill climbing)  Giải thuật  Xét trạng thái bắt ñầu  Nếu là ñích => dừng  Ngược lại: thiết lập khởi ñầu như TT hiện tại  Lặp ñến khi: gặp ñích OR không còn luật nào chưa ñược áp dụng vào TT hiện tại  Lựa một luật ñể áp dụng vào TT hiện tại ñể sinh ra một TT mới  Xem xét TT mới này  Nếu là ñích => dừng  Nếu không là ñích, nhưng tốt hơn TT hiện tại => thiết lập TT mới là TT hiện tại  Nếu không tốt hơn thì thì tiếp lần lặp kế 10 Giải thuật leo ñồi (tt)  Giới hạn  Giải thuật có khuynh hướng bị sa lầy ở những cực ñại cục bộ  Lời giải tìm ñược không tối ưu  Không tìm ñược lời giải mặc dù có tồn tại lời giải  Giải thuật có thể gặp vòng lặp vô hạn do không lưu giữ thông tin về các trạng thái ñã duyệt 11 Giải thuật leo ñồi (tt)  Bài toán 8 Hậu  Trang thái bắt ñầu: mỗi Hậu trên 1cột  Trạng thái ñích: các Hậu không thể tấn công nhau  Phép ño Heuristic h(n) : số lượng các cập hậu ñối kháng nhau H(n) = 17 h(n) = 1 12 Tìm kiếm tốt nhất (BFS)  Là phương pháp dung hoà của BrFS và DFS  Có sử dụng ñể ñánh giá ưu thế của mỗi trạng thái, có thể là ước lượng từ nó ñến TT ñích  Tại mỗi bước, GT sẽ chọn trạng thái mà nó cho rằng là có ưu thế nhất trong số các trạng thái ñã sinh ra ñược ñến thời ñiểm ñó  Khác với GT leo ñồi có cải tiến ở chổ: có lưu tất cả những TT ñã phát sinh ñến thời ñiểm chọn TT ñể xét tiếp  Dùng hai danh sách:  OPEN: chứa các TT sẽ ñược xét.  CLOSED: chứa các TT ñã xét qua. 13 Tìm kiếm tốt nhất (BFS)  Giải thuật  OPEN = [TT ñầu]  Lặp ñến khi: gặp ñích OR OPEN rỗng  Lấy TT tốt nhất từ OPEN  Phát sinh các con của nó  Với mỗi con:  Nếu nó chưa ñược phát sinh: gán nó trị ñánh giá, ñưa vào OPEN, ghi nhận TT cha của nó  Nếu ñã ñược phát sinh trước: Nếu ñạt ñến bởi ñường khác tốt hơn => ghi nhận lại TT cha của nó, cập nhật lại trị ñánh giá của nó và của các con của nó 14 Tìm kiếm tốt nhất (BFS) 1. open = [A5]; closed = [ ] 2. ðánh giá A5; open = [B4,C4,D6]; closed = [A5] 3. ðánh giá B4; open = [C4,E5,F5,D6]; closed = [B4,A5] 4. ðánh giá C4; open = [H3,G4,E5,F5,D6]; closed = [C4,B4,A5] 5. ðánh giá H3; open = [O2,P3,G4,E5,F5,D6]; closed = [H3,C4,B4,A5] 6. ðánh giá O2; open = [P3,G4,E5,F5,D6]; closed = [O2,H3,C4,B4,A5] 7. ðánh giá P3; tìm ñược lời giải! Open là queue, xếp theo Heuristic tăng dần 15 Cài ñặt hàm ñánh giá (EF)  Xét trò chơi 8-ô, mỗi trạng thái n, một giá trị f(n): f(n) = g(n) + h(n)  g(n) = khoảng cách thực sự từ n ñến trạng thái bắt ñầu  h(n) = hàm heuristic ñánh giá khoảng cách từ trạng thái n ñến mục tiêu. 57 461 382 57 461 382 567 41 382 57 461 382 start 567 48 321 goal g(n) = 0 g(n) = 1 6 4 6f(n) = h(n): số lượng các vị trí còn sai; 16 Ví dụ 17 Ví dụ 18 Ví dụ 19 Heuristic trong trò chơi ñối kháng  Giải thuật minimax  Hai ñấu thủ trong trò chơi ñược gọi là MIN và MAX.  Mỗi nút lá có giá trị:  1 nếu là MAX thắng,  0 nếu là MIN thắng.  Minimax sẽ truyền các giá trị này lên cao dần trên ñồ thị, qua các nút cha mẹ kế tiếp theo các luật sau:  Nếu trạng thái cha mẹ là MAX, gán cho nó giá trị lớn nhất có trong các trạng thái con.  Nếu trạng thái cha mẹ là MIN, gán cho nó giá trị nhỏ nhất có trong các trạng thái con. 20 Áp dụng GT Minimax vào Trò Chơi NIM MIN MIN MIN MAX MAX MAX 1 1 1 1 1 1 1 0 0 0 0 0 01 KẾT QUẢ CỦA MIN KẾT QUẢ CỦA MAX 21 Minimax với ñộ sâu lớp cố ñịnh  Minimax ñối với một KGTT giả ñịnh 3 là giá trị max của các nút con 2 là giá trị min của các nút con Các nút lá ñược gán các giá trị heuristic nào ñó Còn giá trị tại các nút trong là các giá trị nhận ñược dựa trên giải thuật Minimax (min hay max cua các nút con) 22 Heuristic trong trò chơi tic-tac-toe Hàm Heuristic: E(n) = M(n) – O(n) Trong ñó: M(n) là tổng số ñường thắng có thể của tôi O(n) là tổng số ñường thắng có thể của ñối thủ E(n) là trị số ñánh giá tổng cộng cho trạng thái n 23 Minimax 2 lớp ñược áp dụng vào nước ñi mở ñầu trong tic-tac-toe Max (X) có 5 ñường thắng, Min(O) có 4, hàm heuristic là -1 24 Thu giảm bài toán  ðồ thị AND-OR :  ðược dùng ñể biểu diễn KGTT cho bài toán giải ñược bằng cách phân rã ra các bài toán nhỏ hơn  Khi bài toán ñược phân rã thành N bài toán con, mà tất cả chúng phải ñược giải ñể hoàn thành bài toán lớn thì ñược biểu diễn thành cung AND chỉ ñến N trạng thái con  Nhiều cách giải cho bài toán có thể ñược dùng thì có thể biểu diễn bởi cung OR A có thể ñược thông qua hai cách: - Giải B, hoặc - Giải cả C và D 25 Thu giảm bài toán (tt)  ðồ thị AND-OR :  Nếu dùng giải thuật BFS cho việc tìm lời giải trên ñồ thị AND- OR thì có lẽ không thích hợp vì như xem xét ñồ thị sau:  Nếu giá trị ghi kề bên trạng thái là trị ước lượng cho trạng thái ñó.  Theo BFS thì trạng thái kế tiếp ñược chọn là C, như:  Khi chọn cách giải qua C thì bắt buộc phải giải cả D. Do vậy tổng chi phí cho cách giải này là: C+D+ 2 = 9, 2 là giá trị của hàm g trong BFS  Trong khi ñó nếu chọn cách giải qua B thì chi phí chỉ là: B+1 = 6. 26 Thu giảm bài toán (tt)  GT thu giảm bài toán  Khởi ñộng ñồ thị là TT bắt ñầu.  Lặp ñến khi: TT ñầu ñược gán nhãn là SOLVED OR chi phí vượt qua ngưỡng FUTILITY:  Duyệt ñồ thị bắt ñầu từ TT ñầu, theo con ñường tốt nhất hiện tại, tích luỹ tập trạng thái trên con ñường ñó mà nó chưa ñược mở rộng hoặc ñược gán nhãn SOLVED.  Lấy một TT chưa mở rộng và mở rộng nó. Nếu không có con thì gán FUTILITY bằng trị của TT này. Ngược lại, thêm các con vào ñồ thị và mỗi chúng tính f’ (sử dụng chỉ h’, bỏ qua g). Nếu f’ =0 thì gán nhãn cho TT ñó là SOLVED.  Thay ñổi f’ của TT ñã ñược mở rộng ñể phản ánh thông tin ñược cung cấp bởi con của nó. Lan truyền trị này ngược lên ñồ thị. Nếu một TT có cung mà tất cả các con của nó ñã ñược gán nhãn SOLVED thì nó cũng ñược gán nhãn SOLVED. Khi lan truyền ngược lên ñồ thị ñánh dấu cung nào là tốt nhất như là phần của con ñường tốt nhất hiện tại. 27 Thu giảm bài toán (tt)  GT Thu giảm (tt.) - từng bước: 28 Thu giảm bài toán (tt)  GT Thu giảm (tt.) - từng bước: 29 Giải thuật cắt tỉa α-β  Tìm kiếm theo kiểu depth-first.  Nút MAX có 1 giá trị α (luôn tăng)  Nút MIN có 1 giá trị β (luôn giảm)  Tìm Kiếm có thể kết thúc dưới bất kỳ:  Nút MIN nào có β ≤ α của bất kỳ nút cha MAX nào.  Nút MAX nào có α ≥ β của bất kỳ nút cha MIN nào.  Giải thuật cắt tỉa α-β thể hiện mối quan hệ giữa các nút ở lớp n và n+2, mà tại ñó toàn bộ cây có gốc tại lớp n+1 có thể cắt bỏ. 30 Cắt tỉa α (vị trí MAX) S A C MAX MIN B Có giá trị >= α α - cut Có giá trị = α MAX Có giá trị <= k Có giá trị = k X Y . Z ðiều kiện 1: Chỉ cần biết giá trị tại A và B ðiều kiện 2: Giá trị A > giá trị B ðiều kiện 3: X, Y, .. , Z ở vị trí Max Bỏ những cây con có gốc là X,Y,, Z 31 Cắt tỉa β (vị trí Min) S A C MIN MAX B β - cut MIN Có giá trị = β Có giá trị <= β Có giá trị = k Có giá trị >= k X Y . Z ðiều kiện 1: Chỉ cần biết giá trị tại A và B ðiều kiện 2: Giá trị A < giá trị B ðiều kiện 3: X, Y, .. , Z ở vị trí Min Bỏ những cây con có gốc là X,Y,, Z 32 Cắt tỉa α-β: ví dụ 33 Bài tập: bài 1 (trò ñố 8 ô như) Dùng các hàm lượng giá heuristic sau  h1 = số lượng các vị trí sai khác so với trạng thái goal.  h2 = tổng số ñộ dời ngắn nhất của các ô về vị trí ñúng (khoảng cách Manhattan) hãy triển khai không gian trạng thái của bài toán ñến mức 5 (nếu chưa tìm ñược goal): a) Theo giải thuật leo núi b) Theo giải thuật tìm kiếm rộng c) Theo giải thuật tìm kiếm sâu d) Theo giải thuật tìm kiếm tốt nhất ñầu tiên 458 76 321 Start 567 48 321 Goal 34 Trong cây tìm kiếm dưới ñây, mỗi nút có 2 giá trị ñi kèm: giá trị bên trái của nút (in nghiêng) thể hiện giá trị heuristic của nút, và giá trị bên phải nút thể hiện thứ tự nút ñược duyệt qua. Với mỗi chiến lược tìm kiếm dưới ñây, hãy viết danh sách thứ tự các nút ñược duyệt, so sánh và cho biết ta ñã dùng giải thuật tìm kiếm nào trên cây : a) Tìm kiếm rộng BFS b) Tìm kiếm sâu DFS c) Tìm kiếm tốt nhất ñầu tiên BFS d) Tìm kiếm leo núi Bài tập: bài 2 (duyệt ñồ thị) 35 Kê danh sách các nút ñược duyệt theo tìm kiếm DFS.  Thực hiện giải thuật Minimax trên cây.  Sẽ có gì khác biệt nếu như ta dùng giải thuật cắt tỉa alpha – beta ñể ñịnh trị nút gốc cho cây? Bài tập: bài 3 (minimax)

Các file đính kèm theo tài liệu này:

  • pdfbaigiangtrituenhantaochuong3_7085.pdf