2024 Faculty Courses School of Engineering Undergraduate major in Information and Communications Engineering
Logic and Reasoning
- Academic unit or major
- Undergraduate major in Information and Communications Engineering
- Instructor(s)
- Ryutaroh Matsumoto / Kotaro Funakoshi
- Class Format
- Lecture/Exercise (Face-to-face)
- Media-enhanced courses
- -
- Day of week/Period
(Classrooms) - 5-6 Tue / 5-6 Fri
- Class
- -
- Course Code
- ICT.H217
- Number of credits
- 110
- Course offered
- 2024
- Offered quarter
- 4Q
- Syllabus updated
- Mar 17, 2025
- Language
- Japanese
Syllabus
Course overview and goals
Sentences expressed by a language have a meaning. In order to process meanings using a computer, we need to consider logical inference itself as a mathematical object. In this lecture, we learn logic as a basic methodology for this purpose, which provides a foundation for knowledge processing by the formal approach. Particularly, we learn propositional logic, predicate logic, resolution principle, and a logic programming language Prolog.
Course description and aims
By the end of this course, students will be able to:
1) explain propositional and predicate logic that formalize inference as symbolic operation
2) write program code using a logic programming language Prolog
Keywords
propositional logic, predicate logic, resolution principle, logic Programming, Prolog
Competencies
- Specialist skills
- Intercultural skills
- Communication skills
- Critical thinking skills
- Practical and/or problem-solving skills
Class flow
The first two sessions will be a basic lecture on logic, and the next five sessions will involve Prolog programming exercises, familiarizing students with the concept of logic programming through graphs and automata.
The next six sessions will deepen students' mathematical understanding of propositional logic and predicate logic, and reaffirm the relationship with the logic programming language Prolog.
Course schedule/Objectives
Course schedule | Objectives | |
---|---|---|
Class 1 | Introduction | Explain the background of logic |
Class 2 | Basics of propositional & predicate logic : proposition, connectives, truth value, predicate | Explain proposition, connectives, truth value, and predicate |
Class 3 | Basics of Prolog: program execution and basic operations | Setup Prolog programming environment and run sample programs |
Class 4 | List and recursion | Write Prolog code that handles list and recursion |
Class 5 | Graph search | Write Prolog code that implement graph search |
Class 6 | Automaton | Write Prolog code that implement automaton |
Class 7 | Syntax analysis | Write Prolog code that implement syntax analysis |
Class 8 | Propositional logic 1: syntax, semantics, tautology | Explain syntax, semantics, and tautology |
Class 9 | Propositional logic 2: normal form, Boolean algebras | Explain Boolean algebras and normal form |
Class 10 | Proofs in natural deduction: inconsistent, reductio ad absurdum, derivation | Explain inconsistent, reductio ad absurdum, and derivation |
Class 11 | Predicate logic: quantifiers, term, formula | Explain quantifiers, term, and formula |
Class 12 | Resolution principle | Explain resolution principle |
Class 13 | Logic programming language Prolog | Explain the syntax and semantics of the Prolog programming language |
Class 14 | Term-end paper test & programming | Solve questions and a programming problem |
Study advice (preparation and review)
To enhance effective learning, students are encouraged to spend approximately 100 minutes preparing for class and another 100 minutes reviewing class content afterwards (including assignments) for each class.
They should do so by referring to textbooks and other course material.
Textbook(s)
Handouts are distributed
Reference books, course materials, etc.
Logic and Structure, D. van Dalen, Springer-Verlag, 1983
Evaluation methods and criteria
Exercise is 40%, and the final exam is 60%.
The final exam may be replaced with a report when holding the exam is difficult.
Related courses
- ICT.H212 : Automata and Languages (ICT)
Prerequisites
Students are required to be able to submit reports through T2SCHOLA.
Other
Installing a Prolog environment to your PC or setting up a network access software is needed.
The details of the setups are explained in the lecture.