Course syllabus

Course-PM

DAT630 Project in parallel computing lp3 VT25 (7.5 hp)

Course is offered by the department of Computer Science and Engineering

Contact details

  • Miquel Pericàs <miquelp@chalmers.se> (Examiner + Lecturer)
  • Hari Abram <hariv@chalmers.se> (Teaching Assistant)
  • Sonia Rani Gupta <soniar@chalmers.se> (Teaching Assistant)

Course purpose

This course looks at the design of high-performance and energy efficient software for parallel computers, performance modeling, and HW/SW codesign of parallel and heterogeneous computer systems. The course is a project-oriented course in which you will develop skills for programming and assessing the performance of parallel and heterogeneous computers. A series of lectures on the principles of parallel hardware provide required background for architecture-aware program optimization. Via group assignments you will furthermore develop your teamwork skills, including version control, communication and presentation.

Schedule

Check TimeEdit for slots and rooms. Wednesday 8h sessions are self-study session. Lab rooms are allocated which you can use to work on your projects. In addition. we come 9h-10h every week allocated to project supervision. You can meet us in our offices (or zoom) to discuss about your progress.

The following schedule is likely to change! Check periodically. In general, we will try to notify changes well ahead of the affected sessions. 

When Where What

Responsible

#1 Jan 21st, 10-12h ES51 Introduction to DAT630 and Project Description Miquel
#2 Jan 24th, 9-12h SB-M415 Tutorial #1:  GIT, Gitlab, CI/CD Hari / Sonia
#3 Jan 28th, 9-12h SB-M415 Lecture #1: Benchmarking, Vector Architectures Miquel
#4 Jan 31st, 9-12h EL42 Supervision  Hari / Sonia / Miquel
#5 Feb 4th, 9-12h SB-M022 Lecture #2: Chip Multiprocessors Miquel
#6 Feb 7th, 9-12h EL43 Supervision Hari / Sonia / Miquel
#7 Feb 11th, 9-12h SB-M022 Tutorial #2: Containers, Job Scheduling Hari / Sonia
#8 Feb 14th, 10h-12h EF Supervision Hari / Sonia / Miquel
#9 Feb 18th, 9h-12h SB-M022 Lecture #3: GPGPU Miquel
#10 Feb 21 -- NO MEETINGS ON THIS DAY 
#11 Feb 25, 9h-12h SB-M415 cancelled
#12 Feb 28, 9h-12h online Lecture #4: HW-support for MPI Miquel
#13 March 4th, 9h-12h SB-M415 Lecture #5: Hands-on on HW/SW codesign Sonia
#14 March 7th, 9h-12h Supervision Hari / Sonia / Miquel
#15 March 11th, 9h-12h no lecture (work on report and presentation)
#16 March 14th, 8h-12h EE Project Presentations (all teams) Miquel

 

Course design

The course consists of project sessions (lectures and tutorials), and lectures covering parallel computer architecture. 
The main topic of the course is a multi-week project in which students, organized into teams, will port and optimize a given code to several programming models, practice basic software engineering, teamwork and performance engineering skills. The project will be supported by a set of supervision session and several tutorial sessions on: software
  • version control and testing
  • containers and singularity
  • advanced performance analysis and optimization
  • tools for HW/SW codesign
The focus of the lectures is on:
  • multicore, manycore and vector architecture, with a focus on the memory hierarchy and its implications to the performance of OpenMP  and vector programs
  • architectural support for message passing, and how it impacts the performance of MPI programs
  • architecture of GPGPUs, and how it impacts optimization of CUDA programs

Continuous feedback will be collected to assess the degree of learning and to improve future versions of the course.

The course will use Canvas as the main tool for communication. Chalmers Gitlab will be used for software development. 

Changes made since the last occasion

This is the first edition of this course

Learning objectives and syllabus

After completion of the course the student should be able to:
Knowledge and understanding
  • describe current approaches to parallel computing
  • explain the design principles of the hardware support for the shared memory and message passing programming models
  • describe the implementation of different models of thread-level parallelism, such as chip multiprocessors, many-cores or GPGPUs
  • list basic approaches to software engineering, performance engineering and teamwork
Competence and skills
  • design scalable parallel software and analyze its performance
  • debug and optimize the execution of parallel programs on heterogeneous computers
  • apply performance modeling and simulation techniques for performance prediction and HW/SW codesign. 
  • apply teamwork skills for version control, communication, presentation, and conflict management. 
  • ability to cooperate in diverse group compositions with team members with different skills, cultural and educational backgrounds, gender and nationality
Judgement and approach
  • analyze the trade-offs of different approaches to parallel computing in terms of function, performance and cost
  • analyze and judge the performance portability of a piece of software

Link to the syllabus on Studieportalen.

https://www.chalmers.se/en/education/your-studies/find-course-and-programme-syllabi/course-syllabus/DAT630/?acYear=2025/2026

Examination form

The course has two components: written examination (1.5c) and project (6c) 

The written examination will consist of a 2h exam covering lectures 1-6. The written exam has only two grades: pass/fail. Bonus points will be given throughout the course that impact the written exam. 

The project will be evaluated based on multiple criteria: 

  • quality of the porting and optimization effort (1-5)
  • application of versioning, containers and performance analysis methodologies (1-5)
  • quality of the written report (1-5)
  • quality of the presentation (1-5)
  • quality of the peer review (1-5)
  • individual feedback by the each team's supervisor (1-5)

A grade of 3 needs to be achieved in each of the four categories in order to get a project grade. The final grade will be the average of the four grades, with rounding to the nearest full grade. Grades 3.5 and 4.5 will be rounded upwards.

Both the written examination and project need to be approved in order to get a course grade. The final course grade will be the same as the project grade. 

Course summary:

Date Details Due