2024 Faculty Courses School of Computing Department of Mathematical and Computing Science Graduate major in Mathematical and Computing Science
Topics in Algebra
- Academic unit or major
- Graduate major in Mathematical and Computing Science
- Instructor(s)
- Shunsuke Tsuchioka
- Class Format
- Lecture (Face-to-face)
- Media-enhanced courses
- -
- Day of week/Period
(Classrooms) - 7-8 Mon / 7-8 Thu
- Class
- -
- Course Code
- MCS.T417
- Number of credits
- 200
- Course offered
- 2024
- Offered quarter
- 4Q
- Syllabus updated
- Mar 14, 2025
- Language
- Japanese
Syllabus
Course overview and goals
Understanding dependent types and formal proofs via an implementation of a verifier
Course description and aims
(1) implementation of a verifier based on the textbook "Type Theory and Formal Proof: An Introduction by R. Nederpelt and G. Geuvers" in a programming language such as C, python, etc.
(2) formal proof by using your verifier of simple propositions
(3) theoretical background will not be explained because I put emphasis on implementation in the course
Keywords
lambda cube, formal proof, dependent types
Competencies
- Specialist skills
- Intercultural skills
- Communication skills
- Critical thinking skills
- Practical and/or problem-solving skills
Class flow
Mondays will be for explaining the textbook. Thursdays will be exercise-style implementation time.
Course schedule/Objectives
Course schedule | Objectives | |
---|---|---|
Class 1 | introduction | Understand the content of the class |
Class 2 | implementation (alpha equivalence) | Understand the content of the class |
Class 3 | lambda cube | Understand the content of the class |
Class 4 | implementation (beta reduction) | Understand the content of the class |
Class 5 | descriptive definitions (alias) | Understand the content of the class |
Class 6 | implementation (delta conversion) | Understand the content of the class |
Class 7 | primitive definitions (axioms) | Understand the content of the class |
Class 8 | implementation (type inference) | Understand the content of the class |
Class 9 | implementation (complexity) | Understand the content of the class |
Class 10 | de Bruijn index | Understand the content of the class |
Class 11 | implementation (optimization) | Understand the content of the class |
Class 12 | propositions-as-types (proofs-as-terms) correspondence (PAT) | Understand the content of the class |
Class 13 | proof assistant (Lean) | Understand the content of the class |
Class 14 | A future of mathematics? (IMHO) | Understand the content of the class |
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)
「Type Theory and Formal Proof: An Introduction (by R. Nederpelt and H. Geuvers) 」, Cambridge University Press (viewable at Tokyo Tech)
Reference books, course materials, etc.
I will open a course webpage and upload supplementing materials
Evaluation methods and criteria
Based on your implementation (source code) and comprehension checks
Related courses
- MTH.A301 : Algebra I
- MTH.A302 : Algebra II
- MTH.A331 : Algebra III
Prerequisites
(1) I require that you can write a simple code in one or more programming languages (mandatory)
(2) You can execute my binary for reference if you have a C++ compiler (not mandatory)
(3) I only require that you are familiar with elementary mathematics (high school level, not undergraduate level)