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 : EPCD Online

Postgraduate Course: Practical Introduction to High Performance Computing (EPCD11001)

Course Outline
SchoolSchool of Informatics CollegeCollege of Science and Engineering
Credit level (Normal year taken)SCQF Level 11 (Postgraduate)
Course typeOnline Distance Learning AvailabilityNot available to visiting students
SCQF Credits20 ECTS Credits10
Summary*This course is primarily for online learning students. It is usually taken by online learning students in EPCC and students on the Data Science, Technology & Innovation programme. On-campus students may instead be interested in EPCC11004 HPC Architectures, EPCC11002 Message-Passing Programming and/or EPCC 11003 Threaded Programming.*

High Performance Computing (HPC) is a fundamental technology used in solving scientific and commercial problems. Many of the grand challenges of science depend on simulations and models run on HPC facilities to make progress, for example: protein folding, the search for the Higgs boson and developing nuclear fusion. In industry, sophisticated computer models are integral to the development of products such as jet engines, wind turbines and new drugs.

Modern supercomputers are parallel computers, gaining their power from many thousands of individual processors. Developing software to run on these systems requires using new parallel programming techniques.

The course will cover all the fundamental concepts that underpin modern HPC. The course is practical in the sense that you will explore these topics by running parallel programs on real HPC systems such as an UK national Tier-2 system, Cirrus.

The course will be delivered entirely online, and videos, notes and exercises will be released as the course progresses.
Course description Modern supercomputers are parallel computers, gaining their power from many thousands of individual processors. Developing software to run on these systems requires using new parallel programming technologies. The course will cover all the fundamental concepts that underpin modern HPC. The course is practical in the sense that you will explore these topic by running parallel programs on real HPC systems such as an UK national Tier-2 system, Cirrus. The same techniques can also be applied to smaller systems such as multi-core desktops, graphics processors and computing clusters.

The course has three main themes:

1) Hardware, Architectures, System Software
How are HPC systems constructed and what impact do components play in performance of applications? What system software is used on HPC systems and how does it impact the user experience?

2) Parallel Programming
What are the key parallel programming paradigms in use on modern HPC systems and how are they implemented and made available to users in practice? How do you measure parallel performance and scaling? How do you debug and profile parallel applications?

3) Applications on HPC systems
What types of applications run on modern HPC systems and what are the limiting factors to scaling and performance in these areas? What does the future hold for HPC applications - how will they run on next generation HPC systems.
Entry Requirements (not applicable to Visiting Students)
Pre-requisites Co-requisites
Prohibited Combinations Other requirements None
Course Delivery Information
Academic year 2024/25, Not available to visiting students (SS1) Quota:  None
Course Start Full Year
Course Start Date 16/09/2024
Timetable Timetable
Learning and Teaching activities (Further Info) Total Hours: 200 ( Online Activities 40, Programme Level Learning and Teaching Hours 4, Directed Learning and Independent Learning Hours 156 )
Assessment (Further Info) Written Exam 0 %, Coursework 100 %, Practical Exam 0 %
Additional Information (Assessment) Coursework 100 %«br /»
«br /»
Summative«br /»
1. Individual report on performance analysis of HPC program on a designated system (50%);«br /»
2. Individual essay: comparison of HPC architectures and their suitability for different HPC applications (50%).
Feedback Provided through discussion in live sessions, formative feedback, and on assessed work
No Exam Information
Learning Outcomes
On completion of this course, the student will be able to:
  1. Understand the key components of HPC architectures and how they are put together to form complete systems
  2. Build and test code in a Linux/Unix environment, execute in parallel and understand the stages involved.
  3. Compare and contrast the message-passing and multithreaded parallel programming models, and describe four key parallelisation strategies used in modern HPC codes.
  4. Understand the importance of performance and Amdahl's law, and measure and comment on the performance of parallel codes.
  5. Explain the current uses of HPC and the key issues for HPC in the future.
Reading List
There is no single compulsory course text. Pointers to appropriate material will be made available via Leganto and recommendations during discussions based on topics raised.
Additional Information
Graduate Attributes and Skills - Critical thinking
- Communication of complex ideas in accessible language
- Working in an interdisciplinary field
- Programming and Scripting
KeywordsHPC,High Performance Computing,Parallelism,Parallel Programming,Computational Science,Hardware
Contacts
Course organiserMs Weronika Filinger
Tel: (0131 6) 50 5908
Email: w.filinger@epcc.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