Lecture Details :
Theory of Computation by Prof.Kamala Krithivasan,Department of Computer Science and Engineering,IIT Madras. For more details on NPTEL visit http://nptel.iitm.ac.in
Course Description :
The objective of the course is to provide an exposition first to the notion of computability, then to the notion of computational feasibility or tractability.
We first convince ourselves that for our purpose it suffices to consider only language recognition problems instead of general computational problems.
We then provide a thorough account of finite state automata and regular languages, not only because these capture the simplest language class of interest and are useful in many diverse domains.
But also because many fundamental notions like nondeterminism, proofs of impossibility, etc. get discussed at a conceptually very simple level. We then consider context grammars and languages, and their properties.
Next, we consider Turing machines (TMs), show that as a model it is very robust, and the reasonableness of the Church-Turing hypothesis. After we realize TMs can work with (codes of) TMs as inputs, we obtain a universal TM.
We then obtain the separation of the classes r.e., and recursive. A number of TM related problems are shown to be undecidable. Next,Postís correspondence problem (PCP) is shown undecidable.
Finally, we introduce the notion of feasible or tractable computation. Classes NP, co-NP are defined and we discuss why these are important. We discuss the extended Church-Turing hypothesis.
After we discuss polynomial time many-one reducibility and prove Cook-Levin theorem, a number of natural problems from different domains are shown NP-complete.
The treatment is informal but rigorous. Emphasis is on appreciating that the naturalness and the connectedness of all the different notions and the results that we see in the course.
Introduction: Scope of study as limits to compubality and tractability.
Why it suffices to consider only decision problems, equivalently, set membership problems. Notion of a formal language.
DFAs and notion for their acceptance, informal and then formal definitions. Class of regular languages.
Closure of the class under complementation, union and intersection. Strategy for designing DFAs.
Pumping lemma for regular languages. Its use as an adversarial game.
Generalized version. Converses of lemmas do not hold.
NFAs. Notion of computation trees. Definition of languages accepted. Construction of equivalent DFAs of NFAs. NFAs with epsilon transitions. Guess and check paradigm for design of NFAs.
Regular expressions. Proof that they capture precisely class of regular languages. Closure properties of and decision problems for regular languages.
Myhill-Nerode theorem as characterization of regular languages.States minimization of DFAs.
Context free languages:
Notion of grammars and languages generated by grammars. Equivalence of regular grammars and finite automata. Context free grammars and their parse trees. Context free languages. Ambiguity.
Pushdown automata (PDAs): deterministic and nondeterministic. Instantaneous descriptions of PDAs.Language acceptance by final states and by empty stack. Equivalence of these two.
PDAs and CFGs capture precisely the same language class.
Elimination of useless symbols, epsilon productions, unit productions from CFGs. Chomsky normal form.
Pumping lemma for CFLs and its use. Closure properties of CFLs. Decision problems for CFLs.
Turing machines, r.e. languages, undecidability:
Informal proofs that some computational problems cannot be solved.
Turing machines (TMs), their instantaneous descriptions. Language acceptance by TMs. Hennie convention for TM transition diagrams.Robustness of the model-- equivalence of natural generalizations as well as restrictions equivalent to basic model. Church-Turing hypothesis and its foundational implications.
Codes for TMs. Recursively enumerable (r.e.) and recursive languages. Existence of non-r.e. languages. Notion of undecidable problems. Universal language and universal TM. Separation of recursive and r.e. classes. Notion of reduction. Some undecidable problems of TMs. Rice's theorem.
Undecidability of Post's correspondence problem (PCP), some simple applications of undecidability of PCP.
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.
Other Resources :
Other Computer Science Courses
- Software Engineering by UC Berkeley
- Digital Hardware Design by Other
- XHTML and CSS by Other
- Numerical Methods and Programing by IIT Madras
- COMP1927 Data Structures and Algorithms by The University of New South Wales
- Structure and Interpretation of Computer Programs by MIT
- CSEP 544 Database Management Systems by University of Washington
- C# Beginners by Other
- Oracle Database Design by Other
» check out the complete list of Computer Science Video lectures
Computer Science Lecture Notes
- Information Retrieval by University of Massachusetts
- Software Engineering and Security by Athens University of Economics and Business
- CPS 140 Computer Science by Duke University
- CS368: Java for C++ Programmers by University of Wisconsin
- CSE 373/548: Analysis of Algorithms by Stony Brook University
- CS345 Data Mining and Clustering by Stanford
- Pixels, Numbers, and Programs by University of Washington
- CS 696 Emerging Technologies: Java Distributed Computing by UC San Diego
- Introduction to Java Development by N/A