Formal Language & Automata Theory (BTCS 502-18)

Course Details

Credits: 3

Hours per Week: L:3 T:1 P:0

Course Objectives

This course aims to:

Course Outcomes

After completion of this course, students will be able to:

  1. Write a formal notation for strings, languages and machines.
  2. Design finite automata to accept a set of strings of a language.
  3. Design context free grammars to generate strings of context free language.
  4. Determine equivalence of languages accepted by Push Down Automata and languages generated by context free grammars.
  5. Distinguish between computability and non-computability and Decidability and undecidability.

Detailed Syllabus

Module 1: Introduction

Alphabet, languages and grammars, productions and derivation, Chomsky hierarchy of languages.

[3hrs] (CO1)

Module 2: Regular languages and finite automata

Regular expressions and languages, deterministic finite automata (DFA) and equivalence with regular expressions, nondeterministic finite automata (NFA) and equivalence with DFA, regular grammars and equivalence with finite automata, properties of regular languages, pumping lemma for regular languages, minimization of finite automata.

[8hrs] (CO2)

Module 3: Context-free languages and pushdown automata

Context-free grammars (CFG) and languages (CFL), Chomsky and Greibach normal forms, nondeterministic pushdown automata (PDA) and equivalence with CFG, parse trees, ambiguity in CFG, pumping lemma for context-free languages, deterministic pushdown automata, closure properties of CFLs.

[8hrs] (CO3)

Module 4: Context-sensitive languages

Context-sensitive grammars (CSG) and languages, linear bounded automata and equivalence with CSG.

[5hrs] (CO4)

Module 5: Turing machines

The basic model for Turing machines (TM), Turing recognizable (recursively enumerable) and Turing-decidable (recursive) languages and their closure properties, variants of Turing machines, nondeterministic TMs and equivalence with deterministic TMs, unrestricted grammars and equivalence with Turing machines, TMs as enumerators.

[8hrs] (CO5)

Module 6: Undecidability & Intractablity

Church-Turing thesis, universal Turing machine, the universal and diagonalization languages, reduction between languages and Rice's theorem, undecidable problems about languages. Intractablity: Notion of tractability/feasibility. The classes NP and co-NP, their importance. Polynomial time many-one reduction. Completeness under this reduction. Cook-Levin theorem: NP-completeness of propositional satisfiability, other variants of satisfiability. NP-complete problems from other domains: graphs (clique, vertex cover, independent sets, Hamiltonian cycle), number problem (partition), set cover.

[12hrs] (CO5)

Suggested Readings

Text Books

  1. John E. Hopcroft, Rajeev Motwani and Jeffrey D. Ullman, Introduction to Automata Theory, Languages, and Computation, Pearson Education Asia.

Reference Books

  1. Harry R. Lewis and Christos H. Papadimitriou, Elements of the Theory of Computation, Pearson Education Asia.
  2. Dexter C. Kozen, Automata and Computability, Undergraduate Texts in Computer Science, Springer.
  3. Michael Sipser, Introduction to the Theory of Computation, PWS Publishing.
  4. John Martin, Introduction to Languages and The Theory of Computation, Tata McGraw Hill.