This repository contains material required to complete exercises for the Parallel Programming lab in the 2024 summer semester, including assignment sheets and any associated materials. Note that some of this material is based on previous years.
Make sure to read this document carefully, as it contains vital information regarding the grading of exercises.
Generally, topics discussed here include
- parallel programming concepts
- shared memory parallelization using OpenMP
- performance-oriented programming
- proper experiment orchestration and benchmarking
- parallel programming tools
This schedule gives you an overview of the topics we will discuss on each date. It will be updated continuously throughout the semester. Note that exercises associated with a given date are to be discussed on that day, i.e., solutions for that assignment have to be handed in via OLAT by 17:00 on the previous day (Monday).
Date | Assignment | Topics |
---|---|---|
2024-03-05 | - | Administrative matters, introduction to LCC3 |
2024-03-12 | 1 | Working on LCC3, initial measurements |
2024-03-19 | 2 | LCC3 hardware, Amdahl's law |
2024-04-09 | 3 | Sequential performance, cache effects |
2024-04-16 | 4 | OpenMP parallelism, performance analysis, false sharing |
2024-04-23 | 5 | OpenMP performance analysis and flush |
2024-04-30 | 6 | Dependence Analysis |
2024-05-07 | 7 | OpenMP correctness, auto-vectorization, dependence analysis |
2024-05-14 | 8 | OpenMP affinity and loop scheduling |
2024-05-21 | 9 | Vectorization |
2024-05-28 | 10 | OpenMP task parallelism, heat stencil |
2024-06-04 | 11 | Profiling and parallelization of a mystery application |
2024-06-11 | 12 | Scalar architectures and optimizations |
2024-06-18 | 13 | N-Body simulation |
All programming exercise solutions you hand in must compile and run on the LCC3 cluster as described in the LCC3 tutorial. One way way of ensuring this is by developing on LCC3 directly, either through a terminal or using an editor/IDE with support for remote development via SSH (such as Visual Studio Code).
Note that the default version of the GCC compiler present on LCC3 is very
outdated. You may load a never version by calling module load gcc/12.2.0-gcc-8.5.0-p4pe45v
.
As the tutorial states, use job scripts to run your applications on LCC3 compute nodes, do NOT run applications directly on the LCC3 login node.
NOTE: You have to be inside the University network to be able to connect via SSH. See here for more information.
The hostname of LCC3 is login.lcc3.uibk.ac.at
.
All programming exercises are conducted in C or C++.
Your code should always compile without warnings, when passing the flags -Wall -Wextra -Werror -std=gnu11
. Error handling is your discretion, but wherever you
do or do not include error handling you need to be able to justify it.
Make sure your code is properly formatted using either your IDE/Text editor of
choice, or by using a tool such as clang-format
. You can find an example
.clang-format file in this repository. Failure to
consistently format code may result in lower scores.
Try to write self-documenting code by choosing descriptive variable and
function names. While you may want to add comments to certain sections of your
code, try to avoid trivial comments such as fopen(...); // open file
. The best
source code comments are the ones you do NOT need to write. All names and
comments should be written in English.
Finally, all submitted code must be accompanied by a GNU Makefile. That is, your
solution must be able to be compiled with a single call to make
. You can find
an example Makefile and more information here.