# Logical Fundamentals of Computer Science

Rationale
Logic is one of the foundations of computer science. This course will give students the basic tools to pursue other areas in computer science, or build on this basic course towards more ambitious use of logic in computer science.

Course Description
This course will cover propositional and first order logic and provide an introduction to other logics like intuitionistic logic and modal logic.

Detailed list of topics:
Propositional logic and truth tables. Notions of satisfaction and validity.
A quick introduction to NP-completeness. First order logic, quantifiers.
Satisfaction, validity.
G ̈odel’s completeness theorem. Intuitionistic and Modal logic.
Logics of Justification and Knowledge. Dynamic Logic and Logic of Programs Basic model theory if there is time.
Learning Goals/Outcomes
1. Students will learn how to work with proofs in propositional logic, first order logic and various modal logics.
2. They will be expected to show familiarity with the main notions and results in logic
3. They should be able to reproduce proofs of major theorems, especially the com- pleteness theorem of G ̈odel butalso the soundness and completeness results in modal and related logics.
4. The students should know the history of justification logic, G ̈odel’s problem and Artemov’s solution to it.
5. Students should be familiar with Hoare logic and Dynamic Logic and how they are used to prove correctness of programs.
6. Students should be aware of the applications of epistemic logic in social reasoning and game theory.

Assessment
Homeworks will be assigned each week and graded. There will be a final and a midterm examination as well. Students who do exceptionally well in the midterm examination will have the option to write a paper in lieu of the final. Typically, the homeworks and the midterm count for 25% of the course each and the final for 50%.