Winter 2018

Theoretical Foundations of Software Engineering


This course is an introduction to the theoretical foundations of software engineering covering topics in automata theory, computability, and computational complexity

As an aspiring software engineer, the goal of this course is to leave you with a deeper understanding of what we really mean when we talk about computers and computing. We'll delve into the essence of what a computer really is, which will then let us examine different kinds of computational problems. Some of these problems are easy to compute, some are hard to compute, and some cannot even be computed at all.

This course is not about circuits, CPUs, or any hardware in particular, nor is it about about any programming language or program in particular. Rather this course is about exploring the fundamental capabilities and limitations of any computer, and in turn, of the very software you will write through your career.


Jan 19th
I've added some Youtube lectures in the lecture resources. They're a great suppliment to what we're
Jan 18th
Note the tutorials are held Wednesday from 8:30am-10:30am in UCC-37. There was a typo on the course info page that incorrectly stated the tutorial began at 2:30pm. This has been corrected.
Jan 17th
Assignment 1 is available. The first tutorial will begin Wednesday Jan. 24th.
Jan 8th
Website is available.