IN5050 – Programming heterogeneous multi-core architectures

Schedule, syllabus and examination date

Course content

The course addresses issues related to heterogeneous multi-core architectures that are today found in all computing devices, ranging from mobile phones, commodity desktops to large computing clusters.

The students will learn how asymmetric cores, threading models, memory hierarchies, and interconnect technologies determine whether decisions that are made in the parallel implementations of example algorithms are successful or not.

The students will get hands-on experience of this challenge by programming three different heterogeneous architectures. During the course, the students will understand the challenges in writing efficient programs for the different architectures. Programming and documenting the effect of alternative choices are an important part of the course.

The three concrete architectures change with the current relevance for the market. Currently, students will experience dedicated SIMD units in CPUs (ARM), graphics processing units (NVidia), and machines connected by PCI Express (Dolphin ICS).

Learning outcome

After completing the course you:

  • have an understanding of the ties between good parallelization choice and concrete parallel architectures and parallelization frameworks (e.g. threading, vectorization, and combinations).
  • are knowledgeable about different ways of solving parallelization tasks for alternative parallelization models, memory hierarchies and system architectures.
  • have a good insight into the evaluation of alternative design and implementation options for parallelization depending on an architecture and framework.
  • are knowledgeable about locating, understanding and fixing bottlenecks in parallel programs
  • know the architecture and framework of three widely used contemporary platforms for parallel programming
  • can program three widely-used platforms
  • have experience in presenting an assessment of alternative problem solutions in oral, written and poster formats

Admission to the course

Students admitted at UiO must?apply for courses?in Studentweb. Students enrolled in other Master's Degree Programmes can, on application, be admitted to the course if this is cleared by their own study programme.

Nordic citizens and applicants residing in the Nordic countries may?apply to take this course as a single course student.

If you are not already enrolled as a student at UiO, please see our information about?admission requirements and procedures for international applicants.

C or C++ programming, operating systems (e.g. IN3000 – Operating Systems/IN4000 – Operating Systems)

Overlapping courses

Teaching

The course will consist of

  • Lectures: 30 hours (in sets of 2 hours)
    • Attendance is not mandatory
  • Three oral, interactive poster presentations: 6 hours (in sets of 2 hours)
    • Presentation is mandatory
    • Attendance at all presentations is mandatory
    • Only valid in the same semester
  • Three home exams
    • Report about platform-specific choices and performance achievements (graded)
    • Working source code (graded)
    • Design document (mandatory but not graded)
    • Poster illustrating performance results (mandatory but not graded)

Examination

Students are assessed on the basis of portfolio evaluation, which includes 3 project assignments, where each assignment includes a delivery of source code, a delivery of a report and oral presentations.

  • Each project assignment has approximately equal weight (~33%)
  • Missing project assignments without valid reasons count as an F

The entire portfolio must be passed in the same semester, it is not possible to transfer parts to another semester.

It will also be counted as one of?your three?attempts to sit the exam for this course, if you sit the exam for one of the following courses:?IN9050 – Programming Heterogeneous Multi-Core Architectures,?INF5063, INF9063

Examination support material

All, but no text or code must be copied verbatim from other sources.

Language of examination

You may write your examination paper in Norwegian, Swedish, Danish or English.

Grading scale

Grades are awarded on a scale from A to F, where A is the best grade and F is a fail. Read more about the grading system.

Resit an examination

In this course, postponed exams are not offered for exam candidates who are ill before the exam or who become ill during the exam. A deferred submission deadline may be offered. The illness must be documented with a doctor's certificate dated no later than the ordinary submission date. You must submit the doctor's certificate to the Student Administration at IFI before the submission deadline for the home exam.

More about examinations at UiO

You will find further guides and resources at the web page on examinations at UiO.

Last updated from FS (Felles studentsystem) Nov. 17, 2025 12:22:53 PM

Facts about this course

Level
Master
Credits
10
Teaching
Spring
Examination
Spring
Teaching language
Norwegian (English on request)