Bài giảng Chương trình dịch: Bài 4 do Trương Xuân Nam biên soạn, cùng nắm kiến thức trong bài học này thông qua tìm hiểu các nội dung sau: Bộ phân tích từ vựng cho ngôn ngữ A, Automat hữu hạn không đơn định (NFA), chuyển đổi từ biểu thức chính quy sang NFA, bộ phân tích từ vựng dựa trên DFA,...
Nội dung trích xuất từ tài liệu:
Bài giảng Chương trình dịch: Bài 4 - Trương Xuân Nam
CHƯƠNG TRÌNH DỊCH
Bài 4: Dùng DFA để phân tích từ vựng
Nội dung
1. Bộ phân tích từ vựng cho ngôn ngữ A
2. Automat hữu hạn (FA)
1. Đồ thị chuyển (TD)
2. Automat hữu hạn không đơn định (NFA)
3. Automat hữu hạn đơn định (DFA)
3. Chuyển đổi biểu thức chính quy sang DFA
1. Chuyển đổi từ biểu thức chính quy sang NFA
2. Chuyển đổi từ NFA sang DFA
3. DFA tối ưu cho phân tích từ vựng
4. Bộ phân tích từ vựng dựa trên DFA
5. Bài tập
TRƯƠNG XUÂN NAM
2
Phần 1
Bộ phân tích từ vựng cho ngôn
ngữ A
TRƯƠNG XUÂN NAM
3
Ngôn ngữ A
Viết bộ PTTV cho một ngôn ngữ lập trình đơn giản giúp
người sử dụng thực hiện các phép toán số
1. Mỗi lệnh viết trên 1 dòng
2. Lệnh bao giờ cũng có dạng =
3. là một tên riêng, không cần khai báo trước,
giống quy cách tên biến thông dụng, biến luôn là số
4. theo quy cách biểu thức số học, có thể gồm
Số nguyên, số thực, biến
Lời gọi hàm toán học thông dụng: sqrt, log, exp, power,…
Các phép toán thông dụng + - * / %
Các cặp ngoặc tròn
TRƯƠNG XUÂN NAM
4
Bộ PTTV đơn giản (mã giả C#)
// chứa thông tin về một từ tố
class Word {
public int wordType;
// chứa từ loại của từ
public string wordContent;
// chứa nội dung của từ
}
// bộ phân tích từ vựng
class PTTV {
// phân tích chuỗi S thành dãy các từ tố
public List process(string S) { … }
// lấy ra từ tố tiếp theo
Word getNextWord() { … }
}
TRƯƠNG XUÂN NAM
5
Bài giảng Chương trình dịch: Bài 4 - Trương Xuân Nam
Số trang: 55
Loại file: pdf
Dung lượng: 1.25 MB
Lượt xem: 22
Lượt tải: 0
Xem trước 6 trang đầu tiên của tài liệu này:
Thông tin tài liệu:
Tìm kiếm theo từ khóa liên quan:
Bài giảng Chương trình dịch Chương trình dịch Dùng DFA để phân tích từ vựng Chuyển đổi biểu thức chính quy Phân tích từ vựng dựa trên DFATài liệu có liên quan:
-
Giáo trình Lập trình cơ bản với C++: Phần 1
77 trang 242 0 0 -
Bài giảng Lập trình C căn bản: Chương 2 - Phạm Thế Bảo
31 trang 98 0 0 -
Giáo trình Lập trình nâng cao: Phần 1 - Nguyễn Văn Vinh
126 trang 36 0 0 -
Tập bài giảng Chương trình dịch
218 trang 33 0 0 -
Bài giảng Điện tử tin học lớp 11: Bài 1
9 trang 33 0 0 -
Nhập môn Chương trình dịch - Bài 1
17 trang 31 0 0 -
Bài giảng Thực hành chương trình dịch: Bài 5 - Phạm Đăng Hải
66 trang 31 0 0 -
Lý thuyết automata và ngôn ngữ hình thức
48 trang 29 0 0 -
Nhập môn Chương trình dịch - Bài 14
16 trang 29 0 0 -
Giáo trình Ôtômát và ngôn ngữ hình thức: Phần 2
98 trang 28 0 0