THE UNIVERSITY of EDINBURGH

DEGREE REGULATIONS & PROGRAMMES OF STUDY 2024/2025

Timetable information in the Course Catalogue may be subject to change.

University Homepage
DRPS Homepage
DRPS Search
DRPS Contact
DRPS : Course Catalogue : School of Informatics : Informatics - Distance Learning

Postgraduate Course: Message Passing Programming (INFD11011)

Course Outline
SchoolSchool of Informatics CollegeCollege of Science and Engineering
Credit level (Normal year taken)SCQF Level 11 (Postgraduate)
Course typeOnline Distance Learning AvailabilityAvailable to all students
SCQF Credits10 ECTS Credits5
Summary*This course is delivered online for students on Online Learning programmes within the College of Science and Engineering only. On-campus students interested in the material should refer to INFR11163 - Message-passing Programming*

Parallel programming by definition involves co-operation between processors to solve a common problem. The programmer has to define the tasks that will be executed by the processors, and also how these tasks exchange data and synchronise with each other.

In the message-passing model the tasks are separate processes that communicate by explicitly sending each other messages. All parallel operations are performed via calls to some message-passing interface that is entirely responsible for interfacing with the physical communication network.

This course uses the de facto standard for message passing, the Message Passing Interface (MPI), which is a library callable from C, C++ or Fortran. Parallel programs written using MPI can run on almost any system from a multicore laptop up to the world's largest supercomputers.
Course description The course makes use of lecture content delivered in both video form and delivered live via e.g. Blackboard Collaborate. Practical activities will be set for students to undertake in their own time in advance of regular tutorial sessions run via Blackboard Collaborate, with discussion and support available from other students, demonstrators, and staff via dedicated discussion areas (e.g. Learn Discussion Boards, Slack).

The course will cover the following topics:

- The message-passing model
- Message-passing parallelisation of a regular domain code
- MPI terminology
- The anatomy of send and receive (synchronous and asynchronous)
- Point-to-point message-passing examples
- Non-blocking operations
- Collectives
- Communicator management
- Derived datatypes (focusing mainly on array subsections)
- Practicalities / Hints and Tips
Entry Requirements (not applicable to Visiting Students)
Pre-requisites Students MUST have passed: Practical Introduction to High Performance Computing (INFR11184) OR Practical Introduction to High Performance Computing (PGPH11093) OR Practical Introduction to High Performance Computing (INFD11009)
Co-requisites
Prohibited Combinations Students MUST NOT also be taking Message-passing Programming (INFR11163)
Other requirements Students must have taken Practical Introduction to High Performance Computing in a previous session
Information for Visiting Students
Pre-requisitesAbility to program in C, C++ or Fortran.
High Demand Course? Yes
Course Delivery Information
Not being delivered
Learning Outcomes
On completion of this course, the student will be able to:
  1. Describe the message-passing model in detail.
  2. Explain the circumstances which cause issues such as deadlock.
  3. Implement standard message-passing algorithms in MPI.
  4. Measure and comment on the performance of MPI programs.
  5. Design, implement and debug efficient parallel programs to solve regular-grid problems.
Reading List
"Using MPI: Portable Parallel Programming with the Message-Passing Interface", William Gropp, Ewing Lusk and Anthony Skjellum.
Additional Information
Graduate Attributes and Skills Project planning.
Project management skills.
Effective written and diagrammatic communication.
Technical writing.
Data collection and analysis.
Additional Class Delivery Information Fully delivered online
KeywordsProgramming,message passing,parallel,distributed memory,MPI,HPC,Parallelism
Contacts
Course organiserDr David Henty
Tel: (0131 6)50 5960
Email: d.henty@ed.ac.uk
Course secretaryMr James Richards
Tel: 90131 6)51 3578
Email: J.Richards@epcc.ed.ac.uk
Navigation
Help & Information
Home
Introduction
Glossary
Search DPTs and Courses
Regulations
Regulations
Degree Programmes
Introduction
Browse DPTs
Courses
Introduction
Humanities and Social Science
Science and Engineering
Medicine and Veterinary Medicine
Other Information
Combined Course Timetable
Prospectuses
Important Information