IN9050 – 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 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 low-power CPUs (ARM), graphics processing units (GPUs, NVidia) and machines interconnected by PCI Express interconnect (Dolphin ICS).

Learning outcome

After finishing the course you´ll

  • 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
  • have an understanding of typical pipelines for multimedia workloads such as video encoders
  • know the architecture and framework of three widely used contemporary platforms for parallel programming
  • have experience in presenting an assessment of alternative problem solutions in oral, written and poster formats
  • have insight into the state-of-the-art in parallelization for a selected platform
  • have experience in parallelizing a real-world workload
  • have experience in presenting a lecture to master-level students

Admission to the course

PhD candidates from the University of Oslo should apply for classes and register for examinations through Studentweb. If a course has limited intake capacity, priority will be given to PhD candidates who follow an individual education plan where this particular course is included.

PhD candidates who have been admitted to another higher education institution must apply for a position as a visiting student within a given deadline.

Data communication (IN3230 – Computer Networks), operating systems (f.ex. IN3000/IN4000 – Operating Systems)

Overlapping courses

Teaching

The course will consist of

  • Lectures: 24 hours (currently in 4 blocks)
    • Attendance is not mandatory
  • Group lectures: 12 hours (in 4 blocks)
    • Attendance is not mandatory
  • Three oral, interactive poster presentations: 9 hours (in 3 blocks)
    • Presentation of extensive project’s progress is mandatory
    • Attendance of all presentations is mandatory
    • Only valid in the same semester
  • One home exam
    • Report about background of the extensive real-world application that is the subject of parallelization, related work, platform-specific choices, and performance assessment (pass/fail)
    • Working source code (pass/fail)
    • Poster illustrating performance results (mandatory but not graded)
  • A 30-minute lecture about a particular real-world test case

Examination

One graded home exam consisting of source code, a report, and a presentation in lecture style.

All parts of the exam must be passed, and in the same 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: IN5050 - Programming Heterogeneous Multi-Core ArchitecturesINF5063 - Programming heterogeneous multi-core architectures (continued)INF9063 - Programming heterogeneous multi-core architectures (continued)

Examination support material

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

Grading scale

Grades are awarded on a pass/fail scale. 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 (Common Student System) Mar. 19, 2024 6:40:43 AM

Facts about this course

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