This site is from a past semester! The current version will be here when the new semester starts.

Using this Website


CS2103/T: Software Engineering

A balanced, iterative, and brownfield introduction to Software Engineering...

CS2103/T is an introductory Software Engineering course. It has a 50-50 balance of basic SE theory knowledge and practical skills that you need to gain before industry internships or . The course follows an to covering topics. It is also one of the rare SE courses that includes a , in addition to a .

  • On the theory side, this course is supported by a customized online textbook Software Engineering for Self-Directed Learners, integrated into this course website.

  • The practice side, you will first ramp up your technical skills by doing a small individual project (greenfield) in which you will develop a personal assistant chatbot called Duke. Then, you will move to a team project (brownfield) in which you will take over an existing project AddressBook-Level3 (AB3) -- a relatively small yet non-trivial (6 ) generic product -- and enhance it into a better product or evolve it in a direction that you choose.

What does mean to 'follow an iterative approach in covering topics'?

It means, we cover a little bit of at first and then iteratively go deeper into them later, revisiting each aspect many times over the course of the semester. In contrast, a sequential approach would have covered one SE aspect before moving to the next (e.g., teach the requirements aspect completely before moving to the design aspect).

In each week, we cover topics that are most relevant to the project tasks that you are expected to do around that time.

This way of 'jumping around' topics feels chaotic but consider the benefits:

  • It allows you to start doing SE projects early, and do it iteratively too. That is, you can start with a small project from the very start and make it bigger progressively, learning from earlier mistakes, and getting multiple chances to improve on previous attempts.
  • Important SE aspects such as testing can be practiced from the very beginning. If we followed a sequential approach, you can only learn it near the end of the semester.
  • It lowers the risk of missing out some SE aspects altogether. For example, suppose your schedule got heavier in the second half of the semester, and you could barely keep up with the course during that half. You still go away with the basic knowledge of all SE aspects rather than knowing some aspects deeply while missing some other aspects altogether.

To help you cope with the non-sequential progression of topics, this course website contains two versions of the topics.

  1. In the Schedule page, you'll find the topics organized into the order we cover them in each week.
  2. In the Textbook page, you'll find the topics in their natural sequential order. This format is suitable for exam reference.

Given below is a summary of what the course covers and does not cover.

Topic Covered Not covered
Java Used heavily, but not taught syntax (reason: expected prerequisite knowledge)
OOP Used in a non-trivial project, basics (reason: expected prerequisite knowledge)
SE tools/practices those specific to start-ups
Modeling (sufficient to be able to describe SE artifacts using models, such as seen in this Developer Guide of AB3) intensive
Requirements to gather and document project requirements rapid prototyping, heavy UI design, designing a product from scratch
Documentation Documentation targeting end users (example) as well as those targeting developers (example) Marketing materials
Project Management Iterative delivery of a product, working collaboratively with team members, on-site as well as remotely Setting up project infrastructure from scratch
Testing and
Applications domains Cross-platform desktop applications Web programming, Mobile programming, Database programming


Using this Website