Advanced Computer Systems (ACS)

Course content

The overall purpose of this course is to offer students an understanding of techniques in computer systems with a focus on correctness and adherence to system properties, such as modularity and atomicity, while at the same time achieving high performance. The course exposes students to various system mechanisms, especially from distributed systems, database systems, and network systems. 

The course will explore the following aspects:

  • System abstractions and design principles
  • Modularity with clients and services
  • Performance
  • Atomicity and transactions
  • Concurrency control and recovery
  • Reliability, fault-tolerance, and redundancy
  • Distributed protocols for replication
  • Large-scale data processing

MSc Programme in Computer Science

Learning outcome

Knowledge to

  • Describe the design of transactional and distributed systems, including techniques for modularity, performance, and fault tolerance.
  • Explain how to employ strong modularity through a client-service abstraction as a paradigm to structure computer systems, while hiding the complexity of implementation from clients.
  • Explain techniques for large-scale data processing.    


Skills to

  • Implement systems that include mechanisms for modularity, atomicity, and fault tolerance.
  • Structure and conduct experiments to evaluate a system's performance.


Competences to

  • Discuss design alternatives for a modular computer system, identifying desired system properties as well as describing mechanisms for improving performance while arguing for their correctness.
  • Analyse protocols for concurrency control and recovery, as well as for distribution and replication.
  • Apply the principles of large-scale data processing to analyse concrete information-processing problems.


Lectures and exercise sessions.

See Absalon when the course is set up.

- Basic principles of operating systems and/or databases.
- Working knowledge of a standard programming language (Java, C#, etc), including concurrency and communication mechanisms.
- Notions of UNIX / shell scripting are helpful, but not required.
- Academic qualifications equivalent to a BSc degree is recommended.

This course was formerly known as "Principles of Computer Systems Design".

Continuous feedback during the course of the semester

Written feedback is provided as comments to assignment solutions in Absalon.
Continuous feedback is provided during exercise classes, where a time window of each class is allocated for Q&A with teaching assistants.

7,5 ECTS
Type of assessment
Written examination, 4 hours under invigilation

The course has been selected for ITX exam
All aids allowed

This includes books, notes and private computer but not access to the internet.


The University will make computers available to students taking on-site exams at ITX. Students are therefore not permitted to bring their own computers, tablets or mobile phones. If textbooks and/or notes are permitted, according to the course description, these must be in paper format or uploaded through Digital Exam.

Marking scale
7-point grading scale
Censorship form
External censorship
Criteria for exam assessment

See Learning Outcome.

Single subject courses (day)

  • Category
  • Hours
  • Lectures
  • 42
  • Theory exercises
  • 70
  • Project work
  • 90
  • Exam
  • 4
  • English
  • 206


Course number
7,5 ECTS
Programme level
Full Degree Master

1 block

Block 2
No limit
Study Board of Mathematics and Computer Science
Contracting department
  • Department of Computer Science
Contracting faculty
  • Faculty of Science
Course Coordinator
  • Dmitriy Traytel   (7-7775647c77686f43676c316e7831676e)

Yongluan Zhou
Dmitriy Traytel

Saved on the 22-11-2021

Are you BA- or KA-student?

Are you bachelor- or kandidat-student, then find the course in the course catalog for students:

Courseinformation of students