PMPH is structured to have four hours of hopefully physical lectures and four hours of hopefully physical labs per week; potentially we will have no lectures in the last few weeks of the course, so you can concentrate on project work (to be announced).
- Tuesday 10:00 - 12:00 (øv - NBB 01.3.I.164, Jagtvej 155)
- Thursday 10:00 - 12:00 (aud - Aud 07, Universitetsparken 5, HCØ)
- Thursday 13:00 - 17:00 (or later if students ask for it). In all kind of places, see https://skema.ku.dk/tt/tt.asp?SDB=ku2122&language=EN&folder=Reporting&style=textspreadsheet&type=student+set&idtype=id&id=167568&weeks=1-53&days=1-7&periods=1-68&width=0&height=0&template=SWSCUST+student+set+textspreadsheet
The current plan is that everybody will have a physical place at the lecture and lab. Unless we are forced to move to virtual teaching, the lectures and labs will not be recorded, so please plan to attend.
Throughout the course, you will hand in four weekly assignments, which will count for 40% of the final grade. In the last month of the course, you will work on a group project (up to three students per group), and will submit the report and accompanying code. The group project will be presented orally at the exam together with the answers to some individual questions, and this will count for 60% of your final grade.
The "weekly-assignments" (W-assignments) are tentatively planned to be published in each Thursday of the first four weeks. They have one week editing time. If a serious attempt was made but the solution is not satisfactory (or simply if you want to improve your assignment, hence grade), an updated solution should be resubmitted one week after the time when the assignment was graded. Extensions may be possible, but your TA will need to agree with it TA.
For the group project no re-submission is possible; the deadline is the Friday just before the exam week.
The oral examination will be hold in the exam week (Wednesday, Thursday and Friday if necessary). The final evaluation will take up to 20 minutes per student, but probably the whole group will be examined at a time (unless you wish otherwise).
Weekly and group assignment handin is still on Absalon.
Teacher: Cosmin Oancea.
Teaching assistant (TA): Dmitry Serykh.
The plan is that the teacher will conduct the lectures and the lab. The TA will be mainly in charge of grading the weekly assignments and patrolling the Absalon discussion forum.
All lectures and lab sessions will be delivered in English. The assignments and projects will be posted in English, and while you can chose to hand in solutions in either English or Danish, English is preferred. All course material except for the hardware book is distributed via this GitHub page. (Assignment handin is still on Absalon.)
-
The hardware track of the course covers (lecture) topics related to processor, memory and interconnect design, including cache coherency, which are selected from the book Parallel Computer Organization and Design, by Michel Dubois, Murali Annavaram and Per Stenstrom, ISBN 978-521-88675-8. Cambridge University Press, 2012. The book is available at the local bookstore (biocenter). It is not mandatory to buy it---Cosmin thinks that it is possible to understand the material from the lecture slides, which are detailed enough---but also note that lecture notes are not provided for the hardware track, because of copyright issues.
-
The software track covers (lecture) topics related to parallel-programming models and recipes to recognize and optimize parallelism and locality of reference. It demonstrates that compiler optimizations are essential to fully utilizing hardware, and that some optimizations can be implemented both in hardware and software, but with different pro and cons. The lecture notes are available here, and additional (facultative) reading material (papers) will be linked with individual lectures; see Course Schedule Section below.
-
The lab track teaches GPGPU hardware specifics and programming in Futhark, CUDA, and OpenMP. The intent is that the lab track applies in practice some of the parallel programming principles and optimizations techniques discussed in the software tracks. It is also intended to provide help for the weekly assignment, project, etc.
This course schedule is tentative and will be updated as we go along.
The lab sessions are aimed at providing help for the weeklies and group project. Do not assume you can solve them without attending the lab sessions.
Date | Time | Topic | Material |
---|---|---|---|
07/09 | 10:00-12:00 | Intro, Hardware Trends and List Homomorphisms (SFT), Chapters 1 and 2 in Lecture Notes | Sergei Gorlatch, "Systematic Extraction and Implementation of Divide-and-Conquer Parallelism"; Richard S. Bird, "An Introduction to the Theory of Lists"; Jeremy Gibons, "The third homomorphism theorem" |
09/09 | 10:00-12:00 | List Homomorphism & Parallel Basic Blocks (SFT), Chapters 2 and 3 in Lecture Notes | Various papers related to flattening, but which are not very accessible to students |
09/09 | 13:00-17:00 | Lab: Gentle Intro to CUDA, Futhark programming, First Weekly | Parallel Programming in Futhark, sections 1-4, futhark code for the first week (list homs) |
09/09 | some time | Assignment 1 handout | |
14/09 | 10:00-12:00 | Parallel Basic Block & Flattening Nested Parallelism (SFT) | chapers 3 and 4 in Lecture Notes |
16/09 | 10:00-12:00 | Flattening Nested Parallelism (SFT) | , chapter 4 in Lecture Notes |
16/09 | 13:00-17:00 | Lab: Fun Quiz; Reduce and Scan in Cuda | discussing second weekly, helping with the first |
16/09 | some time | Assignment 2 handout | |
21/09 | 10:00-12:00 | In-Order Pipelines (HWD) | Chapter 3 of "Parallel Computer Organization and Design" Book |
23/09 | 10:00-12:00 | Optimizing ILP, VLIW Architectures (SFT-HWD) | Chapter 3 of "Parallel Computer Organization and Design" Book |
23/09 | 13:00-17:00 | Lab: GPU hardware: three important design choices. | helping with the first two weekly assignments. |
23/09 | No new weekly assignment this week; the third will be published next week | ||
28/09 | 10:00-12:00 | Dependency Analysis of Imperative Loops | Chapter 5 of lecture Notes |
30/09 | 10:00-12:00 | Optimizing Locality, Case Study: Nearest Neighbor, Matrix Multiplication and Transposition | Chapters 5 and 6 of lecture Notes |
30/09 | 13:00-17:00 | Lab: Recognizing Scan and Reduce Patterns in Imperative Code | helping with the weekly assignments. |
30/09 | some time | Assignment 3 handout | |
05/10 | 10:00-12:00 | Memory Hierarchy, Bus-Based Coherency Protocols (HWD) | Chapter 4 and 5 of "Parallel Computer Organization and Design" Book |
07/10 | 10:00-12:00 | HWD: Bus-Based Coherency Protocols and Scalable Coherence Protocols | Chapters 5 and 6 of "Parallel Computer Organization and Design" Book |
07/10 | 13:00-17:00 | Lab: Presenting Possible Group Projects, Assignment 4 handout | helping with weekly assignments, discussing group projects. |
12/10 | 10:00-12:00 | Scalable Coherence Protocols, Scalable Interconect (HWD) | Chapters 5 and 6 of "Parallel Computer Organization and Design" Book |
14/10 | 10:00-12:00 | Inspector-Executor Techniques for Locality Optimizations (SFT) | Various scientific papers |
14/10 | 13:00-17:00 | Lab: Working on the 4th Weekly Assignment | helping project and anything else. |
19/10 | 10:00-12:00 | Autumn break (no lecture) | |
21/10 | 10:00-12:00 | Autumn break (no lecture) | |
21/10 | 13:00-17:00 | Autumn break (no lab) | |
26/10 | 10:00-12:00 | Zoom Lab Session upon student request | Helping with group-project, weekly assignments |
28/10 | 10:00-12:00 | Modern CPU Design: Tomasulo Algorithm (HWD) | Chapter 3 of "Parallel Computer Organization and Design" Book |
28/10 | 13:00-17:00 | Lab: help with group project |
The weekly assignments are mandatory, must be solved individually, and make up 40% of your final grade. Submission is on Absalon.
You will receive feedback a week after the handin deadline (at the latest). You then have another week to prepare a resubmission. That is, the resubmission deadline is two weeks after the original handin deadline.
Several potential choices for group project may be found in folder group-projects
, namely
- You are free to propose your own project, for example from the machine learning field, but please discuss it first with Cosmin, to make sure it is a relevant project, i.e., on which you can apply some of the techniques/reasoning that we have studied in PMPH.
- Single Pass Scan in Cuda (basic block of parallel programming)
- Bfast: a landscape change detection algorithm (Remote Sensing)
- Local Volatility Calibration (Finance)
- Fast Sorting Algorithm(s) for GPUs
- HP Implementation for Fusing Tensor Contractions (Deep Learning): read the paper, implement the technique (some initial code is provided), and try to replicate the results of the paper.
All students will be provided individual accounts on a multi-core and GPGPU machine that supports multi-core programming via C++/OpenMP and CUDA programming. Login to GPU & 16 multicore machines will become operational after 6th of September:
You log in by first SSHing to the bastion server
ssh-diku-apl.science.ku.dk
using your KU license plate (abc123
) as
the user name, and then SSHing on to one of the GPU machines.
$ ssh -l <ku_id> ssh-diku-apl.science.ku.dk
$ ssh gpu04-diku-apl
(or gpu02-diku-apl or gpu03-diku-apl).
Despite their names, they each have 16 cores with 2-way hyperthreading CPUs and plenty of RAM as well. The GPUs are:
-
gpu02-diku-apl
,gpu03-diku-apl
have dual GTX780 Ti GPUs. -
gpu04-diku-apl
has a GTX 2080 Ti GPU (by far the fastest).
For CUDA to work, you may need to add the following to your $HOME/.bash_profile
or $HOME/.bashrc
file (on one of the gpu02..4-diku-apl machines):
CUDA_DIR=/usr/local/cuda
export PATH=$CUDA_DIR/bin:$PATH
export LD_LIBRARY_PATH=$CUDA_DIR/lib64:$LD_LIBRARY_PATH
export LIBRARY_PATH=$LD_LIBRARY_PATH:$LIBRARY_PATH
export CPLUS_INCLUDE_PATH=$CUDA_DIR/include:$CPLUS_INCLUDE_PATH
export C_INCLUDE_PATH=$CUDA_DIR/include:$C_INCLUDE_PATH
-
We will use a basic subset of Futhark during the course. Futhark related documentation can be found at Futhark's webpage, in particular a tutorial and user guide
-
CUDA C Best Practices Guide you may want to browse through this guide to see what offers. No need to read all of it closely.
-
Some of the compiler transformations taught in the software track can be found in this book Optimizing Compilers for Modern Architectures. Randy Allen and Ken Kennedy, Morgan Kaufmann, 2001, but you are not expected to buy it or read for the purpose of PMPH.
-
Similarly, some course topics are further developed in this book High-Performance Computing Paradigm and Infrastructure, e.g., Chapters 3, 8 and 11, but again, you are not expected to buy it or read for the purpose of PMPH.