Formal Language: A Practical Introduction
Author: Adam Brooks Webber
Copyright: 2008
Binding: Paperback
Page Count: 388
Security policy
Delivery policy
Return policy
Description:
NOW AVAILABLE AS AN E-BOOK (Note on e-book edition: For $30, you get access to this book on any computer or mobile device connected to the Internet. This access does not expire.)
This book has two major goals. The first is to help you understand and appreciate the beautiful and enduring ideas of formal language. These ideas are the birthright of all computer scientists, and they will profoundly change the way you think about computation. They are not only among the most beautiful, but also among the most useful tools in computer science. They are used to solve problems in a wide variety of practical applications, and they are especially useful for defining programming languages and for building language systems. The second purpose of this book is to help you develop a facility with these useful tools. Our code examples are in Java, but they are not particularly Java-centric and should be accessible to any programmer.
There is also a third major reason to study formal language, one that is not a primary focus of this book: to learn the techniques of mathematical proof. When you are learning about formal language, it can also be a good time to learn proof techniques, because the subject is full of theorems to practice on. But this book tries to make the beautiful and useful ideas for formal language accessible to students at all levels of mathematical interest and ability. To that end, although the book presents and discusses many simple proofs, it does not try to teach advanced proof techniques. Relatively few of the exercises pose challenging proof problems. Those planning graduate-level study of theoretical computer science would be well advised not to rely exclusively on this book for that kind of training.
Table of Contents:
- Fundamentals (PDF preview)
- Finite Automata
- Closure Properties for Regular Languages
- Deterministic-Finite-Automata Applications (PDF preview)
- Nonderministic Finite Automata
- NFA Applications
- Regular Expressions (PDF preview)
- Regular Expression Applications
- Advanced Topics in Regular Languages
- Grammars
- Nonregular Languages
- Context-free Languages
- Stack Machines
- The Context-free Frontier
- Stack Machine Applications
- Turing Machines
- Computability
- Uncomputability
- Cost Models
- Deterministic Complexity Classes
- Complexity Classes
Appendix A: From an NFA to a Regular Expression
Appendix B: A Time-Hierarchy Theorem
Appendix C: Som NP-Hardess Proofs