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: Performance Programming (EPCD11009)

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
SummaryPerformance is key for both efficient use of computing hardware and ensuring applications (be they computational simulation, machine learning, databases, etc...) complete their tasks in an acceptable amount of time. However this is one of the more difficult requirements to satisfy:

- Issues effecting performance often vary between different hardware and software environments. This requires performance issues to be frequently re-visited as the hardware and software environment changes.
- Performance programming requires detailed knowledge of the underlying environment
- The design decisions necessary to achieve good performance are often in conflict with other desirable properties of the program.

After taking this course students should have a good practical understanding of the general issues and methodologies associated with designing building and refactoring codes to meet performance requirements. In addition they will have an overview of a number of subjects that are important in the understanding of performance on current systems.
Course description The course will cover the following topics:
- Overview of performance programming. Methodology, the optimisation cycle.
- Designing for performance. Encapsulation as an aid to performance tuning.
- Tools for performance programming. Profilers and code instrumentation.
- Compilers and compiler optimisation.
- Memory hierarchies, Memory structures and associated optimisations.
- Performance tuning for shared memory.
- Floating point performance. Pipelines, SIMD, vectorisation.
Entry Requirements (not applicable to Visiting Students)
Pre-requisites Co-requisites
Prohibited Combinations Other requirements None
Information for Visiting Students
Pre-requisitesNone
Course Delivery Information
Academic year 2024/25, Available to all students (SV1) Quota:  None
Course Start Semester 1
Timetable Timetable
Learning and Teaching activities (Further Info) Total Hours: 100 ( Online Activities 30, Programme Level Learning and Teaching Hours 2, Directed Learning and Independent Learning Hours 68 )
Assessment (Further Info) Written Exam 0 %, Coursework 100 %, Practical Exam 0 %
Additional Information (Assessment) A single coursework consisting of two submissions (25%/75%).«br /»
«br /»
Coursework is expected to be worked on consistently across the Semester building on material from lectures and practicals as they are delivered. Although the first and second submission dates are sequential they are inherently linked and some work not assessed until the second submission is clearly relevant to feed into the first submission. The two should be treated as a single coherent piece of work with the first coursework offering students an opportunity to receive feedback which can be acted upon to improve the later higher-stakes submission.
Feedback Provided through regular weekly live sessions and discussions on output of practical exercises as well as on assessed work.
No Exam Information
Learning Outcomes
On completion of this course, the student will be able to:
  1. Understand and demonstrate the appropriate methodology when attempting to improve code performance.
  2. Understand how performance is achieved via hardware, compilers and operating systems.
  3. Appreciate the limitations of systems and recognise when these will have a serious impact.
  4. Interpret the observed performance of code in terms of how its execution is realised on the system.
  5. Identify code regions appropriate for manual optimisation and propose, implement and evaluate optimisations on these regions.
Reading List
Provided via Learn/Leganto and through live session discussions based on topics raised by students.
Additional Information
Graduate Attributes and Skills Programming
Solution Exploration and Evaluation
Communication of technical information via written report
Time management
Planning, implementation, and analysis
Special Arrangements This is an Online Learning course. An on-campus version (EPCC11009) runs in Semester 2.
KeywordsPerformance Programming,HPC,EPCC,Parallelism,Optimisation,Profilers,Compilers,SIMD,Vectors
Contacts
Course organiserMr William Jackson
Tel:
Email: Adrian.Jackson@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