/hpps-e2024-pub

Public repository for HPPS

Primary LanguageC

Syllabus and Material for High Performance Programming and Systems (HPPS)

Welcome to the course website for HPPS! All material and general information will be provided here. Announcements, assignment handin, and the discussion forum remains on Absalon. While this website is a Git repository, you are not required or expected to use Git to interact with it, but feel free to do so if convenient for you.

Basics

HPPS takes place in block 2. There are three kinds of in-person teaching activities: lectures, exercises and the study café. All take place physically on campus.

Lectures are mostly conventional and serve as warmup for the exercises.

Exercises are conducted in four smaller classes, each conducted by a teaching assistant (TA). An exercise session involves working on problems that will help you learn the curriculum, and in many cases directly train you in the skills you will need for the mandatory assignments.

Study cafés are places where you can get assistance with the mandatory assignments.

This course website is used for handing out material.

Discord can be used for asking questions. (Invite link TBA). You are not required or expected to use Discord. We continue to monitor the Absalon discussion forum, and course announcements are posted solely on Absalon.

Absalon is used for handing in assignments and for course announcements.

Textbook

The textbooks are as follows:

Schedule

Tuesday

  • Lecture: 10:00-12:00 (Aud 03, HCØ).

Thursday

  • Exercises: 10:00-12:00

  • Lecture: 13:00-15:00 (Aud 03, HCØ)

  • Exercises: 15:00-17:00

Exercises are held in the following four classrooms.

  • Class 1: 10:00-12:00, 1-0-10 (DIKU), 15:00-17:00: 1-0-10 (DIKU)

  • Class 2: 10:00-12:00, 1-0-14 (DIKU), 15:00-17:00: 1-0-14 (DIKU)

  • Class 3: 10:00-12:00, 4-0-10 (Biocenter), 15:00-17:00: 4-0-10 (Biocenter).

  • Class 4: 10:00-12:00, Auditorium Syd (NEXS), 15:00-17:00: Auditorium Syd (NEXS).

Friday

  • Assignment café 13:00-15:00 (room TBD).

Assignments

There are 6 assignment in total during the course with deadlines roughly every week. They overlap slightly to allow for more flexibility in your scheduling, but think of them as weekly assignment.

The assignments will be graded with points from 0 to 4 and it is not possible to re-hand-in any of the assignments.

Assignments are made to be solved in groups of preferably three students, but groups of two active students will also do. We strongly encourage you not to work alone. Groups cannot be larger than three students. Each group must make their own solutions and cannot share implementations and report with other. You may however discuss material and ideas.

A1

  • Handout: 21/11

  • Handin deadline: 1/12

A2

  • Handout: 28/11

  • Handin deadline: 8/12

A3

  • Handout: 5/12

  • Handin deadline: 15/12

A4

  • Handout: 12/12

  • Handin deadline: 22/12

A5

  • Handout: 19/12

  • Handin deadline: 5/1

A6

  • Handout: 2/1

  • Handin deadline: 12/1

Study café

Every Friday in from 13:00-15:00 you can attend the assignment café to get help with the assignments.

Languages

All written material will be in English.

Most oral teaching will be in Danish or English, depending on the specific teacher or TA.

You will mainly be programming in C and Python.

Software

You will be using a Unix command line and Unix tools for much of the course. See the Unix software guide.

See also this guide on the GDB debugger, which is a very useful tool for debugging C programs.

If you prefer an IDE, see the VS Code installation and setup guide.

People

The teachers are

The TAs are TBA.

Exam

Format

The exam will be a take-home exam that will be very similar in form to the mandatory assignments. See examples of old exams here. It has an estimated workload of 20 hours. It will involve practical programming and performance analysis of programs.

Qualification

To qualify for the exam you are required to achieve at least 50% of the total number of points in the first five assignments (that is, 10 points at minimum). You also need to get at least one point in each of the first five assignment.

Date

Tentative: The exam will likely be held in week 3, Monday 9:00 to Wednesday 12:00.

Course plan

Each week has an associated subdirectory here on GitHub that lists expected reading and relevant exercises.