Bài giảng Lí thuyết ngôn ngữ hình thức và ôtômát - Chương 2: Ngôn ngữ chính quy và ôtômát hữu hạn - Nguyễn Thị Minh Huyền

Bài tập ứng dụng biểu thức chính quy Cú pháp phổ biến của biểu thức chính quy Mỗi kí tự biểu diễn chính nó, trừ các kí tự điều khiển (metacharacter): ? + - * . { } [ ] ( ) n | ˆ $ Để biểu diễn các kí tự điều khiển, thêm dấu n vào trước [03a−c] ≡ f0; 3; a; b; cg, [ˆ15] ≡ tập các kí tự khác 1 và 5 . biểu diễn kí tự bất kì, ˆ và $ đánh dấu đầu và cuối dòng n< và n> đánh dấu đầu và cuối từ, nb đánh dấu biên từ, nB đánh dấu xâu rỗng không ở biên từ Phép lặp: ?, *, +, fng, fn; g, fn; mg Phép lấy tích ghép, phép hợp nn biểu diễn xâu con nằm giữa cặp () thứ n trước đó.

pdf41 trang | Chia sẻ: thanhle95 | Lượt xem: 595 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Bài giảng Lí thuyết ngôn ngữ hình thức và ôtômát - Chương 2: Ngôn ngữ chính quy và ôtômát hữu hạn - Nguyễn Thị Minh Huyền, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Lí thuyết ngôn ngữ hình thức và ôtômát Chương 2. Ngôn ngữ chính quy và ôtômát hữu hạn Nguyễn Thị Minh Huyền Khoa Toán - Cơ - Tin học Trường Đại học Khoa học Tự nhiên Hà Nội Ngôn ngữ chính quy Văn phạm chính quy Ôtômat hữu hạn Nguồn (đồ thị chuyển) Ch2. NN chính quy& ôtômát hữu hạn 1 / 37 Ôtômát hữu hạn Nội dung 1. Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Ôtômát hữu hạn, không đơn định Đơn định hoá ôtômát Bài tập 2. Tính đóng của lớp ngôn ngữ chính quy 3. Biểu thức chính quy 4. Điều kiện cần của ngôn ngữ chính quy 5. Điều kiện cần và đủ của ngôn ngữ chính quy Ch2. NN chính quy& ôtômát hữu hạn 2 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Ví dụ Dàn máy phát thanh: P (nút Power): 2 chế độ ON/OFF S (nút chọn nguồn phát): chuyển đổi giữa 3 chế độ CD/Tape/Radio. Chỉ thay đổi được trạng thái của S khi máy bật (P = ON). Khi tắt máy (P = OFF ), S không thay đổi giá trị Ban đầu, máy tắt và ở chế độ CD. Bài toán: Cho 1 dãy thao tác bấm nút P hoặc S. Dãy thao tác này có cho phép đưa máy về trạng thái bật và ở chế độ Radio không? Ch2. NN chính quy& ôtômát hữu hạn 3 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Định nghĩa hình thức Ôtômat hữu hạn, đơn định Bộ năm A = (S,Σ, s0, δ,F ) S: tập hữu hạn các trạng thái, S 6= ∅ Σ 6= ∅ : bảng chữ cái vào s0 ∈ S trạng thái khởi đầu F ⊆ S : tập trạng thái kết δ : S × Σ→ S : hàm chuyển trạng thái δ(p, a) = q : máy đang ở trạng thái p, nếu đọc được chữ cái vào a thì chuyển sang trạng thái q biểu diễn dạng bảng Ch2. NN chính quy& ôtômát hữu hạn 4 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Biểu diễn ôtômat Biểu diễn bằng đồ thị chuyển (nguồn) Đỉnh vào, đỉnh ra/kết, cung s1 s2 0 1 0 1 Ch2. NN chính quy& ôtômát hữu hạn 5 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Ngôn ngữ đoán nhận bởi ôtômat hữu hạn, đơn định Hàm chuyển mở rộng δˆ : S × Σ∗ → S δˆ(p, ) = p ∀p ∈ S,a ∈ Σ, y ∈ Σ∗ : δˆ(p,ay) = δˆ(δ(p,a), y) Ngôn ngữ đoán nhận bởi ôtômat A: L(A) = {x ∈ Σ∗|δˆ(s0, x) ∈ F} Ch2. NN chính quy& ôtômát hữu hạn 6 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Tương đương giữa ôtômat và văn phạm chính quy Ôtômat hữu hạn, đơn định A tương đương văn phạm chính quy G: L(A) = L(G) Chuyển từ ôtômat sang văn phạm chính quy Chuyển từ văn phạm chính quy sang ôtômat G = ({a,b, c}, {S,A,B},S,P), P gồm các quy tắc: S → aA|bA|cB A→ cA|aB B → bB|a|c Ch2. NN chính quy& ôtômát hữu hạn 7 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Bài tập Cho bảng chữ cái Σ = {a,b, c}, xây dựng ôtômat đoán nhận các ngôn ngữ sau: 1. L1 = {an|n ≥ 2} 2. L2 = {x ∈ Σ∗||x | ≥ 1} 3. L3 = {ambnck |m ≥ 1,n ≥ 0, k ≥ 2} 4. L4 = {x ∈ Σ∗||x | lẻ} Ch2. NN chính quy& ôtômát hữu hạn 8 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, không đơn định Ôtômát hữu hạn, không đơn định Khác với ôtômat đơn định ở hàm chuyển: δ : S × (Σ ∪ {})→ 2S δ(p,a) ⊆ S Biểu diễn bằng đồ thị (nguồn): Đỉnh vào, đỉnh ra/kết, cung rỗng, cung cốt yếu, đỉnh cốt yếu (có cung cốt yếu đi vào) Ngôn ngữ đoán nhận bởi ôtômat không đơn định: Mở rộng hàm chuyển như ôtômat đơn định L(A) = {x ∈ Σ∗|δ(s0, x) ∩ F 6= ∅} Ch2. NN chính quy& ôtômát hữu hạn 9 / 37 Ôtômát hữu hạn Ôtômát hữu hạn, không đơn định Một số khái niệm, tính chất Đơn định: hàm chuyển đơn trị Đầy đủ: hàm chuyển xác định khắp nơi Đơn định và đầy đủ: Trong bảng hàm chuyển mọi ô đều có 1 trạng thái 2 ôtômat/nguồn tương đương: đoán nhận/sinh cùng một ngôn ngữ Ôtômat đơn định tương đương với ôtômat không đơn định? Ch2. NN chính quy& ôtômát hữu hạn 10 / 37 Ôtômát hữu hạn Đơn định hoá ôtômát Đơn định hoá nguồn Cho nguồn không đơn định A. Xây dựng nguồn đơn định, đầy đủ A′ tương đương với A Kí hiệu: S(A) – tập tất cả các đỉnh, F (A) - tập đỉnh ra, D(A) – tập đỉnh cốt yếu N(p,q) : tập các từ đi từ đỉnh p đến đỉnh q Cho a ∈ Σ, δ(p,a) = {q ∈ D(A)|a ∈ N(p,q)} δ(M ,a) = {∪δ(p,a),p ∈ M}, M ⊂ D(A) s′0 = {s0} Tập đỉnh của A′: ∀M ∈ S(A′) đã xác định, a ∈ Σ, bổ sung cung ghi chữ cái a tới đỉnh δ(M ,a) Tập đỉnh kết: F (A′) = {M ∈ S(A′)|M ∩ F (A) 6= ∅} Ch2. NN chính quy& ôtômát hữu hạn 11 / 37 Ôtômát hữu hạn Đơn định hoá ôtômát Đơn định hóa ôtômat Cho ôtômat không đơn định A. Xây dựng ôtômat đơn định, đầy đủ A′ tương đương với A A = (S,Σ, s0, δ,F ). Giả sử ∀s ∈ S, δ(s, ) = ∅ Xây dựng T : 2S × Σ→ 2S ∀s ∈ S,∀a ∈ Σ,T (s,a) = {s′ ∈ S|s′ ∈ δ(s,a)} ∀B ⊆ S,∀a ∈ Σ,T (B,a) = {∪T (s,a)|s ∈ B} A′ = (S′,Σ, {s0}, δ′,F ′) S′ ⊆ 2S, xây dựng trong quá trình xây dựng hàm T ∀p ∈ S′: δ′(p,a) = T (p,a) F ′ = {p ∈ S′|p ∩ F 6= ∅} Ch2. NN chính quy& ôtômát hữu hạn 12 / 37 Ôtômát hữu hạn Đơn định hoá ôtômát Tóm tắt lại Ngôn ngữ chính quy có thể sinh/đoán nhận bởi: văn phạm chính quy ôtômat hữu hạn (luôn đưa về được dạng đơn định, đầy đủ) nguồn/đồ thị chuyển (luôn đưa về được dạng đơn định, đầy đủ) Ch2. NN chính quy& ôtômát hữu hạn 13 / 37 Ôtômát hữu hạn Bài tập Bài tập Xây dựng ôtômat đoán nhận một ngôn ngữ đã cho 1. Xây dựng 3 ôtômat đoán nhận các tập các số tự nhiên chia hết cho 2, cho 3 và cho 5. 2. Xây dựng ôtômat mô phỏng máy bán nước tự động dùng tiền xu (1000, 2000, 5000). Giá 1 lon nước ngọt là 5000, 1 chai nước suối là 3000. Ch2. NN chính quy& ôtômát hữu hạn 14 / 37 Tính đóng của lớp ngôn ngữ chính quy Nội dung 1. Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Ôtômát hữu hạn, không đơn định Đơn định hoá ôtômát Bài tập 2. Tính đóng của lớp ngôn ngữ chính quy 3. Biểu thức chính quy 4. Điều kiện cần của ngôn ngữ chính quy 5. Điều kiện cần và đủ của ngôn ngữ chính quy Ch2. NN chính quy& ôtômát hữu hạn 15 / 37 Tính đóng của lớp ngôn ngữ chính quy Các phép toán trên nguồn Trang 53 -> 66 (giáo trình) Phép lấy phần bù Phép hợp Phép giao Phép lấy tích ghép Phép soi gương Phép lặp, lặp cắt Phép chia trái, chia phải Ch2. NN chính quy& ôtômát hữu hạn 16 / 37 Tính đóng của lớp ngôn ngữ chính quy Tính đóng của lớp ngôn ngữ chính quy Lớp ngôn ngữ chính quy đóng với các tất cả phép toán trên ngôn ngữ: hợp, giao, lấy phần bù, tích ghép, lặp, lặp cắt, soi gương, chia trái, chia phải. Ch2. NN chính quy& ôtômát hữu hạn 17 / 37 Biểu thức chính quy Nội dung 1. Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Ôtômát hữu hạn, không đơn định Đơn định hoá ôtômát Bài tập 2. Tính đóng của lớp ngôn ngữ chính quy 3. Biểu thức chính quy 4. Điều kiện cần của ngôn ngữ chính quy 5. Điều kiện cần và đủ của ngôn ngữ chính quy Ch2. NN chính quy& ôtômát hữu hạn 18 / 37 Biểu thức chính quy Biểu thức chính quy (Regular expression) Định nghĩa (quy nạp) Cho Σ = {a1,a2, . . . ,an} Cơ sở quy nạp: B = ai , B = , B = ∅ là các biểu thức chính quy, biểu diễn các ngôn ngữ {ai}, {}, ∅ Quy nạp: Cho B1,B2 là các biểu thức chính quy Khi đó B1.B2,B1 ∪ B2,B∗1 , (B1) cũng là các biểu thức chính quy Chỉ có các biểu thức được xác định như trên mới là các biểu thức chính quy trên bảng chữ cái Σ Ch2. NN chính quy& ôtômát hữu hạn 19 / 37 Biểu thức chính quy Biểu thức chính quy – nguồn Xây dựng nguồn tương đương với biểu thức chính quy Cơ sở quy nạp: Nguồn sinh {a}, {}, ∅ Các phép toán: hợp, tích ghép, lặp: phép toán trên nguồn Xây dựng biểu thức chính quy tương đương với nguồn Đường đi thông thường: tích ghép, hợp Chu trình: lặp Ch2. NN chính quy& ôtômát hữu hạn 20 / 37 Biểu thức chính quy Biểu thức chính quy Ngôn ngữ chính quy⇔ Biểu thức chính quy Biểu thức chính quy trong lập trình Tìm kiếm xâu theo mẫu (pattern) nào đó VD: Xử lí gộp tên tệp Tìm kiếm trong Unix/Linux Tìm kiếm, thay thế xâu trong emacs Công cụ xử lí xâu trong các ngôn ngữ lập trình Ch2. NN chính quy& ôtômát hữu hạn 21 / 37 Biểu thức chính quy Bài tập ứng dụng biểu thức chính quy Cú pháp phổ biến của biểu thức chính quy Mỗi kí tự biểu diễn chính nó, trừ các kí tự điều khiển (metacharacter): ? + - * . { } [ ] ( ) \ | ˆ $ Để biểu diễn các kí tự điều khiển, thêm dấu \ vào trước [03a−c] ≡ {0,3,a,b, c}, [ˆ15] ≡ tập các kí tự khác 1 và 5 . biểu diễn kí tự bất kì, ˆ và $ đánh dấu đầu và cuối dòng \ đánh dấu đầu và cuối từ, \b đánh dấu biên từ, \B đánh dấu xâu rỗng không ở biên từ Phép lặp: ?, *, +, {n}, {n, }, {n,m} Phép lấy tích ghép, phép hợp | \n biểu diễn xâu con nằm giữa cặp () thứ n trước đó. Ch2. NN chính quy& ôtômát hữu hạn 22 / 37 Biểu thức chính quy Bài tập ví dụ về RE Viết biểu thức chính quy theo cú pháp trên để tìm các xâu sau trong các tệp : (a) Từ language (b) Các dòng trong đó từ language xuất hiện ít nhất 2 lần (c) Các số thập phân Ch2. NN chính quy& ôtômát hữu hạn 23 / 37 Biểu thức chính quy Bài tập ví dụ về RE và FSA (Finite State Automata) Xác định biểu thức chính quy và ôtômat đơn định hữu hạn đoán nhận các ngôn ngữ : (i) Tập số thực dấu phẩy động (ii) Tập các xâu gồm các chữ số 0-9 có chứa xâu con 11 (iii) Tập ngày tháng theo định dạng ngày(2 chữ số)/tháng(2 chữ số). Chú ý ràng buộc số ngày trong tháng. Ch2. NN chính quy& ôtômát hữu hạn 24 / 37 Điều kiện cần của ngôn ngữ chính quy Nội dung 1. Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Ôtômát hữu hạn, không đơn định Đơn định hoá ôtômát Bài tập 2. Tính đóng của lớp ngôn ngữ chính quy 3. Biểu thức chính quy 4. Điều kiện cần của ngôn ngữ chính quy 5. Điều kiện cần và đủ của ngôn ngữ chính quy Ch2. NN chính quy& ôtômát hữu hạn 25 / 37 Điều kiện cần của ngôn ngữ chính quy Điều kiện cần của ngôn ngữ chính quy: Bổ đề bơm Ứng dụng: Khẳng định một ngôn ngữ không phải là chính quy Ôtômat tối tiểu: Trong các ôtômat đơn định, đầy đủ đoán nhận một ngôn ngữ chính quy, gọi các ôtômat có số trạng thái ít nhất là các ôtômat tối tiểu Điều kiện cần: Giả sử L là ngôn ngữ chính quy Luôn tồn tại l ∈ N+: ∀z ∈ L, |z| > l thì tìm được 3 từ u, x , v (|x | ≥ 1) để z = uxv ∀n = 0, 1, 2 · · · : zn = uxnv ∈ L Ch2. NN chính quy& ôtômát hữu hạn 26 / 37 Điều kiện cần của ngôn ngữ chính quy Chứng minh L - ngôn ngữ chính quy, đoán nhận được bởi một otomat tối tiểu có n trạng thái Chọn l = n, xét từ z ∈ L, với |z| = m > l Đặt δ(s0,a1) = st,1, δ(st,1,a2) = st,2, · · · δ(st,m−1,am) = st,m Vì m > l nên ∃i < j : st,i = st,j Đặt u = a1 · · · ai , x = ai+1 · · · aj , v = aj+1 · · · am Khi đó δ(s0,u) = δ(s0,ux) = δ(s0,uxn) ∀n ≥ 0 ⇔ δ(s0,uv) = δ(s0,uxv) = δ(s0,uxnv) ∀n ≥ 0 ⇔ ∀n ≥ 0: zn = uxnv ∈ L. Ch2. NN chính quy& ôtômát hữu hạn 27 / 37 Điều kiện cần của ngôn ngữ chính quy Ứng dụng Áp dụng chứng minh một ngôn ngữ không phải là chính quy L1 = {ap|p nguyên tố} Giả sử L1 chính quy⇒ ∀p nguyên tố đủ lớn, ∃m, k ≥ 0,n ≥ 1: p = m + n + k , thoả mãn ∀i ≥ 0, aman∗iak ∈ L1. Chọn i = p + 1 = m + n + k + 1, có aman∗iak = aman∗(m+n+k+1)ak = ap(n+1) ∈ L1 ⇒ mâu thuẫn L2 = {anbn|n ≥ 1} Giả sử L2 chính quy, ∀n đủ lớn, ∃u, x , v ∈ {a,b}∗, |x | > 0: uxv = anbn và ∀i ≥ 0, ux iv ∈ L2 Xét 3 trường hợp x là từ con của an, x là từ con của bn, x chứa cả a và b để đưa đến kết luận mâu thuẫn. Ch2. NN chính quy& ôtômát hữu hạn 28 / 37 Điều kiện cần của ngôn ngữ chính quy Ứng dụng Áp dụng chứng minh một ngôn ngữ không phải là chính quy L1 = {ap|p nguyên tố} Giả sử L1 chính quy⇒ ∀p nguyên tố đủ lớn, ∃m, k ≥ 0,n ≥ 1: p = m + n + k , thoả mãn ∀i ≥ 0, aman∗iak ∈ L1. Chọn i = p + 1 = m + n + k + 1, có aman∗iak = aman∗(m+n+k+1)ak = ap(n+1) ∈ L1 ⇒ mâu thuẫn L2 = {anbn|n ≥ 1} Giả sử L2 chính quy, ∀n đủ lớn, ∃u, x , v ∈ {a,b}∗, |x | > 0: uxv = anbn và ∀i ≥ 0, ux iv ∈ L2 Xét 3 trường hợp x là từ con của an, x là từ con của bn, x chứa cả a và b để đưa đến kết luận mâu thuẫn. Ch2. NN chính quy& ôtômát hữu hạn 28 / 37 Điều kiện cần của ngôn ngữ chính quy Ứng dụng Áp dụng chứng minh một ngôn ngữ không phải là chính quy L1 = {ap|p nguyên tố} Giả sử L1 chính quy⇒ ∀p nguyên tố đủ lớn, ∃m, k ≥ 0,n ≥ 1: p = m + n + k , thoả mãn ∀i ≥ 0, aman∗iak ∈ L1. Chọn i = p + 1 = m + n + k + 1, có aman∗iak = aman∗(m+n+k+1)ak = ap(n+1) ∈ L1 ⇒ mâu thuẫn L2 = {anbn|n ≥ 1} Giả sử L2 chính quy, ∀n đủ lớn, ∃u, x , v ∈ {a,b}∗, |x | > 0: uxv = anbn và ∀i ≥ 0, ux iv ∈ L2 Xét 3 trường hợp x là từ con của an, x là từ con của bn, x chứa cả a và b để đưa đến kết luận mâu thuẫn. Ch2. NN chính quy& ôtômát hữu hạn 28 / 37 Điều kiện cần của ngôn ngữ chính quy Ứng dụng Áp dụng chứng minh một ngôn ngữ không phải là chính quy L1 = {ap|p nguyên tố} Giả sử L1 chính quy⇒ ∀p nguyên tố đủ lớn, ∃m, k ≥ 0,n ≥ 1: p = m + n + k , thoả mãn ∀i ≥ 0, aman∗iak ∈ L1. Chọn i = p + 1 = m + n + k + 1, có aman∗iak = aman∗(m+n+k+1)ak = ap(n+1) ∈ L1 ⇒ mâu thuẫn L2 = {anbn|n ≥ 1} Giả sử L2 chính quy, ∀n đủ lớn, ∃u, x , v ∈ {a,b}∗, |x | > 0: uxv = anbn và ∀i ≥ 0, ux iv ∈ L2 Xét 3 trường hợp x là từ con của an, x là từ con của bn, x chứa cả a và b để đưa đến kết luận mâu thuẫn. Ch2. NN chính quy& ôtômát hữu hạn 28 / 37 Điều kiện cần của ngôn ngữ chính quy Ứng dụng Áp dụng chứng minh một ngôn ngữ không phải là chính quy L1 = {ap|p nguyên tố} Giả sử L1 chính quy⇒ ∀p nguyên tố đủ lớn, ∃m, k ≥ 0,n ≥ 1: p = m + n + k , thoả mãn ∀i ≥ 0, aman∗iak ∈ L1. Chọn i = p + 1 = m + n + k + 1, có aman∗iak = aman∗(m+n+k+1)ak = ap(n+1) ∈ L1 ⇒ mâu thuẫn L2 = {anbn|n ≥ 1} Giả sử L2 chính quy, ∀n đủ lớn, ∃u, x , v ∈ {a,b}∗, |x | > 0: uxv = anbn và ∀i ≥ 0, ux iv ∈ L2 Xét 3 trường hợp x là từ con của an, x là từ con của bn, x chứa cả a và b để đưa đến kết luận mâu thuẫn. Ch2. NN chính quy& ôtômát hữu hạn 28 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Nội dung 1. Ôtômát hữu hạn Ôtômát hữu hạn, đơn định và ngôn ngữ chính quy Ôtômát hữu hạn, không đơn định Đơn định hoá ôtômát Bài tập 2. Tính đóng của lớp ngôn ngữ chính quy 3. Biểu thức chính quy 4. Điều kiện cần của ngôn ngữ chính quy 5. Điều kiện cần và đủ của ngôn ngữ chính quy Ch2. NN chính quy& ôtômát hữu hạn 29 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Quan hệ tương đương bất biến phải Cho tập X 6= ∅ và quan hệ hai ngôi T (x , y) trên X . T là quan hệ tương đương: phản xạ, đối xứng, bắc cầu ⇒ T chia X thành các lớp tương đương X1,X2, · · · ,Xm, lập thành phân hoạch của X theo quan hệ T (các tập Xi khác rỗng, rời nhau, hợp với nhau bằng tập X ). Khi đó m (có thể hữu hạn hoặc vô hạn) gọi là chỉ số của quan hệ tương đương T . Ví dụ m hữu hạn: Quan hệ đồng dư cho n > 0 trên tập số tự nhiên. Ví dụ m vô hạn: Quan hệ có cùng số chữ số trên tập số tự nhiên. Quan hệ tương đương bất biến phải: ∀z ∈ X , nếu T (x , y)⇒ T (xz, yz). Ch2. NN chính quy& ôtômát hữu hạn 30 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Quan hệ tương đương bất biến phải RL Cho ngôn ngữ L ⊆ Σ∗, x , y ∈ Σ∗ được gọi là có quan hệ RL (x RL y)nếu x và y không có hậu tố phân biệt z nào: ∀z ∈ Σ∗ : xz ∈ L⇔ yz ∈ L Ví dụ: Cho L = (00)+ 00RL0000 01RL001 RL là một quan hệ tương đương bất biến phải Cho một ôtômat đơn định, đầy đủ đoán nhận ngôn ngữ L chính quy, 2 từ x , y ∈ Σ∗ thoả mãn δ(s0, x) = δ(s0, y) có quan hệ RL. Ch2. NN chính quy& ôtômát hữu hạn 31 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Quan hệ RL: Ví dụ Kí hiệu [x]: lớp từ tương đương bất biến phải theo quan hệ RL với x trên Σ∗ Ví dụ, cho L = (00)+ [] = {} [0] = 0(00)∗ [1] = 0∗1(0|1)∗ [00] = (00)+ Ch2. NN chính quy& ôtômát hữu hạn 32 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Định lí Myhill-Nerode (điều kiện cần và đủ của ngôn ngữ chính quy) L là ngôn ngữ chính quy⇔ L là hợp của một số lớp tương đương theo quan hệ tương đương bất biến phải với chỉ số hữu hạn trên tập Σ∗. Chứng minh điều kiện cần: L chính quy⇒ L đoán nhận được bởi ôtômat đơn định, đầy đủ A = (S,Σ, s0, δ,F ) Xây dựng quan hệ tương đương bất biến phải T : T (x , y)⇔ δ(s0, x) = δ(s0, y) Chỉ số của T : T chia Σ∗ thành phân hoạch X1, · · · ,Xm Giả sử x ∈ Xi và δ(s0, x) = sti : Xi gắn với trạng thái sti A hữu hạn trạng thái nên m hữu hạn (không vượt quá |S|) Xét tất cả các lớp tương đương Xi1 , · · · ,Xin : Xij ∩ L 6= ∅ Chứng minh được L = ∪Xij (j = 1, · · · ,n) Ch2. NN chính quy& ôtômát hữu hạn 33 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Định lí Myhill-Nerode (tiếp) Chứng minh điều kiện đủ Có quan hệ T chia Σ∗ thành phân hoạch X1, · · · ,Xm. L là hợp của một số lớp Xi . Xây dựng ôtômat A = (S,Σ, s0, δ,F ) : Kí hiệu lớp có chứa từ p là [p], lớp chứa từ rỗng [] Xây dựng S = {X1, · · · ,Xm} s0 = [], F = {[p] | p ∈ L} δ([p], a) = [pa] A đoán nhận L Nhận xét: Số trạng thái của S bằng chỉ số của T ⇒ A là ôtômat tối tiểu sinh L. Ch2. NN chính quy& ôtômát hữu hạn 34 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Ứng dụng định lí Myhill-Nerode Xét tính chính quy của một ngôn ngữ Xây dựng ôtômat tối tiểu Ch2. NN chính quy& ôtômát hữu hạn 35 / 37 Điều kiện cần và đủ của ngôn ngữ chính quy Xét tính chính quy của ngôn ngữ Các ví dụ sau đều xét Σ = {0,1} L1 = {0n1n|n ≥ 1} L2 = {x |x = xR}, xR : từ ngược của x L3 = {xwx |x ∈ {0,1},w ∈ (0|1)+} Ch2. NN chính quy& ôtômát hữu hạn 36 / 37